ZORALab's Hestia Technical Specifications
The technical specifications to refer when using ZORALab's Hestia. Easy-going, offline supported (via web PWA installation), and detailed oriented.
Objectives and Purposes
Safe Use of Software Libraries
The goal is to offer the use of software libraries in a reliable and safe manner not just from programming languages themselves but also its ecosystem and external threats like geo-politics or supply chain.
Product Designs
Decentralized Distribution
By design, ZORALab's Hestia carefully pick programming languages that do not
soley depending on its specialized distribution system alone for countering
geo-political and after-the-fact business changes nuisance threats (e.g.
implement restrictive geo-fencing or sudden steep price hike overnight without
any notices). At the most upstream source (us), all supported technologies MUST
be distributable and re-distributable securely, online and offline with just a
simple .zip
archive format.
Stream Vs. Memory
For ZORALab's Hestia, there are 2 orientations when it comes to designing
algorithm: (1) stream-oriented [S]
focuses on extremely low memory
footprint but takes more time for processing; (2) memory-oriented
[M]
focuses on maximum memory usage for faster speed. The default
everyone practice is usually memory-oriented where most people would care less
about how much the memory is used in a 64-bit operating system.
Microcontrollers and embedded folks however, tend to prefer stream-oriented
due to the memory size limitations. Hence, all functions and methods
**MUST**cater both stream-oriented and memory-oriented executions,
whichever comes first.
Monomorphize By CPU Size
One problem ZORALab's Hestia set to solve is to facilitate all functions and methods by CPU Size (8-Bits, 16-bits, 24-bits, 32-bits, 64-bits, ...2048-bits). Most standard libraries are heavily geared towards 64-bits CPU, making it very difficult to port into other CPU types like 8-bits and 16-bits. Therefore, to combat scarcity, ZORALab's Hestia manually monomorphize all processing functions and methods giving the end users a choice rather than no-choice.
Import Direction
For ZORALab's Hestia, ALWAYS LET USER TO ONLY IMPORT LEAF PACKAGES WHENEVER AVAILABLE. Build the leaf package to the point of self-sufficient manner. As for the parent packages, **they are there to facilitate common utilities among the children packages**. Below is the import pattern:
PATTERN [Leaf] -> [SuperCommon]/[Leaf] -------------> [SuperCommon]/[Common]/[Leaf] ----------------------> EXAMPLES hestiaSTRING ⮱ hestiaSTRING.M64_Sanitize hestiaNET/hestiaHTTP ⮱ hestiaHTTP.Server ⮱ hestiaHTTP.Client hestiaNET/hestiaHTTP/hestiaPWA ⮱ hestiaPWA.ToAppJS ⮱ hestiaPWA.ToAppManifest
Naming Convention
To comply with the import direction above and to avoid conflicting with the standard libraries for facilitating a good experience of inter-operability, ZORALab's Hestia employs its own naming convention across all supported technologies. We are still using Go's Titlecase as export indicator while Nim will just append its required astrisk at the end. ZORALab's Hestia naming convention follow this pattern:
「·PATTERN·」 PACKAGE = (x_)[origin][OUTPUT](_[VARIANT](_[SKU])) CONSTANT = (X/x_)(priv_)[PURPOSE]_[NAME](_[VARIANT](_[SKU])) FUNCTION = (X/x_)[[S/s]/[M/m]][CPU_BITS/N]_[Verb](_[VARIANT](_[SKU])) METHOD = (X/x_)[[S/s]/[M/m]][CPU_BITS/N]_[Verb](_[VARIANT](_[SKU])) 「·LEGENDS·」 () = Optional [] = Compulsory Variable Values / = OR lower = lowercase UPPER = UPPERCASE X_, x_ = experimental ---- EXAMPLES ---- 「·PACKAGE·」 hestiaSTRING (hugo, go, nim) x_hestiaSTRING (hugo, go, nim) hestiaGUI/zoralabCORE (hugo, go, nim) hestiaGUI/x_zoralabCORE (hugo, go, nim) x_hestiaGUI/x_zoralabCORE (hugo, go, nim) 「·CONSTANT·」 hestiaNET.TLS_1_3 (go-pub, nim-pub*) hestiaNET.X_TLS_1_3 (go-pub, nim-pub*) hestiaSYS.SYSTEM_NAME (go-pub, nim-pub*) hestiaNET.priv_TLS_1_3 (go-priv, nim-priv) hestiaNET.priv_TLS_1_3 (go-priv, nim-priv) hestiaSYS.priv_SYSTEM_NAME (go-priv, nim-priv) 「·FUNCTION·」 hestiaSTRING/Sanitize (hugo-pub) hestiaSTRING.M64_Sanitize (go-pub, nim-pub*) hestiaSTRING.S8_Sanitize (go-pub, nim-pub*) hestiaSTRING.m64_Sanitize_V2 (go-priv, nim-priv) hestiaSTRING.s8_Sanitize_V2 (go-priv, nim-priv) hestiaSTRING.X_S8_Sanitize_V3 (go-pub, nim-pub*) hestiaSTRING.x_S8_Sanitize_V3 (go-priv, nim-priv) hestiaTESTING.SN_Format (go-pub, nim-pub*) hestiaTESTING.MN_Format (go-pub, nim-pub*) 「·METHOD·」 obj.M64_Sanitize (go-pub, nim-pub*) obj.S8_Sanitize (go-pub, nim-pub*) obj.m64_Sanitize_V2 (go-priv, nim-priv) obj.s8_Sanitize_V2 (go-priv, nim-priv) obj.X_S8_Sanitize_V3 (go-pub, nim-pub*) obj.x_S8_Sanitize_V3 (go-priv, nim-priv)
Error Code and No Panic
Error string returning as practiced in Go is actually quite expensive when deployed in low memory footprint environment. Hence, we only use back the conventional internal 'hestiaERROR' error codes (2 bytes) instead. Also, DO NOT PANIC. All functions and methods must be as deterministic as possible. The lesser the abstraction, the better.
Use Macro and Avoid Generics
Generics is only serving 1 specific type of meta-programming and monomorphization. The problem is that at each cpu size, the monomorphic algorithm can be very different and in most cases generics can't cater such capability. THEREFORE, DO NOT USE IT. If the language provides macro system, use that instead.
Function vs. Method
Since the package is output oriented: package function by default and method whenever makes sense for duck-typing and associated processing (e.g. interfaces). The most important job is getting them documented. Among known common names (or verbs) are:
Add Append Begin Copy Delete Divide End Index(VARIANT) Insert(VARIANT) Join Length Minus Modulus Multiply Next Parse[OBJECT] Pop Prepend Previous Replace(VARIANT) Reserve Sanitize Scan Search Sort(VARIANT) Split(VARIANT) String To[OBJECT] Validate(VARIANT) Zero 「·LEGENDS·」 () = Optional [] = Compulsory Variable Values
WASM Capable
All packages shall be usable in WASM. Do not let user to mess with Javascript when used including UI rendering (that's what the library for).
Constants
This package does not offer any constant value.
Variables
This package does not offer any variable.
Offered Functions
This package does not offer any function.
Data Types
This package does not offer any data type.
Catalog
Here are all of the leaf libraries' specifications for you to browse through.
Package | Details |
---|---|
hestiaGUI | All GUI rendering UI component packages grouped here. |
Epilogue
Looks like we have arrived to the last station. Intrigued to get in touch? Please feel free to start contacting us via the following public channels:
GitHub Discussion Portal