Skip to content

Commit

Permalink
Initial Commit
Browse files Browse the repository at this point in the history
  • Loading branch information
CodaFi committed Jul 8, 2015
1 parent 89bfabe commit 1e54027
Showing 1 changed file with 167 additions and 0 deletions.
167 changes: 167 additions & 0 deletions Operators.swift
@@ -0,0 +1,167 @@
//
// Operators.swift
// Operadics
//
// Created by Robert Widmann on 07/07/2015.
// Copyright (c) 2015 TypeLift. All rights reserved.
//

/// MARK: Combinators

/// Compose | Applies one function to the result of another function to produce a third function.
infix operator {
associativity right
precedence 190
}

/// Apply | Applies an argument to a function.
infix operator § {
associativity right
precedence 0
}

/// Pipe Backward | Applies the function to its left to an argument on its right.
infix operator <| {
associativity right
precedence 0
}

/// Pipe forward | Applies an argument on the left to a function on the right.
infix operator |> {
associativity left
precedence 0
}

/// MARK: Control.*

/// Fmap | Maps a function over the value encapsulated by a functor.
infix operator <^> {
associativity left
precedence 140
}

/// Ap | Applies a function encapsulated by a functor to the value encapsulated by another functor.
infix operator <*> {
associativity left
precedence 140
}

/// Bind | Sequences and composes two monadic actions by passing the value inside the monad on the
/// left to a function on the right yielding a new monad.
infix operator >>- {
associativity left
precedence 110
}

/// Extend | Duplicates the surrounding context and computes a value from it while remaining in the
/// original context.
infix operator ->> {
associativity left
precedence 110
}

/// MARK: Data.Result

/// From | Creates a Result given a function that can possibly fail with an error.
infix operator !! {
associativity none
precedence 120
}

/// MARK: Data.Monoid

/// Append | Alias for a Semigroup's operation.
infix operator <> {
associativity right
precedence 160
}

/// MARK: Control.Category

/// Right-to-Left Composition | Composes two categories to form a new category with the source of
/// the second category and the target of the first category.
///
/// This function is literally `•`, but for Categories.
infix operator <<< {
precedence 110
associativity right
}

/// Left-to-Right Composition | Composes two categories to form a new category with the source of
/// the first category and the target of the second category.
///
/// Function composition with the arguments flipped.
infix operator >>> {
precedence 110
associativity right
}

/// MARK: Control.Arrow

/// Split | Splits two computations and combines the result into one Arrow yielding a tuple of
/// the result of each side.
infix operator *** {
precedence 130
associativity right
}

/// Fanout | Given two functions with the same source but different targets, this function
/// splits the computation and combines the result of each Arrow into a tuple of the result of
/// each side.
infix operator &&& {
precedence 130
associativity right
}

/// MARK: Control.Arrow.Choice

/// Splat | Splits two computations and combines the results into Eithers on the left and right.
infix operator +++ {
precedence 120
associativity right
}

/// Fanin | Given two functions with the same target but different sources, this function splits
/// the input between the two and merges the output.
infix operator ||| {
precedence 120
associativity right
}

/// MARK: Control.Arrow.Plus

/// Op | Combines two ArrowZero monoids.
infix operator <+> {
precedence 150
associativity right
}

/// MARK: Data.JSON

/// Retrieve | Retrieves a value from a dictionary of JSON values using a given keypath.
///
/// If the given keypath is not present or the retrieved value is not of the appropriate type, this
/// function returns `.None`.
infix operator <? {
precedence 150
associativity left
}

/// Force Retrieve | Retrieves a value from a dictionary of JSON values using a given keypath,
/// forcing any Optionals it finds.
///
/// If the given keypath is not present or the retrieved value is not of the appropriate type, this
/// function will terminate with a fatal error. It is recommended that you use Force Retrieve's
/// total cousin `<?` (Retrieve).
infix operator <! {
precedence 150
associativity left
}

/// MARK: Data.Set

/// Intersection | Returns the intersection of two sets.
infix operator {}

/// Union | Returns the union of two sets.
infix operator {}

0 comments on commit 1e54027

Please sign in to comment.