Skip to content

Latest commit

 

History

History
179 lines (142 loc) · 6.2 KB

README.md

File metadata and controls

179 lines (142 loc) · 6.2 KB

The CSpydr Programming Language

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.

Current Status

Made with Stars Forks License Issues

A list of all the features, that are/will be implemented.

cspc Compiler features:
  • 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 and import 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
CSpydr Language features:
  • 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 and loop
  • 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
CSpydr Standard library features
  • basic c17 libc-header implementation
  • glfw and OpenGL/GLU header files
  • cURL header implementation
  • from-the-ground custom written stdlib based on linux syscalls (in progress)

Installation

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!

Getting CSpydr

$ git clone https://github.com/spydr06/cspydr.git

Dependencies

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 with llvm-c bindings (optional)

Programs:

  • cmake
  • gcc or clang
  • as (GNU assembler)
  • ld (GNU linker)
  • llvm-config (optional)

Building

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)

Installation

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

Usage

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

The CSpydr Syntax

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

Examples

For more examples, please refer to the examples/ directory in this repository.

(I will write a proper documentation in the future!)

Editor support

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.

Contributing

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.

License

CSpydr is licensed under the MIT License

Resources | Reference | Inspiration