coursework/cw04.tex
changeset 313 90ccc385c547
parent 309 640e4a05cd9b
child 320 0c43ef11e086
--- a/coursework/cw04.tex	Mon Nov 24 09:06:27 2014 +0000
+++ b/coursework/cw04.tex	Fri Nov 28 13:11:17 2014 +0000
@@ -48,7 +48,14 @@
 \noindent
 where you might need to give the correct path to the class file. There
 are also other resources about Jasmin on the Internet, for example
-\mbox{\url{http://goo.gl/Qj8TeK}} and \mbox{\url{http://goo.gl/fpVNyT}}\;.\bigskip
+
+\begin{center}
+\url{http://www.ceng.metu.edu.tr/courses/ceng444/link/f3jasmintutorial.html}
+
+and
+
+\url{http://www.csc.villanova.edu/~tway/courses/csc8505/s2011/handouts/JVM%20and%20Jasmin.pdf}
+\end{center}
 
 \noindent
 You need to submit a document containing the answers for the two questions 
@@ -59,15 +66,22 @@
 in a txt-file or as pdf.\bigskip
 
 
-\subsection*{Question 1 (marked with 2\%)}
+\subsection*{Question 1 (marked with 5\%)}
 
-You need to lex and parse WHILE programs and submit the assembler 
-instructions for the Fibonacci program and for the program you submitted
-in Coursework 2 in Question 3. The latter should be so modified that 
-a user can input the upper bound on the console (in the original question
-it was fixed to 100).
+You need to lex and parse WHILE programs, and then generate
+Java Byte Code instructions for the Jasmin assmebler. As
+solution you need to submit the assembler instructions for the
+Fibonacci and Factorial programs. Both should be so modified
+that a user can input on the console which Fibonacci number 
+and which Factorial should calculated. The Fibonacci program
+is  given in Figure~\ref{fibs}.
 
-\subsection*{Question 2 (marked with 2\%)}
+\begin{figure}[t]
+\lstinputlisting[language=while]{../progs/fib.while}
+\caption{The Fibonacci program in the WHILE language.}
+\end{figure}
+
+\subsection*{Question 2 (marked with 5\%)}
 
 Extend the syntax of you language so that it contains also \texttt{for}-loops, like
 
@@ -128,7 +142,9 @@
 \end{minipage}
 \end{center}
 
-
+\noindent 
+Note that in this program the variable \pcode{i} is used
+twice. You need to make a decision how it should be compiled?
 
 \subsection*{Further Information}
 
@@ -142,7 +158,7 @@
 
 \begin{center}
 \begin{minipage}{10cm}
-\begin{lstlisting}[language=Java,basicstyle=\ttfamily]
+\begin{lstlisting}[language=Java,numbers=none]
 class HelloWorld {
     public static void main(String[] args) {
         System.out.println("Hello World!");
@@ -159,14 +175,14 @@
 \texttt{javap -v HelloWorld}
 \end{center}
 
-\noindent
-to see the assembler instructions of the Java byte code that has been generated for this
-program. You can compare this with the code generated for the Scala
-version of Hello World.
+\noindent to see the assembler instructions of the Java byte
+code that has been generated for this program. You can compare
+this with the code generated for the Scala version of Hello
+World.
 
 \begin{center}
 \begin{minipage}{10cm}
-\begin{lstlisting}[language=Scala,basicstyle=\ttfamily]
+\begin{lstlisting}[language=Scala,numbers=none]
 object HelloWorld {
    def main(args: Array[String]) {
       println("Hello World!")
@@ -179,15 +195,17 @@
 
 \subsection*{Library Functions}
 
-You need to generate code for the commands \texttt{write} and \texttt{read}. This
-will require the addition of some ``library'' functions to your generated code. The first
-command even needs two versions, because you might want to write out an
-integer or a string. The Java byte code will need two separate functions for this.
-For writing out an integer, you can use the assembler code
+You need to generate code for the commands \texttt{write} and
+\texttt{read}. This will require the addition of some
+``library'' functions to your generated code. The first
+command even needs two versions, because you need to write out
+an integer and string. The Java byte code will need two
+separate functions for this. For writing out an integer, you
+can use the assembler code
 
 \begin{center}
 \begin{minipage}{12cm}
-\begin{lstlisting}[basicstyle=\ttfamily, numbers=none]
+\begin{lstlisting}[language=JVMIS, numbers=none]
 .method public static write(I)V 
     .limit locals 5 
     .limit stack 5 
@@ -207,7 +225,7 @@
 
 \begin{center}
 \begin{minipage}{8cm}
-\begin{lstlisting}[basicstyle=\ttfamily, numbers=none]
+\begin{lstlisting}[language=JVMIS, numbers=none]
 iload n 
 invokestatic XXX/XXX/write(I)V
 \end{lstlisting}
@@ -225,7 +243,7 @@
 
 \begin{center}
 \begin{minipage}{12cm}
-\begin{lstlisting}[basicstyle=\ttfamily, numbers=none]
+\begin{lstlisting}[language=JVMIS, numbers=none]
 .method public static writes(Ljava/lang/String;)V
    .limit stack 2
    .limit locals 2
@@ -239,12 +257,12 @@
 \end{center}
 
 \noindent
-The code that needs to be generated for \texttt{write "some\_string"} commands 
+The code that needs to be generated for \code{write "some_string"} commands 
 is
 
 \begin{center}
 \begin{minipage}{8cm}
-\begin{lstlisting}[basicstyle=\ttfamily, numbers=none]
+\begin{lstlisting}[language=JVMIS,numbers=none]
 ldc "some_string"
 invokestatic XXX/XXX/writes(Ljava/lang/String;)V
 \end{lstlisting}
@@ -260,7 +278,7 @@
 
 \begin{center}
 \begin{minipage}{8cm}
-\begin{lstlisting}[basicstyle=\ttfamily, numbers=none]
+\begin{lstlisting}[language=JVMIS,numbers=none]
 invokestatic XXX/XXX/read()I 
 istore n
 \end{lstlisting}
@@ -272,7 +290,7 @@
 
 
 \begin{figure}[p]\small
-\begin{lstlisting}[basicstyle=\ttfamily, numbers=none]
+\begin{lstlisting}[language=JVMIS,numbers=none]
 .method public static read()I 
       .limit locals 10 
       .limit stack 10