erick-alcachofa a3d5c0ac68
feat(parser): implement full statement parsing and control flow logic
Signed-off-by: erick-alcachofa <erick@artichoke.dev>

Complete the transition from a declarations-only parser to a functional
imperative parser. This commit introduces the implementation for all
major statement types, loop constructs, and core control flow logic.

- **Match Case Update**: Updated `grammar.ebnf` to use pipe delimiters
  `|id|` for unwrapped variables in match cases, replacing the previous
  parenthetical syntax.
- **Labels**: Implemented loop labeling using the `ident := loop`
  syntax. Labels are validated to ensure they only prefix valid loop
  constructs.
- **Labels and Ranges**: Standardized the use of the `:=` operator for
  both loop labels (`label := loop`) and range-for declarations (`let i
  := range`).

- **Conditional Branches**:
    - Fully implemented `if` and `else` statements.
    - Added support for optional variable unwrapping (e.g., `if (expr)
      |val|`).
    - Supported `else if` chaining by recursively parsing if-statements
      within else-branches.
- **Loops**:
    - **C-Style For**: Implemented `for (init; cond; post)` with
      optional initializers and post-loop expressions.
    - **Range For**: Implemented `for (let i := range)` with mutability
      controls.
    - **While & Do-While**: Implemented standard condition-based loops.
    - **Infinite Loop**: Added the explicit `loop` keyword for infinite
      iteration.
    - **Loop Dispatch**: Added a lookahead mechanism in
      `parseForLoopStatement` to differentiate between C-style and
      Range-style loops based on token positioning.

- **Variables**: Implemented `let`/`def` parsing within local scopes,
  including type annotations and initializers.
- **Defer Logic**: Implemented `defer` and `errdefer` for scope-guarded
  execution.
- **Jumps**: Implemented `break`, `continue` (with optional label
  targets), and `return` (with optional expressions).
- **Match & Switch**: Fully implemented branch parsing, with possible
  default cases via the `_` (underscore) keyword.

- **Expression Integration**: Stubbed `parseExpression` in a new
  `Expressions.cpp` to serve as the integration point for value parsing.
- **OverloadSet**: Integrated `OverloadSet` utility in `Statements.cpp`
  to cleanly handle AST node variant visitation for label injection.
- **Error Handling**: Standardized error reporting across all new paths
  using `langException`, providing specific "expected" messages for
  delimiters and keywords.
2025-12-25 23:27:06 -06:00
2025-03-04 12:50:53 -06:00
2025-05-10 21:07:49 -06:00
2025-03-01 01:27:46 -06:00
2025-03-01 01:27:46 -06:00

⚠️ WIP Highly Experimental Project

  • The language, compiler, and tools are under active development and may be very unstable.
  • There will likely be breaking changes and periods where no work is done on the project.

The artichoke Programming Language

artichoke is a modern, statically-typed programming language designed to satisfy my personal preferences and requirements for programming, combining the low-level control and powerful modern features like a robust type system, generics, integrated error handling, and a clean, ergonomic syntax.

The goal of artichoke is to provide a language that is simple, safe, and productive for programming, eliminating common pitfalls without sacrificing performance or control.

For a detailed guide to the language, please see the project wiki.

Core Philosophy & Features

artichoke is built around a few core principles to create a safer, more productive programming experience:

  • Explicitness: Type conversions and error handling are explicit.
  • Safety: Non-nullable pointers, a robust type system, and deterministic resource management are prioritized.
  • Modern Ergonomics: Features like generics, defer, and a clean module system reduce boilerplate and improve readability.

The language includes a powerful generic type system, first-class error handling, a full suite of control flow statements (including match), a true module system, and compile-time reflection.

Project Status

artichoke is currently in the design and grammar-specification phase. The grammar is stable, and the next step is the implementation of a compiler (parser, semantic analyzer, and code generator).

Building from Source

# Get the source code
git clone https://git.artichoke.dev/me/artichoke-lang.git

# Configure cmake
# Optionally add -DENABLE_TESTING=ON for building tests
cmake -DCMAKE_BUILD_TYPE=Release -S . -B build

# Build the project
cmake --build build

# Run the binary
./build/frontend/artichoke-c

# Run the tests if enabled
ctest --test-dir build/tests --output-on-failure

# Install if wanted
cmake --install build --prefix=/usr/local

# Run the installed binary
arti-c

Contributing

The artichoke project is hosted on a personal, self-hosted Gitea instance. If you are interested in contributing, you have two options:

  1. Request an Account: Please contact support@artichoke.dev to request an account on the Gitea instance.
  2. Submit Patches: Alternatively, you can send patches or diffs directly to the same email address.

In all cases, proper attribution will be given for your contributions in the source files and/or the project wiki.

License

This project is licensed under the GNU Affero General Public License v3.0. The full license text can be found in the LICENSE file in this repository.

Description
artichoke programming language
https://lang.artichoke.dev/
Readme GNU-AGPLv3 672 KiB
Languages
C++ 98.4%
CMake 1.3%
Shell 0.3%