A high-performance nullable type implementation for Nim, designed for explicit null handling without relying on Option[T] or reference types. Optimized for functional programming patterns with minimal runtime overhead.
- Zero-cost abstractions: Inlined operations with discriminated unions
- Functional programming: Built-in map,flatMap, andgetOrElseoperations
- Type safety: Compile-time null checking with runtime safety in debug mode
- Memory efficient: Minimal footprint using tagged unions
- Comprehensive: Works with primitives, objects, collections, and custom types
- Well-tested: Extensive test suite covering edge cases and performance scenarios
Simply copy nullable.nim to your project or add it to your Nim package.
import nullable
# Creating nullable values
let age = some(25)
let name = none[string]()
# Checking for values
if age.hasValue:
  echo "Age: ", age.value  # Age: 25
if name.isNull:
  echo "Name not provided"
# Using defaults
let displayName = name.getOrElse("Anonymous")
echo displayName  # Anonymousimport nullable
let number = some(10)
# Transform values
let doubled = number.map(proc(x: int): int = x * 2)
echo doubled  # Some(20)
# Chain operations
let result = number
  .map(proc(x: int): int = x * 3)
  .map(proc(x: int): string = "Result: " & $x)
echo result  # Some(Result: 30)
# Flat mapping
let validated = number.flatMap(proc(x: int): FastNullable[string] = 
  if x > 0: some($x) else: none[string]())
echo validated  # Some(10)import nullable
type
  Person = object
    name: string
    age: int
let person = some(Person(name: "Alice", age: 30))
let noPerson = none[Person]()
# Type-safe access
if person.hasValue:
  echo person.value.name  # Alice
# Functional operations
let personInfo = person.map(proc(p: Person): string = 
  p.name & " is " & $p.age & " years old")
echo personInfo  # Some(Alice is 30 years old)For better readability, the module provides common type aliases:
import nullable
let count: FastNullableInt = createFastNullableInt(42)
let message: FastNullableString = createFastNullableString("Hello")
let flag: FastNullableBool = some(true)
# Access with convenience functions
if count.hasValue:
  echo getFastIntValue(count)  # 42- FastNullable[T]- Generic nullable type
- FastNullableInt,- FastNullableString,- FastNullableFloat,- FastNullableBool- Common type aliases
- some[T](value: T)- Create a nullable with a value
- none[T]()- Create an empty nullable
- hasValue(): bool- Returns true if contains a value
- isNull(): bool- Returns true if empty
- value(): T- Gets the value (unsafe - check hasValue first)
- map[U](f: T -> U): FastNullable[U]- Transform the value if present
- flatMap[U](f: T -> FastNullable[U]): FastNullable[U]- Transform and flatten
- getOrElse(default: T): T- Get value or return default
- $nullable- String representation (- Some(value)or- None)
- ==- Equality comparison
Nullable is designed for performance:
- Uses discriminated unions for minimal memory overhead
- All operations are inlined for zero-cost abstractions
- No heap allocations for the nullable wrapper itself
- Efficient branching with simple boolean checks
=== Benchmark - FastNullable vs Option vs ref/nil ===
FastNullable: 0.0832 seg. Resultado: 249999500000
Option: 0.0596 seg. Resultado: 249999500000
ref/nil: 0.1063 seg. Resultado: 249999500000
Run the comprehensive test suite:
nim c -r nullable_unittest.nimThe test suite includes:
- Basic functionality tests
- Edge case handling
- Complex type operations
- Functional programming patterns
- Performance verification
- Error handling in debug mode
While Nim's Option[T] is excellent for many use cases, FastNullable offers:
- Explicit null semantics without reference types
- Extended functional API with flatMapand chaining
- Performance optimization for critical paths
- Custom domain modeling with type aliases
- Clear intent for nullable vs optional semantics
Contributions are welcome! Please ensure:
- All tests pass
- New features include corresponding tests
- Code follows the existing style
- Performance implications are considered
MIT License - see LICENSE file for details.
Developed by David Ochoa with assistance from AI tools during development and optimization.