HiLang 2.2.0
See the version list below for details.
dotnet add package HiLang --version 2.2.0
NuGet\Install-Package HiLang -Version 2.2.0
<PackageReference Include="HiLang" Version="2.2.0" />
<PackageVersion Include="HiLang" Version="2.2.0" />
<PackageReference Include="HiLang" />
paket add HiLang --version 2.2.0
#r "nuget: HiLang, 2.2.0"
#:package HiLang@2.2.0
#addin nuget:?package=HiLang&version=2.2.0
#tool nuget:?package=HiLang&version=2.2.0
HiLang
HiLang is a minimal high-level language to describe the schema of a domain, taking inspiration from protobuf (.proto models) for hierarchical structures and SQL DML for entities, relations and views.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. 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. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- FSharp.Core (>= 9.0.201)
- FsLexYacc (>= 11.3.0)
- FsLexYacc.Runtime (>= 11.3.0)
- Microsoft.CodeAnalysis.Analyzers (>= 3.11.0)
- Microsoft.CodeAnalysis.CSharp (>= 4.13.0)
- Nerdbank.GitVersioning (>= 3.7.115)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on HiLang:
| Package | Downloads |
|---|---|
|
Hiperspace.SQL
# Hiperspace.SQL Hiperspace.SQL is a full SQL query engine for Hiperspace, supporting the full range of joins, aggregations, and subqueries. Hiperspace.SQL provides the same query functionality as a .NET client can use with LINQ queries, but without the need to write code in C#/F# Hiperspace fully supports point-in-time "time travel" queries that are not possible with Python Data-Frames or DuckDB ## Features - Hiperspace.SQL is not limited to queries of columns within a table, but supports the full navigation of properties of Hiperspace elements - Where a column is a complex object it is returned as a JSON object - Executing a batch of SQL statements return columnar data frames (dictionary of column-name and array of values) - Explain SQL returns the execution plan, detailing the SetSPaces accessed and keys used for search (Key, Index, Scan) - The Parquet method returns a Parquet file that can be used with any Apache Parquet library, or added to DuckDB OLAP store |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 2.5.1 | 159 | 10/23/2025 |
| 2.5.0 | 176 | 10/20/2025 |
| 2.4.6 | 191 | 9/23/2025 |
| 2.4.4 | 268 | 8/7/2025 |
| 2.4.2 | 151 | 7/28/2025 |
| 2.4.0 | 171 | 7/10/2025 |
| 2.3.8 | 154 | 7/1/2025 |
| 2.3.7 | 182 | 6/18/2025 |
| 2.3.4 | 168 | 6/5/2025 |
| 2.2.2 | 181 | 5/5/2025 |
| 2.2.1 | 221 | 4/14/2025 |
| 2.2.0 | 127 | 3/29/2025 |
| 2.1.9 | 229 | 3/5/2025 |
| 2.1.6 | 135 | 2/15/2025 |
| 2.1.0 | 141 | 1/24/2025 |
| 2.0.0 | 111 | 1/14/2025 |
| 1.3.9 | 159 | 11/15/2024 |
| 1.3.0 | 143 | 10/5/2024 |
| 1.2.18 | 188 | 9/15/2024 |
| 1.2.16 | 167 | 9/7/2024 |
| 1.2.15 | 154 | 9/1/2024 |
| 1.2.11 | 131 | 8/6/2024 |
| 1.2.9 | 133 | 7/26/2024 |
| 1.2.8 | 169 | 7/19/2024 |
| 1.2.6 | 146 | 7/15/2024 |
| 1.2.4 | 164 | 7/4/2024 |
| 1.2.0 | 171 | 5/30/2024 |
| 1.1.37 | 158 | 5/11/2024 |
| 1.1.34 | 151 | 4/22/2024 |
| 1.1.30 | 157 | 3/24/2024 |
| 1.1.26 | 164 | 3/14/2024 |
| 1.1.23 | 174 | 2/26/2024 |
| 1.1.22 | 174 | 2/16/2024 |
| 1.1.21 | 224 | 1/11/2024 |
| 1.1.19 | 197 | 1/1/2024 |
| 1.1.17 | 173 | 12/23/2023 |
| 1.1.11 | 181 | 12/16/2023 |
| 1.1.10 | 186 | 12/6/2023 |
| 1.1.7 | 181 | 11/30/2023 |
| 1.1.5 | 175 | 11/21/2023 |
| 1.0.14-prerelease | 236 | 8/6/2023 |
https://www.cepheis.com/hiperspace/20250329
# Overview
This release introduces transitive edges, which extend the Graph model provided by `Node` and `Edge` views to include transitive traversal of an entire graph without the need for recursive queries of esoteric query languages and integrated with the data views provided by `Hiperspace`. `Graph.TransitiveEdge` encapsulates all the Edges that can be projected as a Transitive Edge using a simple set of rules.
[Transitive Edge blog](https://www.cepheis.com/blog/blog/transitive-edge) and [Enterprise Transitive Edge](https://www.cepheis.com/blog/blog/enterprise-transitive-edge) goes into the details of our model of `Transitive Edge`, but the [graph-automorphic](https://en.wikipedia.org/wiki/Graph_automorphism) view is that a `Transitive Edge` encapsulates all the edges between *nodes* and allows the user to focus on the ends rather than the intermediate steps between them, and view the data as relations using commodity business intelligence software without *esoteric* graph query languages.
## Hiperspace
The [Hiperspace](Hiperspace) package includes the additional `Graph` package types
| Name |░| Notes |
|-|-|-|
| GraphFunctions || static functions that can be sued directly, or via import in a *.hilang* schema |
| Route || Value type that defines name and rules for projecting `Edge` as `Transitive Edge` and extending to all related nodes |
| Rule || The rules for matching {From node type, edge type, to node type} Edges, to the transititive edge projection |
### SubSpace
* `SubSpace` includes an additional *view* `SetSpace` `TransitiveEdges` that includes all elements that implement this view
* `FindPaths` inteface function provides a method that matches the `Graph.GraphFunctions.Paths` function, but in a way that *domain spaces* can send the graph search to a server for parallel execution on computers that have many CPU cores.
### Fix PartitionSpace and GenerationSpace
These two Space interceptors provide the partitioning of data by *hash-bucket* and *date-range*, but fault in the implementation of state-machine to implement `IAsyncEnumerable<>` in .NET9, can result in the *map/reduce* channel being disposed before the last message is processed (*warning to the wise: don't use AI generated suggestions without considering the stress-environments that it doesn't have a clue about*)
# Hilang
The [HiLang](HiLang) schema compiler has been enhanced to include the additional {**function**, **value**,**view**,**segment**} declarations for features of `Hiperspace`.
There are three ways that an element can project a view in Hilang:
* `entity Person = Node (From = member/this, To = member/this, Name="value", TypeName = "Person")` where each member of the view is mapped to a specific member of the element
* `entity Person = Node()` where the view members are automatically matched by name with members of the element
* `entity Name = View_Name = member` **This language element has been enhanced to include a set of values** e.g. the set returned from `TransitativeEdge` function
# Hiperspace.SQL
The [Hiperspace.SQL](Hiperspace.SQL) already includes the ability to access deep structure methods like `SELECT p.Father.Name AS Father FROM Persons AS p WHERE p.Name = :parameter;', but now also allows deep structure to members to be used in `FROM` clauses to join to segments and sets within each row.
e.g. `Person` has an extension segment `MotherChild` and property `AllRelatives` that yields a `HashSet<TransitiveEdge>`, which can now be joined to in a SQL query.
```
select p.Name as Person,
r.To.Name as Relation,
r.TypeName as Relationship,
r.Length as Length,
r.Width as Width
from Persons as p,
p.AllRelatives as r
where p.Name = :name;
select p.Name as Parent, c.Name as Child
from Persons as p,
p.MotherChild as c
where p.Name = :name;
```