# 0.3.1 * Allow passing a `:normalizer` to the DSL. * Builders don't have to provide `keywords` as we can filter them automatically. # 0.2.2 * Remove `Activity#end_events`. # 0.2.1 * Restructure all `Wrap`-specific tasks. * Remove `Hash::Immutable`, we will use the `hamster` gem instead. # 0.2.0 * The `Activity#call` API is now ```ruby signal, options, _ignored_circuit_options = Activity.( options, **circuit_options ) ``` The third return value, which is typically the `circuit_options`, is _ignored_ and for all task calls in this `Activity`, an identical, unchangeable set of `circuit_options` is passed to. This dramatically reduces unintended behavior with the task_wrap, tracing, etc. and usually simplifies tasks. The new API allows using bare `Activity` instances as tasks without any clumsy nesting work, making nesting very simple. A typical task will look as follows. ```ruby ->( (options, flow_options), **circuit_args ) do [ signal, [options, flow_options], *this_will_be_ignored ] end ``` A task can only emit a signal and "options" (whatever data structure that may be), and can *not* change the `circuit_options` which usually contain activity-wide "global" configuration. # 0.1.6 * `Nested` now is `Subprocess` because it literally does nothing else but calling a _process_ (or activity). # 0.1.5 # 0.1.4 * `Nested` now uses kw args for `start_at` and the new `call` option. The latter allows to set the called method on the nested activity, e.g. `__call`. # 0.1.3 * Introduce `Activity#outputs` and ditch `#end_events`. # 0.1.2 * Consistent return values for all graph operations: `node, edge`. * `Edge` now always gets an id. * `#connect_for!` always throws away the old edge, fixing a bug where graph and circuit would look different. * Internal simplifications for `Graph` alteration methods. # 0.1.1 * Fix loading order. # 0.0.12 * In `Activity::Before`, allow specifying what predecessing tasks to connect to the new_task via the `:predecessors` option, and without knowing the direction. This will be the new preferred style in `Trailblazer:::Sequence` where we can always assume directions are limited to `Right` and `Left` (e.g., with nested activities, this changes to a colorful selection of directions). # 0.0.11 * Temporarily allow injecting a `to_hash` transformer into a `ContainerChain`. This allows to ignore certain container types such as `Dry::Container` in the KW transformation. Note that this is a temp fix and will be replaced with proper pattern matching. # 0.0.10 * Introduce `Context::ContainerChain` to eventually replace the heavy-weight `Skill` object. * Fix a bug in `Option` where wrong args were passed when used without `flow_options`. # 0.0.9 * Fix `Context#[]`, it returned `nil` when it should return `false`. # 0.0.8 * Make `Trailblazer::Option` and `Trailblazer::Option::KW` a mix of lambda and object so it's easily extendable. # 0.0.7 * It is now `Trailblazer::Args`. # 0.0.6 * `Wrapped` is now `Wrap`. Also, a consistent `Alterations` interface allows tweaking here. # 0.0.5 * The `Wrapped::Runner` now applies `Alterations` to each task's `Circuit`. This means you can inject `:task_alterations` into `Circuit#call`, which will then be merged into the task's original circuit, and then run. While this might sound like crazy talk, this allows any kind of external injection (tracing, input/output contracts, step dependency injections, ...) for specific or all tasks of any circuit. # 0.0.4 * Simpler tracing with `Stack`. * Added `Context`. * Simplified `Circuit#call`. # 0.0.3 * Make the first argument to `#Activity` (`@name`) always a Hash where `:id` is a reserved key for the name of the circuit. # 0.0.2 * Make `flow_options` an immutable data structure just as `options`. It now needs to be returned from a `#call`. # 0.0.1 * First release into an unsuspecting world. 🚀