mirror of
https://github.com/luau-lang/rfcs.git
synced 2025-04-05 19:11:00 +01:00
Update syntax-if-statements-initializers.md
This commit is contained in:
parent
fad18b4680
commit
614a6c26f2
1 changed files with 41 additions and 1 deletions
|
@ -8,7 +8,47 @@ Introduce an initializer expression that declares and initializes variables in i
|
|||
|
||||
Initializers can improve code clarity and reduce scope pollution by allowing developers to declare variables in the conditions of if statements. Declaring variables at the point of use in if statements for the scope of the if statement's blocks simplifies code, leading to better readability and understanding of program logic. By limiting the scope of variables to the if statement's blocks, the risk of unintended variable reuse and naming conflicts is reduced.
|
||||
|
||||
The reduced scope pollution improves register space in extreme cases (or auto-generated code) where developers have many variables defined and have to work around register limits by reducing the register size. In some scenarios, especially on Roblox, initializing variables within if statements can lead to improved performance and reduced complexity by avoiding unnecessary calls by developers. A common paradigm used by Roblox developers is to use `Instance:FindFirstChild` in their condition and then access it afterwards instead of keeping an existing variable around in the new scope, polluting the existing scope.
|
||||
The reduced scope pollution improves register space in extreme cases (or auto-generated code) where developers have many variables defined and have to work around register limits by reducing the register size. In some scenarios, especially on Roblox, initializing variables within if statements can lead to improved performance and reduced complexity by avoiding unnecessary calls by developers. A common paradigm used by Roblox developers is to use `Instance:FindFirstChild` in their condition and then access it afterwards instead of keeping an existing variable around in the new scope, polluting the existing scope.
|
||||
|
||||
Another benefit provided by initializers is being able to compact verbose guard clauses into a singular if statement.
|
||||
|
||||
Example:
|
||||
|
||||
```lua
|
||||
function PlayerControl:GetEntities()
|
||||
if self.RemovedSelf then
|
||||
return self.Instances
|
||||
end
|
||||
|
||||
local entity = self:TryGetEntity()
|
||||
if entity == nil then
|
||||
return self.Instances
|
||||
end
|
||||
|
||||
local index = table.find(self.Instances, entity.Root)
|
||||
if index == nil then
|
||||
return self.Instances
|
||||
end
|
||||
|
||||
table.remove(self.Instances, index)
|
||||
self.RemovedSelf = true
|
||||
|
||||
return self.Instances
|
||||
end
|
||||
```
|
||||
|
||||
```lua
|
||||
function PlayerControl:GetEntities()
|
||||
if self.RemovedSelf then
|
||||
elseif local entity = self:TryGetEntity() where entity == nil then
|
||||
elseif local index = table.find(self.Instances, entity.Root) then
|
||||
table.remove(self.Instances, index)
|
||||
self.RemovedSelf = true
|
||||
end
|
||||
|
||||
return self.Instances
|
||||
end
|
||||
```
|
||||
|
||||
# Design
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue