Miscellaneous
Documentation | Examples | Community | Releases | Contributing | Architecture
Nevalang is a new kind of programming language where instead of writing step-by-step instructions you create networks where data flows between nodes as immutable messages and everything runs in parallel by default. After type-checking, your program is compiled into machine code and can be distributed as a single executable with zero dependencies.
Combined with built-in stream processing support and features like advanced error handling, Nevalang is the perfect choice for cloud-native applications requiring high concurrency.
Future updates will include visual programming and Go interoperability to allow gradual adoption and leverage existing ecosystem.
β οΈ This project is under active development and not yet production-ready.
import { fmt }
def Main(start any) (stop any) {
println fmt.Println<string>
---
:start -> 'Hello, World!' -> println -> :stop
}
Whatβs happening here:
import { fmt }
loads the fmt
package for printingdef Main
defines the main component with input port start
and output port stop
:start -> βHello, World!β -> println -> :stop
defines a connection that sends Hello, World!
string to the println
printer-node and then terminates the program?
operator to avoid boilerplateLet's compare Nevalang with Go. We could compare it to any language but Go is a simple reference since Nevalang is written in Go.
Feature | Neva | Go |
---|---|---|
Paradigm | Dataflow - nodes send and receive messages through connections | Control flow - execution moves through instructions step by step |
Concurrency | Implicit - everything is concurrent by default | Explicit - goroutines, channels, and mutexes |
Error Handling | Errors as values with ? operator to avoid boilerplate | Errors as values with if err != nil {} boilerplate |
Mutability | Immutable - no variables and pointers; data races are not possible | Mutable - variables and pointers; programmer must avoid data races |
Null Safety | Yes - nil pointer dereference is impossible | No - nil pointer dereference is possible |
Zero Values | No zero values - everything must be explicitly initialized | Zero values by default - everything can be initialized implicitly |
Subtyping | Structural - types are equal by their shape | Nominal - types are equal by their name |
Traceback | Automatic - every message traces its path | Manual - programmer must explicitly wrap every error to add context |
Dependency Injection | Built-in - any component with dependency expects injection | Manual - programmer must create constructor function that takes dependencies |
Stream Processing | Native support with components like Map/Filter/Reduce | Programmer must manually implement dataflow patterns with goroutines and channels |
As you can see, this is quite an ambitious project. Typically, such projects are backed by companies, but Nevalang is maintained by a very small group of enthusiasts. Your support by joining us will show interest and motivate us to continue.
Please give us a star βοΈ to increase our chances of getting into GitHub trends - the more attention Nevalang gets, the higher our chances of actually making a difference.
Please keep in mind that these resources might not be ready or may be outdated due to the current state of the project. However, rest assured that we take development seriously. We simply don't have enough time to keep everything up to date all the time. Please don't feel intimidated and contact us on our social platforms if you have any questions. We welcome any feedback, no matter what.