CX is a general purpose, interpreted and compiled programming language, with a very strict type system and a syntax similar to Golang's. CX provides a new programming paradigm based on the concept of affordances.
CX is a general purpose, interpreted and compiled programming language, with a very strict type system and a syntax similar to Golang's. CX provides a new programming paradigm based on the concept of affordances, where the user can ask the programming language at runtime what can be done with a CX object (functions, expressions, packages, etc.), and interactively or automatically choose one of the affordances to be applied. This paradigm has the main objective of providing an additional security layer for decentralized, blockchain-based applications, but can also be used for general purpose programming.
CX requires a Golang version of 1.15
or higher.
You can find binary releases for most major systems on the release page.
If you are using a apt
compatible system, install the dependencies with"
sudo apt-get update
sudo apt-get install -y glade xvfb libxinerama-dev libxcursor-dev libxrandr-dev libgl1-mesa-dev libxi-dev libperl-dev libcairo2-dev libpango1.0-dev libglib2.0-dev libopenal-dev libxxf86vm-dev make
If you have not setup Golang on your machine, follow this guide to install and setup Go.
Download CX's repository using Go:
go get github.com/skycoin/cx
Get required Go dependencies with:
go get -u golang.org/x/mobile/cmd/gomobile
go get golang.org/x/mobile/gl
Navigate to CX's repository.
Build CX's binary and install by running:
make build
make install
make test
Add the CX binary path to your operating system's $PATH
. For example, in Linux:
export PATH=$PATH:$HOME/cx/bin
You should test your installation by running:
make test
If you have not setup Golang on your machine, follow this guide to install and setup Go.
If you do not have git
installed, do so with:
brew install git
Download CX's repository using Go:
go get github.com/skycoin/cx
Navigate to CX's repository.
Build CX's binary and install by running:
make build
make install
Add the CX binary path to your operating system's $PATH
. For example, in Linux:
export PATH=$PATH:$HOME/cx/bin
You should test your installation by running:
make test
Compiling CX on Windows requires a recent version of Git to be installed.
Pacman is a utility which manages software packages.
To install pacman, download Mysys2 and run the installer.
When the installation is complete, click Run MSYS2 now
.
If MSYS2 has already been installed, run it through the start menu.
You can run a full system upgrade and install required dependencies with:
pacman -Syu git mingw-w64-x86_64-openal base-devel mingw-w64-x86_64-toolchain
if [ ! -a /mingw64/lib/libOpenAL32.a ]; then ln -s /mingw64/lib/libopenal.a /mingw64/lib/libOpenAL32.a; fi
if [ ! -a /mingw64/lib/libOpenAL32.dll.a ]; then ln -s /mingw64/lib/libopenal.dll.a /mingw64/lib/libOpenAL32.dll.a; fi
You can compile CX by running:
cx-setup.bat
Test your installation by running:
cx lib/args.cx tests/main.cx ++wdir=tests ++disable-tests=issue
You can update your CX installation by running:
make install
Or on Windows:
cx-setup.bat
If you are interested in learning more about CX, please refer to the resources documentation.
If you want to get started with some basic example programs and tutorials check out the tutorials section.
The docs also provide a high level overview over the language.
Guide for cx compiler development
how to write cx wrapping libraty in Go Programming Language