LionWeb-CSharp 0.2.4-beta.0

This is a prerelease version of LionWeb-CSharp.
There is a newer prerelease version of this package available.
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                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="LionWeb-CSharp" Version="0.2.4-beta.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add LionWeb-CSharp --version 0.2.4-beta.0                
#r "nuget: LionWeb-CSharp, 0.2.4-beta.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// 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:

For convenience, the UML representation of the LionCore M3 meta-metamodel, including the separate LionCore built-ins language, is reproduced here:

A UML representation of the LionCore M3 meta-metamodel and LionCore built-ins

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 of INode, release version declaration
    • M2/: LionCore built-ins
    • M3/: implementation of the LionCore M3 to define languages with, computed properties and extension methods defined on top of those, and (de-)serialization of language definitions
    • Serialization/: implementation of (de-)serialization for the Node type, and definition of the serialization chunk format (after it's been unmarshalled from JSON)
    • Utilities/: utilities like Cloner, Comparer, or ReferenceUtils
  • 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 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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