Hiperspace.Rocks
2.5.0
Prefix Reserved
See the version list below for details.
dotnet add package Hiperspace.Rocks --version 2.5.0
NuGet\Install-Package Hiperspace.Rocks -Version 2.5.0
<PackageReference Include="Hiperspace.Rocks" Version="2.5.0" />
<PackageVersion Include="Hiperspace.Rocks" Version="2.5.0" />
<PackageReference Include="Hiperspace.Rocks" />
paket add Hiperspace.Rocks --version 2.5.0
#r "nuget: Hiperspace.Rocks, 2.5.0"
#:package Hiperspace.Rocks@2.5.0
#addin nuget:?package=Hiperspace.Rocks&version=2.5.0
#tool nuget:?package=Hiperspace.Rocks&version=2.5.0
Hiperspace.Rocks
RocksDB is a remarkable technology, originally developed by Google (LevelDB) and optimized by Facebook for
absolutely lowest possible latency writing to SSD devices.
RocksDB used Log-structured-Merge (LSM) to stream updates while maintaining fast key access.
It is used both as a key/value database, and also as a driver for relational-databases, message-stores,
blockchain and various analytical services. The use of LSM optimizes performance and life of SSD devices.
Hiperspace.Rocks uses RockDB to store elements in durable SSD memory
| 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 is compatible. 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. |
-
net8.0
- Hiperspace (>= 2.5.0)
- Microsoft.Bcl.HashCode (>= 6.0.0)
- protobuf-net.Core (>= 3.2.56)
- RocksDB (>= 10.4.2.62171)
- System.Numerics.Tensors (>= 9.0.10)
-
net9.0
- Hiperspace (>= 2.5.0)
- Microsoft.Bcl.HashCode (>= 6.0.0)
- protobuf-net.Core (>= 3.2.56)
- RocksDB (>= 10.4.2.62171)
- System.Numerics.Tensors (>= 9.0.10)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 2.5.35 | 45 | 2/27/2026 |
| 2.5.33 | 95 | 2/14/2026 |
| 2.5.32 | 96 | 1/30/2026 |
| 2.5.29 | 97 | 1/17/2026 |
| 2.5.28 | 102 | 12/31/2025 |
| 2.5.26 | 182 | 12/21/2025 |
| 2.5.21 | 436 | 12/10/2025 |
| 2.5.18 | 669 | 12/3/2025 |
| 2.5.13 | 206 | 11/24/2025 |
| 2.5.8 | 188 | 11/15/2025 |
| 2.5.2 | 224 | 11/6/2025 |
| 2.5.0 | 206 | 10/20/2025 |
| 2.4.6 | 211 | 9/23/2025 |
| 2.4.4 | 295 | 8/7/2025 |
| 2.4.2 | 182 | 7/28/2025 |
| 2.4.0 | 212 | 7/10/2025 |
| 2.3.8 | 211 | 7/1/2025 |
| 2.3.7 | 209 | 6/18/2025 |
| 2.3.3 | 213 | 6/5/2025 |
| 2.2.2 | 233 | 5/5/2025 |
https://www.cepheis.com/hiperspace/20251020
## Overview
This release introduced the **message** element for client/server scenarios where you might want to run a query on a server and transfer only the final results to a client. This is especially useful for whole graph queries that select every element that is related to the subject ***node*** for a *butterfly* view.
-----
## Message
The [HiLang Message](https://www.cepheis.com/hiperspace/message) page goes into detail about the structure of *messages*.. but it is worth referring to an example for clarity. The `CustomerCube` *message* takes a reference to a *Customer* and returns all the information need to display a *hipercube* in a [Web Assembly](https://webassembly.org/) browser client, transfered with [Protobuf](https://protobuf.dev/) compression between client and server
```
message API.CustomerCube
(
Customer : Acc.Customer #1
)
{
CustomerTree : List<Acc.Customer> #2,
Sector : List<Acc.Sector> #3,
Accounts : List<Acc.Account> #4 ,
"Using the generated cube element from Transaction and its dimensions"
Cube : List<Acc.Transaction_Cube> #5,
"Using the generated cube drilldown from cube"
Drilldown : List<Acc.Transaction_CubeDrillDown> #6
};
```
**NB** `Cube : List<Acc.Transaction_Cube>` is a *physical* element, generated from the `Transaction` *@Fact* property, and including the *@Dimension* {*Customer, Account, Sector*} and *@Measure* analysis properties
When the schema is compiled with [HiLang](HiLang), implementations are not provided for
```
namespace API
{
public partial class CustomerCube : IMessage
{
public Task<IMessage> InvokeAsync(CancellationToken token = default)
{
}
public async IAsyncEnumerable<IMessage> InvokeStreamAsync([EnumeratorCancellation]CancellationToken token = default)
{
yield return await InvokeAsync(token);
}
}
}
```
which must be added to the schema project to provide implementation for the server-side functions
-----
### HiperSpace
`HiperSpace` has two additional methods that transfer messages through the layers of Hiperspaces, until a server `SubSpace` is found that will execute the message, and return the value
```
public virtual Task<byte[]> InvokeAsync(byte[] key, CancellationToken token = default) => Task.FromResult(key);
public virtual IAsyncEnumerable<byte[]> InvokeStreamAsync(byte[] key, CancellationToken token = default) => new byte[][] { key }.ToAsyncEnumerable();
```
### SubSpace
`SubSpace` has the above functions (*because they also implement* `HiperSpace`), plus the domain specific functions needed for code like `var msg = await space.InvokeAsync(new CustomerCube {Customer = myCust}); to be executed on a client.
```
public async Task<TMessage> InvokeAsync<TMessage>(TMessage item, CancellationToken token = default)
where TMessage : class, IMessage
public async IAsyncEnumerable<TMessage> InvokeStreamAsync<TMessage>(TMessage item, [EnumeratorCancellation]CancellationToken token = default)
```
There are no equivalent synchronous messages handling functions because the only reason for using messages is to perform query processing on a server, and Blazor client cannot use any blocking operations.
With this release the *obsolete* function `public abstract object? Get(string sid);` has been removed, and `Get<object?>(string sid)` should be used instead.
-----
#### Domain implementation
The Domain implementation of `SubSpace` (*generated by HiLang*) includes logic to execute the message logic in the first *domain Space* that has the `RemoteLabel` set to true. Generated HiLang schema will not compile until the `InvokeAsync` and `InvokeStreamAsync` functions have been added by the implementor.
-----
### HiLang
HiLang `segment` (*many*) and `aspect` (*optionally one*) can be applied to any `entity` to extend the definition of the entity with information that is versioned separately. Consider the example of [TOGAF](https://github.com/channell/Hiperspace/blob/master/examples/TOGAF/TOGAF.hilang) where every entity type can include any number of ***Gaps*** each of which have separate storage and references to their `owner` with navigation from the `owner` using the ***Gap*** property.
[HiLang](HiLang) Generates {*ServiceGap, DriverGap, ActorGap, FunctionGap, CapabilityGap, ProductGap, GoalGap, ObjectiveGap, MeasureGap, ActivityGap, EventGap, ProcessGap, ControlGap, ValueStreamGap, CourseOfActionGap, EntityGap, LogicalGap, PhysicalGap, SystemGap, ComponentGap, DeployedGap, PlatformGap, HostGap, InstanceGap*} to provide storage for entity specific versions of the ***Gap***, and *View* to bring togther every different implementation for query together.
When *segment*/*aspect* is only used in a single comtext, we can end-up with very long segment implementation names like `CustomerAccountTransaction` when `Customer` has many `Account` *segments* , which has many `Transaction` segments. To minimise the generated classes, an additional *step* has been added to HiLang to remove the generated prefix when a segment is only used in one context.
This version changes `CustomerAccountTransaction` to `Transaction`. If we subsequently need to add the segment to another *entity*, the prefix would be added back to distinguish different owners of `Transaction`.
**NB** Hiperspace does not store the name of the *element* with every instance (only the #id is stored), so any change will be transparent.
-----
### LatestSpace
`LatestSpace` is a specialisation fo HeapSpace, that discards history to reduce memory usage. the main use-case is with Blazor Web-Assembly clients that have no interest in the history of an Element, but need to hold the durable representation for synchronization at the end of a session.
## References
References to other libraries have been updated