CSpydr is a low-level, static typed, free and open-source, compiled programming language inspired by Rust and C. This repository contains cspc
(the CSpydr Programming Language Compiler), as well as CSpydr's Standard Libraray, some code examples and unit tests.
A list of all the features, that are/will be implemented.
- Assembly code generator for
x86_64 linux
- LLVM codegen target (maybe even WASM?)
- move to an intermediate bytecode compiler
- AST to JSON converter (in progress)
- C transpiler (deprecated)
- lexing tokens
-
macro
andimport
preprocessor - parsing an AST, validation of syntax and semantics
- type evaluator & checking
- implicit type casts
- "projects" - prebuild libraries such as the
stdlib
- CLI and error handling
- memory management
- primitive data types
i8
i16
i32
i64
u8
u16
u32
u64
f32
f64
f80
bool
char
void
- pointers, arrays and c-like arrays
&
[]
'c[]
- custom data types
struct
union
enum
{}
(tuples) - control statements
if
match
for
while
loop
ret
break
continue
noop
with
do-while
do-unless
- different loop types:
for
,while
,do-while
andloop
- expressions
-
extern
functions and globals - type-related keywords
sizeof
typeof
alignof
len
- file imports
- macros and macro-overloading
- default macros
__version__
__system__
__architecture__
__time__
__compile_type__
__main_file__
__file__
__line__
__func__
- namespaces, functions, globals, typedefs
- inline
asm
code blocks - lambda expressions
- templates in fuctions and structs
- va lists
- functions as struct members
- basic
c17
libc
-header implementation -
glfw
andOpenGL
/GLU
header files -
cURL
header implementation - from-the-ground custom written
stdlib
based on linux syscalls (in progress)
Currently, CSpydr is only available for Linux. Once a first major release is in sight I will create an AUR repository for Arch Linux, but at the moment building and installation is done via CMake from source. Of course you can still use CSpydr via WSL on Windows!
$ git clone https://github.com/spydr06/cspydr.git
CSpydr depends on the following libraries. They need to be installed on your computer for CSpydr to successfully build. Be sure to also install the corresponding -dev
or -devel
of library packages for header files.
Libraries:
libbsd
json-c
glibc
llvm
withllvm-c
bindings (optional)
Programs:
cmake
gcc
orclang
as
(GNU assembler)ld
(GNU linker)llvm-config
(optional)
Building CSpydr is done via CMake using the following commands (after cloning this repository):
$ cd ./cspydr
$ cmake .
$ make
If you don't want llvm in your build, you can disable it with:
$ cmake . -DNO_LLVM=1 $ make(to reenable, set
NO_LLVM=0
)
Global installation is necessary, because of the compiler needing the standard library to be present at /usr/share/cspydr/std
.
To install CSpydr with all of its components (cspc - The CSpydr Compiler and the CSpydr Standard Library), enter this command (needs root privileges):
# make install
Alternatively, you can specify the path of the std library with the -p
or --std-path
flags:
$ cspc <your build command> -p ./src/std
To compile a CSpydr program use the following command:
$ cspc build <your file>
To directly run a program use this command:
$ cspc run <your file>
To launch a special debug shell, start your program using the debug
action:
(not finished yet!)
$ cspc debug <your file>
Get help using this command:
$ cspc --help
A simple hello-world program:
import "io.csp";
fn main(): i32
{
std::io::puts("Hello, World!");
<- 0;
}
Running this program is as easy as entering the following command:
$ cspc run hello-world.csp
For more examples, please refer to the examples/
directory in this repository.
(I will write a proper documentation in the future!)
CSpydr currently only supports Visual Studio Code, since thats the code editor I personally use for developing. I will add support for other editors later on.
Check out the Visual Studio Code extension here.
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.
Please make sure to update the unit tests as appropriate.
CSpydr is licensed under the MIT License
- chibicc C compiler: https://github.com/rui314/chibicc.git
- vcc: https://github.com/lemoncmd/vcc.git
- tac programming language: https://github.com/sebbekarlsson/tac.git
- summus programming language: https://github.com/igor84/summus.git
- porth programming language: https://gitlab.com/tsoding/porth.git
- cURL C library for transferring data: https://github.com/curl/curl