Add Strand; update some docblocks

This commit is contained in:
Aaron Piotrowski 2015-12-21 11:04:51 -06:00
parent cd8cc4ce9a
commit 9a0f48b076
7 changed files with 29 additions and 12 deletions

View File

@ -1,6 +1,17 @@
# Change log # Change log
All notable changes to this project will be documented in this file. This project adheres to [Semantic Versioning](http://semver.org/). All notable changes to this project will be documented in this file. This project adheres to [Semantic Versioning](http://semver.org/).
## [0.2.2] - 2015-12-21
### Added
- Added the `Icicle\Concurrent\Strand` interface that combines `Icicle\Concurrent\Context` and `Icicle\Concurrent\Sync\Channel`. This interface is implemented by the following classes (note that these classes implemented the two component interface separately, so no changes were made to the implementation):
- `Icicle\Concurrent\Forking\Fork`
- `Icicle\Concurrent\Threading\Thread`
- `Icicle\Concurrent\Process\ChannelledProcess`
### Changed
- `Icicle\Concurrent\Strand` interface is now required by the constructor of `Icicle\Concurrent\Worker\AbstractWorker`.
## [0.2.1] - 2015-12-16 ## [0.2.1] - 2015-12-16
### Added ### Added
- Added `Icicle\Concurrent\Worker\DefaultQueue` implementing `Icicle\Concurrent\Worker\Queue` that provides a queue of workers that can be pulled and pushed from the queue as needed. Pulling a worker marks it as busy and pushing the worker back into the queue marks it as idle. If no idle workers remain in the queue, a worker is selected from those marked as busy. A worker queue allows a set of interdependent tasks (for example, tasks that depend on an environment value in the worker) to be run on a single worker without having to create and start separate workers for each task. - Added `Icicle\Concurrent\Worker\DefaultQueue` implementing `Icicle\Concurrent\Worker\Queue` that provides a queue of workers that can be pulled and pushed from the queue as needed. Pulling a worker marks it as busy and pushing the worker back into the queue marks it as idle. If no idle workers remain in the queue, a worker is selected from those marked as busy. A worker queue allows a set of interdependent tasks (for example, tasks that depend on an environment value in the worker) to be run on a single worker without having to create and start separate workers for each task.
@ -66,6 +77,8 @@ First release.
- Non-blocking mutexes and semaphores for protecting parcels. - Non-blocking mutexes and semaphores for protecting parcels.
[0.2.2]: https://github.com/icicleio/concurrent/releases/tag/v0.2.2
[0.2.1]: https://github.com/icicleio/concurrent/releases/tag/v0.2.1
[0.2.0]: https://github.com/icicleio/concurrent/releases/tag/v0.2.0 [0.2.0]: https://github.com/icicleio/concurrent/releases/tag/v0.2.0
[0.1.1]: https://github.com/icicleio/concurrent/releases/tag/v0.1.1 [0.1.1]: https://github.com/icicleio/concurrent/releases/tag/v0.1.1
[0.1.0]: https://github.com/icicleio/concurrent/releases/tag/v0.1.0 [0.1.0]: https://github.com/icicleio/concurrent/releases/tag/v0.1.0

View File

@ -5,6 +5,7 @@ use Icicle\Concurrent\Exception\ForkException;
use Icicle\Concurrent\Exception\StatusError; use Icicle\Concurrent\Exception\StatusError;
use Icicle\Concurrent\Exception\SynchronizationError; use Icicle\Concurrent\Exception\SynchronizationError;
use Icicle\Concurrent\Process; use Icicle\Concurrent\Process;
use Icicle\Concurrent\Strand;
use Icicle\Concurrent\Sync\Channel; use Icicle\Concurrent\Sync\Channel;
use Icicle\Concurrent\Sync\ChannelledStream; use Icicle\Concurrent\Sync\ChannelledStream;
use Icicle\Concurrent\Sync\Internal\ExitFailure; use Icicle\Concurrent\Sync\Internal\ExitFailure;
@ -20,7 +21,7 @@ use Icicle\Stream\Pipe\DuplexPipe;
/** /**
* Implements a UNIX-compatible context using forked processes. * Implements a UNIX-compatible context using forked processes.
*/ */
class Fork implements Channel, Process class Fork implements Process, Strand
{ {
/** /**
* @var \Icicle\Concurrent\Sync\Channel A channel for communicating with the child. * @var \Icicle\Concurrent\Sync\Channel A channel for communicating with the child.

View File

@ -4,12 +4,12 @@ namespace Icicle\Concurrent\Process;
use Icicle\Concurrent\Exception\StatusError; use Icicle\Concurrent\Exception\StatusError;
use Icicle\Concurrent\Exception\SynchronizationError; use Icicle\Concurrent\Exception\SynchronizationError;
use Icicle\Concurrent\Process as ProcessContext; use Icicle\Concurrent\Process as ProcessContext;
use Icicle\Concurrent\Sync\Channel; use Icicle\Concurrent\Strand;
use Icicle\Concurrent\Sync\ChannelledStream; use Icicle\Concurrent\Sync\ChannelledStream;
use Icicle\Concurrent\Sync\Internal\ExitStatus; use Icicle\Concurrent\Sync\Internal\ExitStatus;
use Icicle\Exception\InvalidArgumentError; use Icicle\Exception\InvalidArgumentError;
class ChannelledProcess implements Channel, ProcessContext class ChannelledProcess implements ProcessContext, Strand
{ {
/** /**
* @var \Icicle\Concurrent\Process\Process * @var \Icicle\Concurrent\Process\Process

4
src/Strand.php Normal file
View File

@ -0,0 +1,4 @@
<?php
namespace Icicle\Concurrent;
interface Strand extends Context, Sync\Channel {}

View File

@ -33,7 +33,7 @@ interface Channel
* @throws \Icicle\Concurrent\Exception\SynchronizationError If the context has not been started or the context * @throws \Icicle\Concurrent\Exception\SynchronizationError If the context has not been started or the context
* unexpectedly ends. * unexpectedly ends.
* @throws \Icicle\Concurrent\Exception\ChannelException If sending on the channel fails. * @throws \Icicle\Concurrent\Exception\ChannelException If sending on the channel fails.
* @throws \Icicle\Concurrent\Exception\InvalidArgumentError If an ExitStatusInterface object is given. * @throws \Icicle\Exception\InvalidArgumentError If an ExitStatus object is given.
*/ */
public function send($data); public function send($data);
} }

View File

@ -1,11 +1,10 @@
<?php <?php
namespace Icicle\Concurrent\Threading; namespace Icicle\Concurrent\Threading;
use Icicle\Concurrent\Context;
use Icicle\Concurrent\Exception\StatusError; use Icicle\Concurrent\Exception\StatusError;
use Icicle\Concurrent\Exception\SynchronizationError; use Icicle\Concurrent\Exception\SynchronizationError;
use Icicle\Concurrent\Exception\ThreadException; use Icicle\Concurrent\Exception\ThreadException;
use Icicle\Concurrent\Sync\Channel; use Icicle\Concurrent\Strand;
use Icicle\Concurrent\Sync\ChannelledStream; use Icicle\Concurrent\Sync\ChannelledStream;
use Icicle\Concurrent\Sync\Internal\ExitStatus; use Icicle\Concurrent\Sync\Internal\ExitStatus;
use Icicle\Coroutine; use Icicle\Coroutine;
@ -21,7 +20,7 @@ use Icicle\Stream\Pipe\DuplexPipe;
* maintained both in the context that creates the thread and in the thread * maintained both in the context that creates the thread and in the thread
* itself. * itself.
*/ */
class Thread implements Channel, Context class Thread implements Strand
{ {
/** /**
* @var Internal\Thread An internal thread instance. * @var Internal\Thread An internal thread instance.

View File

@ -2,7 +2,7 @@
namespace Icicle\Concurrent\Worker; namespace Icicle\Concurrent\Worker;
use Icicle\Awaitable\Delayed; use Icicle\Awaitable\Delayed;
use Icicle\Concurrent\Context; use Icicle\Concurrent\Strand;
use Icicle\Concurrent\Exception\StatusError; use Icicle\Concurrent\Exception\StatusError;
use Icicle\Concurrent\Exception\WorkerException; use Icicle\Concurrent\Exception\WorkerException;
use Icicle\Concurrent\Worker\Internal\TaskFailure; use Icicle\Concurrent\Worker\Internal\TaskFailure;
@ -13,7 +13,7 @@ use Icicle\Concurrent\Worker\Internal\TaskFailure;
abstract class AbstractWorker implements Worker abstract class AbstractWorker implements Worker
{ {
/** /**
* @var \Icicle\Concurrent\Context * @var \Icicle\Concurrent\Strand
*/ */
private $context; private $context;
@ -39,11 +39,11 @@ abstract class AbstractWorker implements Worker
/** /**
* @param \Icicle\Concurrent\Context $context * @param \Icicle\Concurrent\Strand $strand
*/ */
public function __construct(Context $context) public function __construct(Strand $strand)
{ {
$this->context = $context; $this->context = $strand;
$this->busyQueue = new \SplQueue(); $this->busyQueue = new \SplQueue();
} }