latest pushes
This commit is contained in:
		| @@ -5,41 +5,41 @@ | ||||
|  | ||||
| # Addition | ||||
| result=$((5 + 3)) | ||||
| echo Addition: 5 + 3 = $result | ||||
| echo Addition: "5 + 3 =" $result | ||||
|  | ||||
| # Subtraction | ||||
| result=$((10 - 4)) | ||||
| echo Subtraction: 10 - 4 = $result | ||||
| echo Subtraction: "10 - 4 =" $result | ||||
|  | ||||
| # Multiplication | ||||
| result=$((6 * 7)) | ||||
| echo Multiplication: 6 * 7 = $result | ||||
| echo Multiplication: "6 * 7 =" $result | ||||
|  | ||||
| # Division | ||||
| result=$((20 / 4)) | ||||
| echo Division: 20 / 4 = $result | ||||
| echo Division: "20 / 4 =" $result | ||||
|  | ||||
| # Modulus | ||||
| result=$((17 % 5)) | ||||
| echo Modulus: 17 % 5 = $result | ||||
| echo Modulus: "17 % 5 =" $result | ||||
|  | ||||
| # Compound operation | ||||
| result=$(( (10 + 5) * 2 )) | ||||
| echo Compound: (10 + 5) * 2 = $result | ||||
| echo Compound: "(10 + 5) * 2 =" $result | ||||
|  | ||||
| # Using variables | ||||
| a=7 | ||||
| b=3 | ||||
| result=$((a + b)) | ||||
| echo Variables: $a + $b = $result | ||||
| echo Variables: "$a + $b =" $result | ||||
|  | ||||
| # Increment | ||||
| count=0 | ||||
| count=$((count + 1)) | ||||
| echo Increment: count after increment = $count | ||||
| echo Increment: count after increment "=" $count | ||||
|  | ||||
| # Decrement | ||||
| count=$((count - 1)) | ||||
| echo Decrement: count after decrement = $count | ||||
| echo Decrement: count after decrement "=" $count | ||||
|  | ||||
| echo Basic math operations completed. | ||||
|   | ||||
| @@ -5,27 +5,27 @@ | ||||
|  | ||||
| # Create a test file | ||||
| echo "Creating test file..." | ||||
| echo "Hello, World!" > test.txt | ||||
| write test.txt "Hello, World!" | ||||
|  | ||||
| # Read the contents of the file | ||||
| echo "\nReading test file:" | ||||
| cat test.txt | ||||
| read test.txt | ||||
|  | ||||
| # Append to the file | ||||
| echo "\nAppending to test file..." | ||||
| echo "This is a new line" >> test.txt | ||||
| append test.txt "This is a new line" | ||||
|  | ||||
| # Read the updated contents | ||||
| echo "\nReading updated test file:" | ||||
| cat test.txt | ||||
| read test.txt | ||||
|  | ||||
| # Write to a new file | ||||
| echo "\nWriting to a new file..." | ||||
| echo "This is a new file" > new_file.txt | ||||
| write new_file.txt "This is a new file" | ||||
|  | ||||
| # Read the new file | ||||
| echo "\nReading new file:" | ||||
| cat new_file.txt | ||||
| read new_file.txt | ||||
|  | ||||
| # List files in the current directory | ||||
| echo "\nListing files in the current directory:" | ||||
| @@ -35,26 +35,6 @@ ls -l | ||||
| echo "\nRenaming file..." | ||||
| mv new_file.txt renamed_file.txt | ||||
|  | ||||
| # Check if file exists | ||||
| echo "\nChecking if files exist:" | ||||
| if [ -f "test.txt" ]; then | ||||
|     echo "test.txt exists" | ||||
| else | ||||
|     echo "test.txt does not exist" | ||||
| fi | ||||
|  | ||||
| if [ -f "new_file.txt" ]; then | ||||
|     echo "new_file.txt exists" | ||||
| else | ||||
|     echo "new_file.txt does not exist" | ||||
| fi | ||||
|  | ||||
| if [ -f "renamed_file.txt" ]; then | ||||
|     echo "renamed_file.txt exists" | ||||
| else | ||||
|     echo "renamed_file.txt does not exist" | ||||
| fi | ||||
|  | ||||
| # Delete files | ||||
| echo "\nDeleting files..." | ||||
| rm test.txt renamed_file.txt | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
|  | ||||
| # Simple function | ||||
| function greet() { | ||||
|     echo "Hello, $1!" | ||||
|     echo Hello | ||||
| } | ||||
|  | ||||
| echo "Testing simple function:" | ||||
|   | ||||
| @@ -6,31 +6,32 @@ | ||||
| # String concatenation | ||||
| first_name=John | ||||
| last_name=Doe | ||||
| full_name=$first_name $last_name | ||||
| full_name="$first_name $last_name" | ||||
| echo Full name: $full_name | ||||
|  | ||||
| # String length | ||||
| string="Hello, World!" | ||||
| echo "The string '$string' has ${#string} characters." | ||||
| echo The string '$string' has ${#string} characters. | ||||
|  | ||||
| # Substring extraction | ||||
| echo "The first 5 characters are: ${string:0:5}" | ||||
| echo The first 5 characters are: ${string:0:5} | ||||
|  | ||||
| # String replacement | ||||
| sentence="The quick brown fox jumps over the lazy dog" | ||||
| echo "Original sentence: $sentence" | ||||
| echo Original sentence: $sentence | ||||
| new_sentence=${sentence/fox/cat} | ||||
| echo "Modified sentence: $new_sentence" | ||||
| echo Modified sentence: $new_sentence | ||||
|  | ||||
| # Converting to uppercase and lowercase | ||||
| echo "Uppercase: ${string^^}" | ||||
| echo "Lowercase: ${string,,}" | ||||
| echo Uppercase: ${string^^} | ||||
| echo Lowercase: ${string,,} | ||||
|  | ||||
| # Trimming whitespace | ||||
| padded_string="   trim me   " | ||||
| echo "Original string: '$padded_string'" | ||||
| trimmed_string=${padded_string## } | ||||
| trimmed_string=${trimmed_string%% } | ||||
| echo "Trimmed string: '$trimmed_string'" | ||||
| echo Original string: '$padded_string' | ||||
| trimmed_string="${padded_string#"${padded_string%%[![:space:]]*}"}"  # Trim leading whitespace | ||||
| trimmed_string="${trimmed_string%"${trimmed_string##*[![:space:]]}"}"  # Trim trailing whitespace | ||||
| echo Trimmed string: '$trimmed_string' | ||||
|  | ||||
| echo "String manipulation operations completed." | ||||
| # Completion message | ||||
| echo String manipulation operations completed. | ||||
|   | ||||
										
											Binary file not shown.
										
									
								
							| @@ -38,10 +38,8 @@ impl Executor { | ||||
|  | ||||
|     pub fn run(&mut self, args: Vec<String>) -> Result<(), String> { | ||||
|         if args.len() > 1 { | ||||
|             // Execute script file | ||||
|             self.execute_script(&args[1]) | ||||
|         } else { | ||||
|             // Interactive mode | ||||
|             self.run_interactive_mode() | ||||
|         } | ||||
|     } | ||||
| @@ -64,34 +62,13 @@ impl Executor { | ||||
|             let line = line.map_err(|e| format!("Error reading line {}: {}", index + 1, e))?; | ||||
|             let trimmed_line = line.trim(); | ||||
|             if trimmed_line.is_empty() || trimmed_line.starts_with('#') { | ||||
|                 continue; // Skip empty lines and comments | ||||
|             } | ||||
|  | ||||
|             // Handle variable assignments and arithmetic operations | ||||
|             if trimmed_line.contains('=') { | ||||
|                 let parts: Vec<&str> = trimmed_line.splitn(2, '=').collect(); | ||||
|                 if parts.len() == 2 { | ||||
|                     let var_name = parts[0].trim().to_string(); | ||||
|                     let var_value = parts[1].trim().to_string(); | ||||
|  | ||||
|                     if var_value.starts_with("$((") && var_value.ends_with("))") { | ||||
|                         // Arithmetic expression | ||||
|                         let result = self.interpreter.evaluate_arithmetic(&var_value)?; | ||||
|                         self.interpreter | ||||
|                             .variables | ||||
|                             .insert(var_name, result.to_string()); | ||||
|                     } else { | ||||
|                         // Regular variable assignment | ||||
|                         let expanded_value = self.interpreter.expand_variables(&var_value); | ||||
|                         self.interpreter.variables.insert(var_name, expanded_value); | ||||
|                     } | ||||
|                     continue; | ||||
|                 } | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             if let Err(e) = self.process_content(trimmed_line) { | ||||
|                 return Err(format!("Error on line {}: {}", index + 1, e)); | ||||
|                 eprintln!("Error on line {}: {}", index + 1, e); | ||||
|             } | ||||
|             io::stdout().flush().unwrap(); | ||||
|         } | ||||
|         Ok(()) | ||||
|     } | ||||
| @@ -114,28 +91,6 @@ impl Executor { | ||||
|     } | ||||
|  | ||||
|     fn process_content(&mut self, content: &str) -> Result<(), String> { | ||||
|         // Handle variable assignments and arithmetic operations | ||||
|         if content.contains('=') { | ||||
|             let parts: Vec<&str> = content.splitn(2, '=').collect(); | ||||
|             if parts.len() == 2 { | ||||
|                 let var_name = parts[0].trim().to_string(); | ||||
|                 let var_value = parts[1].trim().to_string(); | ||||
|  | ||||
|                 if var_value.starts_with("$((") && var_value.ends_with("))") { | ||||
|                     // Arithmetic expression | ||||
|                     let result = self.interpreter.evaluate_arithmetic(&var_value)?; | ||||
|                     self.interpreter | ||||
|                         .variables | ||||
|                         .insert(var_name, result.to_string()); | ||||
|                 } else { | ||||
|                     // Regular variable assignment | ||||
|                     let expanded_value = self.interpreter.expand_variables(&var_value); | ||||
|                     self.interpreter.variables.insert(var_name, expanded_value); | ||||
|                 } | ||||
|                 return Ok(()); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         let ast_nodes = self.parse_content(content)?; | ||||
|         self.execute(ast_nodes) | ||||
|     } | ||||
| @@ -159,6 +114,11 @@ impl Executor { | ||||
|             ASTNode::Command { name, args } => Arc::get_mut(&mut self.processes) | ||||
|                 .unwrap() | ||||
|                 .execute_command(&mut self.interpreter, name, args), | ||||
|             ASTNode::Assignment { name, value } => { | ||||
|                 let expanded_value = self.interpreter.expand_variables(&value); | ||||
|                 self.interpreter.variables.insert(name, expanded_value); | ||||
|                 Ok(None) | ||||
|             } | ||||
|             ASTNode::Pipeline(commands) => { | ||||
|                 self.processes.execute_pipeline(&self.interpreter, commands) | ||||
|             } | ||||
|   | ||||
| @@ -45,30 +45,11 @@ impl Processes { | ||||
|             .map(|arg| interpreter.expand_variables(arg)) | ||||
|             .collect(); | ||||
|  | ||||
|         // Handle arithmetic assignments | ||||
|         if expanded_name.contains('=') { | ||||
|             let parts: Vec<&str> = expanded_name.splitn(2, '=').collect(); | ||||
|             if parts.len() == 2 { | ||||
|                 let var_name = parts[0].trim().to_string(); | ||||
|                 let var_value = parts[1].trim().to_string(); | ||||
|  | ||||
|                 if var_value.starts_with("$((") && var_value.ends_with("))") { | ||||
|                     // Arithmetic expression | ||||
|                     let result = interpreter.evaluate_arithmetic(&var_value)?; | ||||
|                     interpreter.variables.insert(var_name, result.to_string()); | ||||
|                 } else { | ||||
|                     // Regular variable assignment | ||||
|                     let expanded_value = interpreter.expand_variables(&var_value); | ||||
|                     interpreter.variables.insert(var_name, expanded_value); | ||||
|                 } | ||||
|                 return Ok(Some(0)); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         match expanded_name.as_str() { | ||||
|             "echo" => { | ||||
|                 let output = expanded_args.join(" "); | ||||
|                 println!("{}", output); | ||||
|                 io::stdout().flush().unwrap(); | ||||
|                 Ok(Some(0)) | ||||
|             } | ||||
|             "cd" => { | ||||
| @@ -149,11 +130,7 @@ impl Processes { | ||||
|                 Ok(Some(0)) | ||||
|             } | ||||
|             _ => { | ||||
|                 if let Some(func) = interpreter.functions.get(&expanded_name) { | ||||
|                     return interpreter.interpret_node(Box::new(func.clone())); | ||||
|                 } | ||||
|  | ||||
|                 // If it's not a built-in command or variable assignment, try to execute as external command | ||||
|                 // If it's not a built-in command, try to execute as external command | ||||
|                 match Command::new(&expanded_name).args(&expanded_args).spawn() { | ||||
|                     Ok(mut child) => { | ||||
|                         let status = child.wait().map_err(|e| e.to_string())?; | ||||
|   | ||||
| @@ -222,7 +222,7 @@ impl Interpreter { | ||||
|             let a = self.get_var_value(tokens[0])?; | ||||
|             let b = self.get_var_value(tokens[2])?; | ||||
|  | ||||
|             match tokens[1] { | ||||
|             let result = match tokens[1] { | ||||
|                 "+" => Ok(a + b), | ||||
|                 "-" => Ok(a - b), | ||||
|                 "*" => Ok(a * b), | ||||
| @@ -241,7 +241,9 @@ impl Interpreter { | ||||
|                     } | ||||
|                 } | ||||
|                 _ => Err(format!("Unsupported operation: {}", tokens[1])), | ||||
|             } | ||||
|             }; | ||||
|  | ||||
|             result | ||||
|         } else { | ||||
|             Err("Invalid arithmetic expression".to_string()) | ||||
|         } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user