Skip to content
This repository has been archived by the owner on Mar 13, 2019. It is now read-only.

DEPRECATED: A compiler for the Adamant language that is in the process of being bootstrapped. Compiles to C.

Notifications You must be signed in to change notification settings

adamant-deprecated/adamant.tools.compiler

Repository files navigation

Deprecated Adamant Compiler

A compiler for the Adamant language that is in the process of being bootstrapped. The compiler currently compiles a small subset of the Adamant language to C. It is capable of compiling itself and a small test suite. Additional language features are being implemented and the compiler code refactored to take advantages of them.

Project Status: Alpha Deprecated

This project should not be used.

Implementation Notes

The list of the currently implemented language features can be found in the docs directory.

Bootstrapping Structure

Because the Adamant compiler is being bootstrapped, there are multiple versions of the compiler that must be dealt with at any given time. This can be confusing at first if one is not used to thinking about the bootstrapping process. Many of the directories contain subdirectories for each version of the compiler. The four versions of the compiler are:

  • previous: the previous version of the compiler is used as a stable development environment for the next version of the compiler.
  • current: the version of the compiler being developed at any given time as compiled by the previous version of the compiler.
  • bootstrapped: to ensure that the current version doesn't introduce any breaking issues, it is used to recompile its own source. The version produced is the bootstrapped version.
  • double-bootstrapped: to avoid some very unusual edge cases, the compiler is recompiled using the bootstrapped version to make sure that the same output is produced.

Directory Structure

  • src: the source code of the compiler
  • target: where executable binaries are placed. Contains a directory for each version of the compiler as well as a directory for the compiled test cases.
  • test-cases: contains Adamant code files representing test cases for the compiler functionality and matching C code files that are the expected output of the compiler for the given input.
  • translated: where the Adamant code that has been compiled to C is placed before compiling to binary. Contains a directory for each version of the compiler and for the test cases.

Build and Test Scripts

The build uses the Cake build tool and runs cross platform. To run the build on Linux or MacOS you will need Mono installed. To build, simply run the Cake build tool either with the default target or the partigular target you want to build.

Building on Windows

From a Powershell command prompt at the root of the repo run .\build.ps1 or .\bulld.ps1 -Target <Target>

Building on Linux and MacOS

From the command prompt at the root of the repo run:

./build.sh

or

./build.sh -Target=<Target>

Build Targets

You can read the build\build.cake file to see the full list of targets. The targets that will normally be used are:

  • Default: The default target, builds and tests both current and bootstrapped versions.
  • Build-Current: Just builds the current version.
  • Test-Current: Builds and tests the current version.
  • Build-Bootstrapped: Builds current and bootstrapped.
  • Test-Bootstrapped: Builds current and bootstrapped, then tests bootstrapped.
  • Build-Expected: Builds the expected C results of the test cases. That is the *.c files in the test-cases directory.
  • Run-Expected: Builds and runs the expected C results of the test cases. That is the *.c files in the test-cases directory.
  • All: This is what the CI build will check. Builds and tests all versions of the compiler. Also, builds and runs the expected results of the test cases.

Development Cycle

Since the compiler is being bootstrapped, the versions of the compiler discussed above must be managed. Additionally, to avoid issues with trying to distributing binaries of the compiler for each commit, the C for each version is committed on a separate branch in the repository. This enables someone to clone the repository, compile the C code and begin development. When you build, you will be using the last version of the compiler that was published to the main repo. Commits must be pushed to the main repo before the CI build can pick them up and check in the matching C source. That source is on a separate branch accessible only by tags. As such, you will need to fetch tags by running git fetch --tags to get the built C code.

Several directories are intentionally not committed and are in the .gitignore file. These are:

  • target
  • translated

About

DEPRECATED: A compiler for the Adamant language that is in the process of being bootstrapped. Compiles to C.

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published