aboutsummaryrefslogtreecommitdiff
path: root/hypsrc-test/src/Operators.hs
blob: 1dcb8856f8cbab0a085468aa6b6175b3f9b372b2 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
{-# LANGUAGE Haskell2010 #-}
module Operators where


(+++) :: [a] -> [a] -> [a]
a +++ b = a ++ b ++ a

($$$) :: [a] -> [a] -> [a]
a $$$ b = b +++ a

(***) :: [a] -> [a] -> [a]
(***) a [] = a
(***) a (_:b) = a +++ (a *** b)

(*/\*) :: [[a]] -> [a] -> [a]
a */\* b = concatMap (*** b) a

(**/\**) :: [[a]] -> [[a]] -> [[a]]
a **/\** b = zipWith (*/\*) [a +++ b] (a $$$ b)


(#.#) :: a -> b -> (c -> (a, b))
a #.# b = const $ (a, b)