diff --git a/software/32.Zig/README.md b/software/32.Zig/README.md index 6889dfa8..b3d10107 100644 --- a/software/32.Zig/README.md +++ b/software/32.Zig/README.md @@ -1,18 +1,18 @@ -# Workshop 13 - Introduction to Zig +# Workshop 32 - Introduction to Zig -Welcome to this introductory workshop on Zig! Zig is a modern programming language that emphasizes robustness, performance and clarity. Today, you'll learn how to install Zig, create your first project, and discover the language's key concepts by creating a palindrome detection program. +Welcome to this introductory workshop on Zig! Zig is a modern programming language that emphasizes robustness, performance and clarity. Today, you'll learn : +✔️ how to install Zig +✔️ create your first project +✔️ discover the language's key concepts by creating a few projects -## Prerequisites +## Introduction -- Basic programming skills (C, C++, or any other language) -- A computer with Internet access +Zig is a general-purpose programming language focused on robustness, performance, and simplicity. It offers manual memory management, safety features, built-in cross-compilation, and seamless C interoperability, making it ideal for system programming and high-performance applications. -## Workshop objectives +### Prerequisites -- Install Zig on your machine -- Initialize a Zig project -- Understand the basics of the Zig language -- Create a palindrome detection program +- Basic programming skills (C, C++, or any other language) +- A computer with Internet access ## Step 0 - SETUP @@ -20,93 +20,167 @@ All the required information to install dependencies can be found in [SETUP.md]( > 💡 We recommend you to follow the [Getting started](https://ziglang.org/learn/getting-started/) for this workshop. -### Step 1 - Hello World! in Zig +## Step 1 - Hello World! in Zig -> ❗ We strongly advise you to use the resources given for this exercise. +> ❗ We strongly advise you to use the documentation provided for this exercise. + +📑 Description: For the first exercise, we simply ask you to write `Hello world!` in your terminal when you run your program. -To do this, create a file `main.zig` in a folder called `src`. +📌 Tasks: +create a file `main.zig` in a folder called `src` with your logic to print the "hello world" -> 💡 Zig file has `zig` extension. +📚 Documentation: +> 💡 Zig file has `zig` extension. > 💡 Now, that you have created a file `main.zig`, you can use other files. To use them in your `main.zig` you have to integrate the module ([read more](https://stackoverflow.com/questions/71186556/how-do-i-include-one-zig-file-from-another-zig-file)) -#### Resources +- [Build System](https://ziglang.org/learn/build-system/) +- [Doc.Zig](https://ziglang.org/documentation/master/) + +✔️ Validation: + + you should see the following : - - [Build System](https://ziglang.org/learn/build-system/) - - [Doc.Zig](https://ziglang.org/documentation/master/) + ```sh + Hello, World! + ``` -### Step 2 - Palindrome? +## Step 2 - Palindrome? > ❗ We strongly advise you to use the resources given for this exercise. +📑 Description: + For the second exercise, you have to create a function that takes as parameter a string `word`. +📌 Tasks: + Create a file `palindrome.zig` for this new function. This function must return true if the word given in parameter is a palindrome and false in the opposite case. -#### Resources - - [What is a palindrome ?](https://www.wikiwand.com/en/Palindrome) - - [New function](https://ziglang.org/documentation/master/#Functions) - - [The types in Zig](https://ziglang.org/documentation/master/#Primitive-Types) - - [Control_Structures](https://zig.guide/language-basics/while-loops) +📚 Documentation: + + -[What is a palindrome ?](https://www.wikiwand.com/en/Palindrome) + -[New function](https://ziglang.org/documentation/master/#Functions) + -[The types in Zig](https://ziglang.org/documentation/master/#Primitive-Types) + -[Control_Structures](https://zig.guide/language-basics/while-loops) -### Step 3 - Fibonacci sequence + ✔️ Validation: + + When you compile and run palindrome.zig, the output should be: + + ```sh + madam is palindrome: true + ``` + or + + ```sh + hello is palindrome: false + ``` + +## Step 3 - Fibonacci sequence > ❗ We strongly advise you to use the resources given for this exercise. -Create a file `fibonacci.zig` for this new function. +📑 Description: + +For the third exercise, you need to create a function that generates and displays the Fibonacci sequence up to a specified number of elements. + +📌 Tasks: + +- Create a file `fibonacci.zig` for this new function. For the third exercise, create a function that takes one parameter: + - A number `max` with type `i32` that represent the number of element to compute. -You must now display the sequence of Fibonacci from the number of starts to the maximum value. +- You must now display the sequence of Fibonacci from the number of starts to the `max` value. Here is a small example of the beginning of the Fibonacci sequence: -```shell -0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, ... -``` + ```shell + 0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, ... + ``` + +📚 Documentation: + + -[Fibonacci number](https://www.wikiwand.com/en/Fibonacci_number) + -[Match](https://ziglang.org/documentation/master/#Standard-Library-Math-Functions) + -[Vector](https://ziglang.org/documentation/master/#Vectors) -#### Resources - - [Fibonacci number](https://www.wikiwand.com/en/Fibonacci_number) - - [Match](https://ziglang.org/documentation/master/#Standard-Library-Math-Functions) - - [Vector](https://ziglang.org/documentation/master/#Vectors) + ✔️ Validation: + Given the Fibonacci sequence (see previous example), if max is 5, the function should output: -### Step 4 - A simple and useful `Calculator`! + ```sh + 0, 1, 1, 2, 3 + ``` + +## Step 4 - A simple and useful `Calculator` > ❗ We strongly advise you to use the resources given for this exercise. +📑 Description: + Let's go further now! The objective of this fifth exercise is to create a simplifying calculator. -Create a file `calculator.zig` for this new function. +📌 Tasks: + +- Create a file `calculator.zig` for this new function. To do this, you have to make a calculator that can do: + - `Addition` - `Multiplication` - `Division` - `Subtraction` -between two values that must be retrieved one after the other from the user's input. +- between two values that must be retrieved one after the other from the user's input. > 💡 Pay attention to your error handling ! -Display the result of the calculation in your terminal. +- Display the result of the calculation in your terminal. + +📚 Documentation: + -[Errors](https://ziglang.org/documentation/master/#Errors) + -[Memory](https://zig.guide/standard-library/allocators) + -[ArrayList](https://zig.guide/standard-library/arraylist) + + ✔️ Validation: + + You should get something like this : + + ```sh + First number: 5 + Operation: + + Second number: 3 + 8 + ``` + + Here's a typical error handeling example : + + ```sh + First number: abc + Operation: + + Second number: 3 + Expected Output: Error message indicating invalid input. + ``` -#### Resources - - [Errors](https://ziglang.org/documentation/master/#Errors) - - [Memory](https://zig.guide/standard-library/allocators) - - [ArrayList](https://zig.guide/standard-library/arraylist) +## Bonuses - TO DO List and C Code translation -### Step 5 - Simple Todo List in Zig +### TO DO List -#### Objective +📑 Description: + +Now that you're used to the basics, you will do a little project to apply what you've learnt so far. + +📌 Tasks: Create a command-line todo list application where you can: @@ -114,18 +188,74 @@ Create a command-line todo list application where you can: - Delete a todo by ID - View all todos -Each todo has: +Each todo should have at least three fields: - id (auto-incremented) - name - description -### Step 5 - Use your C code +> 💡 To easily test your functions during this workshop remember to check the testing tools mentioned above + +📚 Documentation: + +- [New function](https://ziglang.org/documentation/master/#Functions) +- [The types in Zig](https://ziglang.org/documentation/master/#Primitive-Types) + +✔️ Validation: + + ```sh + ./zig-out/bin/main + + Choose an action: + 1. Add Todo + 2. Delete Todo + 3. View Todos + 4. Exit + > 1 + Enter name: Buy groceries + Enter description: Milk, eggs, and bread + Todo added successfully. + ``` + + ```sh + Choose an action: + 5. Add Todo + 6. Delete Todo + 7. View Todos + 8. Exit + > 3 + ID: 1, Name: Buy groceries, Description: Milk, eggs, and bread + Choose an action: + 9. Add Todo + 10. Delete Todo + 11. View Todos + 12. Exit + > 4 + ``` + + > 💡 Pay attention to your error handling ! + +### Use The C Translation tool + +📑 Description: + +Zig provides the command zig translate-c for automatic translation from C source code. You can try to read the documentation and have fun with the tool. + +📚 Documentation: + + -[Translate-C](https://zig.guide/working-with-c/translate-c) + -[cImport](https://zig.guide/working-with-c/c-import) + -[LinkLibC](https://zig.guide/working-with-c/linking-libc) + +## Conclusion + +Well done ! You've accomplished a lot with the Zig Workshop, and there is so much more to discover. Refer to the official documentation to deep-dive into it. + +Hope you enjoyed the workshop! + +## Authors -Zig provides the command zig translate-c for automatic translation from C source code +- Elie STROUN +- Pierre LISSOPE -#### Resources - - [Translate-C](https://zig.guide/working-with-c/translate-c) - - [cImport](https://zig.guide/working-with-c/c-import) - - [LinkLibC](https://zig.guide/working-with-c/linking-libc) - +> 🚀 Follow us on our different social networks, and put a star 🌟 on `PoC's` repositories. \ No newline at end of file diff --git a/software/32.Zig/SETUP.md b/software/32.Zig/SETUP.md index b286bd6c..3003b235 100644 --- a/software/32.Zig/SETUP.md +++ b/software/32.Zig/SETUP.md @@ -1,6 +1,6 @@ # Installing Zig -### For Fedora +## For Fedora Since most students use Fedora, installing Zig is very simple. Just open a terminal and run the following command: diff --git a/software/32.Zig/TODO.md b/software/32.Zig/TODO.md deleted file mode 100644 index e4aac804..00000000 --- a/software/32.Zig/TODO.md +++ /dev/null @@ -1,56 +0,0 @@ -# Step 3 - Simple Todo List in Zig - -## Objective - -Create a command-line todo list application where you can: - - - Add a new todo - - Delete a todo by ID - - View all todos - -Each todo has: - - - id (auto-incremented) - - name - - description - -## Examples - -### User Interaction - - ./zig-out/bin/main - - Choose an action: - 1. Add Todo - 2. Delete Todo - 3. View Todos - 4. Exit - > 1 - Enter name: Buy groceries - Enter description: Milk, eggs, and bread - -### Output - - Todo added successfully. - Choose an action: - 1. Add Todo - 2. Delete Todo - 3. View Todos - 4. Exit - > 3 - ID: 1, Name: Buy groceries, Description: Milk, eggs, and bread - Choose an action: - 1. Add Todo - 2. Delete Todo - 3. View Todos - 4. Exit - > 4 - - > 💡 Pay attention to your error handling ! - -## Resources - -> 💡 To easily test your functions during this workshop remember to check the tools mentioned above - -- [New function](https://ziglang.org/documentation/master/#Functions) -- [The types in Zig](https://ziglang.org/documentation/master/#Primitive-Types)