Giter VIP home page Giter VIP logo

deplang-jvm's Introduction

ARCHIVED: see https://github.com/atennapel/tynka for a new implementation of this idea

Experimental implementation of a "dysfunctional" programming language. The idea originates from this presentation by Andras Kovacs: https://www.youtube.com/watch?v=ai4vU1Naopk .

We have a language with two layers, one compile-time layer with full dependent types and a runtime-layer with a simply-typed language without higher-order functions or closures. We can get back higher-order functions and polymorphism in the compile-time layer, but after staging we get a very simple language that is easy to compile.

Try it out:

sbt "run examples/Test"
javac jvmstd/Pair.java
javac jvmstd/List.java
java Test

TODO:

  • Surface syntax
  • Parsing
  • Core syntax
  • Values
  • Evaluation
  • Unification
  • Globals
  • Elaboration
  • Pretty printing
  • Staging
  • IR syntax
  • Metas, zonking and unification
  • Meta insertion
  • Sigmas
    • Syntax
    • Parsing
    • Elaboration
  • IR simplifier
  • IR lambda removal: eta expansion, closure conversion, lambda lifting
  • Bytecode generation
    • Primitives
    • Boxing/unboxing
    • main method
    • Definitions without parameters to static properties
  • Named sigma projection
  • Bool type with if expression
  • Allow if to return lambdas
  • Fixpoint
  • Add Int and primitive binops
  • Remove Nat
  • Tail recursion
  • Primitive polymorphic list datatype
    • Type
    • Constructors
    • Elimination
  • More simplification: case-of-case, app and case commutation
  • Better inlining (inline linear lambdas, constants, globals)
  • Combine jumps (for example if+comparisons)

deplang-jvm's People

Contributors

atennapel avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.