Hybrid visual and textual functional programming.
Go to file
Dmitry Bushev 93c4453299
Update ExpressionValueUpdate Notification API (#1033)
ExpressionValueUpdate notification contains information about the
executed object. To have the full information about this object, IDE
needs the id of the corresponding suggestion. PR updates the
notification adding the suggestion id of the executed object.

- update: public API for ExpressionValueUpdate notification
- update: ContextEventsListener groups ExpressionValueUpdates and sends
  them in a batch
- update: ContextRegistry listens to the notifications from runtime and
  routes them to the corresponding listener.
- test: add ContextEventsListenerSpec
2020-07-28 23:24:04 +03:00
.cargo Prepare the repo for working on rust code (#841) 2020-06-16 17:18:11 +01:00
.github [Tool] Move engine build after launcher 2020-07-23 11:42:14 +02:00
distribution [Feat, Tool] Add CLI Parser for the Launcher 2020-07-22 19:28:03 +02:00
docs Update ExpressionValueUpdate Notification API (#1033) 2020-07-28 23:24:04 +03:00
engine Update ExpressionValueUpdate Notification API (#1033) 2020-07-28 23:24:04 +03:00
lib Update ExpressionValueUpdate Notification API (#1033) 2020-07-28 23:24:04 +03:00
project [Build,Doc] Make builds work outside a repository 2020-07-27 12:45:19 +02:00
test Method naming fixes (#1024) 2020-07-22 12:01:35 +02:00
tools Add a markdown style guide (#1022) 2020-07-21 13:59:40 +01:00
.gitignore Add Installation Mechanism in the Launcher 2020-07-28 14:57:52 +02:00
.jvmopts Java 11 Migration (#928) 2020-07-01 13:21:13 +02:00
.prettierignore Update the prettier ignore settings 2020-07-21 15:42:54 +01:00
.prettierrc.json Add a markdown style guide (#1022) 2020-07-21 13:59:40 +01:00
.scalafmt.conf Bump scalafmt to 2.6.2 (#969) 2020-07-06 10:10:06 +01:00
build.sbt [Tool] Move engine build after launcher 2020-07-23 11:42:14 +02:00
Cargo.toml Create a stub AST for the parser (#1019) 2020-07-22 12:45:08 +01:00
LICENSE Set up the repository (#1) 2019-06-11 17:07:54 +01:00
package.json Add a markdown style guide (#1022) 2020-07-21 13:59:40 +01:00
README.md Add a markdown style guide (#1022) 2020-07-21 13:59:40 +01:00


Enso Language

Enso Language


Fluidly Combining Worlds

Actions Status License License Chat

Enso is an open-source, visual language for data science that lets you design, prototype, develop and refactor any application by connecting visual elements together. Enso lets you collaborate with your co-workers, interactively fine-tune parameters, inspect results and visually profile and debug your programs in real-time, creating a moment where the mind is free to let the body create.

Enso consists of several sub projects, including the Enso Language Compiler and the Enso Integrated Development Environment (IDE). You can also check out the Enso Website for more information.

This repository contains Enso Engine, which consists of the compiler, type-checker, runtime and language server. These components implement Enso the language in its entirety, and are usable in isolation.

Getting Started

While we currently don't have any official releases of Enso, nightly builds can be obtained from the CI artifacts. For more information on how to run these, please refer to the documentation on getting Enso.

If you want to read more about the internals of Enso, please take a look at the developer documentation rendered here, or in the repository here.

Building

The project builds on any platform where GraalVM can run. You will need the source code, and sbt. For more information, please read the detailed instructions in CONTRIBUTING.md.

Enso's Design

If you would like to gain a better understanding of the principles on which Enso is based, or just delve into the why's and what's of Enso's design, please take a look in the docs/ folder. It is split up into subfolders for each component of Enso. You can view this same documentation in a rendered form at the developer docs website.

This folder also contains a document on Enso's design philosophy, that details the thought process that we use when contemplating changes or additions to the language.

This documentation will evolve as Enso does, both to help newcomers to the project understand the reasoning behind the code, but also to act as a record of the decisions that have been made through Enso's evolution.

License

This repository is licensed under the Apache 2.0, as specified in the LICENSE file.

This license set was choosen to both provide you with a complete freedom to use Enso, create libraries, and release them under any license of your choice, while also allowing us to release commercial products on top of the platform, including Enso Cloud and Enso Enterprise server managers.

Contributing to Enso

Enso is a community-driven open source project which is and will always be open and free to use. We are committed to a fully transparent development process and highly appreciate every contribution. If you love the vision behind Enso and you want to redefine the data processing world, join us and help us track down bugs, implement new features, improve the documentation or spread the word!

If you'd like to help us make this vision a reality, please feel free to join our chat, and take a look at our development and contribution guidelines. The latter describes all the ways in which you can help out with the project, as well as provides detailed instructions for building and hacking on Enso.

If you believe that you have found a security vulnerability in Enso, or that you have a bug report that poses a security risk to Enso's users, please take a look at our security guidelines for a course of action.