HiLang 2.4.4
dotnet add package HiLang --version 2.4.4
NuGet\Install-Package HiLang -Version 2.4.4
<PackageReference Include="HiLang" Version="2.4.4" />
<PackageVersion Include="HiLang" Version="2.4.4" />
<PackageReference Include="HiLang" />
paket add HiLang --version 2.4.4
#r "nuget: HiLang, 2.4.4"
#:package HiLang@2.4.4
#addin nuget:?package=HiLang&version=2.4.4
#tool nuget:?package=HiLang&version=2.4.4
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.303)
- FsLexYacc (>= 11.3.0)
- FsLexYacc.Runtime (>= 11.3.0)
- Microsoft.CodeAnalysis.CSharp (>= 4.14.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.4.4 | 165 | 8/7/2025 |
2.4.2 | 91 | 7/28/2025 |
2.4.0 | 140 | 7/10/2025 |
2.3.8 | 132 | 7/1/2025 |
2.3.7 | 151 | 6/18/2025 |
2.3.4 | 145 | 6/5/2025 |
2.2.2 | 150 | 5/5/2025 |
2.2.1 | 200 | 4/14/2025 |
2.2.0 | 97 | 3/29/2025 |
2.1.9 | 212 | 3/5/2025 |
2.1.6 | 111 | 2/15/2025 |
2.1.0 | 112 | 1/24/2025 |
2.0.0 | 91 | 1/14/2025 |
1.3.9 | 131 | 11/15/2024 |
1.3.0 | 114 | 10/5/2024 |
1.2.18 | 154 | 9/15/2024 |
1.2.16 | 137 | 9/7/2024 |
1.2.15 | 126 | 9/1/2024 |
1.2.11 | 104 | 8/6/2024 |
1.2.9 | 103 | 7/26/2024 |
1.2.8 | 138 | 7/19/2024 |
1.2.6 | 116 | 7/15/2024 |
1.2.4 | 135 | 7/4/2024 |
1.2.0 | 139 | 5/30/2024 |
1.1.37 | 128 | 5/11/2024 |
1.1.34 | 124 | 4/22/2024 |
1.1.30 | 131 | 3/24/2024 |
1.1.26 | 148 | 3/14/2024 |
1.1.23 | 150 | 2/26/2024 |
1.1.22 | 144 | 2/16/2024 |
1.1.21 | 196 | 1/11/2024 |
1.1.19 | 168 | 1/1/2024 |
1.1.17 | 155 | 12/23/2023 |
1.1.11 | 151 | 12/16/2023 |
1.1.10 | 155 | 12/6/2023 |
1.1.7 | 151 | 11/30/2023 |
1.1.5 | 147 | 11/21/2023 |
1.0.14-prerelease | 190 | 8/6/2023 |
https://www.cepheis.com/hiperspace/20250807
## Overview
Partition elimination is an advanced feature in SQL relational databases, that skip access to a partition view when the optimizer can determine that it will not return any values. This release adds the feature to Hiperspace views to skip `SetSpace` access that is not needed, *most commonly for Graph queries*
### SQL Views
```
/* for the view */
CREATE VIEW costs AS
SELECT cost, 'Sales' as area FROM sales_costs UNION
SELECT cost, 'Operations' as area FROM ops_costs UNION
SELECT cost, 'Assets' as area FROM asset_costs ;
/* queried as */
SELECT cost FROM costs WHERE area = 'Sales';
/* will skip the query ops_costs and asset_costs since it will return no rows */
```
### Hiperspace Views
Hiperspace views provide the same function, but rather than define a view separately, the view definition is part `element` definition, with the view being created as a union of all the `elements` { `entity`, `segment`, `aspect`, `view` } that provide the `view`.
```
segment Togaf.Has.Requirement : Togaf.Base
= Node ( SKey = SKey, Name = Name, TypeName = "AF-Requirement"),
Edges (From = owner, To = this, Name = Name, FromTypeName = "AF-Has-Requirement", ToTypeName = "AF-Requirement-For") ;
```
defines a `segment` named `Togaf.Has.Requirement` *that can be viewed* as a `Node` with the `TypeName` "AF-Requirement". Within the [TOGAF](https://github.com/channell/Hiperspace/blob/master/examples/TOGAF/TOGAF.hilang) sample there are
**201** elements that *can be viewed* as a `Node`, all of which are included in the `SubSpace` view `Nodes`.
Prior to this release a LINQ query `from node in Nodes where node.TypeName == "AF-Requirement";` would scan all **201** `SetSpace` before filtering to include only *requirements*, but will now skip the scan of the other **200** types. This is especially useful for graph data-explorer browsers that will typically search for a single source node type
This is implemented with the `SetSpace<>` function `public virtual bool IsSkippable(object template) => false;` that is overridden in **HiLang** generated code, and used by all `View` Sets
## RefSet<>
The `RefSet<>` collection of references to segments or other entities (via index) has been updated to include `AddAsync` to simplify the addition of a segment reference when used from a web-assembly client.