Hiperspace.Rocks 2.5.43

Prefix Reserved
dotnet add package Hiperspace.Rocks --version 2.5.43
                    
NuGet\Install-Package Hiperspace.Rocks -Version 2.5.43
                    
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="Hiperspace.Rocks" Version="2.5.43" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Hiperspace.Rocks" Version="2.5.43" />
                    
Directory.Packages.props
<PackageReference Include="Hiperspace.Rocks" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Hiperspace.Rocks --version 2.5.43
                    
#r "nuget: Hiperspace.Rocks, 2.5.43"
                    
#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.
#:package Hiperspace.Rocks@2.5.43
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Hiperspace.Rocks&version=2.5.43
                    
Install as a Cake Addin
#tool nuget:?package=Hiperspace.Rocks&version=2.5.43
                    
Install as a Cake Tool

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 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 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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.43 28 4/1/2026
2.5.39 87 3/20/2026
2.5.35 98 2/27/2026
2.5.33 103 2/14/2026
2.5.32 104 1/30/2026
2.5.29 106 1/17/2026
2.5.28 111 12/31/2025
2.5.26 190 12/21/2025
2.5.21 446 12/10/2025
2.5.18 677 12/3/2025
2.5.13 216 11/24/2025
2.5.8 195 11/15/2025
2.5.2 234 11/6/2025
2.5.0 216 10/20/2025
2.4.6 226 9/23/2025
2.4.4 301 8/7/2025
2.4.2 190 7/28/2025
2.4.0 219 7/10/2025
2.3.8 223 7/1/2025
2.3.7 215 6/18/2025
Loading failed

https://www.cepheis.com/hiperspace/20260401
# Overview
This release includes minor enhancement to the graph functionality when used with **Hiperspace.DB** graph view.  **Hiperspace.DB** provides a *graph* view that aggregates alll databases, so that graph shows all connections both local and foreign.   In the following example *Togaf.Has.WorkPackage*  includes a value *ProjectKey* that could be a stringified `SKey` reference to a project plan in another database.  When the *project* is viewed as a graph in  **Hiperspace.DB**, the graph includes paths between a *project plan* and *strategic goals*.

```
segment Togaf.Has.WorkPackage : Togaf.Base
   = Node        ( SKey = SKey, Name = Name, TypeName = "AF-WorkPackage"),
     Edge        (From = owner, To = this, Name = Name, TypeName = "AF-Has-WorkPackage"),
     Togaf.Edge_ (To = owner, From = this, Name = Name, TypeName = "AF-WorkPackage-For"),
     Togaf.Edges (From = this, To = Project, Name = Name, FromTypeName = "AF-WorkPackage-Plan", ToTypeName = "AF-Plan-WorkPackage"),
     Graph.HiperEdge = StrategicEdges #2675
{
   ProjectKey      : String #29
}
[
   "All Togaf.Edges that can be projected as Transitative Togaf.Edges to a Business Goal"
   @Once
   StrategicEdges  = StrategicEdge(this),
   Project         = externalnode(ProjectKey)
];
```
For efficiency, the `SKey` property has been changed from a [Base64](https://en.wikipedia.org/wiki/Base64) encoding of the *key* to add the option of a database prefix.  The `Node SKey` "Togaf.ascxyz==" will only search for matching items "abcxyz==" in the *Togaf* database.  Within the *Togaf* database, only the specific segment is searched because the *key* includes the `#Id` of the element set.

the following SQL query would return a table of all *project plans* and *Goals* that can be reached through the {component, service, function, process, capability, etc} that are in some way associated with the *Work Package*
```
SELECT project.Name AS "Project Name"
    , goal.Name AS "Goal Name"
    , project.SKey as "Project Id"
    , goal.SKey as "Goal Id"
FROM   Nodes as project
    , project.Tos as planedge
    , planedge.To as workpackage
    , workpackage.Tos as workedge
    , workedge.To as goal
WHERE  project.TypeName = 'Plan'
 AND  planedge.TypeName = 'AF-Plan-WorkPackage'
 AND  workpackage.TypeName = 'AF-WorkPackage'
 AND  workedge.TypeName = 'Strategic-Goal'
 AND  goal.TypeName = 'AF-Goal';
```
NB the five table join uses *implicit* joins in  `Hiperspace.SQL` because `project.Tos` and `workpackage.Tos` are `Set<Edge>` properties that are *implicitly* filtered by the source `Node`