aboutsummaryrefslogtreecommitdiffstats
Commit message (Collapse)AuthorAge
* feat(web): toggle identifier coloringLibravatar Kristóf Marussy2024-01-03
|
* refactor(web): subtler error predicate highlightLibravatar Kristóf Marussy2024-01-03
|
* feat(web): color identifiers and nodesLibravatar Kristóf Marussy2024-01-03
| | | | | We use a palette-based coloring strategy, where each class and enum gets a color from
* refactor: matching node names in CLI and webLibravatar Kristóf Marussy2024-01-01
|
* Merge pull request #50 from kris7t/generator-roundtripLibravatar Kristóf Marussy2023-12-25
|\ | | | | Round-trip model serialization and command line application
| * refactor(generator): scope overridesLibravatar Kristóf Marussy2023-12-25
| |
| * feat: command line model generatorLibravatar Kristóf Marussy2023-12-24
| |
| * chore(deps): bump dependenciesLibravatar Kristóf Marussy2023-12-24
| |
| * fix(language): unambigous reference serializationLibravatar Kristóf Marussy2023-12-24
| |
| * feat: solution serializerLibravatar Kristóf Marussy2023-12-24
| |
| * refactor(language): use file extension providerLibravatar Kristóf Marussy2023-12-22
| |
| * feat: state-based store for cross referencesLibravatar Kristóf Marussy2023-12-08
|/ | | | | | | Efficiently store cross references even if default ref(*, *): false. Uses propagation rules instead of view queries to reason about type constraints and multiplicity.
* chore: upgrade to Eclipse 2023-12Libravatar Kristóf Marussy2023-12-08
| | | | | | | Updates references to Eclipse in documentation (but IntelliJ is the preferred editor now). Also fixes incompatibilities with the Eclipse compiler.
* fix: typoLibravatar Kristóf Marussy2023-12-05
|
* chore(deps): Java 21Libravatar Kristóf Marussy2023-12-03
| | | | Also bumps other dependencies.
* fix: lower multiplicity objectiveLibravatar Kristóf Marussy2023-12-01
| | | | We were spuriously counting lower multiplicity errors for non-existent objects.
* Merge pull request #48 from kris7t/validatorLibravatar Kristóf Marussy2023-11-19
|\ | | | | Improve content assist and validator
| * feat(langauge): validate exists and equalsLibravatar Kristóf Marussy2023-11-19
| |
| * feat(language): arity validationLibravatar Kristóf Marussy2023-11-19
| |
| * fix: upper and lower scopesLibravatar Kristóf Marussy2023-11-19
| | | | | | | | | | | | | | | | | | Make sure the scope bound guides the best-first search and is always obeyed even if it can't be fully represented using the scoped partial model abstraction. For representable bounds (classes and unary predicate that are always fully knwon to be false or true in the initial model) this leads to duplicated computations.
| * chore(deps): bump dependenciesLibravatar Kristóf Marussy2023-11-19
| |
| * build: silence test-fixtures publication warningLibravatar Kristóf Marussy2023-11-17
| |
| * fix: contains assertionsLibravatar Kristóf Marussy2023-11-17
| |
| * feat(language): opposite reference validationLibravatar Kristóf Marussy2023-11-17
| |
| * fix: scope upper boundsLibravatar Kristóf Marussy2023-11-17
| |
| * refactor(language): opposite content assistLibravatar Kristóf Marussy2023-11-17
| | | | | | | | Only show references that may plausibly appear in an opposite declaration.
| * feat: predicates as reference typesLibravatar Kristóf Marussy2023-11-17
| | | | | | | | | | | | | | | | | | | | Now unary predicates may be used as types for cross-references. This might create circular references between predicate, but no differently than when the user manually creates predicates with circular references. The reference types of containment and container references still have to be classes, because we use the class hierarchy to encode contained types.
| * feat(language-ide): content assist filteringLibravatar Kristóf Marussy2023-11-17
| |
| * feat(language): validate unique namesLibravatar Kristóf Marussy2023-11-17
| |
| * feat(langugage): detect ambiguous referencesLibravatar Kristóf Marussy2023-11-17
|/
* build: prepare for Maven publicationLibravatar Kristóf Marussy2023-11-17
|
* Merge pull request #47 from kris7t/generator-facadeLibravatar Kristóf Marussy2023-11-03
|\ | | | | Generator facade
| * refactor: smenatics and facadesLibravatar Kristóf Marussy2023-11-03
| | | | | | | | | | Also moves model metadata into language-web, since we only use it on the frontent.
| * refactor(langauge-web): use generator facadesLibravatar Kristóf Marussy2023-11-03
| |
| * feat: model semantics facadeLibravatar Kristóf Marussy2023-11-03
| |
| * feat: model generator facadeLibravatar Kristóf Marussy2023-11-03
|/
* refactor(interpreter): aggreagator batchingLibravatar Kristóf Marussy2023-10-26
| | | | | | | | | | | | | Optimize calls to potentially costly aggregators by only extracting the value from a stateful aggregator when it is needed by subsequent RETE nodes. This optimization only works with timeless evaluation and delete-and-rederive evaluation disabled, i.e., only for queries without any recursion. Potentially, it could also be extended to other mailboxes if needed. We replace the BehaviorChangingMailbox of ColumnAggregatorNode with a DefaultMailbox to force update batching. Batched updates only extract the value from the aggregator when it has been already updated with all received tuples.
* chore(deps): dedupe Yarn dependenciesLibravatar Kristóf Marussy2023-10-20
|
* Merge pull request #46 from ↵Libravatar Kristóf Marussy2023-10-20
|\ | | | | | | | | graphs4value/dependabot/npm_and_yarn/babel/traverse-7.23.2 build(deps): bump @babel/traverse from 7.22.10 to 7.23.2
| * build(deps): bump @babel/traverse from 7.22.10 to 7.23.2Libravatar dependabot[bot]2023-10-19
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Bumps [@babel/traverse](https://github.com/babel/babel/tree/HEAD/packages/babel-traverse) from 7.22.10 to 7.23.2. - [Release notes](https://github.com/babel/babel/releases) - [Changelog](https://github.com/babel/babel/blob/main/CHANGELOG.md) - [Commits](https://github.com/babel/babel/commits/v7.23.2/packages/babel-traverse) --- updated-dependencies: - dependency-name: "@babel/traverse" dependency-type: indirect ... Signed-off-by: dependabot[bot] <support@github.com>
* | Merge pull request #43 from graphs4value/dependabot/npm_and_yarn/postcss-8.4.31Libravatar Kristóf Marussy2023-10-20
|\ \ | |/ |/| build(deps): bump postcss from 8.4.27 to 8.4.31
| * build(deps): bump postcss from 8.4.27 to 8.4.31dependabot/npm_and_yarn/postcss-8.4.31Libravatar dependabot[bot]2023-10-08
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Bumps [postcss](https://github.com/postcss/postcss) from 8.4.27 to 8.4.31. - [Release notes](https://github.com/postcss/postcss/releases) - [Changelog](https://github.com/postcss/postcss/blob/main/CHANGELOG.md) - [Commits](https://github.com/postcss/postcss/compare/8.4.27...8.4.31) --- updated-dependencies: - dependency-name: postcss dependency-type: indirect ... Signed-off-by: dependabot[bot] <support@github.com>
* | chore(deps): bump dependenciesLibravatar Kristóf Marussy2023-10-19
| |
* | fix(frontend): contains contextual keywordLibravatar Kristóf Marussy2023-10-16
| | | | | | | | | | | | | | Make sure contains is parsed as a contextual keyword whenever possible. The existing cut operator wasn't sufficient for this, so we also add dynamic precedence to the grammar rule.
* | Merge pull request #45 from kris7t/interpreter-communication-trackerLibravatar Kristóf Marussy2023-10-15
|\ \ | | | | | | Optimize Interpreter communication tracker
| * | refactor(interpreter): communication tracker algorithmLibravatar Kristóf Marussy2023-10-15
| | | | | | | | | | | | | | | | | | | | | Use a faster algorithm to detect cycles in the RETE network. Only if cycles are detected fall back to the transitive closure algorithm to construct the SCCs and the reduced graph.
| * | refactor(interpreter): generify RepresentativeElectionAlgorithmLibravatar Kristóf Marussy2023-10-15
|/ / | | | | | | | | Let representative election be used in places where IncSCCAlg was used with generic arguments other than Object.
* | Merge pull request #44 from kris7t/interpreter-performance-fixLibravatar Kristóf Marussy2023-10-15
|\ \ | |/ |/| Interpreter performance fix
| * refactor(semantics): simple name creationLibravatar Kristóf Marussy2023-10-15
| | | | | | | | Use a simpler data structure for constructing simple names.
| * refactor(interpreter-rete): recipe hashingLibravatar Kristóf Marussy2023-10-14
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Use isomorphism-aware hashing to speed up RecipeRecognizer. Due to possibly cyclic (recursive) recipes, we can't recursively turn recipes into a canonical form. Recipes referring to already canonical (non-recurisve, or recursive and entirely canonicalized) recipes can be hashed, while recursive recipes in the middle of caninicalization still have to be compared more slowly by their contents. To keep the list of recipes compared by contents small, recipes are assigned a hash code whenever possible. We keep the equivalence class IDs for recipes, as there might be hash code clashes, as well as recursive recipes that only later get assigned a hash code. Also fixes a concurrency problem with equivalence class IDs by using an AtomicLong. Also reworks recipe instantiation, as now recipes might be canonicalized before they are instantiated.