mirror of
https://github.com/KarolS/millfork.git
synced 2025-04-04 22:29:32 +00:00
Update documentation
This commit is contained in:
parent
778fc41187
commit
ff03b50668
@ -417,7 +417,7 @@ for <variable> : [ <comma separated expressions> ] {
|
||||
|
||||
* `<enum type>` – traverse enum constants of given type, in arbitrary order
|
||||
|
||||
* `<array>` – traverse array contents, in arbitrary order,
|
||||
* `<array>` – traverse given array, in arbitrary order,
|
||||
assigning the index to `<variable>` and either the element or the pointer to the element to `<variable2>`
|
||||
|
||||
* `<comma separated expressions>` – traverse every value in the list, in the given order.
|
||||
@ -425,6 +425,26 @@ Values do not have to be constant.
|
||||
If a value is not a constant and its value changes while executing the loop, the behaviour is undefined.
|
||||
Jumps using `goto` across the scope of this kind of loop are disallowed.
|
||||
|
||||
Examples:
|
||||
|
||||
struct S { ... }
|
||||
pointer.S p
|
||||
S s
|
||||
byte i
|
||||
array(str) arr [8]
|
||||
enum E { E_1, E_2, E_3 }
|
||||
E e
|
||||
|
||||
for i,0,until,8 { ... } // executes the body with i=0, i=1, ... i=7
|
||||
for i,0,to,7 { ... } // executes the body with i=0, i=1, ... i=7
|
||||
for i,0,paralleluntil,8 { ... } // executes the body with i=0, i=1, ... i=7 (in arbitrary order)
|
||||
for i,0,parallelto,8 { ... } // executes the body with i=0, i=1, ... i=7 (in arbitrary order)
|
||||
for i,7,downto,0 { ... } // executes the body with i=7, i=6, ... i=0
|
||||
for i:arr { ... } // executes the body with i=0, i=1, ... i=7 (in arbitrary order)
|
||||
for i,s:arr { ... } // executes the body with i=0, s=arr[0]; i=1, s=arr[1]; ... i=7, s=arr[7] (in arbitrary order)
|
||||
for i,p:arr { ... } // executes the body with i=0, p=arr[0].pointer; ... i=7, p=arr[7].pointer (in arbitrary order)
|
||||
for e:E { ... } // executes the body with e=E_1, e=E_2, e=E_3 (in arbitrary order)
|
||||
|
||||
### `break` and `continue` statements
|
||||
|
||||
Syntax:
|
||||
@ -447,6 +467,7 @@ Labelless `break` and `continue` apply to the innermost `for`, `while` or `do-wh
|
||||
`break for`, `continue do` etc. apply to the innermost loop of the given type.
|
||||
|
||||
`break i` and `continue i` apply to the innermost `for` loop that uses the `i` variable.
|
||||
`for` loops of the form `for i,j:array` can be broken from using `break i` only, not `break j`.
|
||||
|
||||
### `goto` and `label`
|
||||
|
||||
|
@ -36,6 +36,10 @@ where `X` is a power of two. Even if this makes the struct 12 bytes instead of 1
|
||||
* Avoid reusing temporary variables.
|
||||
It makes it easier for the optimizer to eliminate the variable entirely.
|
||||
|
||||
* Mark the most frequently used local variables as `register`.
|
||||
It will increase chances that those variables, and not the ones less frequently used,
|
||||
are inlined into registers or put in the zeropage.
|
||||
|
||||
## Functions
|
||||
|
||||
* Write many functions with no parameters and use `-finline`.
|
||||
|
@ -58,6 +58,10 @@ nav:
|
||||
- Undefined behaviour: abi/undefined-behaviour.md
|
||||
- Undocumented instruction support: abi/undocumented.md
|
||||
- Variable storage: abi/variable-storage.md
|
||||
- Additional guides:
|
||||
- Optimization guide: various/optimization.md
|
||||
- Differences from C: various/cdiff.md
|
||||
- Differences in assembly: various/asmdiff.md
|
||||
- External links:
|
||||
- Downloads: https://github.com/KarolS/millfork/releases/
|
||||
- Source code: https://github.com/KarolS/millfork
|
||||
|
Loading…
x
Reference in New Issue
Block a user