Utilisez 4 espaces pour chaque niveau d'indentation.
Il n'y a pas de différence entre l'utilisation de guillemets doubles "
et de guillemets simples '
.
Des espaces sont placés autour des opérateurs et après les virgules, mais pas à l'intérieur des parenthèses et après les noms de fonctions.
-- Correct
x = 10
fruits = {" pomme" , " banane" , " orange" , " kiwi" , " ananas" }
-- Incorrect
x = 10
fruits = {" pomme" ," banane" ," orange" ," kiwi" ," ananas" }
Évitez les espaces supplémentaires autour des parenthèses, des crochets et des accolades.
-- Correct
function foo (x )
return x * 2
end
local tabl = {key = " valeur" }
local myArray = {1 , 2 , 3 , 4 , 5 }
-- Incorrect
function foo ( x )
return x * 2
end
local tabl = { key = " valeur" }
local myArray = { 1 , 2 , 3 , 4 , 5 }
Si un élément VGUI invisible est nécessaire, ne créez pas de fonction de peinture vide - assignez-la à nil
.
-- Correct
local pan = vgui .Create (" DPanel" )
pan .Paint = nil
-- Incorrect
local pan = vgui .Create (" DPanel" )
pan .Paint = function () end
Utilisez _
pour les variables ignorées.
for _ , item in ipairs (items ) do
foo (item )
end
Les fonctions et les méthodes ont une syntaxe en majuscules, les propriétés des objets sont toujours en minuscules.
Les arguments des fonctions sont en minuscules.
Préférez utiliser Is
lors de la nomination des fonctions booléennes.
local function IsEven (x )
return x % 2 == 0
end
Préférez la syntaxe de fonction à la syntaxe de variable.
-- Correct
local function eat ()
...
end
-- Incorrect
local eat = function ()
...
end
Utilisez la notation par points pour accéder aux propriétés connues.
local Person = {
age = 20
}
-- Correct
Person .age
-- Incorrect
Person [" age" ]
false
et nil
sont des valeurs fausses dans les expressions conditionnelles.
-- Correct
if name then
...
end
-- Incorrect
if name != nil then
...
end
Mettez un espace après //
et --
.
Évitez d'aligner les déclarations de variables.
-- Incorrect
local a = 1
local long_identifier = 2
Utilisez les noms des requêtes réseau, en tenant compte du script/de l'addon auquel elles appartiennent, et de leur rôle.
-- Exemples
util .AddNetworkString (" GangSystem-InvitePlayer" )
util .AddNetworkString (" HatShop-Buy" )
Lors de l'envoi d'une requête réseau, la syntaxe imbriquée de l'écriture des données doit être préservée.
net .Start (" Test" )
net .WriteString (" Hello World" )
net .WriteTable ({6 , 8 , 10 , 12 })
net .SendToServer ()
Lors de l'écriture d'un bloc/de blocs de code, utilisez le même style de noms de variables.
Le nom du hook doit indiquer l'addon/le script auquel le code appartient et la signification du hook.
hook .Add (" PlayerSay" , " AutoDonate.OpenMenu" , function (pl , text )
if text == " /donate" then
pl :ConCommand (" autodonate_menu" )
end
end )
Lors de la déclaration de variables de couleur et de matériau, indiquez leur appartenance.
local color_button = Color (75 , 75 , 75 )
local mat_medal = Material (" icon16/rosette.png" )
S'il y a une itération dans le bloc de code, mettez en cache les variables.
local color_text = Color (25 , 25 , 25 )
hook .Add (" HUDPaint" , " CustomHUD.Test" , function ()
draw .SimpleText (" Bonjour" , " TargetID" , 25 , 25 , color_text )
end )
-- Quelque part lors de la création de l'interface
local pl_nick = LocalPlayer ():Name ()
pnl .Paint = function (_ , w , h )
draw .RoundedBox (6 , 0 , 0 , w , h , color_black )
draw .SimpleText (pl_nick , " Trebuchet24" , w * 0.5 , h * 0.5 , color_white , 1 , 1 )
end
2. Structure des fichiers
Les fichiers GLua doivent être nommés en minuscules.
Consacrez un dossier séparé pour votre addon dans le répertoire lua/
. Référez-vous à lui via un fichier *_autorun.lua
dans lua/autorun/
.