Files
metabuilder/mojo/compiler/examples/loops.mojo
T
git 83f1533bce feat(mojo): integrate Modular Mojo compiler implementation
Extracted from modular repo and reorganized:

Compiler Implementation:
- 21 compiler source files (frontend, semantic, IR, codegen, runtime)
- 15 comprehensive test files (lexer, parser, type checker, backend, etc.)
- 9 compiler usage example programs

Architecture (5 phases):
- Frontend: Lexer, parser, AST generation (lexer.mojo, parser.mojo, ast.mojo)
- Semantic: Type system, checking, symbol resolution (3 files)
- IR: MLIR code generation (mlir_gen.mojo, mojo_dialect.mojo)
- Codegen: LLVM backend, optimization passes (llvm_backend.mojo, optimizer.mojo)
- Runtime: Memory mgmt, reflection, async support (3 files)

File Organization:
- mojo/compiler/src/: Compiler implementation (21 files, 952K)
- mojo/compiler/tests/: Test suite (15 files)
- mojo/compiler/examples/: Usage examples (9 files)
- mojo/samples/: Mojo language examples (37 files, moved from examples/)

Documentation:
- mojo/CLAUDE.md: Project-level guide
- mojo/compiler/CLAUDE.md: Detailed architecture documentation
- mojo/compiler/README.md: Quick start guide
- mojo/samples/README.md: Example programs guide

Status:
- Compiler architecture complete (Phase 4)
- Full test coverage included
- Ready for continued development and integration

Files tracked:
- 45 new compiler files (21 src + 15 tests + 9 examples)
- 1 moved existing directory (examples → samples)
- 3 documentation files created
- 1 root CLAUDE.md updated

Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>
2026-01-23 19:05:44 +00:00

39 lines
824 B
Mojo

#!/usr/bin/env mojo
# Example: Loops - while and for
fn factorial(n: Int) -> Int:
"""Calculate factorial using a while loop."""
var result = 1
var i = 1
while i <= n:
result = result * i
i = i + 1
return result
fn sum_range(n: Int) -> Int:
"""Sum numbers from 0 to n using a for loop."""
var total = 0
for i in range(n + 1):
total = total + i
return total
fn fibonacci(n: Int) -> Int:
"""Calculate nth Fibonacci number."""
if n <= 1:
return n
var a = 0
var b = 1
var i = 2
while i <= n:
let temp = a + b
a = b
b = temp
i = i + 1
return b
fn main():
print("Factorial of 5:", factorial(5))
print("Sum of 0 to 10:", sum_range(10))
print("10th Fibonacci number:", fibonacci(10))