Source code for course "How to create your own programming language"
Go to file
2024-02-17 21:48:09 +02:00
.github/workflows Fix CI 2024-01-12 22:06:06 +02:00
docs Support for long number declaration 2024-02-10 23:30:37 +02:00
editors Add GTKSourceView syntax 2024-02-17 21:48:09 +02:00
examples Add server examples 2024-01-12 20:52:30 +01:00
gradle/wrapper Gradle 8, Java 17+ 2023-08-12 23:58:11 +03:00
modules Refactor ounit functions 2024-02-10 22:30:10 +02:00
ownlang-core Improve errors displaying for container expressions 2024-01-27 20:39:05 +02:00
ownlang-desktop Redeclare module versions 2024-01-12 20:52:30 +01:00
ownlang-parser Support for long number declaration 2024-02-10 23:30:37 +02:00
ownlang-utils Disable jline expansion 2024-01-29 18:38:51 +02:00
.gitattributes Create .gitattributes 2020-05-27 16:55:52 +03:00
.gitignore Add GTKSourceView syntax 2024-02-17 21:48:09 +02:00
build.gradle Disable jline expansion 2024-01-29 18:38:51 +02:00
gradlew Fix CI 2024-01-12 22:06:06 +02:00
gradlew.bat Gradle 8, Java 17+ 2023-08-12 23:58:11 +03:00
LICENSE Обновлены файлы проекта 2016-02-25 23:18:09 +02:00
program.own Fix use statement in programs 2024-01-12 20:52:30 +01:00
proguard.properties Add SonarCloud integration, update gradle wrapper 2018-10-19 15:21:07 +03:00
README.md Fix CI 2024-01-12 22:06:06 +02:00
settings.gradle Add Gradle ownlangExec and generateMarkdownModules tasks 2024-01-12 20:52:30 +01:00

OwnLang

OwnLang - dynamic functional programming language inspired by Scala and Python. Available for PC, Android and Java ME devices.

Installing

Free Pro Desktop
Free Pro v1.5.0

Also available as AUR package:

yay -S ownlang

Key features

Higher-order functions

Functions are values, so we can store them to variables for operating.

operations = {
  "+" : def(a,b) = a+b,
  "-" : def(a,b) = a-b,
  "*" : def(a,b) = a*b,
  "/" : ::division
}

def division(v1, v2) {
  if (v2 == 0) return "error: division by zero"
  return v1 / v2
}

for name, operation : operations {
  println "2 " + name + " 3 = " + operation(2, 3)
}

Pattern Matching

Pattern matching with value pattern, tuple pattern, list pattern and optional condition.

def factorial(n) = match n {
  case 0: 1
  case n if n < 0: 0
  case _: n * factorial(n - 1)
}

def fizzbuzz(limit = 100) {
  for i = 1, i <= limit, i++ {
    println match [i % 3 == 0, i % 5 == 0] {
      case (true, false): "Fizz"
      case (false, true): "Buzz"
      case (true, true): "FizzBuzz"
      case _: i
    }
  }
}

// run
fizzbuzz()

Functional data operations

Operate data in functional style.

use std, functional

nums = [1,2,3,4,5,6,7,8,9,10]
nums = filter(nums, def(x) = x % 2 == 0)
// Squares of even numbers
squares = map(nums, def(x) = x * x)
foreach(squares, ::echo)
// Sum of squares
sum = reduce(squares, 0, def(x, y) = x + y)
println "Sum: " + sum
// Same using stream
println "Sum: " + stream(range(1, 11))
  .filter(def(x) = x % 2 == 0)
  .map(def(x) = x * x)
  .reduce(0, def(x, y) = x + y)

Operator overloading

Why not?

use std, types, math

def `..`(a, b) = range(a, b)
def `**`(a, b) = int(pow(a, b))
for y : 1 .. 10 {
  println sprintf("2 ^ %d = %d", y, 2 ** y)
}

Network module

Easy async HTTP requests with http module.

use std, http, functional

// GET request
http("https://api.github.com/events", def(r) {
  use json
  events = jsondecode(r)
  println events[0]
})

// POST request
http("http://jsonplaceholder.typicode.com/users", "POST", {
  "name": "OwnLang",
  "versionCode": 10
}, ::echo)

// PATCH request
http("http://jsonplaceholder.typicode.com/users/2", "PATCH", {"name": "Patched Name"}, ::patch_callback)

def patch_callback(v) {
  println v
}

Language specification

English and Russian

Examples

Build

Build using Gradle ./gradlew shadowJar

or take a look to latest release for binaries.

Run

To run script use command

java -jar OwnLang.jar -f input.own

or

java -jar OwnLang.jar < input.own

License

MIT - see MIT license information