A programming language to allow simple queue manipulation
- Manipulate a single queue per program
- Queue elements may be integers from 0 - 10
- All major queue methods are implemented
- Two versions of our language: compiled and interpreted
- Displays parsing and analysis data in real time as it runs
ADD will add an element to the back of the queue
REMOVE will remove an element to the front of the queue
PEEK will display the element at the front of the queue
LENGTH will display the current length of the queue
- Boolean expression to be placed inside an IF statement.
- Evaluates to true if the queue is empty.
Works like EMPTY only evaluates to true if the queue is not empty.
Shows the queue in its current state
- Can only take EMPTY or NOT_EMPTY as an argument.
- The line following the IF statement will be evaluated only if the IF statement is true.
<line> ----> <expression>;
<expression> ----> ADD <element> |
REMOVE |
PEEK |
LENGTH |
VIEW |
IF (<if_expr>)
<if_expr> ----> EMPTY |
NOT_EMPTY
<element> ----> <int>
<int> ----> 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10
- Read in a text file to a string
- Pass the source code string to Parser.java
- Parser.java finds all the tokens and puts them in an array
- The array is passed back to our main driver
############## Parsing.... #################
Next token is ADD
Next token is 1
Next token is ;
Next token is ADD
Next token is 5
Next token is ;
Next token is ADD
Next token is 9
Next token is ;
Next token is ADD
Next token is 8
Next token is ;
Next token is VIEW
Next token is ;
Next token is REMOVE
Next token is ;
Next token is VIEW
Next token is ;
Next token is PEEK
Next token is ;
Next token is LENGTH
Next token is ;
Next token is VIEW
Next token is ;
Next token is IF
Next token is (
Next token is NOT_EMPTY
Next token is )
Next token is ;
Next token is VIEW
Next token is ;
Next token is IF
Next token is (
Next token is EMPTY
Next token is )
Next token is ;
Next token is VIEW
Next token is ;
This stage combines token analysis and writing to "machine code" (java)
- The token array is passed into LexicalAnalyzer.java
- Tokens are converted from our Q Language code to java code
- The java code is written to output.java
############## Analyzing.... #################
Next line of execution: queue.add(1);
Next line of execution: queue.add(5);
Next line of execution: queue.add(9);
Next line of execution: queue.add(8);
Next line of execution: queue.view();
Next line of execution: queue.remove();
Next line of execution: queue.view();
Next line of execution: queue.showFirst((Integer) queue.peek());
Next line of execution: queue.getLength(queue.size());
Next line of execution: queue.view();
Next line of execution: queue.view();
Next line of execution: queue.view();
- output.java is compiled to output.class using Runtime.exec().
- output.class acts as our executable, the output from our pseudo-compiler
############## Compiling.... #################
############## Done! #################
Your file is compiled. You can run it by running:
java output
Happy queueing!
$ java Queue myfile.queue
$ java output
-
The logic behind the interpreted version is nearly identical to that of the compiled version.
-
The major difference is the order in which everything runs
-
No more separate parsing, analyzing, compiling, and running.
-
A verbose option allows users to see how to program steps through the code.
- Like the compiled version, our source code is translated into a string.
- The string of Q Language code is passed to our Interpreter.java
- The Interpreter has one loop that runs through the source code, parsing, analyzing, and executing as it goes.
- Once a token is found, it is analyzed.
- If the analysis finds an instruction to run, the instruction will be run right away.
Adding -v before the source file will display the parsing data along with the runtime data.
Got token ADD
Got token 1
Got token ;
Got token ADD
Got token 5
Got token ;
Got token ADD
Got token 9
Got token ;
Got token ADD
Got token 8
Got token ;
Got token VIEW
1 <- 5 <- 9 <- 8 <-
Got token ;
Got token REMOVE
Got token ;
Got token VIEW
5 <- 9 <- 8 <-
Got token ;
Got token PEEK
The first element is: 5
Got token ;
Got token LENGTH
The length is: 3
Got token ;
Got token VIEW
5 <- 9 <- 8 <-
Got token ;
Got token IF
-IN IF-
Got token (
Got token NOT_EMPTY
Got token )
Got token ;
Got token VIEW
5 <- 9 <- 8 <-
Got token ;
-OUT IF-
Got token IF
-IN IF-
Got token (
Got token EMPTY
Got token )
Got token ;
Got token VIEW
Got token ;
Without the -v option, the program will only display what was requested in the source file:
1 <- 5 <- 9 <- 8 <-
5 <- 9 <- 8 <-
The first element is: 5
The length is: 3
5 <- 9 <- 8 <-
5 <- 9 <- 8 <-
$ java Queue -v myfile.queue