Go to file
Mahmoud Emad 49e85ff8e6
Some checks failed
Rhai Tests / Run Rhai Tests (push) Has been cancelled
docs: Enhance PostgreSQL client module documentation
- Add details about the new PostgreSQL installer feature.
- Include prerequisites for installer and basic operations.
- Expand test file descriptions with installer details.
- Add descriptions for installer functions.
- Include example usage for both basic operations and installer.
2025-05-09 15:47:26 +03:00
.github/workflows ci: Add CI workflow for Rhai tests 2025-05-08 15:09:16 +03:00
.roo ... 2025-04-03 06:08:18 +02:00
aiprompts ... 2025-04-04 15:05:48 +02:00
docs docs: Enhance PostgreSQL client module documentation 2025-05-09 15:47:26 +03:00
examples feat: Add PostgreSQL and Redis client support 2025-05-09 09:45:50 +03:00
src docs: Enhance PostgreSQL client module documentation 2025-05-09 15:47:26 +03:00
.gitignore feat: Add text module tests to SAL 2025-05-08 17:00:22 +03:00
build_herodo.sh ... 2025-04-05 19:00:59 +02:00
Cargo.toml feat: Add PostgreSQL connection pooling support 2025-05-09 10:45:53 +03:00
LICENSE Initial commit 2025-04-02 05:08:51 +00:00
README.md ... 2025-04-02 08:45:47 +02:00
run_rhai_tests.sh ci: Add CI workflow for Rhai tests 2025-05-08 15:09:16 +03:00

SAL (System Abstraction Layer)

A Rust library that provides a unified interface for interacting with operating system features across different platforms. It abstracts away platform-specific details, allowing developers to write cross-platform code with ease.

Features

  • File System Operations: Simplified file and directory management
  • Process Management: Create, monitor, and control processes
  • System Information: Access system details and metrics
  • Git Integration: Interface with Git repositories
  • Redis Client: Robust Redis connection management and command execution
  • Text Processing: Utilities for text manipulation and formatting

Modules

Redis Client

The Redis client module provides a robust wrapper around the Redis client library for Rust, offering:

  • Automatic connection management and reconnection
  • Support for both Unix socket and TCP connections
  • Database selection via environment variables
  • Thread-safe global client instance
  • Simple command execution interface

View Redis Client Documentation

OS Module

Provides platform-independent interfaces for operating system functionality.

Git Module

Tools for interacting with Git repositories programmatically.

Process Module

Utilities for process creation, monitoring, and management.

Text Module

Text processing utilities for common operations.

Usage

Add this to your Cargo.toml:

[dependencies]
sal = "0.1.0"

Basic example:

use sal::redisclient::execute;
use redis::cmd;

fn main() -> redis::RedisResult<()> {
    // Execute a Redis command
    let mut cmd = redis::cmd("SET");
    cmd.arg("example_key").arg("example_value");
    execute(&mut cmd)?;
    
    // Retrieve the value
    let mut get_cmd = redis::cmd("GET");
    get_cmd.arg("example_key");
    let value: String = execute(&mut get_cmd)?;
    println!("Value: {}", value);
    
    Ok(())
}