Skip to content

Loops

In Umbra, for is the only looping construct, offering two distinct forms: the initialized for statement and the conditional for statement.

Initialized

The initialized for loop has an initializer, stop condition, and an optional step value, structured as

loops.u
for mut i num = 0, 10, 2 {
  io::println(i)
}
where i starts at 0, runs until 10, and increments by 2 on each iteration, resulting in

0
2
4
6
8
10

Conditional

The conditional for loop, on the other hand, is structured with a condition, executing as long as the condition remains true.

loops.u
for i < 10 {

}

If no condition is specified, the loop becomes infinite, running until explicitly broken with break.

loops.u
mut i num = 0

for {
  if i > 10 {
    break
  }

  i = i + 1
}

Control loop flow

Umbra also includes break and continue statements to control loop flow. break immediately exits the loop, while continue skips to the next iteration, allowing precise control over looping behavior.

for mut i num = 0, 100 {
  if i % 2 == 0 {
    continue
  }

  if i > 10 {
    break
  }

  io::println(i)
}

results in

1
3
5
7
9
Next example: Conditions