Go is an amazing, awesome programming language. But it has in many ways too much, and in other ways, too little. This is an attempt to balance it.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
champii 228c5a04bf Use custom antlr4 build for visitor pattern 9 months ago
docs Use custom antlr4 build for visitor pattern 9 months ago
lib Use custom antlr4 build for visitor pattern 9 months ago
parser Use custom antlr4 build for visitor pattern 9 months ago
scripts Updated website 10 months ago
tests removed test file on generics 9 months ago
.gitattributes gitattributes 10 months ago
.gitignore Add parser files 9 months ago
.gitlab-ci.yml Documentation website 10 months ago
LICENSE Initial commit 11 months ago
Makefile Add parser files 9 months ago
README.md Version tag v0.7.2 10 months ago
cli.go Version tag v0.7.2 10 months ago
main.go Better error system, Correct line and column, Simple AST and colors 10 months ago

README.md

Og-Lang v0.7.2 (Optimistic Golang)

Documentation Website

GoDoc

We are looking for a better name !
Renaming Og

Disclamer

This software is in its early stage.

Quick overview

This language aim to save developer time as much as possible by implementing syntactic sugar like templates or auto return. It might borrow some concepts from functionnal languages like function composition or currying.

This is a quick and dirty syntactic coloration made by hand in optic to highlight main features of the language, please don’t judge me (Or better, please contribute to make a better one :] )

Overview

Demo

Build

Here is the procedure to regenerate the parser from the grammar if you want to make changes to it.
If you just want to (re)build the binary, you can call make build or just go build (needs a previously generated parser from grammar. See below)
You will need Java, the Antlr4 library is in ./parser/antlr4-4.7.1-SNAPSHOT-complete.jar

# Get Og
go get -u github.com/champii/og 
cd $GOPATH/src/github.com/champii/og

# This will regenerate the grammar,
# Compile the existing sources from the previous Og (`og lib`)
# And run the tests.
# Needs the last official `og` binary version at global scope.
make

# It cleans the `lib` folder,
# Then compiles og from the previous global version (`og lib`)
# Then recomiles it from itself (`./og lib`)
# And run the tests
make re

# Simple exemple
og exemples/import.og

The current build time of the project is around 5s for all sources files with ./og alone, and around 20s for full rebootstrap with make re (That bootstraps from old version then rebootstraps from itself, with go build and go test each time).

Quotes

"Golang On Steroids" - Socrates
"The Code like it should be. 5/7"- Mahatma Gandhi
"(..Recursive Facepalm..)" - Google