Perform all semantic checks and execute the program

Assignment Help Computer Engineering
Reference no: EM131307260

Program Assignment -

For this assignment we are expanding on assignment 3.  Now that we have parsed input, we will execute the code.

As a reminder, the language has the following rules:

1. An empty string is a semantic error.

2. The language contains only two types: a string and an integer.

3. The language contains only two statements: a print statement, and a set statement.

4. PRINT means evaluate the expression and printing the result on standard out.

5. SET means evaluate the expression and save the value in the variable named ID

6. It is an error to use a variable that has not been set.

7. The addition and multiplication operators associate left-to-right.

8. Addition is defined only between two integers or two strings. String addition is concatenation.

9. Multiplication is defined between two integers or between an integer and a string. Multiplying a string by an integer X repeats the string X times.

10. The language includes a subscripting operator which may have one or two expressions inside the square bracket, separated by a semicolon. Both expressions must evaluate to integers, which are used as indexes into the string (starting, of course, from zero). A single expression results in a string containing the single character at that position. Two expressions results in a substring beginning at the first position and ending at the character before the second position. If either of the expressions would access a character that is not in the string, this will be deemed a runtime error.

11. All other combination of types and operations are undefined.

For this assignment, after parsing you must perform all semantic checks and execute the program. Please note that some of the checks can be performed statically (an empty string constant is an error, and using a variable before setting it is an error), but some can only be performed at run time.

Failing a static check should print an error message and stop execution. Failing a dynamic check should print the string RUNTIME ERROR followed by a description of the error (for example; RUNTIME ERROR types being added are not permitted).

Observe that doing this assignment involves evaluating the parse tree, which is a recursive operation. Defining a virtual eval() function, with different implementations in different classes, is a useful approach. It's also likely that you will need to define some idea of a Type and a Value for this assignment. The eval() function will likely want to return a Value, and will need to test a Type.  

Your program should read the file whose name is passed as a command line argument, or the standard input if no command line argument is provided. You may divide this assignment into as many files as you like. You MUST use p2lex.h from the last assignment, with no changes. You MUST have your lexical analyzer in a separate file.

Attachment:- Assignment.zip

Reference no: EM131307260

Questions Cloud

Find the equation of the line tangent to the curve at : Find the equation of the line tangent to the curve at. Find the equation of the line tangent to the curve at. Let C be the curve given parametrically by. Find an equation for the line tangent to C at the point corresponding to.
Development of a new technology like mobile banking : Work with two other class members in a virtual environment on this exercise. Write a short paper or presentation that summarizes your analysis and opinions of how working virtually helped or hindered your results.
What proportion of total variation in weight can be explain : What proportion of the total variation in the weight can be explained by this model? How about after adjusting for the number of terms in the model.
Calculate number of different combinations for the spheres : There are 3 x 103 spheres in a box. Calculate the number of different combinations for the spheres in order to have 1100 spheres in the front third of the box.
Perform all semantic checks and execute the program : For this assignment, after parsing you must perform all semantic checks and execute the program. Please note that some of the checks can be performed statically (an empty string constant is an error, and using a variable before setting it is an er..
Find the smallest value of k : a linear spring k is to be designed to stop a 20-mg railroad car traveling at 8km/h within 400 mm after impact. Find the smallest value of k that will produce the desired result.
Calculate the delta of the call option : Under which circumstances does the investor make profit? When will the option be exercised? Draw a diagram to show the variation in the investors profit and the share price at the maturity of the option.
Determine the effective moment and vertical shear force : Determine the effective moment and vertical shear force that would be required to replicate the effect of the three bar forces in Problem 1.15.
Review the employee handbook at your place of employment : Review the employee handbook at your place of employment -  Do the company policies articulate a difference in how the company treats workplace injuries as opposed to other disabling injuries (such as non-work related injuries or congenital or inna..

Reviews

len1307260

12/10/2016 3:49:33 AM

I attached 5 files below. DirectionA4.pdf tells you the direction you need to follow. guide.pdf is some information on best way to approach this assignment. p2lex.h and p2lex.cpp are the header and source file for lexical analyzer. These are needed for the assignment. Assignment3code.cpp is the parse tree that was developed in previous project so you can use Assignment3code.cpp as the parse tree to implement this assignment. Please make the code compile, but don't make it look to perfect. This code will be only tested on Linux computer.

Write a Review

 

Computer Engineering Questions & Answers

  Create a symbolic equation for het capacity

Empirical constants do not have physical meaning but are used to make the equation fir the data. Create a symbolic equation for het capacity and solve it for T.

  Present the business case for technology investments

paper describing how to formulate and present the business case for technology investments

  Program to count the number of times page is opened

Generate a page in order to count the number of times the page is viewed by the user in a single session. Each time page is refreshed or opened in the browser during the session counts as 1 page view.

  What are pros and cons of society''s increasing reliance data

What are pros and cons of society's increasing reliance data

  Describe the type and basic uses of the system how the

write a 700- to 1050-word paper identifying and describing how specific system used in an organization has transformed

  Discussion of the physical aspects of disk performance

In our discussion of the physical aspects of disk performance, we stated that replacing 7200 RPM disks with 10,000 RPM disks can bring a 10% to 50% performance improvement.

  Give a formula in terms of the black-scholes formula

A contract, D, pays 30% of the increase (if any) of a stock's value in a year. If St follows Black-Scholes assumptions, give a formula in terms of the Black-Scholes formula for the price of D.

  Identify threats for which a matching vulnerability exists

The Assignment Using the NIST Special Publication 800-30, complete a Risk Assessment to identify potential threats for which a matching vulnerability exists in the above described environment.

  What are your impressions of the noun technique

Create a UML class diagram using the classes you have identified and add names to the associations and multiplicity constraints. What are your impressions of the noun technique?

  Explain two methods for categorical data conversion

explain two methods for categorical data conversion. List the advantages and disadvantages of this approach.

  Write a program which simulates a forest fire

Write a program which simulates a forest fire on a 12 x 12 matrix. You will model the effects of the fire from it's inception until it burns out.

  Distinguish between open and closed applications.

explain  HTML, XML and Java programming. What is the difference between the three.

Free Assignment Quote

Assured A++ Grade

Get guaranteed satisfaction & time on delivery in every assignment order you paid with us! We ensure premium quality solution document along with free turntin report!

All rights reserved! Copyrights ©2019-2020 ExpertsMind IT Educational Pvt Ltd