neva

0

🌊 Dataflow programming language with static types and implicit parallelism. Compiles to machine code and Go

Miscellaneous

visual-programming
golang
flow-based-programming
compiler
Nevalang logo

Neva Programming Language

Dataflow

Next-generation programming language that solves programmer's problems

Documentation | Examples | Community | Releases | Contributing | Architecture

tests lint

πŸ€” What Is Nevalang?

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.

πŸ‘‹ Hello, World!

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 printing
  • def 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

πŸ”₯ Features

  • πŸ“¨ Dataflow Programming - Write programs as message-passing graphs
  • πŸ”€ Implicit Parallelism - Everything is parallel by default, no async-await/threads/goroutines/etc.
  • πŸ›‘οΈ Strong Static Typing - Robust type system with generics and pattern-matching
  • πŸš€ Machine Code Compilation - Compile for any Go-supported platform, including WASM
  • ⚑️ Stream Processing - Handle real-time data with streams as first class citizens
  • 🧯 Advanced Error Handling - Errors as values with ? operator to avoid boilerplate
  • 🧩 Functional Patterns - Immutability and higher-order components
  • πŸ”Œ Dependency Injection - Modularity with interfaces and DI
  • πŸͺΆ Minimal Core - Simple language with limited abstractions
  • πŸ“¦ Package Manager - Publish packages by pushing a git-tag
  • ♻️ Garbage Collection - Automatic memory management using Go's low-latency GC
  • 🌈 Visual Programming (WIP): Edit programs as visual graphs
  • πŸ”„ Go Interoperability (WIP): Call Go from Neva and Neva from Go
  • πŸ•΅ NextGen Debugging (WIP): Observe execution in realtime and intercept messages on the fly

🧐 Why Nevalang?

Let's compare Nevalang with Go. We could compare it to any language but Go is a simple reference since Nevalang is written in Go.

FeatureNevaGo
ParadigmDataflow - nodes send and receive messages through connectionsControl flow - execution moves through instructions step by step
ConcurrencyImplicit - everything is concurrent by defaultExplicit - goroutines, channels, and mutexes
Error HandlingErrors as values with ? operator to avoid boilerplateErrors as values with if err != nil {} boilerplate
MutabilityImmutable - no variables and pointers; data races are not possibleMutable - variables and pointers; programmer must avoid data races
Null SafetyYes - nil pointer dereference is impossibleNo - nil pointer dereference is possible
Zero ValuesNo zero values - everything must be explicitly initializedZero values by default - everything can be initialized implicitly
SubtypingStructural - types are equal by their shapeNominal - types are equal by their name
TracebackAutomatic - every message traces its pathManual - programmer must explicitly wrap every error to add context
Dependency InjectionBuilt-in - any component with dependency expects injectionManual - programmer must create constructor function that takes dependencies
Stream ProcessingNative support with components like Map/Filter/ReduceProgrammer must manually implement dataflow patterns with goroutines and channels

πŸ“’ Community

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.

πŸ™ Support

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.

GitHub Star

πŸ’­ What's Next?

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.

🀝 Contributing

  1. See contributing and architecture
  2. Check out roadmap and kanban-board
  3. Also please read our CoC
  4. Join discord server