Skip to content

Latest commit

 

History

History
139 lines (108 loc) · 7.38 KB

README.md

File metadata and controls

139 lines (108 loc) · 7.38 KB

What is Daisho?



The goal of this project is to create a language that's basically C , but way nicer to work with. It transpiles to POSIX C , but provides a way to pave over the sharp edges that come with writing C directly.

In particular, Daisho is focused on generic traits. However, interop between C , Daisho , and Python code should be seamless, and no performance shall be left on the table.


Status

Although everything is a WIP, it's not like no progress has been made. The collection of C libraries that will underpin the compiler and language runtime is almost done. These libraries are already a useful tool in their own right. The goal of this project is to make writing C less painful, and these libraries already accomplish that to some degree. They provide many things that C programmers usually spend a considerable amount of time rewriting for every project.

Also, a lot of work is happening in pgen, a tokenizer/parser generator that I'm bootstrapping for compiling the grammar of this language. To see that grammar, look at daic/grammar/daisho.peg.

I'm almost done writing the parser. Now I'm working on symbol table generation and type unification.


How can I get involved?

If you have suggestions or want to talk about type systems and their implementation, come on over to our Discord.

On the code side, there's not a lot that people can help with. Once a prototype compiler is working, there should be a lot more to do. But until then, I'm the limiting factor.

For right now, what would be useful is to free up some of my time. What would get us to a working compiler the fastest isn't people pitching in to help write it, but people pitching in to write documentation and tests.

The other thing that would be very helpful would be to have people to talk to about language features and their implementation. I have clear goals, but certain aspects of the design of the language are unfinished, particularly the type unification and monomorphization algorithms. These thoughts have plagued me for months. If you know something about type systems, or know someone who does and is willing to talk, let me know. Having people to talk to about that would be excellent, and would also get the language done a lot faster.


Project Structure

If you're planning on contributing, here's the general lay of the land.

  • planning/ - Documentation about how the language is going to work.
  • daic/ - The compiler
  • daic-old/ - An early draft of the compiler.
    • Gutted and broken beyond repair, but some can be repurposed.
  • config/ - Configure scripts.
    • Detects which features are available on the platform it's running on.
    • Generates `stdlib/Native/Configs/GeneratedConfig.h. See it for more details.
  • grammar/ - Materials related to generating the parser.
    • This will probably be renamed as the parser-generator is added as a submodule.
  • research/ - Interesting research materials related to building the language.
  • stdlib/ - The Daisho standard library and C runtime libraries
    • Everything is header-only. To use the C runtime library, just #include "Daisho.h".
    • Features:
      • Formatted signal and thread-safe backtraces (depends on glibc)
      • Multiple memory allocators
        • Bump, Fixed size bitmask, and mallocator
      • A memory debugger
        • Keeps a list of unfreed memory.
      • Uniform error handling
      • Optimizing tagged pointers
      • Performance Profiling
      • Threadpools
      • Macros for std::numeric_limits<T>::min()/max()
      • Pseudo-Random number generation
      • A utf-8 Parser
    • All of these features are fully integrated with each other and work together.

System Requirements

  • A POSIX-compliant operating system (Like Linux, MacOS, BSD)
  • A working C toolchain that supports C11.
    • The C compiler should have an optimizer.
  • Reasonable hardware.
    • Daisho doesn't support all the platforms that C does. It assumes CHAR_BIT is 8, an int is 32 bits, long is 64, etc.
    • If your computer isn't 15-20 years old, you're probably fine. If you're not fine, the configure script will fail and you'll get an error message as to why. If that happens, reach out to me on discord with details of your system. If it's a bug, we'll get it worked out.

If you're not on a POSIX operating system (if you're still on Windows), I recommend switching to one. There are good beginner linux distributions, and they're quickly getting better and better. It's possible that Daisho gets ported to Windows, but it's nowhere near my list of priorities, and I don't want to be the one who does it. If you want to be the one that does it, please contact me on Discord. In about a year.


List of inspiring languages:

Lang Inspiration
C Simplicity, flat memory model
C++ Templates, zero cost abstraction
Java Collections/Streams APIs
Python List comprehensions
Rust static/dyn Traits
Vala Compilation model
Cello Metaprogramming on top of C

Daisho is:

  • C, with modern high level language features.
  • Fast to execute (like C), but also fast to write (unlike C).
  • Easy to write and use, mixing C, Python, and Daisho code in the same file.
  • Easy to debug, with tools to find memory leaks and errors.
  • Focused on tooling and user experience.
  • A passion project.

Daisho is not:

  • Memory safe
    • Just like the C that it's based on and compiles to.
    • In practice, you should be fine. Unsafety can be solved through tooling.
      • Memory and UB sanitizer tooling is being built, and will be available as compile flags.
  • Fast at compiling programs
    • This is a goal, but not a priority.
    • For now, having a compiler at all is a higher priority.

Sub-Projects:

  • Daisho Compiler (daic folder)
  • C Standard Library (stdlib folder)
  • Memory Sanitizer (coming soon)
  • UB Sanitizer (coming soon)
  • Package Manager (coming eventually)
  • Language Server (coming eventually)
  • VSCode Extension (coming eventually)
  • Code Formatter (coming eventually)