mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	Update docs.
This commit is contained in:
		
							parent
							
								
									ab7b1625ac
								
							
						
					
					
						commit
						9ff0cc0b8b
					
				| @ -124,9 +124,22 @@ Access to External Variables, Functions and Libraries | ||||
| You can access Solidity variables and other identifiers by using their name. | ||||
| 
 | ||||
| Local variables of value type are directly usable in inline assembly. | ||||
| They can both be read and assigned to. | ||||
| 
 | ||||
| Local variables that refer to memory or calldata evaluate to the | ||||
| address of the variable in memory, resp. calldata, not the value itself. | ||||
| Local variables that refer to memory evaluate to the address of the variable in memory not the value itself. | ||||
| Such variables can also be assigned to, but note that an assignment will only change the pointer and not the data | ||||
| and that it is your responsibility to respect Solidity's memory management. | ||||
| See :ref:`Conventions in Solidity <conventions-in-solidity>`. | ||||
| 
 | ||||
| Similarly, local variables that refer to statically-sized calldata arrays or calldata structs | ||||
| evaluate to the address of the variable in calldata, not the value itself. | ||||
| The variable can also be assigned a new offset, but note that no validation to ensure that | ||||
| the variable will not point beyond ``calldatasize()`` is performed. | ||||
| 
 | ||||
| For dynamic calldata arrays, you can access | ||||
| their calldata offset (in bytes) and length (number of elements) using ``x.offset`` and ``x.length``. | ||||
| Both expressions can also be assigned to, but as for the static case, no validation will be performed | ||||
| to ensure that the resulting data area is within the bounds of ``calldatasize()``. | ||||
| 
 | ||||
| For local storage variables or state variables, a single Yul identifier | ||||
| is not sufficient, since they do not necessarily occupy a single full storage slot. | ||||
| @ -135,9 +148,10 @@ inside that slot. To retrieve the slot pointed to by the variable ``x``, you | ||||
| use ``x.slot``, and to retrieve the byte-offset you use ``x.offset``. | ||||
| Using ``x`` itself will result in an error. | ||||
| 
 | ||||
| For dynamic calldata arrays, you can access | ||||
| their calldata offset (in bytes) and length (number of elements) using ``x.offset`` and ``x.length``. | ||||
| Both expressions can also be assigned to. | ||||
| You can also assign to the ``.slot`` part of a local storage variable pointer. | ||||
| For these (structs, arrays or mappings), the ``.offset`` part is always zero. | ||||
| It is not possible to assign to the ``.slot`` or ``.offset`` part of a state variable, | ||||
| though. | ||||
| 
 | ||||
| Local Solidity variables are available for assignments, for example: | ||||
| 
 | ||||
| @ -178,17 +192,6 @@ Since Solidity 0.7.0, variables and functions declared inside the | ||||
| inline assembly block may not contain ``.``, but using ``.`` is | ||||
| valid to access Solidity variables from outside the inline assembly block. | ||||
| 
 | ||||
| Assignments are possible to assembly-local variables and to function-local | ||||
| variables. Take care that when you assign to variables that point to | ||||
| memory or storage, you will only change the pointer and not the data. | ||||
| 
 | ||||
| You can assign to the ``.slot`` part of a local storage variable pointer. | ||||
| For these (structs, arrays or mappings), the ``.offset`` part is always zero. | ||||
| It is not possible to assign to the ``.slot`` or ``.offset`` part of a state variable, | ||||
| though. | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| Things to Avoid | ||||
| --------------- | ||||
| 
 | ||||
| @ -199,6 +202,8 @@ functional-style opcodes, counting stack height for | ||||
| variable access and removing stack slots for assembly-local variables when the end | ||||
| of their block is reached. | ||||
| 
 | ||||
| .. _conventions-in-solidity: | ||||
| 
 | ||||
| Conventions in Solidity | ||||
| ----------------------- | ||||
| 
 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user