Changes for version 1.882 - 2022-12-02

  • Added ABRT to the list of signals to trap in MCE::Signal.
  • Added a guard to MCE::Core::Worker for checking if exited prematurely.
  • Added init_relay and use_threads import options to MCE and MCE Models.
  • Separated input mutexes from the rest of IPC for lesser latency.
  • Auto-detect if init_relay is defined and set chunk_size to 1 in MCE::Grep, MCE::Map, and MCE::Stream.
  • Update the import function in MCE models, detecting if the caller is another MCE module, to not export model functions.
  • Update the error status if MCE::Child died due to receiving a signal.
  • Improved reaping in MCE::Child, before creating a new child.
  • Improved the timeout handler in MCE::Child and MCE::Mutex::Channel.
  • Fixed private functions _quit and _trap not setting the return value.

Documentation

Documentation describing the core MCE API
Various examples and demonstrations

Modules

MCE
Many-Core Engine for Perl providing parallel processing capabilities
Sugar methods and output iterators
Queue-like and two-way communication capability
Channel for producer(s) and many consumers
Fast channel for producer(s) and many consumers
Channel tuned for one producer and one consumer
Fast channel tuned for one producer and one consumer
Channel for producer(s) and many consumers
Fast channel for producer(s) and many consumers
A threads-like parallelization module compatible with Perl 5.8
Sequence of numbers (for task_id > 0)
File path and Scalar reference input reader
Iterator reader
Array reference and Glob reference input reader
Sequence of numbers (for task_id == 0)
Core methods for the manager process
Core validation methods for Many-Core Engine
Core methods for the worker process
Parallel flow model for building creative applications
Parallel grep model similar to the native grep function
MCE model for building parallel loops
Parallel map model similar to the native map function
Locking for Many-Core Engine
Mutex locking via a pipe or socket
Provides two mutexes using a single channel
Mutex locking via Fcntl
Hybrid (normal and priority) queues
Extends Many-Core Engine with relay capabilities
Temporary directory creation/cleanup and signal handling
Parallel step model for building creative steps
Parallel stream model for chaining multiple maps and greps
Exports functions mapped directly to MCE methods
Utility functions