{{tag>Bionic Focal Jammy programmation BROUILLON}}
----
====== C# ======
[[wpfr>C_sharp|C#]] (CSharp) est un langage de programmation orientée objet, développé par Microsoft pour la plateforme .NET, dérivé de [[:gcc|C, C++]] et proche du [[java|Java]].
===== Pré-requis =====
* Disposer des [[:sudo|droits d'administration]].
* Disposer d'une connexion à Internet configurée et activée.
===== Installation de .NET =====
Il est possible d'installer:
* .NET avec seulement le Runtime pour exécuter des applications.
* .NET SDK nécessaire pour développer, et intégrant le Runtime.
Dans chaque cas, suivre cette [[https://learn.microsoft.com/fr-FR/dotnet/core/install/linux-ubuntu|documentation]].
.NET 6 est inclus dans les dépôts Ubuntu 22.04 et 22.10
Pour vérifier la version du SDK installée, exécuter dans un [[:terminal]]:
dotnet --list-sdks
Le résultat doit être similaire à:
6.0.406 [/usr/share/dotnet/sdk]
Pour vérifier la version du runtime installée:
dotnet --list-runtimes
Le résultat doit être similaire à:
Microsoft.AspNetCore.App 6.0.14 [/usr/share/dotnet/shared/Microsoft.AspNetCore.App]
Microsoft.NETCore.App 6.0.14 [/usr/share/dotnet/shared/Microsoft.NETCore.App]
===== Outils pour le développement =====
Un projet .NET est composé d'une multitude de fichiers. Il est donc conseillé d'utiliser un IDE tel que [[:visual_studio_code|Visual Studio Code]], libre et gratuit, ou bien [[https://www.jetbrains.com/rider/|JetBrains Rider]] (propriétaire et payant).
Il existe également MonoDevelop qui est un IDE gratuit et open source spécialement développé par des passionnés pour amener .NET sur Linux. Fonctionne très bien avec le langage C#
===== Création d'une application console .NET sans IDE =====
- Créer un dossier ''TestHelloWorld'' dans le dossier utilisateur.
- Ouvrir un [[:terminal|terminal]] et se placer dans ce dossier.
- Exécuter la commande:
dotnet new console --use-program-main
Plusieurs fichiers vont être créés dont le fichier:
namespace TestHelloWorld;
class Program
{
static void Main(string[] args)
{
Console.WriteLine("Hello, World!");
}
}
Pour lancer l'application, exécuter la commande:
dotnet run
Résultat:
Hello, World!
===== Création d'une application avec IHM dans Visual Studio Code =====
Pré-requis:
* Pour développer en C#, il faut installer l'[[https://marketplace.visualstudio.com/items?itemName=ms-dotnettools.csharp|extension C#]] (normalement, l'éditeur propose de l'installer dès qu'on ouvre un fichier C#). Pour installer des extensions dans Visual Studio Code, consulter cette [[https://code.visualstudio.com/docs/editor/extension-marketplace|documentation]].
* Pour créer une IHM, il faut utiliser un framework tel que [[https://learn.microsoft.com/fr-FR/dotnet/maui/what-is-maui?view=net-maui-7.0|MAUI]] (pour Linux, développé par la communauté), [[https://platform.uno/|Uno]], [[https://avaloniaui.net/|AvaloniaUI]] ou [[https://github.com/GtkSharp/GtkSharp|GtkSharp]]. Dans l'exemple suivant, nous utiliserons GtkSharp.
Procéder ainsi:\\
* Dans le terminal intégré de Visual Studio Code, exécuter cette commande pour installer le modèle:
dotnet new --install GtkSharp.Template.CSharp
* Vérifier que le modèle est bien installé:
dotnet new --list | grep gtkapp
Le résultat doit être:
Gtk Application gtkapp [C#] Gtk/GUI App
* Choisir ''Ouvrir un dossier'' et, dans la fenêtre de dialogue, créer un dossier ''TestGUI'' puis l'ouvrir. Ce nom de dossier deviendra le nom et l'espace de noms du projet.
* Dans le terminal intégré de Visual Studio Code, exécuter cette commande:
dotnet new gtkapp
Plusieurs fichiers vont se créer, dont ''MainWindow.glade'', qui est le fichier de description du formulaire, que l'on peut modifier avec [[:glade|Glade]]. Le fichier ''MainWindow.cs'' montre comment intégrer un fichier ''.glade'' dans un projet et comment gérer les événements:
using System;
using Gtk;
using UI = Gtk.Builder.ObjectAttribute;
namespace TestGUI
{
class MainWindow : Window
{
[UI] private Label _label1 = null;
[UI] private Button _button1 = null;
private int _counter;
public MainWindow() : this(new Builder("MainWindow.glade")) { }
private MainWindow(Builder builder) : base(builder.GetRawOwnedObject("MainWindow"))
{
builder.Autoconnect(this);
DeleteEvent += Window_DeleteEvent;
_button1.Clicked += Button1_Clicked;
}
private void Window_DeleteEvent(object sender, DeleteEventArgs a)
{
Application.Quit();
}
private void Button1_Clicked(object sender, EventArgs a)
{
_counter++;
_label1.Text = "Hello World! This button has been clicked " + _counter + " time(s).";
}
}
}
Pour lancer l'application, exécuter la commande:
dotnet run
Le résultat sera une fenêtre avec le texte ''Hello World!'' au centre et un bouton ''Click me!'' en bas.
===== Publication =====
Pour le déploiement d'une application, .NET, permet de publier une version autonome incluant le runtime .NET ou une version plus légère sans le runtime (dans ce cas, l'utilisateur devra installer le runtime sur son PC).
Pour plus d'informations, consulter [[https://learn.microsoft.com/fr-FR/dotnet/core/deploying/|cette page]].
===== Scripts =====
Créer un projet .NET pour de petites tâches simples est un peu excessif. Pour cela il existe [[https://github.com/dotnet-script/dotnet-script|dotnet-script]] qui permet d'exécuter du code C# dans un seul fichier de script. Pas de méthode ''Main'', pas de ''.csproj'', et une compilation transparente.
==== Installation ====
Pré-requis: le SDK doit être installé.
Exécuter dans un [[:terminal|terminal]]:
dotnet tool install -g dotnet-script
==== Création d'un script ====
dotnet-script est doté d'une commande d'initialisation pour générer un simple script.
* Créer un dossier ''DotNetScript'' dans le dossier utilisateur.
* Ouvrir un [[:terminal|terminal]] et se placer dans le dossier.
* Exécuter la commande:
dotnet script init
Deux fichiers vont se créer: ''omnisharp.json'' et ''main.csx''.
* ''omnisharp.json'' contient les paramètres du script, tels que le framework cible et les références nuget autorisées.
* ''main.csx'' est structuré pour contenir un exemple simple d'un Hello World fonctionnel. Le contenu ressemblera à ce qui suit :
#!/usr/bin/env dotnet-script
Console.WriteLine("Hello world!");
* Sur Linux, les scripts ainsi créés peuvent être exécutés directement comme s'ils étaient des exécutables. Vérifiez que le script fonctionne en exécutant la commande suivante:
./main.csx
Résultat:
Hello World!
Ci dessous un exemple qui exploite un peu plus le potentiel de .NET en créant un tableau de personnes (nom et âge). Le script se verra passer un paramètre, stocké dans la variable ''Args'' et récupéré dans la variable ''nAge''. Ensuite, le script filtrera les personnes qui ont moins de ''nAge'' années, triées par âge.
Modifiez le fichier ''main.csx'' en copiant et collant le contenu suivant:
#!/usr/bin/env dotnet-script
using System;
using System.Data;
Int16 nAge = 0;
if (Args.Count > 0)
nAge = Convert.ToInt16(Args[0]);
else
{
Console.WriteLine("L'âge n'a pas été spécifié");
return;
}
DataTable dtable = new DataTable();
dtable.Columns.Add("Nom", typeof(string));
dtable.Columns.Add("Age", typeof(Int16));
dtable.Rows.Add("Silvia", 32);
dtable.Rows.Add("Roberto", 28);
dtable.Rows.Add("Leonardo", 25);
dtable.Rows.Add("Francesco", 59);
dtable.Rows.Add("Alessandro", 55);
dtable.Rows.Add("Lorenzo", 18);
dtable.Rows.Add("Mattia", 41);
dtable.Rows.Add("Tommaso", 62);
dtable.Rows.Add("Gabriele", 39);
dtable.Rows.Add("Federico", 20);
int n=0;
DataRow[] dtRows;
dtRows = dtable.Select("Age<" + nAge, "Age ASC");
string strResult;
Console.WriteLine("Ont moins de " + nAge + " ans");
foreach(DataRow row in dtRows)
{
strResult = string.Format("{0, -15}Age: {1}", row["Nom"], row["Age"]);
Console.WriteLine(strResult);
}
Exécuter le script avec la commande:
./main.csx 50
Résultat:
Ont moins de 50 ans
Lorenzo Age: 18
Federico Age: 20
Leonardo Age: 25
Roberto Age: 28
Silvia Age: 32
Gabriele Age: 39
Mattia Age: 41
==== Mode REPL (Read-Evaluate-Print-Loop) ====
Le mode REPL ("mode interactif") est lancé en exécutant dotnet-script sans aucun argument.
Le mode interactif permet de fournir des blocs individuels de code C# qui sont exécutés dès que l'on appuie sur la touche Entrée:
~$ dotnet script
> var x = 1;
> x+x
2
===== Résolution des problèmes =====
Consulter [[https://learn.microsoft.com/fr-FR/dotnet/core/install/linux-package-mixup|cette page]] de documentation Microsoft pour corriger divers problèmes, dont ceux liés aux erreurs lors de l'exécution des commandes:
dotnet new
dotnet run
===== Voir aussi =====
* [[https://learn.microsoft.com/fr-FR/dotnet/csharp/|Documentation Microsoft C#]]
* [[https://learn.microsoft.com/fr-FR/dotnet/fundamentals/|Documentation Microsoft .NET]]
* [[http://www.csharphelp.com/|C# Help]]
* [[https://www.c-sharpcorner.com/|C# Corner]]
* [[https://github.com/dotnet-script/dotnet-script|dotnet-script]] sur Github
----
//Contributeurs principaux : [[:utilisateurs:rafbor]].//