Aller au contenu

Code source

Un article de Wikipédia, l'encyclopédie libre.
Copie papier d'un code source enFortrandes années 1970, imprimé sur dupapier continu(en),dédié aux fichiers textes.

Eninformatique,lecode sourceest untextequi présente lesinstructionscomposant un programme sous une forme lisible, telles qu'elles ont été écrites dans unlangage de programmation.Le code source se matérialise généralement sous la forme d'un ensemble defichiers texte.

Le code source est souvent traduit — par unassembleurou uncompilateur— encode binairecomposé d'instructions exécutables par leprocesseur.Il peut sinon être directementinterprétéà l'exécution du programme. Dans ce deuxième cas, il est parfois traduit au préalable en uncode intermédiairedont l'interprétation est plus rapide.

Dénomination

[modifier|modifier le code]

L'expression est une traduction de l'anglaissource code.Les expressions omettant le terme decodesont communes:les sources,le source.

Carte perforée
Carte perforéecontenant la ligne d'instruction « Z(1) = Y + W(1) ».

Dans les premiers temps de l'informatique, les programmes étaient entrés dans lamémoirede l'ordinateur par l'intermédiaire des interrupteurs du pupitre de commande. Lesinstructions machines,compréhensibles par l'ordinateur, ne pouvaient être saisies qu'encode binaire.Ce qui ne convenait qu'à de tout petits programmes.

Ils ont ensuite été chargés depuis desbandes perforées,puis descartes perforées.

Très rapidement, les programmes ont été rédigés dans un langage symbolique,langage d'assemblageou langage évolué commeFortran,Cobol,puis traduit automatiquement par un programme (assembleur,compilateur).

Avec l'apparition des disques magnétiques et des consoles interactives, des éditeurs de lignes puis deséditeurs de textesont été utilisés pour taper et modifier le code source.

Les possibilités limitées des ordinateurs de l'époque nécessitaient souvent l'impression du code source surpapier continu(en)avec des bandes Carol.

Aujourd'hui, il existe des environnements de développement, ditsEnvironnement de développement intégré(IDE,Integrated Development Environment), qui intègrent notamment les tâches d'édition et de compilation.

Types de code sources

[modifier|modifier le code]

Un logiciel est une suite d'instructions données à une machine. Un processeur ne peut exécuter que des instructions représentées sous une forme binaire particulière. Sauf mécanismes expérimentaux, il n'est pas possible pour un être humain de saisir directement un code binaire dans la représentation qu'en attend le processeur: un être humain ne peut pas écrire directement les champs de bits aux adresses attendues. Il est obligé de passer par un code distinct appelé code source, et qui est par la suite traduit dans la représentation binaire attendue par la machine puis chargé et exécuté par la cible.

Toutefois, l'écriture d'un code sous forme binaire, même dans un fichier séparé, pose de nombreux problèmes de compréhension aux êtres humains. C'est une représentation uniquement constituée d'une suite ininterrompue de 0 et de 1 qui est difficile à lire, à écrire et à maintenir sans assistance technique. La diversité des microprocesseurs et des composants présents dans un ordinateur ou automate, implique qu'un code binaire généré pour un système ne puisse pas êtrea priorile même que sur une machine distincte. Aussi, il existe autant de codes binaires que de configurations et une complexité accrue excluant que l'être humain puisse concevoir simplement un code binaire de grande ampleur.

Pour éviter ces écueils, et puisqu'une traduction est toujours nécessaire, l'être humain écrit un code textuel afin qu'il soit plus lisible, plus compréhensible et plus simple à maintenir: c'est le code source écrit dans unlangage de programmation.Il est, dans la plupart des cas, plus lisible, plus simple à écrire et indépendant du système cible. Un programme tiers (compilateur,interpréteuroumachine virtuelle) se charge de la traduction du code source en code binaire exécutable par la cible.

Copie d'écran d'un code source en Java
Copie d'écran d'un code source enJava.

Le code généré par l'être humain est appelécode source;la façon dont est rédigé cecode sourceest appeléelangage de programmation;le traducteur de ce code dans sa représentation binaire est appelécompilateur,interpréteuroumachine virtuelleselon les modalités de la traduction.

Dans la plupart des langages, on peut distinguer différents éléments dans un code source:

  • les éléments décrivant l’algorithme et les données (le code source proprement dit):
    • des symbolesidentifiantdes variables, desmots clefsdénotant des instructions, des représentations de données;
    • des constantes littérales.
  • les commentaires, qui documentent le code source le plus souvent en langage naturel, destinés aux relecteurs du code source. Ils ne sont pas nécessaires à la production du code exécutable mais peuvent être utilisés par le compilateur pour, par exemple, produire automatiquement de la documentation.

Coloration syntaxique

[modifier|modifier le code]

Un code est plus facile à lire et à écrire avec un éditeur fournissant unecoloration syntaxiquepermettant de distinguer les différents éléments du code source. Les commentaires peuvent par exemple être mis en vert.

Exemple de code enRuby:

a="\nThis is a double quoted string\n"

a=%Q{\nThis is a double quoted string\n}

a=<<BLOCK
This is a double quoted string
This is a double quoted string
BLOCK

a=%/\tThis is a double quoted string\n/

Autre exemple de code en Ruby:

hash={:water=>'wet',:fire=>'hot'}
putshash[:fire]# Τυπώνει: hot

hash.each_pairdo|key,value|# Ή: hash.each do |key, value|
puts"#{key}is#{value}"
end

# Τυπώνει: water is wet
# fire is hot

hash.delete:water# Σβήνει το:water => 'wet'
hash.delete_if{|key,value|value=='hot'}# Σβήνει το:fire => 'hot'

Autre exemple de code en Ruby:

File.open('file.txt','w'){|file|# открытие файла «file.txt» для записи («w» - write)
file.puts'Wrote some text.'
}# Конструкция устраняет неопределённость с закрытием файла: закрывается здесь при любом исходе

Analogie avec la recette de cuisine

[modifier|modifier le code]

L'analogie du code source et de larecette de cuisineest souvent employée dans une volonté devulgarisation.Une recette est une liste organisée d'ingrédients dont les quantités et les fonctions sont définies. Le but est d'obtenir le résultat voulu par le cuisinier, selon unetechniqueet un enchaînement d'opérations déterminés.

Ainsi le code source peut être apparenté à une recette de cuisine.

Ainsi, une personne dégustant un plat est en mesure de deviner les ingrédients qui le composent et d'imaginer comment le réaliser. Néanmoins, pour un plat très raffiné et subtil (comme pourrait l'être un programme), il est fort probable qu'elle ignore le mode opératoire du cuisinier. Pour le connaître, une recette détaillée serait nécessaire (pour un programme, la recette peut compter plusieurs millions de lignes de code). La solution alternative à cela serait d'acheter des plats préparés, c'est un peu ce que l'on fait lorsqu'on achète des logiciels.

Aspects légaux

[modifier|modifier le code]

Le code source peut être public ou privé (voirlogiciel libreetlogiciel propriétaire). Toutefois, le code binaire n'étant qu'une traduction du code source, il est toujours possible d'étudier un logiciel à partir de son code binaire. La légalité des techniques utilisées à ces fins dépend du pays et de l'époque. Elle peut notamment être mise en œuvre pour percer lessecretsd'une machine comme l'ES3B.

Notes et références

[modifier|modifier le code]

Sur les autres projets Wikimedia:

Articles connexes

[modifier|modifier le code]