Please note, the compiler is in a very early stage and not usable yet for compiling real rust programs.
gccrs is a full alternative implementation of the Rust language ontop of GCC with the goal to become fully upstream with the GNU toolchain.
The origin of this project was a community effort several years ago where Rust was still at version 0.9; the language was subject to so much change that it became difficult for a community effort to play catch up. Now that the language is stable, it is an excellent time to create alternative compilers. The developers of the project are keen “Rustaceans” with a desire to give back to the Rust community and to learn what GCC is capable of when it comes to a modern language.
Please find the answers to frequently asked questions over on: https://github.com/Rust-GCC/gccrs/wiki/Frequently-Asked-Questions
Fetch dependencies for Ubuntu:
$ apt install build-essential libgmp3-dev libmpfr-dev libmpc-dev flex bison autogen gcc-multilib dejagnu
Clone the repository
$ git clone git@github.com:Rust-GCC/gccrs.git
Compilation script. It is important to remember that GNU toolchain projects are designed to be built outside of their source directory which is why a build directory is created.
$ mkdir gccrs-build
$ cd gccrs-build
$ ../gccrs/configure --prefix=$HOME/gccrs-install --disable-bootstrap --enable-multilib --enable-languages=rust
$ make
Running the compiler itself without make install we can simply invoke the compiler proper:
$ gdb --args ./gcc/rust1 test.rs -frust-dump-parse -Warray-bounds -dumpbase test.rs -mtune=generic -march=x86-64 -O0 -version -fdump-tree-gimple -o test.s -L/lib/x86_64-linux-gnu -L/lib/../lib64 -L/usr/lib/x86_64-linux-gnu -L/usr/lib/../lib64
To invoking the compiler driver (gccrs) we need to:
$ make install
Then invoke the compiler as expected:
$ gccrs -g -O2 -c test.rs -o test.o
$ gccrs -o test test.o
Invoke the test suite via:
$ make check-rust
Test cases are located within gcc/testsuite/rust.test please feel free to contribute your specific test cases referencing any issues on Github.
There is a docker image hosted over on:
https://hub.docker.com/repository/docker/philberty/gccrs
$ docker pull philberty/gccrs
Or you can build your own image:
$ docker build . -t gccrs-dev
$ docker run --rm -v "$PWD":/usr/src/myapp -w /usr/src/myapp \
gccrs-dev:latest gccrs -g -O2 -c \
gcc/testsuite/rust.test/compilable/type_infer1.rs -o type_infer1.o
Please be aware this project is designed to be pushed upstream to GCC when we reach some milestones, and this means we require contributions to have copyright assignment in place. Please see https://gcc.gnu.org/contribute.html.
Not all contributions must be code; we would love to see new test cases or bugs and issues to be reported. Feel free to add any comments on open PRs
We can be found on all usual Rust channels such as Zulip, but we also have our own channels:
- GCC Rust Zulip: https://gcc-rust.zulipchat.com/
- Twitter: https://twitter.com/gcc_rust