xref: /linux/Documentation/translations/it_IT/process/programming-language.rst (revision eb01fe7abbe2d0b38824d2a93fdb4cc3eaf2ccc1)
1.. include:: ../disclaimer-ita.rst
2
3:Original: :ref:`Documentation/process/programming-language.rst <programming_language>`
4:Translator: Federico Vaga <federico.vaga@vaga.pv.it>
5
6.. _it_programming_language:
7
8Linguaggio di programmazione
9============================
10
11Il kernel è scritto nel linguaggio di programmazione C [it-c-language]_.
12Più precisamente, il kernel viene compilato con ``gcc`` [it-gcc]_ usando
13l'opzione ``-std=gnu11`` [it-gcc-c-dialect-options]_: il dialetto GNU
14dello standard ISO C11.
15Linux supporta anche ``clang`` [it-clang]_, leggete la documentazione
16:ref:`Building Linux with Clang/LLVM <kbuild_llvm>`.
17
18Questo dialetto contiene diverse estensioni al linguaggio [it-gnu-extensions]_,
19e molte di queste vengono usate sistematicamente dal kernel.
20
21Attributi
22---------
23
24Una delle estensioni più comuni e usate nel kernel sono gli attributi
25[it-gcc-attribute-syntax]_. Gli attributi permettono di aggiungere una semantica,
26definita dell'implementazione, alle entità del linguaggio (come le variabili,
27le funzioni o i tipi) senza dover fare importanti modifiche sintattiche al
28linguaggio stesso (come l'aggiunta di nuove parole chiave) [it-n2049]_.
29
30In alcuni casi, gli attributi sono opzionali (ovvero un compilatore che non
31dovesse supportarli dovrebbe produrre comunque codice corretto, anche se
32più lento o che non esegue controlli aggiuntivi durante la compilazione).
33
34Il kernel definisce alcune pseudo parole chiave (per esempio ``__pure``)
35in alternativa alla sintassi GNU per gli attributi (per esempio
36``__attribute__((__pure__))``) allo scopo di mostrare quali funzionalità si
37possono usare e/o per accorciare il codice.
38
39Per maggiori informazioni consultate il file d'intestazione
40``include/linux/compiler_attributes.h``.
41
42Rust
43----
44
45Il kernel supporta sperimentalmente il linguaggio di programmazione Rust
46[it-rust-language]_ abilitando l'opzione di configurazione ``CONFIG_RUST``. Il
47codice verrà compilato usando ``rustc`` [it-rustc]_ con l'opzione
48``--edition=2021`` [it-rust-editions]_. Le edizioni Rust sono un modo per
49introdurre piccole modifiche senza compatibilità all'indietro._
50
51In aggiunta, nel kernel vengono utilizzate alcune funzionalità considerate
52instabili [it-rust-unstable-features]_. Queste funzionalità potrebbero cambiare
53in futuro, dunque è un'obiettivo importante è quello di far uso solo di
54funzionalità stabili.
55
56Per maggiori informazioni fate riferimento a Documentation/rust/index.rst .
57
58.. [it-c-language] http://www.open-std.org/jtc1/sc22/wg14/www/standards
59.. [it-gcc] https://gcc.gnu.org
60.. [it-clang] https://clang.llvm.org
61.. [it-gcc-c-dialect-options] https://gcc.gnu.org/onlinedocs/gcc/C-Dialect-Options.html
62.. [it-gnu-extensions] https://gcc.gnu.org/onlinedocs/gcc/C-Extensions.html
63.. [it-gcc-attribute-syntax] https://gcc.gnu.org/onlinedocs/gcc/Attribute-Syntax.html
64.. [it-n2049] http://www.open-std.org/jtc1/sc22/wg14/www/docs/n2049.pdf
65.. [it-rust-language] https://www.rust-lang.org
66.. [it-rustc] https://doc.rust-lang.org/rustc/
67.. [it-rust-editions] https://doc.rust-lang.org/edition-guide/editions/
68.. [it-rust-unstable-features] https://github.com/Rust-for-Linux/linux/issues/2
69