1.0.7 β€’ Published 6 months ago

@hulle107/libslm-binary v1.0.7

Weekly downloads
-
License
MIT
Repository
github
Last release
6 months ago

Libslm (Life is boring so let's make) Binary

Version License

πŸ“š Indexing

πŸ§ͺ Introduction

Welcome to Libslm Binary β€” a chaotic collection of experiments, half-baked ideas, and bursts of inspiration. This isn't a polished, production-ready framework. It's a playground for concepts that may or may not evolve into something meaningful.

Due to its experimental nature, stability is not guaranteed. Features may change, vanish, or break at any time. If you're here for reliability, you might want to look elsewhere. But if you're here out of curiosity, exploration, or sheer madness β€” welcome aboard.

⚠️ Use at your own risk. Enjoy the ride.

🧩 Binary

This library provides low-level, primitive types for working with binary data. These are designed for precise bit and byte manipulation, with a focus on fixed-width representations.

ℹ️ The core challenge in this library is that all binary values are, fundamentally, just numbers. So after performing arithmetic or bitwise operations, values tend to default back to raw numbers, losing their typed wrapper.

πŸ”„ Changes v1.0.7

  • Removed the use of classes.
  • Removed dword support (for now) due to the complexity of enforcing size constraints.

✨ Features

  • Binary Encapsulation –Represent numbers as fixed-width binary sequences.
  • Arithmetic & Bitwise Operations – Perform operations while maintaining binary structure.
  • Signed Value Conversion – Supports two’s complement interpretation.

🧱 Primitive Types

  • bit – A single binary digit (0 or 1).
  • nibble – A 4-bit unsigned integer.
  • byte – A 8-bit unsigned integer.
  • word – A 16-bit unsigned integer.

πŸ’‘ Usage Example

import {byte, byteArray} from 'libslm-binary';

let first: byte = byte(0x41);
console.info(byte.toArray(first));        // [0, 1, 0, 0, 0, 0, 0, 1]
console.info(byte.toString(first));       // 1000001
console.info(byte.toBinary(first));       // 01000001
console.info(byte.toHexadecimal(first));  // 41
console.info(byte.size);                  // 8
console.info(byte.mask);                  // 255

let second: byte = byte(255);
console.info(byte.toSigned(second));      // -127
console.info(byte.valueOf(second));       // 255

let array: byteArray = [1, 0, 0, 1, 1, 0, 0, 0];
let third: byte = byte.fromArray(array);
console.info(third);                      // 152

πŸ›£οΈ Roadmap

StatusFeature
βœ…Basic implementation
βœ…Basic arithmetic & bitwise operations
βœ…Basic documentation
βœ…Conversion between arrays and types
βœ…Conversion to binary/hex strings
βœ…Signed value support
βœ…Performance improvements
πŸ”²Advanced documentation
πŸ”²Floating-point support

πŸ“ Notes

These types serve as foundational tools for binary manipulation. Given the library's experimental status, expect things to evolve β€” or get scrapped entirely.

1.0.7

6 months ago

1.0.6

7 months ago

1.0.5

7 months ago

1.0.1

7 months ago

1.0.0

7 months ago

0.6.0

7 months ago

0.5.0

7 months ago