LionWeb-CSharp
0.2.4-beta.0
See the version list below for details.
dotnet add package LionWeb-CSharp --version 0.2.4-beta.0
NuGet\Install-Package LionWeb-CSharp -Version 0.2.4-beta.0
<PackageReference Include="LionWeb-CSharp" Version="0.2.4-beta.0" />
paket add LionWeb-CSharp --version 0.2.4-beta.0
#r "nuget: LionWeb-CSharp, 0.2.4-beta.0"
// Install LionWeb-CSharp as a Cake Addin #addin nuget:?package=LionWeb-CSharp&version=0.2.4-beta.0&prerelease // Install LionWeb-CSharp as a Cake Tool #tool nuget:?package=LionWeb-CSharp&version=0.2.4-beta.0&prerelease
README
This project contains the C# implementation of (parts of) the LionWeb specification. Specifically supported are:
- language definition through the LionCore M3 meta-metamodel,
- serialization and deserialization of both languages and instances of those conforming to the LionWeb JSON serialization format,
- a generic, dynamic/reflective base implementation of nodes,
- C# type generation.
For convenience, the UML representation of the LionCore M3 meta-metamodel, including the separate LionCore built-ins language, is reproduced here:
The LionCore built-ins language contains several classifiers (=instances of Classifier
, so reside on the M2-level because they don't admit a self-definition) that can be used within any language definition.
These specifically are
- the
INamed
interface – because many concepts have a "name" property, - the generic
Node
concept – to use as the type of the target(s) of an untyped reference relation, - the four built-in primitive types.
Project organization
Various aspects of LionWeb are represented as directories at the top-level of this project.
Core/
:- base types, including
Node
, a generic, dynamic/reflective implementation ofINode
, release version declaration M2/
: LionCore built-insM3/
: implementation of the LionCore M3 to define languages with, computed properties and extension methods defined on top of those, and (de-)serialization of language definitionsSerialization/
: implementation of (de-)serialization for theNode
type, and definition of the serialization chunk format (after it's been unmarshalled from JSON)Utilities/
: utilities likeCloner
,Comparer
, orReferenceUtils
- base types, including
docs/
: documentation, mainly in the form of diagrams of that as well
API
Languages
Serializing instances of Language
as a LionWeb serialization chunk can be done as follows:
// serialization to internal format:
using LionWeb.Core.M1;
SerializationChunk serializationChunk = new Serializer(LionWebVersions.Current).SerializeToChunk(languages);
// serialization of internal format to JSON:
using LionWeb.Core.Serialization;
JsonUtils.WriteJsonToFile(<path>, serializationChunk);
(Also note that code in these snippets – in particular the using
statements – might not be syntactically correct.
Adjust before use.)
Deserializing a LionWeb serialization chunk containing one or more languages can be done as follows:
JsonUtils.ReadNodesFromStreamAsync(utf8JsonStream, new LanguageDeserializer(LionWebVersions.Current))
.GetAwaiter()
.GetResult()
.Cast<Language>();
Instances
Serializing nodes (as instances of Node
) can be done as follows:
JsonUtils.WriteNodesToStream(utf8JsonStream, new Serializer(LionWebVersions.Current), <nodes>)
Deserializing a LionWeb serialization chunk that's the serialization of nodes from one language can be done as follows:
/// Configure and create deserializer:
var deserializer = new DeserializerBuilder()
.WithLanguage(<language instance>)
.Build();
// read the JSON:
var List<IReadableNode> nodes = JsonUtils.ReadNodesFromStreamAsync(utf8JsonStream, deserializer)
.GetAwaiter()
.GetResult();
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net8.0
- Utf8JsonAsyncStreamReader (>= 1.1.0)
NuGet packages (2)
Showing the top 2 NuGet packages that depend on LionWeb-CSharp:
Package | Downloads |
---|---|
LionWeb-CSharp-Generator
A generator that generates C# source code from a LionWeb M2 |
|
LionWeb.Generator.MpsSpecific
Package Description |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
0.2.4-rc.4 | 0 | 1/28/2025 |
0.2.4-rc.3 | 48 | 1/20/2025 |
0.2.4-rc.2 | 33 | 1/20/2025 |
0.2.4-rc.1 | 34 | 1/17/2025 |
0.2.4-beta.0 | 31 | 1/15/2025 |
0.2.3 | 72 | 1/13/2025 |
0.2.3-rc.2 | 31 | 1/13/2025 |
0.2.3-rc.1.1 | 31 | 1/15/2025 |
0.2.3-rc.1 | 84 | 12/4/2024 |
0.2.2 | 143 | 10/21/2024 |
0.2.2-rc.7 | 79 | 9/17/2024 |
0.2.2-rc.6 | 113 | 7/16/2024 |
0.2.2-rc.5 | 55 | 7/11/2024 |
0.2.2-rc.4 | 59 | 7/9/2024 |
0.2.2-rc.3 | 45 | 7/9/2024 |
0.2.2-rc.2 | 56 | 7/5/2024 |
0.2.2-rc.1 | 75 | 7/5/2024 |