HiLang 2.5.28
dotnet add package HiLang --version 2.5.28
NuGet\Install-Package HiLang -Version 2.5.28
<PackageReference Include="HiLang" Version="2.5.28" />
<PackageVersion Include="HiLang" Version="2.5.28" />
<PackageReference Include="HiLang" />
paket add HiLang --version 2.5.28
#r "nuget: HiLang, 2.5.28"
#:package HiLang@2.5.28
#addin nuget:?package=HiLang&version=2.5.28
#tool nuget:?package=HiLang&version=2.5.28
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 (>= 10.0.100)
- FsLexYacc (>= 11.3.0)
- FsLexYacc.Runtime (>= 11.3.0)
- Microsoft.CodeAnalysis.CSharp (>= 5.0.0)
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.28 | 94 | 12/31/2025 |
| 2.5.26 | 168 | 12/21/2025 |
| 2.5.21 | 1,495 | 12/10/2025 |
| 2.5.18 | 3,571 | 12/3/2025 |
| 2.5.8 | 3,054 | 11/15/2025 |
| 2.5.2 | 3,072 | 11/6/2025 |
| 2.5.1 | 3,044 | 10/23/2025 |
| 2.5.0 | 3,055 | 10/20/2025 |
| 2.4.6 | 3,064 | 9/23/2025 |
| 2.4.4 | 3,149 | 8/7/2025 |
| 2.4.2 | 3,032 | 7/28/2025 |
| 2.4.0 | 3,055 | 7/10/2025 |
| 2.3.8 | 3,038 | 7/1/2025 |
| 2.3.7 | 3,069 | 6/18/2025 |
| 2.3.4 | 3,055 | 6/5/2025 |
| 2.2.2 | 3,056 | 5/5/2025 |
| 2.2.1 | 3,109 | 4/14/2025 |
| 2.2.0 | 3,006 | 3/29/2025 |
| 2.1.9 | 3,117 | 3/5/2025 |
| 2.1.6 | 3,019 | 2/15/2025 |
| 2.1.0 | 3,017 | 1/24/2025 |
| 2.0.0 | 2,992 | 1/14/2025 |
| 1.3.9 | 3,033 | 11/15/2024 |
| 1.3.0 | 3,016 | 10/5/2024 |
| 1.2.18 | 3,061 | 9/15/2024 |
| 1.2.16 | 3,045 | 9/7/2024 |
| 1.2.15 | 3,031 | 9/1/2024 |
| 1.2.11 | 3,011 | 8/6/2024 |
| 1.2.9 | 3,006 | 7/26/2024 |
| 1.2.8 | 3,047 | 7/19/2024 |
| 1.2.6 | 3,022 | 7/15/2024 |
| 1.2.4 | 3,043 | 7/4/2024 |
| 1.2.0 | 3,050 | 5/30/2024 |
| 1.1.37 | 3,039 | 5/11/2024 |
| 1.1.34 | 3,020 | 4/22/2024 |
| 1.1.30 | 3,034 | 3/24/2024 |
| 1.1.26 | 3,048 | 3/14/2024 |
| 1.1.23 | 3,048 | 2/26/2024 |
| 1.1.22 | 3,048 | 2/16/2024 |
| 1.1.21 | 3,100 | 1/11/2024 |
| 1.1.19 | 3,074 | 1/1/2024 |
| 1.1.17 | 3,057 | 12/23/2023 |
| 1.1.11 | 3,054 | 12/16/2023 |
| 1.1.10 | 3,063 | 12/6/2023 |
| 1.1.7 | 3,061 | 11/30/2023 |
| 1.1.5 | 3,050 | 11/21/2023 |
| 1.0.14-prerelease | 257 | 8/6/2023 |
https://www.cepheis.com/hiperspace/20251231
# Overview
Change to the `GetSequence` and `UseSequence` functions to take a parameter to allow the use of `KeyType` for Sequences
Extended `Session2(DateTime? AsAt = null)` to `Session2(DateTime? AsAt = null, DateTime? DeltaFrom = null)` to allow the DeltaFrom parameter to be used in addition to AsAt.
## Obsolete
Several interfaces function have been marked as `Obsolete` and will be removed in the next version.
Currently **Hiperspace** uses a key prefix convention to distinguish *immutable* and *versioned* elements, *VectorSpaces* (for nearest neighbor search) and *sequences*
| Prefix | Description |
|-|-|
| 00| The meta data dictionary for the *Hiperspace*, used to ensure that incompatible libraries cannot corrupt a store |
| 0...| Versioned element that includes a *timestamp* suffix at the end of the key |
| 00...| VectorSpace indexes|
| 001...| Sequence numbers for mutable items|
| |Keys without a prefix are immutable elements without version|
Performance testing of **Hiperspace.DB** has highlighted that the rebuilding of the `MetaMap` used to translate between protobuf *tag/length/value* to *tag/value/length* for index search can be expensive top build when a store has experienced multiple schema changes. The **next** version will change the prefix to:
| Prefix | Description |
|-|-|
|1| The meta data dictionary for the *Hiperspace*, used to ensure that incompatible libraries cannot corrupt a store |
|2| cached `MetaMap` entries for key encode/decode|
|3| validated client library *fingerprint* to avoid the need for `MetaMap` build |
|4| immutable elements without version suffix|
|5| Versioned element that includes a *timestamp* suffix at the end of the key |
|6| VectorSpace indexes|
|7| Sequence numbers for mutable items|
The `#id` for {`Node`, `Edge`, `VectorNode`, `HiperEdge`,`PathMessage`} will also be moved to a *reserved* set of low values with all *domain* keys moved to higher values
-----
## SetSpace
Added two functions to get a sequence counter from the driver:
* `GetSequenceAsync<T>(T element)` to get the current sequence number associated with the domain key
* `UseSequenceAsync<T>(T element)` to get a new sequence number for the with the domain key
**NB** While the main use of Sequence numbers is to provide an alternate (*GPGPU friendly*) sequence number for a `Node`, it can be applied to any key value.
```
// get an order number that is unique within all orders
var orderNo = await space.Orders.UseSequenceAsync (new Order { });
var orderNo = await space.Orders.UseSequenceAsync (new Order.KeyType { });
// get a line number within the owning Order {1,2,3..}
var lineNo = await space.Lines.UseSequenceAsync (new Line { Order = order });
var lineNo = await space.Lines.UseSequenceAsync (new Line.KeyType { Order = order.self });
```
`Get` and `GetASync()` functions now handle not found errors by returning `null` for scenarios where a reference object cannot be found. This is especially useful for views where not found is better handled by `Horizon<>` filters that
-----
## Bind Version
All versions of Bind Function have been marked as Obsolete, with a preference to use the optimistic locking instead (that include the original AsAt copied to AsWas for comparison).
Versions of Bind functions that include the `priorVersion` DateTime value use optimistic concurrency control to prevent updates to a version that has been changed by another session
## Nearest
Hiperspace provides nearest neighbor search using a VectorSpace `aspect` for geospatial and RAG search. These functions have been extended to include a maximum distance search
-----
## Hilang
The Hilang ahead of time compiler has been updated to remove indexes that are a subset of the element key, and will not be used
-----
## Hiperspace.Rocks
The **RocksDB** driver has been upgraded to verion 10.4.2.63147