Skip to content
/ pppl-lab1 Public template

Principles and Practice in Programming Languages: Lab 1: Recursion, Inductive Data Types, and Abstract Syntax

Notifications You must be signed in to change notification settings

csci3155/pppl-lab1

Repository files navigation

Principles and Practice in Programming Languages

Lab 1

Recursion, Inductive Data Types, and Abstract Syntax

This repository contains the student project files. If you are an instructor looking to re-use these materials, please contact Bor-Yuh Evan Chang.

Refer to the lab handout in this repository for details about the assignment. The current version of the lab handout is available on the web here.

This file provides some information to help you get started with setting up your development environment.

Integrity of the Course Materials

The development effort in the course materials, including these lab assignments, the exercises, and the exams, is significant. You agree that you will not share any course materials publicly. The course materials, include your or anyone else's solutions to the lab assignments, exercises, and exams. In particular, you agree not to post your solutions to the lab assignments in a public source code repository, such as public Github repositories. Please use private source code repositories for your work.

Repository Organization

In the directory that you want your project files, clone this repository to your local machine. You can determine the clone URL by clicking the Code button in the GitHub interface.

$ git clone <your .git URL>

In this document, the

$

simply stands for the shell prompt.

The above command will create the directory pppl-lab1.

$ cd pppl-lab1

All other commands in this document will assume that your are in this directory.

Project Files Organization

For Lab 1, the most important project files are shown below.

.
├── README.md (this file)
├── inductive-data-types-lab.ipynb        (the lab handout as a Jupyter Notebook)
└── src
    ├── main
    │   └── scala
    │       └── jsy
    │           └── lab1
    │               ├── Lab1.scala        (implementation template for you to **edit and submit**)
    │               ├── Lab1.worksheet.sc (a scratch worksheet you can use to experiment with your code)
    │               ├── Parser.scala      (a parser provided for you)
    │               └── ast.scala         (the AST definition)
    └── test
        └── scala
            └── jsy
                └── lab1
                    └── Lab1Spec.scala    (test cases you can use to test your implementation)

Prerequisites

The current version of project has been tested with the following:

You may follow the installation instructions from the above links or use your platforms package manager (e.g., Homebrew on macOS).

For working with on the lab projects, you don't have to install Scala directly. Installing sbt is sufficient to automatically download the appropriate Scala version.

Scala Development Tools

For this course, we are supporting the use of VS Code with Metals, a Scala build server.

You are welcome to use any development environment, but we may not be able answer questions in your particular environment. Another commonly used development environment for Scala is IntelliJ IDEA.

You can install Metals through the Marketplace or from the Extensions tab within VS Code.

Note that Metals may complain if it cannot find Java 11. It may prompt you to install Java 11; accepting this will download and install it for Metals specifically.

Opening the Project

The most important key combination is accessing VS Code's Command Palette. When referring to VS Code operations, we use the command name that you can find using the Command Palette, such as opening a folder.

> File: Open Folder...

You can also start a terminal window within VS Code with

> Terminal: Create New Terminal

to follow any of the terminal commands above (e.g., to git clone a repo). This is particularly useful when using a browser-based instance of VS Code like on coding.csel.io.

Open the pppl-lab1 project folder in VS Code. Metals should start automatically, and it may prompt you to import the sbt build after start up. You can click Import build. If you skipped importing the build earlier, you can use

> Metals: Import build

Importing the build may take some time. This is normal.

Now you can open src/main/scala/jsy/lab1/Lab1.scala and src/test/scala/jsy/lab1/Lab1Spec.scala. It is convenient to use Quick Open to open Lab1.scala or Lab1Spec.scala from within the directory structure without typing paths or navigating in the Explorer pane.

Command-Line Tools

While not strictly required, you may also want to use the command-line tools.

You can issue the following command to compile your code:

$ sbt compile

This command

$ sbt clean

deletes the previous compilation.

It is most convenient to run sbt interactively

$ sbt

and then run via

> compile

at the sbt prompt. The slow load time of sbt is due to starting a JVM instance, which is saved by starting it once and re-using the instance for several operations. In the following, we will show sbt commands from the sbt prompt as above.

In sbt, you can also prefix any command with ~ to re-execute the command when any file in the project is updated.

> ~compile

Scala Interactive Console

From sbt, you can start the Scala console using the command

> console

and can import the functions in your lab in the following way

scala> import jsy.lab1.Lab1._

ScalaTest

We will be using the ScalaTest framework for testing. Using this framework, we practice test-driven development (TDD), a standard practice in industry. You do not need to explicitly download ScalaTest.

Once some of the project is implemented, naturally you want to test its functionality and correctness. We provide some unit tests in Lab1Spec.scala to drive your implementation. You can also run all test objects under the src/test directory via

> test

at the sbt prompt.

In VS Code, this can be done in the GUI (or with a VS Code terminal window using the command-line tools).

VS Code Testing UI

Open Lab1Spec.scala. Then, a green triangle is visible next to each test class's definition (e.g., Lab1Spec) or test case that have not run. Clicking this will build and run the tests in that class.

Alternatively, the Testing View (via > View: Show Testing) provides a hierarchical menu for running the tests in the project. You can run all tests in the project by clicking the triangle at the top of the Testing View.

See Running and debugging your code in the Metals documentation for more information.

Troubleshooting

What if I can't run tests?

If you run into issues with running the project, a common issue is using an incompatible Java version. Check that you are using Java 11.

If the issue is running within VS Code, check your Metals: Java Home setting.

If you have another version of Java installed, you may be able to use jEnv to manage your installed JDK versions and to switch between them.

What if I can't import the build?

Have you opened files in src/ using JupyterLab? If so, you may need to delete the .ipynb_checkpoints directory that JupyterLab creates. This directory can interfere with the build import process.

Make sure your VS Code workspace is opened to the pppl-lab1 directory and importantly, not a parent directory. Refer to the Opening the Project instructions above.

About

Principles and Practice in Programming Languages: Lab 1: Recursion, Inductive Data Types, and Abstract Syntax

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published