-
Notifications
You must be signed in to change notification settings - Fork 145
Contributing to Frege
You can contribute to Frege in many ways as outlined on the home page.
For contributions to the core, you need to know how to compile the compiler.
Here is how to do that.
- computer with 256MB memory available to user processes. For compiling very large programs (like the yacc generated parser of the frege compiler, approx. 1800 functions on 40000 lines), 3 to 4 times more memory will be needed.
- 50MB disk space for the unpacked downloads.
- a Java 7 compatible JDK
- Compiler developers will need perl, make and berkeley yacc - look for byacc, pbyacc or byaccj.
##Compile, run and document Frege programs
- Download the latest
frege3
.xx.vvv.jar
from the releases page, and rename it tofregec.jar
- Use your preferred editor. There is some support for Frege in UltraEdit and jEdit, see the
examples/
source directory. - In the
examples/
subdirectory of the source tree you also find some small programs to play with. - Customize your command-line window so that it can display unicode characters. (on Windows, try:
chcp 65001
) - Make sure the JDK7 java compiler is in the path:
javac -version
- Make sure the JDK7 java launcher is in the path:
java -version
- Display usage page of the Frege compiler:
java -jar fregec.jar -help
- Make a subdirectory to hold Frege generated classes:
mkdir build
- Compile your program (the
-Xss1m
protects us from getting stack overflow exceptions and should be sufficient even for large source programs):
java -Xss1m -jar fregec.jar -d build test.fr
- Neither the source code file nor the
fregec.jar
have to reside in the current directory. Of course, if they don't, the compile command above must be adapted accordingly. - Unlike in java, the source path does not have to match the module name. However, when the module name is
x.y.Z
, the class file goes intobuild/x/y/Z.class
, wherebuild
is the (already existing) directory specified with the-d
option, which is the current directory by default. You'll also find the intermediate java file inbuild/x/y/Z.java
, just in case you're interested to see really incomprehensible java code - please protect children and young programming adepts from looking at it. - If your program contained a
main
function, you can now run it with the following command whereTest
is the package or module name. Under Linux, write:
instead of;
to separate class path components:
java -cp build:fregec.jar Test
- If your program contains QuickCheck properties, you can now check them:
java -cp build:fregec.jar frege.tools.Quick Test
- Generate a documentation for your module or for any other module from the
fregec.jar
:
java -cp build:fregec.jar frege.tools.Doc Test
The compiler build environment, scripts, tools and the
Makefile
were originally running on Windows 7, but development shifted more and more to a more developer friendly OS, and at some point no effort was put anymore in keeping up Windows compatibility. However, if you manage to get the tools (nmake, perl, pbyacc, find, grep) it should be not too hard to adapt the Makefile - it is then mostly a matter of getting the path separator right.
Recompiling the compiler is only necessary if you are about to contribute to the compiler itself or the standard library. In this case, you are expected to make sure that you are able to re-compile the compiler and that a clean build will be possible after you changed something.
- get the source distribution with
git clone https://github.com/Frege/frege.git
- cd to the checked out directory and make subdirectories
build
,dist
anddoc
if not present already. - Download the latest
frege3
.xx.vvv.jar
and place it in the working directory under the namefregec.jar
- check if the Makefile macros JAVAC, YACC and JAVA point to the correct executables
- the Makefile macro JAVA defines the property
-Dfrege.javac
. You can specify here a different path for the java compiler that is to be called from the frege compiler. For example, suppose you need JDK 6 for your daily work, so thatjava
andjavac
call the JDK 6 binaries. You could then rename or alias the JDK 7 binaries withjava7
andjavac7
. In this case, settings could look like
JAVAC=javac7
JAVA=java7 "-Dfrege.javac=javac7 -J-Xmx512m"
or, better yet
JAVA=java7 "-Dfrege.javac=internal -J-Xmx512m"
For this to work, the java7
command must be the one from the JDK.
If you work with JDK7 or JDK8, the standard settings in the Makefile
should be fine.
Run the following command:
make runtime compiler
The build will probably take no less than 15 minutes and consists of the following main steps:
- compilation of the compiler sources and library sources needed in the compiler with
fregec.jar
- compilation of the same with the compiler built in the first step
- compilation of the sources with the compiler built in the second step
(It is normal when the CPU utilization goes to 100% for a while even if you have many cores - the compiler will compile a bunch of source files in parallel.)
The result will be a bunch of class files below the build
directory.
You can now run the compiler with
java -cp build frege.compiler.Main -version
To make a new fregec.jar
from the fresh compiler, run
make fregec.jar
The 3 builds are necessary for the following reason: The first build uses the old compiler to build a compiler that incorporates your changes. The second build uses the changed compiler and tries to build another compiler. If this works, and the second compiler itself can successfully create the 3rd compiler and if that one produces the same code as the second one (for a test program, say, where you test the new features), then (and only then) it is reasonable to assume that you didn't break anything.
Because the Frege compiler is self hosting, it cannot be guaranteed at all times that you can do the following:
- download fregec-3.x.y.jar
- checkout the latest sources
- compile the compiler
Unfortunately. (Sometimes even when the HEAD is just 1 commit ahead.) Sorry. This is also the reason why the nightly build is often broken.
If that happens to you, please post a message in the news group and we will happy to get you a bleeding edge compiler.
Home
News
Community
- Online Communities
- Frege Ecosystem
- Frege Day 2015
- Protocol
- Simon Peyton-Jones Transcript
- Talks
- Articles
- Books
- Courses
Documentation
- Getting Started
- Online REPL
- FAQ
- Language and API Reference
- Libraries
- Language Interoperability
- Calling Frege From Java (old)
- Calling Java From Frege
- Calling Frege From Java (new)
- Compiler Manpage
- Source Code Doc
- Contributing
- System Properties
- License
- IDE Support
- Eclipse
- Intellij
- VS Code and Language Server
- Haskell
- Differences
- GHC Options vs Frege
- Learn You A Haskell Adaptations
- Official Doc
Downloads