23 projects tagged "C"
EJDB is an embedded JSON database engine. It aims to be a fast MongoDB-like NoSQL library that can be embedded into C/C++/Nodejs/Python3/Lua applications. It features collection-level write locking, collection level transactions, string token matching queries, and a Node.js binding.
Mod_Dosblock is an Apache module written to provide Dos/DDoS protection at the HTTP layer. It works on HTTP URLs or HTTP headers, and can throttle requests based on the incoming URI/header pattern. This module can be particularly useful in an architecture where the content serving Web servers sit behind reverse proxy Apache servers exposed to the Internet. The gateway servers can throttle/DoS protect HTTP queries, saving the actual serving Web servers.
Open Grid Scheduler/Grid Engine is a batch-queuing system for distributed resource management. It is used by many high-performance clusters and computation farms. Together with basic batch job scheduling, it supports advance reservation, array jobs, parallel make, parallel job management, and GPU management.
The PLCIO library reads and writes data to a variety of programmable logic controllers (PLC). Now in its 20th year, PLCIO is a stable platform allowing the programmer to address PLC memory by their tag names for different data types, regardless of the computer architecture, with the PLC linked either directly or remotely. PLCIO abstracts the application and communications layers so that the programmer of the business and database logic need not worry about the communication details. Full source code is included, as are samples and a CGI interface for PLC access from a Web browser. It runs under Linux, HP-UX, Solaris, and QNX, and can be used as a replacement for the aging Interchange software by Allen-Bradley. PLCIO supports the Serial DF1 and Ethernet protocols of the Allen-Bradley PLC-5, SLC 500, ControlLogix, CompactLogix, and MicroLogix PLCs (using the CIP protocol), the Modicon Quantum PLC, the Wago 750-842 PLC, the Siemens Step5 PLC (using the AS511 serial protocol or via Ethernet using the INAT Echolink), and the Siemens Step 7 200, 300, and 400-series CPUs. It also supports communicating directly with an I/O bus terminal such as the Beckhoff BK9105 or the Phoenix Contact FL IL 24 BK ETH/IP-PAC.
Pcompress is a utility to do compression/decompression and deduplication in parallel by splitting input data into chunks. It has a modular structure and includes support for multiple algorithms like LZMA, Bzip2, PPMD, LZ4, etc., with KECCAK/BLAKE2/SHA-256/512 chunk checksums. SSE optimizations for the bundled LZMA are included. It also implements chunk-level Content-Aware Deduplication and Delta Compression features based on a Rabin Fingerprinting scheme. It has low metadata overhead and overlaps I/O and compression to achieve maximum parallelism. It has AES encryption capability and uses Scrypt from Tarsnap to generate per-session unique keys from passwords. It can work in pipe mode, reading from stdin and writing to stdout. It also provides some adaptive compression modes in which a suitable algorithm is chosen per chunk based on heuristics.
The PostgreSQL extension for CLIPS Expert System provides access to a PostgreSQL database from the CLIPS environment by exposing a number of CLIPS functions. CLIPS users who are familiar with SQL should not have much difficulty in learning how to use the additional functions to interact with the database from the CLIPS environment.