Urbit Developers
  • Hoon

    • Overview
    • Cheat Sheet
    • Irregular forms
    • Hoon Errors
    • Hoon Style Guide
    • Basic Types
    • Advanced Types
    • Auras
    • Arvo
    • Standard Library

      • 1a: Basic Arithmetic
      • 1b: Tree Addressing
      • 1c: Molds and Mold-Builders
      • 2a: Unit Logic
      • 2b: List Logic
      • 2c: Bit Arithmetic
      • 2d: Bit Logic
      • 2e: Insecure Hashing
      • 2f: Noun Ordering
      • 2g: Unsigned Powers
      • 2h: Set Logic
      • 2i: Map Logic
      • 2j: Jar and Jug Logic
      • 2k: Queue Logic
      • 2l: Container from Container
      • 2m: Container from Noun
      • 2n: Functional Hacks
      • 2o: Normalizing Containers
      • 2p: Serialization
      • 2q: Molds and Mold-Builders
      • 3a: Modular and Signed Ints
      • 3b: Floating Point
      • 3c: Urbit Time
      • 3d: SHA Hash Family
      • 3e: AES encryption (Removed)
      • 3f: Scrambling
      • 3g: Molds and Mold-Builders
      • 4a: Exotic Bases
      • 4b: Text Processing
      • 4c: Tank Printer
      • 4d: Parsing (Tracing)
      • 4e: Parsing (Combinators)
      • 4f: Parsing (Rule-Builders)
      • 4g: Parsing (Outside Caller)
      • 4h: Parsing (ASCII Glyphs)
      • 4i: Parsing (Useful Idioms)
      • 4j: Parsing (Bases and Base Digits)
      • 4k: Atom Printing
      • 4l: Atom Parsing
      • 4m: Formatting Functions
      • 4n: Virtualization
      • 4o: Molds
      • 5a: Compiler Utilities
      • 5b: Macro Expansion
      • 5c: Compiler Backend & Prettyprinter
      • 5d: Parser
      • 5e: Molds and mold builders
      • 5f: Profiling support
      • Runes

        • Constants (Atoms and Strings)
        • + lus · Arms
        • | bar · Cores
        • $ buc · Structures
        • % cen · Calls
        • : col · Cells
        • . dot · Nock
        • / fas · Imports
        • ^ ket · Casts
        • ; mic · Make
        • ~ sig · Hints
        • = tis · Subject
        • ? wut · Conditionals
        • ! zap · Wild
        • --, == Terminators
        • Limbs and wings

          • Limbs
          • Wings
          • Zuse

            • 2d(1-5): To JSON, Wains
            • 2d(6): From JSON
            • 2d(7): From JSON (unit)
            • 2e(2-3): Print & Parse JSON
            • 2m: Ordered Maps
          • Arvo

            • Overview
            • Ames

              • Overview
              • Cryptography
              • API Reference
              • Scry Reference
              • Data Types
              • Behn

                • Overview
                • API Reference
                • Scry Reference
                • Examples
                • Clay

                  • Overview
                  • Architecture
                  • Using Clay
                  • Data Types
                  • Scry Reference
                  • API Reference
                  • Examples
                  • Marks

                    • Overview
                    • Writing Marks
                    • Using Marks
                    • Examples
                  • Dill

                    • Overview
                    • API Reference
                    • Scry Reference
                    • Data Types
                    • Eyre

                      • Overview
                      • External API Reference
                      • Internal API Reference
                      • Scry Reference
                      • Data Types
                      • Guide
                      • Gall

                        • Overview
                        • API Reference
                        • Scry Reference
                        • Data Types
                        • Threads Reference
                        • Iris

                          • Overview
                          • API Reference
                          • Data Types
                          • Example
                          • Jael

                            • Overview
                            • API Reference
                            • Scry Reference
                            • Data Types
                            • Examples
                            • Khan

                              • Overview
                              • API Reference
                              • Data Types
                              • Example
                              • Threads

                                • Overview
                                • HTTP API
                                • Reference
                                • Gall

                                  • Start Thread
                                  • Take Result
                                  • Take Facts
                                  • Stop Thread
                                  • Poke Thread
                                  • Examples

                                    • Fetch JSON
                                    • Child Thread
                                    • Main-loop
                                    • Poke Agent
                                    • Scry
                                    • Take Fact
                                  • Concepts

                                    • Scries
                                    • Subscriptions
                                    • Tutorials

                                      • Move Trace
                                      • Reference

                                        • Cryptography
                                        • Filesystem Hierarchy
                                      • Nock

                                        • Nock Definition
                                        • Explanation
                                        • Example
                                        • Implementations
                                        • Vere

                                          • C Runtime System
                                          • Land of Nouns
                                          • API overview by prefix
                                          • C in Urbit
                                          • Writing Jets
                                          • Cryptography
                                          • Azimuth

                                            • Overview
                                            • Urbit HD Wallet
                                            • Azimuth Data Flow
                                            • Azimuth.eth
                                            • Ecliptic.eth
                                            • Advanced Azimuth Tools
                                            • Life and Rift
                                            • Layer 2

                                              • Layer 2 Overview
                                              • Layer 2 Actions
                                              • Transaction Format
                                              • Rollers
                                              • Roller HTTP RPC-API
                                              • Custom Roller Tutorial
                                            • Glossary

                                              • Agent
                                              • Ames
                                              • API
                                              • Aqua
                                              • Arm
                                              • Arvo
                                              • Atom
                                              • Aura
                                              • Aural ASCII
                                              • Azimuth
                                              • Battery
                                              • Behn
                                              • Bowl
                                              • Bridge
                                              • Bunt
                                              • Card
                                              • Case
                                              • Cask
                                              • Cell
                                              • Censures
                                              • Claims
                                              • Clay
                                              • Cold atom
                                              • Comet
                                              • Commit
                                              • Cons
                                              • Context
                                              • Cord
                                              • Core
                                              • Delegated Sending
                                              • Desk
                                              • Dill
                                              • Document Proposal
                                              • Dojo
                                              • Door
                                              • Double-boot
                                              • Dry Gate
                                              • Duct
                                              • Ecliptic
                                              • Entropy
                                              • Event Log
                                              • Eyre
                                              • Face
                                              • Fact
                                              • Foo Bar Baz
                                              • Galaxy
                                              • Gall
                                              • Garden
                                              • Gate
                                              • Generator
                                              • Gift
                                              • Glob
                                              • HD Wallet
                                              • Helm
                                              • Hood
                                              • Hoon
                                              • Invite Tree
                                              • Iris
                                              • Jael
                                              • Jet
                                              • Kelvin versioning
                                              • Kelvin versioning
                                              • Keyfile
                                              • Keywords
                                              • Khan
                                              • Kiln
                                              • Landscape
                                              • Leg
                                              • List
                                              • Loobean
                                              • Lull
                                              • Mark
                                              • Metals
                                              • Mold
                                              • Monad
                                              • Moon
                                              • Move
                                              • Nock
                                              • Noun
                                              • ~
                                              • OTA Updates
                                              • Path Prefix
                                              • Path
                                              • @p
                                              • Payload
                                              • Peek
                                              • pH
                                              • Pier
                                              • Pill
                                              • Planet
                                              • Poke
                                              • Proxies
                                              • Scry
                                              • Replay
                                              • Factory Reset
                                              • Roller
                                              • Naive rollups
                                              • Rune
                                              • Runtime
                                              • Sail
                                              • Sample
                                              • Scry
                                              • Senate
                                              • Ship
                                              • Slam
                                              • Spider
                                              • Sponsor
                                              • Star
                                              • String
                                              • Subject Oriented Programming
                                              • Subject
                                              • Subscription
                                              • Tape
                                              • Thread
                                              • Trap
                                              • Udon
                                              • Upgrade Proposal
                                              • Userspace
                                              • Vane
                                              • Vase
                                              • Vere
                                              • Voting
                                              • Warm atom
                                              • Wet Gate
                                              • Wing
                                              • Wire
                                              • Wrapper
                                              • ~zod
                                              • Zuse
                                              • Additional

                                                • Cryptography
                                                • Mips (Maps of Maps)
                                                • Software Distribution

                                                  • Overview
                                                  • Docket File
                                                  • Glob
                                                Urbit Developers
                                                • Hoon

                                                  • Overview
                                                  • Cheat Sheet
                                                  • Irregular forms
                                                  • Hoon Errors
                                                  • Hoon Style Guide
                                                  • Basic Types
                                                  • Advanced Types
                                                  • Auras
                                                  • Arvo
                                                  • Standard Library

                                                    • 1a: Basic Arithmetic
                                                    • 1b: Tree Addressing
                                                    • 1c: Molds and Mold-Builders
                                                    • 2a: Unit Logic
                                                    • 2b: List Logic
                                                    • 2c: Bit Arithmetic
                                                    • 2d: Bit Logic
                                                    • 2e: Insecure Hashing
                                                    • 2f: Noun Ordering
                                                    • 2g: Unsigned Powers
                                                    • 2h: Set Logic
                                                    • 2i: Map Logic
                                                    • 2j: Jar and Jug Logic
                                                    • 2k: Queue Logic
                                                    • 2l: Container from Container
                                                    • 2m: Container from Noun
                                                    • 2n: Functional Hacks
                                                    • 2o: Normalizing Containers
                                                    • 2p: Serialization
                                                    • 2q: Molds and Mold-Builders
                                                    • 3a: Modular and Signed Ints
                                                    • 3b: Floating Point
                                                    • 3c: Urbit Time
                                                    • 3d: SHA Hash Family
                                                    • 3e: AES encryption (Removed)
                                                    • 3f: Scrambling
                                                    • 3g: Molds and Mold-Builders
                                                    • 4a: Exotic Bases
                                                    • 4b: Text Processing
                                                    • 4c: Tank Printer
                                                    • 4d: Parsing (Tracing)
                                                    • 4e: Parsing (Combinators)
                                                    • 4f: Parsing (Rule-Builders)
                                                    • 4g: Parsing (Outside Caller)
                                                    • 4h: Parsing (ASCII Glyphs)
                                                    • 4i: Parsing (Useful Idioms)
                                                    • 4j: Parsing (Bases and Base Digits)
                                                    • 4k: Atom Printing
                                                    • 4l: Atom Parsing
                                                    • 4m: Formatting Functions
                                                    • 4n: Virtualization
                                                    • 4o: Molds
                                                    • 5a: Compiler Utilities
                                                    • 5b: Macro Expansion
                                                    • 5c: Compiler Backend & Prettyprinter
                                                    • 5d: Parser
                                                    • 5e: Molds and mold builders
                                                    • 5f: Profiling support
                                                    • Runes

                                                      • Constants (Atoms and Strings)
                                                      • + lus · Arms
                                                      • | bar · Cores
                                                      • $ buc · Structures
                                                      • % cen · Calls
                                                      • : col · Cells
                                                      • . dot · Nock
                                                      • / fas · Imports
                                                      • ^ ket · Casts
                                                      • ; mic · Make
                                                      • ~ sig · Hints
                                                      • = tis · Subject
                                                      • ? wut · Conditionals
                                                      • ! zap · Wild
                                                      • --, == Terminators
                                                      • Limbs and wings

                                                        • Limbs
                                                        • Wings
                                                        • Zuse

                                                          • 2d(1-5): To JSON, Wains
                                                          • 2d(6): From JSON
                                                          • 2d(7): From JSON (unit)
                                                          • 2e(2-3): Print & Parse JSON
                                                          • 2m: Ordered Maps
                                                        • Arvo

                                                          • Overview
                                                          • Ames

                                                            • Overview
                                                            • Cryptography
                                                            • API Reference
                                                            • Scry Reference
                                                            • Data Types
                                                            • Behn

                                                              • Overview
                                                              • API Reference
                                                              • Scry Reference
                                                              • Examples
                                                              • Clay

                                                                • Overview
                                                                • Architecture
                                                                • Using Clay
                                                                • Data Types
                                                                • Scry Reference
                                                                • API Reference
                                                                • Examples
                                                                • Marks

                                                                  • Overview
                                                                  • Writing Marks
                                                                  • Using Marks
                                                                  • Examples
                                                                • Dill

                                                                  • Overview
                                                                  • API Reference
                                                                  • Scry Reference
                                                                  • Data Types
                                                                  • Eyre

                                                                    • Overview
                                                                    • External API Reference
                                                                    • Internal API Reference
                                                                    • Scry Reference
                                                                    • Data Types
                                                                    • Guide
                                                                    • Gall

                                                                      • Overview
                                                                      • API Reference
                                                                      • Scry Reference
                                                                      • Data Types
                                                                      • Threads Reference
                                                                      • Iris

                                                                        • Overview
                                                                        • API Reference
                                                                        • Data Types
                                                                        • Example
                                                                        • Jael

                                                                          • Overview
                                                                          • API Reference
                                                                          • Scry Reference
                                                                          • Data Types
                                                                          • Examples
                                                                          • Khan

                                                                            • Overview
                                                                            • API Reference
                                                                            • Data Types
                                                                            • Example
                                                                            • Threads

                                                                              • Overview
                                                                              • HTTP API
                                                                              • Reference
                                                                              • Gall

                                                                                • Start Thread
                                                                                • Take Result
                                                                                • Take Facts
                                                                                • Stop Thread
                                                                                • Poke Thread
                                                                                • Examples

                                                                                  • Fetch JSON
                                                                                  • Child Thread
                                                                                  • Main-loop
                                                                                  • Poke Agent
                                                                                  • Scry
                                                                                  • Take Fact
                                                                                • Concepts

                                                                                  • Scries
                                                                                  • Subscriptions
                                                                                  • Tutorials

                                                                                    • Move Trace
                                                                                    • Reference

                                                                                      • Cryptography
                                                                                      • Filesystem Hierarchy
                                                                                    • Nock

                                                                                      • Nock Definition
                                                                                      • Explanation
                                                                                      • Example
                                                                                      • Implementations
                                                                                      • Vere

                                                                                        • C Runtime System
                                                                                        • Land of Nouns
                                                                                        • API overview by prefix
                                                                                        • C in Urbit
                                                                                        • Writing Jets
                                                                                        • Cryptography
                                                                                        • Azimuth

                                                                                          • Overview
                                                                                          • Urbit HD Wallet
                                                                                          • Azimuth Data Flow
                                                                                          • Azimuth.eth
                                                                                          • Ecliptic.eth
                                                                                          • Advanced Azimuth Tools
                                                                                          • Life and Rift
                                                                                          • Layer 2

                                                                                            • Layer 2 Overview
                                                                                            • Layer 2 Actions
                                                                                            • Transaction Format
                                                                                            • Rollers
                                                                                            • Roller HTTP RPC-API
                                                                                            • Custom Roller Tutorial
                                                                                          • Glossary

                                                                                            • Agent
                                                                                            • Ames
                                                                                            • API
                                                                                            • Aqua
                                                                                            • Arm
                                                                                            • Arvo
                                                                                            • Atom
                                                                                            • Aura
                                                                                            • Aural ASCII
                                                                                            • Azimuth
                                                                                            • Battery
                                                                                            • Behn
                                                                                            • Bowl
                                                                                            • Bridge
                                                                                            • Bunt
                                                                                            • Card
                                                                                            • Case
                                                                                            • Cask
                                                                                            • Cell
                                                                                            • Censures
                                                                                            • Claims
                                                                                            • Clay
                                                                                            • Cold atom
                                                                                            • Comet
                                                                                            • Commit
                                                                                            • Cons
                                                                                            • Context
                                                                                            • Cord
                                                                                            • Core
                                                                                            • Delegated Sending
                                                                                            • Desk
                                                                                            • Dill
                                                                                            • Document Proposal
                                                                                            • Dojo
                                                                                            • Door
                                                                                            • Double-boot
                                                                                            • Dry Gate
                                                                                            • Duct
                                                                                            • Ecliptic
                                                                                            • Entropy
                                                                                            • Event Log
                                                                                            • Eyre
                                                                                            • Face
                                                                                            • Fact
                                                                                            • Foo Bar Baz
                                                                                            • Galaxy
                                                                                            • Gall
                                                                                            • Garden
                                                                                            • Gate
                                                                                            • Generator
                                                                                            • Gift
                                                                                            • Glob
                                                                                            • HD Wallet
                                                                                            • Helm
                                                                                            • Hood
                                                                                            • Hoon
                                                                                            • Invite Tree
                                                                                            • Iris
                                                                                            • Jael
                                                                                            • Jet
                                                                                            • Kelvin versioning
                                                                                            • Kelvin versioning
                                                                                            • Keyfile
                                                                                            • Keywords
                                                                                            • Khan
                                                                                            • Kiln
                                                                                            • Landscape
                                                                                            • Leg
                                                                                            • List
                                                                                            • Loobean
                                                                                            • Lull
                                                                                            • Mark
                                                                                            • Metals
                                                                                            • Mold
                                                                                            • Monad
                                                                                            • Moon
                                                                                            • Move
                                                                                            • Nock
                                                                                            • Noun
                                                                                            • ~
                                                                                            • OTA Updates
                                                                                            • Path Prefix
                                                                                            • Path
                                                                                            • @p
                                                                                            • Payload
                                                                                            • Peek
                                                                                            • pH
                                                                                            • Pier
                                                                                            • Pill
                                                                                            • Planet
                                                                                            • Poke
                                                                                            • Proxies
                                                                                            • Scry
                                                                                            • Replay
                                                                                            • Factory Reset
                                                                                            • Roller
                                                                                            • Naive rollups
                                                                                            • Rune
                                                                                            • Runtime
                                                                                            • Sail
                                                                                            • Sample
                                                                                            • Scry
                                                                                            • Senate
                                                                                            • Ship
                                                                                            • Slam
                                                                                            • Spider
                                                                                            • Sponsor
                                                                                            • Star
                                                                                            • String
                                                                                            • Subject Oriented Programming
                                                                                            • Subject
                                                                                            • Subscription
                                                                                            • Tape
                                                                                            • Thread
                                                                                            • Trap
                                                                                            • Udon
                                                                                            • Upgrade Proposal
                                                                                            • Userspace
                                                                                            • Vane
                                                                                            • Vase
                                                                                            • Vere
                                                                                            • Voting
                                                                                            • Warm atom
                                                                                            • Wet Gate
                                                                                            • Wing
                                                                                            • Wire
                                                                                            • Wrapper
                                                                                            • ~zod
                                                                                            • Zuse
                                                                                            • Additional

                                                                                              • Cryptography
                                                                                              • Mips (Maps of Maps)
                                                                                              • Software Distribution

                                                                                                • Overview
                                                                                                • Docket File
                                                                                                • Glob
                                                                                              Reference/Hoon/Standard Library

                                                                                              2i: Map Logic

                                                                                              ++by

                                                                                              Map operations

                                                                                              Container arm for map operation arms. A map is a set of key-value pairs. The contained arms inherit its sample map, a.

                                                                                              Accepts

                                                                                              a is a map.

                                                                                              Source

                                                                                              ++ by
                                                                                              ~/ %by
                                                                                              =| a=(tree (pair)) :: (map)
                                                                                              =* node ?>(?=(^ a) n.a)
                                                                                              |@

                                                                                              Examples

                                                                                              > ~(. by (malt (limo ~[a+1 b+2 c+3])))
                                                                                              < 27.jus
                                                                                              [ a
                                                                                              ?(
                                                                                              %~
                                                                                              [ n=[?(p=%a p=%b p=%c) q=@ud]
                                                                                              l=nlr([p=?(%a %b %c) q=@ud])
                                                                                              r=nlr([p=?(%a %b %c) q=@ud])
                                                                                              ]
                                                                                              )
                                                                                              <123.zao 46.hgz 1.pnw %140>
                                                                                              ]
                                                                                              >

                                                                                              ++all:by

                                                                                              Logical AND

                                                                                              Computes the logical AND on the results of slamming every element in map a with gate b.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a gate.

                                                                                              Produces

                                                                                              A flag.

                                                                                              Source

                                                                                              ++ all
                                                                                              ~/ %all
                                                                                              |* b=$-(* ?)
                                                                                              |- ^- ?
                                                                                              ?~ a
                                                                                              &
                                                                                              ?&((b q.n.a) $(a l.a) $(a r.a))

                                                                                              Examples

                                                                                              > =a (malt (limo ~[a+1 b+[2 3]]))
                                                                                              > (~(all by a) |=(a=* ?@(a & |)))
                                                                                              %.n
                                                                                              > =a (malt (limo ~[a+1 b+2 c+3 d+4 e+5]))
                                                                                              > (~(all by a) |=(a=@ (lte a 6)))
                                                                                              %.y
                                                                                              > (~(all by a) |=(a=@ (lte a 4)))
                                                                                              %.n

                                                                                              ++any:by

                                                                                              Logical OR

                                                                                              Computes the logical OR on the results of slamming every element with gate b.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a wet gate.

                                                                                              Produces

                                                                                              A flag.

                                                                                              Source

                                                                                              ++ any
                                                                                              ~/ %any
                                                                                              |* b=$-(* ?)
                                                                                              |- ^- ?
                                                                                              ?~ a
                                                                                              |
                                                                                              ?|((b q.n.a) $(a l.a) $(a r.a))

                                                                                              Examples

                                                                                              > =a (malt (limo ~[a+1 b+[2 3]]))
                                                                                              > (~(any by a) |=(a=* ?@(a & |)))
                                                                                              %.y
                                                                                              > =a (malt (limo ~[a+1 b+2 c+3 d+4 e+5]))
                                                                                              > (~(any by a) |=(a=@ (lte a 4)))
                                                                                              %.y

                                                                                              ++apt:by

                                                                                              Check correctness

                                                                                              Computes whether a has a correct horizontal order and a correct vertical order, producing a flag.

                                                                                              Accepts

                                                                                              a is a map.

                                                                                              Produces

                                                                                              A flag.

                                                                                              Source

                                                                                              ++ apt
                                                                                              =< $
                                                                                              ~/ %apt
                                                                                              =| [l=(unit) r=(unit)]
                                                                                              |. ^- ?
                                                                                              ?~ a &
                                                                                              ?& ?~(l & &((gor p.n.a u.l) !=(p.n.a u.l)))
                                                                                              ?~(r & &((gor u.r p.n.a) !=(u.r p.n.a)))
                                                                                              ?~ l.a &
                                                                                              &((mor p.n.a p.n.l.a) !=(p.n.a p.n.l.a) $(a l.a, l `p.n.a))
                                                                                              ?~ r.a &
                                                                                              &((mor p.n.a p.n.r.a) !=(p.n.a p.n.r.a) $(a r.a, r `p.n.a))
                                                                                              ==

                                                                                              Examples

                                                                                              > =a (malt `(list [@tas @])`~[a+1 b+2 c+3 d+4 e+5])
                                                                                              > ~(apt by a)
                                                                                              %.y
                                                                                              > =z ?~(a ~ a(p.n `@tas`%z))
                                                                                              > z
                                                                                              [n=[p=%z q=2] l={[p=%e q=5]} r={[p=%d q=4] [p=%a q=1] [p=%c q=3]}]
                                                                                              > ~(apt by z)
                                                                                              %.n

                                                                                              Discussion

                                                                                              See section 2f for more information on noun ordering.

                                                                                              ++bif:by

                                                                                              Bifurcate

                                                                                              Splits map a into two maps l and r, which contain the items either side of key b with value c but not including b-c.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a noun.

                                                                                              c is a noun.

                                                                                              Produces

                                                                                              A cell of two maps.

                                                                                              Source

                                                                                              ++ bif
                                                                                              ~/ %bif
                                                                                              |* [b=* c=*]
                                                                                              ^+ [l=a r=a]
                                                                                              =< +
                                                                                              |- ^+ a
                                                                                              ?~ a
                                                                                              [[b c] ~ ~]
                                                                                              ?: =(b p.n.a)
                                                                                              ?: =(c q.n.a)
                                                                                              a
                                                                                              a(n [b c])
                                                                                              ?: (gor b p.n.a)
                                                                                              =+ d=$(a l.a)
                                                                                              ?> ?=(^ d)
                                                                                              d(r a(l r.d))
                                                                                              =+ d=$(a r.a)
                                                                                              ?> ?=(^ d)
                                                                                              d(l a(r l.d))

                                                                                              Examples

                                                                                              > =a (malt `(list [@tas @])`~[a+1 b+2 c+3 d+4 e+5])
                                                                                              > (~(bif by a) b+2)
                                                                                              [l=[n=[p=%e q=5] l=~ r=~] r=[n=[p=%d q=4] l=~ r=[n=[p=%c q=3] l={[p=%a q=1]} r={}]]]
                                                                                              > `[(map @tas @) (map @tas @)]`(~(bif by a) b+2)
                                                                                              [{[p=%e q=5]} {[p=%d q=4] [p=%a q=1] [p=%c q=3]}]

                                                                                              Discussion

                                                                                              Note that maps are horizontally ordered by the mug hash of their keys and vertically ordered by the double-mug hash of their keys. This means bifurcating the map (malt ~[10^10 20^20 30^30 40^40 50^50]) at 30^30 will not produce [{10^10 20^20} {40^40 50^50}], but rather [{20^20} {10^10 40^40 50^50}] due to the tree structure resulting from their mug hashes.


                                                                                              ++del:by

                                                                                              Delete

                                                                                              Produces map a with the element located at key b removed.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a key as a noun.

                                                                                              Produces

                                                                                              A map.

                                                                                              Source

                                                                                              ++ del
                                                                                              ~/ %del
                                                                                              |* b=*
                                                                                              |- ^+ a
                                                                                              ?~ a
                                                                                              ~
                                                                                              ?. =(b p.n.a)
                                                                                              ?: (gor b p.n.a)
                                                                                              a(l $(a l.a))
                                                                                              a(r $(a r.a))
                                                                                              |- ^- [$?(~ _a)]
                                                                                              ?~ l.a r.a
                                                                                              ?~ r.a l.a
                                                                                              ?: (mor p.n.l.a p.n.r.a)
                                                                                              l.a(r $(l.a r.l.a))
                                                                                              r.a(l $(r.a l.r.a))

                                                                                              Examples

                                                                                              > =a `(map @tas @)`(malt (limo ~[a+1 b+2 c+3 d+4]))
                                                                                              > a
                                                                                              {[p=%b q=2] [p=%d q=4] [p=%a q=1] [p=%c q=3]}
                                                                                              > `(map @tas @)`(~(del by a) %z)
                                                                                              {[p=%b q=2] [p=%d q=4] [p=%a q=1] [p=%c q=3]}
                                                                                              > `(map @tas @)`(~(del by a) %b)
                                                                                              {[p=%d q=4] [p=%a q=1] [p=%c q=3]}

                                                                                              ++dif:by

                                                                                              Difference

                                                                                              Computes the difference between a and b, producing the map of key-value pairs in a whose keys are not in b.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a map.

                                                                                              Produces

                                                                                              A map.

                                                                                              Source

                                                                                              ++ dif
                                                                                              ~/ %dif
                                                                                              =+ b=a
                                                                                              |@
                                                                                              ++ $
                                                                                              |- ^+ a
                                                                                              ?~ b
                                                                                              a
                                                                                              =+ c=(bif p.n.b q.n.b)
                                                                                              ?> ?=(^ c)
                                                                                              =+ d=$(a l.c, b l.b)
                                                                                              =+ e=$(a r.c, b r.b)
                                                                                              |- ^- [$?(~ _a)]
                                                                                              ?~ d e
                                                                                              ?~ e d
                                                                                              ?: (mor p.n.d p.n.e)
                                                                                              d(r $(d r.d))
                                                                                              e(l $(e l.e))
                                                                                              --

                                                                                              Examples

                                                                                              > =a `(map @tas @)`(malt (limo ~[a+1 b+2 c+3 d+4]))
                                                                                              > =b `(map @tas @)`(malt (limo ~[c+3 d+4 e+5 f+6]))
                                                                                              > a
                                                                                              {[p=%b q=2] [p=%d q=4] [p=%a q=1] [p=%c q=3]}
                                                                                              > b
                                                                                              {[p=%e q=5] [p=%d q=4] [p=%f q=6] [p=%c q=3]}
                                                                                              > `(map @tas @)`(~(dif by a) b)
                                                                                              {[p=%b q=2] [p=%a q=1]}
                                                                                              > =a `(map @tas @)`(malt (limo ~[a+1 b+2 c+3 d+4]))
                                                                                              > =b `(map @tas @)`(malt (limo ~[a+2 e+4 f+5]))
                                                                                              > a
                                                                                              {[p=%b q=2] [p=%d q=4] [p=%a q=1] [p=%c q=3]}
                                                                                              > b
                                                                                              {[p=%e q=4] [p=%f q=5] [p=%a q=2]}
                                                                                              > `(map @tas @)`(~(dif by a) b)
                                                                                              {[p=%b q=2] [p=%d q=4] [p=%c q=3]}

                                                                                              Discussion

                                                                                              This only compares keys, so if both maps contain the same key with different values, that key-value pair is not considered a difference and will not be included in the resulting map.


                                                                                              ++dig:by

                                                                                              Address of key

                                                                                              Produce the address of key b within map a.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a key as a noun.

                                                                                              Produces

                                                                                              A unit.

                                                                                              Source

                                                                                              ++ dig
                                                                                              |= b=*
                                                                                              =+ c=1
                                                                                              |- ^- (unit @)
                                                                                              ?~ a ~
                                                                                              ?: =(b p.n.a) [~ u=(peg c 2)]
                                                                                              ?: (gor b p.n.a)
                                                                                              $(a l.a, c (peg c 6))
                                                                                              $(a r.a, c (peg c 7))

                                                                                              Examples

                                                                                              > =a `(map @tas @)`(malt (limo ~[a+1 b+2 c+3 d+4]))
                                                                                              > (~(dig by a) %a)
                                                                                              [~ 252]
                                                                                              > (~(dig by a) %b)
                                                                                              [~ 2]
                                                                                              > (~(dig by a) %e)
                                                                                              ~

                                                                                              ++gas:by

                                                                                              Concatenate

                                                                                              Insert a list of key-value pairs b into map a. For a key which exists in both a and b, the value is replaced with the value in b.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a list of cells of key-value nouns p and q.

                                                                                              Produces

                                                                                              A map.

                                                                                              Source

                                                                                              ++ gas
                                                                                              ~/ %gas
                                                                                              |* b=(list [p=* q=*])
                                                                                              => .(b `(list _?>(?=(^ a) n.a))`b)
                                                                                              |- ^+ a
                                                                                              ?~ b
                                                                                              a
                                                                                              $(b t.b, a (put p.i.b q.i.b))

                                                                                              Examples

                                                                                              > =a `(map @tas @)`(malt (limo ~[a+1 b+2 c+3 d+4]))
                                                                                              > a
                                                                                              {[p=%b q=2] [p=%d q=4] [p=%a q=1] [p=%c q=3]}
                                                                                              > `(map @tas @)`(~(gas by a) ~[e+5 f+6 g+7])
                                                                                              {[p=%e q=5] [p=%b q=2] [p=%d q=4] [p=%f q=6] [p=%g q=7] [p=%a q=1] [p=%c q=3]}
                                                                                              > =a `(map @tas @)`(malt (limo ~[a+1 b+2]))
                                                                                              > a
                                                                                              {[p=%b q=2] [p=%a q=1]}
                                                                                              > `(map @tas @)`(~(gas by a) ~[a+100 b+200])
                                                                                              {[p=%b q=200] [p=%a q=100]}
                                                                                              > `(map @tas @)`(~(gas by `(map @tas @)`~) ~[a+100 b+200])
                                                                                              {[p=%b q=200] [p=%a q=100]}

                                                                                              ++get:by

                                                                                              Grab unit value

                                                                                              Produce the unit value of the value located at key b within map a.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a key as a noun.

                                                                                              Produces

                                                                                              A unit.

                                                                                              Source

                                                                                              ++ get
                                                                                              ~/ %get
                                                                                              |* b=*
                                                                                              => .(b `_?>(?=(^ a) p.n.a)`b)
                                                                                              |- ^- (unit _?>(?=(^ a) q.n.a))
                                                                                              ?~ a
                                                                                              ~
                                                                                              ?: =(b p.n.a)
                                                                                              (some q.n.a)
                                                                                              ?: (gor b p.n.a)
                                                                                              $(a l.a)
                                                                                              $(a r.a)

                                                                                              Examples

                                                                                              > a
                                                                                              {[p=%b q=2] [p=%d q=4] [p=%a q=1] [p=%c q=3]}
                                                                                              > (~(get by a) %a)
                                                                                              [~ 1]
                                                                                              > (~(get by a) %b)
                                                                                              [~ 2]
                                                                                              > (~(get by a) %z)
                                                                                              ~

                                                                                              ++got:by

                                                                                              Assert

                                                                                              Produce the value located at key b within map a. Crash if key b does not exist.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a key as a noun.

                                                                                              Produces

                                                                                              A noun.

                                                                                              Source

                                                                                              ++ got
                                                                                              |* b=*
                                                                                              (need (get b))

                                                                                              Examples

                                                                                              > =a `(map @tas @)`(malt (limo ~[a+1 b+2 c+3 d+4]))
                                                                                              > a
                                                                                              {[p=%b q=2] [p=%d q=4] [p=%a q=1] [p=%c q=3]}
                                                                                              > (~(got by a) %a)
                                                                                              1
                                                                                              > (~(got by a) %b)
                                                                                              2
                                                                                              > (~(got by a) %z)
                                                                                              dojo: hoon expression failed

                                                                                              ++gut:by

                                                                                              Grab value with default

                                                                                              Produce the value located at key b within map a. Use default value c if key does not exist.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a key as a noun.

                                                                                              c is a noun.

                                                                                              Produces

                                                                                              A noun.

                                                                                              Source

                                                                                              ++ gut
                                                                                              |* [b=* c=*]
                                                                                              (fall (get b) c)

                                                                                              Examples

                                                                                              > =a `(map @tas @)`(malt (limo ~[a+1 b+2 c+3 d+4]))
                                                                                              > a
                                                                                              {[p=%b q=2] [p=%d q=4] [p=%a q=1] [p=%c q=3]}
                                                                                              > (~(gut by a) %a 9.999)
                                                                                              1
                                                                                              > (~(gut by a) %b 9.999)
                                                                                              2
                                                                                              > (~(gut by a) %z 9.999)
                                                                                              9.999

                                                                                              ++has:by

                                                                                              Key existence check

                                                                                              Checks whether map a contains an element with key b, producing a flag.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a key as a noun.

                                                                                              Produces

                                                                                              A flag.

                                                                                              Source

                                                                                              ++ has
                                                                                              ~/ %has
                                                                                              |* b=*
                                                                                              !=(~ (get b))

                                                                                              Examples

                                                                                              > =a `(map @tas @)`(malt (limo ~[a+1 b+2 c+3 d+4]))
                                                                                              > a
                                                                                              {[p=%b q=2] [p=%d q=4] [p=%a q=1] [p=%c q=3]}
                                                                                              > (~(has by a) %a)
                                                                                              %.y
                                                                                              > (~(has by a) %z)
                                                                                              %.n

                                                                                              ++int:by

                                                                                              Intersection

                                                                                              Produces a map of the (key) intersection between two maps of the same type, a and b. If both maps have an identical key that point to different values, the element from map b is used.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a map.

                                                                                              Produces

                                                                                              A map.

                                                                                              Source

                                                                                              ++ int
                                                                                              ~/ %int
                                                                                              =+ b=a
                                                                                              |@
                                                                                              ++ $
                                                                                              |- ^+ a
                                                                                              ?~ b
                                                                                              ~
                                                                                              ?~ a
                                                                                              ~
                                                                                              ?: (mor p.n.a p.n.b)
                                                                                              ?: =(p.n.b p.n.a)
                                                                                              b(l $(a l.a, b l.b), r $(a r.a, b r.b))
                                                                                              ?: (gor p.n.b p.n.a)
                                                                                              %- uni(a $(a l.a, r.b ~)) $(b r.b)
                                                                                              %- uni(a $(a r.a, l.b ~)) $(b l.b)
                                                                                              ?: =(p.n.a p.n.b)
                                                                                              b(l $(b l.b, a l.a), r $(b r.b, a r.a))
                                                                                              ?: (gor p.n.a p.n.b)
                                                                                              %- uni(a $(b l.b, r.a ~)) $(a r.a)
                                                                                              %- uni(a $(b r.b, l.a ~)) $(a l.a)
                                                                                              --

                                                                                              Examples

                                                                                              > =a `(map @tas @)`(malt (limo ~[a+1 b+2 c+3 d+4]))
                                                                                              > =b `(map @tas @)`(malt (limo ~[c+3 d+4 e+5 f+6]))
                                                                                              > a
                                                                                              {[p=%b q=2] [p=%d q=4] [p=%a q=1] [p=%c q=3]}
                                                                                              > b
                                                                                              {[p=%e q=5] [p=%d q=4] [p=%f q=6] [p=%c q=3]}
                                                                                              > `(map @tas @)`(~(int by a) b)
                                                                                              {[p=%d q=4] [p=%c q=3]}
                                                                                              > =a `(map @tas @)`(malt (limo ~[a+1 b+2]))
                                                                                              > =b `(map @tas @)`(malt (limo ~[a+100 b+200]))
                                                                                              > a
                                                                                              {[p=%b q=2] [p=%a q=1]}
                                                                                              > b
                                                                                              {[p=%b q=200] [p=%a q=100]}
                                                                                              > `(map @tas @)`(~(int by a) b)
                                                                                              {[p=%b q=200] [p=%a q=100]}

                                                                                              ++jab:by

                                                                                              Transform value

                                                                                              Produce map a with the value at key b transformed by gate c.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a noun, and a key in a.

                                                                                              c is a gate.

                                                                                              Produces

                                                                                              A map.

                                                                                              Source

                                                                                              ++ jab
                                                                                              ~/ %jab
                                                                                              |* [key=_?>(?=(^ a) p.n.a) fun=$-(_?>(?=(^ a) q.n.a) _?>(?=(^ a) q.n.a))]
                                                                                              ^+ a
                                                                                              ::
                                                                                              ?~ a !!
                                                                                              ::
                                                                                              ?: =(key p.n.a)
                                                                                              a(q.n (fun q.n.a))
                                                                                              ::
                                                                                              ?: (gor key p.n.a)
                                                                                              a(l $(a l.a))
                                                                                              ::
                                                                                              a(r $(a r.a))

                                                                                              Examples

                                                                                              > =a `(map @tas @)`(malt (limo ~[a+1 b+2 c+3 d+4]))
                                                                                              > a
                                                                                              {[p=%b q=2] [p=%d q=4] [p=%a q=1] [p=%c q=3]}
                                                                                              > `(map @tas @)`(~(jab by a) %d |=(x=@ (pow x 2)))
                                                                                              {[p=%b q=2] [p=%d q=16] [p=%a q=1] [p=%c q=3]}
                                                                                              > (~(jab by a) %z |=(x=@ (pow x 2)))
                                                                                              dojo: hoon expression failed
                                                                                              > (~(jab by a) %d |=(a=@ [a a]))
                                                                                              -need.?(%~ [n=[p=@tas q=@] l=nlr([p=@tas q=@]) r=nlr([p=@tas q=@])])
                                                                                              -have.[n=[p=@tas q=[@ @]] l=nlr([p=@tas q=@]) r=nlr([p=@tas q=@])]
                                                                                              nest-fail
                                                                                              dojo: hoon expression failed

                                                                                              ++key:by

                                                                                              Set of keys

                                                                                              Produces a set of all keys in map a.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              Produces

                                                                                              A set.

                                                                                              Source

                                                                                              ++ key
                                                                                              =< $
                                                                                              ~/ %key
                                                                                              =+ b=`(set _?>(?=(^ a) p.n.a))`~
                                                                                              |. ^+ b
                                                                                              ?~ a b
                                                                                              $(a r.a, b $(a l.a, b (~(put in b) p.n.a)))

                                                                                              Examples

                                                                                              > =a `(map @tas @)`(malt (limo ~[a+1 b+2 c+3 d+4]))
                                                                                              > ~(key by a)
                                                                                              {%b %d %a %c}

                                                                                              ++mar:by

                                                                                              Add with validation

                                                                                              Produces map a with the addition of key-value pair b and c, where the value is a nonempty unit.

                                                                                              Accept a noun and a unit of a noun of the type of the map's keys and values, respectively. Validate that the value is not null and put the pair in the map. If the value is null, delete the key.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a noun.

                                                                                              c is a unit.

                                                                                              Produces

                                                                                              A map.

                                                                                              Source

                                                                                              ++ mar
                                                                                              |* [b=* c=(unit *)]
                                                                                              ?~ c
                                                                                              (del b)
                                                                                              (put b u.c)

                                                                                              Examples

                                                                                              > =a `(map @tas @)`(malt (limo ~[a+1 b+2 c+3 d+4]))
                                                                                              > a
                                                                                              {[p=%b q=2] [p=%d q=4] [p=%a q=1] [p=%c q=3]}
                                                                                              > `(map @tas @)`(~(mar by a) %e (some 5))
                                                                                              {[p=%e q=5] [p=%b q=2] [p=%d q=4] [p=%a q=1] [p=%c q=3]}
                                                                                              > `(map @tas @)`(~(mar by a) %a (some 10))
                                                                                              {[p=%b q=2] [p=%d q=4] [p=%a q=10] [p=%c q=3]}
                                                                                              > `(map @tas @)`(~(mar by a) %a ~)
                                                                                              {[p=%b q=2] [p=%d q=4] [p=%c q=3]}

                                                                                              ++put:by

                                                                                              Add key-value pair

                                                                                              Produces a with the addition of the key-value pair of b and c.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a key of the same type as the keys in a.

                                                                                              c is a value of the same type of the values in a.

                                                                                              Produces

                                                                                              A map.

                                                                                              Source

                                                                                              ++ put
                                                                                              ~/ %put
                                                                                              |* [b=* c=*]
                                                                                              |- ^+ a
                                                                                              ?~ a
                                                                                              [[b c] ~ ~]
                                                                                              ?: =(b p.n.a)
                                                                                              ?: =(c q.n.a)
                                                                                              a
                                                                                              a(n [b c])
                                                                                              ?: (gor b p.n.a)
                                                                                              =+ d=$(a l.a)
                                                                                              ?> ?=(^ d)
                                                                                              ?: (mor p.n.a p.n.d)
                                                                                              a(l d)
                                                                                              d(r a(l r.d))
                                                                                              =+ d=$(a r.a)
                                                                                              ?> ?=(^ d)
                                                                                              ?: (mor p.n.a p.n.d)
                                                                                              a(r d)
                                                                                              d(l a(r l.d))

                                                                                              Examples

                                                                                              > =a `(map @tas @)`(malt (limo ~[a+1 b+2 c+3]))
                                                                                              > a
                                                                                              {[p=%b q=2] [p=%a q=1] [p=%c q=3]}
                                                                                              > `(map @tas @)`(~(put by a) %d 4)
                                                                                              {[p=%b q=2] [p=%d q=4] [p=%a q=1] [p=%c q=3]}
                                                                                              > `(map @tas @)`(~(put by a) %a 10)
                                                                                              {[p=%b q=2] [p=%a q=10] [p=%c q=3]}
                                                                                              > (~(put by a) 42 'foo')
                                                                                              mull-grow
                                                                                              mull-nice
                                                                                              -need.?(%~ [n=[p=@tas q=@] l=nlr([p=@tas q=@]) r=nlr([p=@tas q=@])])
                                                                                              -have.[[@ud @t] %~ %~]
                                                                                              nest-fail
                                                                                              dojo: hoon expression failed

                                                                                              ++rep:by

                                                                                              Reduce to product

                                                                                              Accumulate elements of map a using gate b, producing a noun.

                                                                                              Accepts

                                                                                              a is a map.

                                                                                              b is a gate.

                                                                                              Produces

                                                                                              A noun.

                                                                                              Source

                                                                                              ++ rep
                                                                                              ~/ %rep
                                                                                              |* b=_=>(~ |=([* *] +<+))
                                                                                              |-
                                                                                              ?~ a +<+.b
                                                                                              $(a r.a, +<+.b $(a l.a, +<+.b (b n.a +<+.b)))

                                                                                              Examples

                                                                                              > =a `(map @tas @)`(malt (limo ~[a+1 b+2 c+3 d+4]))
                                                                                              > a
                                                                                              {[p=%b q=2] [p=%d q=4] [p=%a q=1] [p=%c q=3]}
                                                                                              > (~(rep by a) |=([p=[@tas @] q=@] ~&([p q] (add +.p q))))
                                                                                              [[%b 2] 0]
                                                                                              [[%d 4] 2]
                                                                                              [[%c 3] 6]
                                                                                              [[%a 1] 9]
                                                                                              q=10

                                                                                              Discussion

                                                                                              The gate will iteratively be fed a cell whose head is a key-value pair from the map and whose tail is an accumulator, producing the final value of the accumulator.


                                                                                              ++rib:by

                                                                                              Transform + product

                                                                                              c is a gate with a sample like [[key value] accumulator] and a product like [accumulator [key value]]. Each key-value pair in map a is passed to c and replaced with the key-value pair c produced. The final value of the accumulator and the modified map are returned. b is the initial value of the accumulator.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a noun, and is the initial value of the accumulator.

                                                                                              c is a gate.

                                                                                              Produces

                                                                                              A cell of a noun and a map.

                                                                                              Source

                                                                                              ++ rib
                                                                                              |* [b=* c=gate]
                                                                                              |- ^+ [b a]
                                                                                              ?~ a [b ~]
                                                                                              =+ d=(c n.a b)
                                                                                              =. n.a +.d
                                                                                              =+ e=$(a l.a, b -.d)
                                                                                              =+ f=$(a r.a, b -.e)
                                                                                              [-.f a(l +.e, r +.f)]

                                                                                              Examples

                                                                                              In this example, all values less than three are changed to zero, and a list of their keys are produced along with the modified map.

                                                                                              > =a `(map @t @)`(malt ~[['a' 1] ['b' 2] ['c' 3] ['d' 4] ['e' 5]])
                                                                                              > a
                                                                                              {[p='e' q=5] [p='b' q=2] [p='d' q=4] [p='a' q=1] [p='c' q=3]}
                                                                                              > =c |= [[k=@t v=@] acc=(list @t)]
                                                                                              ?: (lth v 3)
                                                                                              [[k acc] [k 0]]
                                                                                              [acc [k v]]
                                                                                              > `[(list @t) (map @t @)]`(~(rib by a) *(list @t) c)
                                                                                              [<|a b|> {[p='e' q=5] [p='b' q=0] [p='d' q=4] [p='a' q=0] [p='c' q=3]}]

                                                                                              Discussion

                                                                                              Key-value pairs in the map are transformed in their existing tree location. This means if you change the key, you'd likely produce a map with an incorrect order, so typically you should only change the value.


                                                                                              ++run:by

                                                                                              Transform values

                                                                                              Iterates over every value in map a using gate b, producing a map.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a gate.

                                                                                              Produces

                                                                                              A map.

                                                                                              Source

                                                                                              ++ run
                                                                                              ~/ %run
                                                                                              |* b=gate
                                                                                              |-
                                                                                              ?~ a a
                                                                                              [n=[p=p.n.a q=(b q.n.a)] l=$(a l.a) r=$(a r.a)]

                                                                                              Examples

                                                                                              > =a `(map @t @)`(malt ~[['a' 1] ['b' 2] ['c' 3] ['d' 4] ['e' 5]])
                                                                                              > `(map @t @)`(~(run by a) dec)
                                                                                              {[p='e' q=4] [p='b' q=1] [p='d' q=3] [p='a' q=0] [p='c' q=2]}

                                                                                              ++rut:by

                                                                                              Transform nodes

                                                                                              Applies a gate b to nodes in map a. The sample of gate b is a key-value pair, and it produces a new value.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a gate.

                                                                                              Produces

                                                                                              A map.

                                                                                              Source

                                                                                              ++ rut
                                                                                              |* b=gate
                                                                                              |-
                                                                                              ?~ a a
                                                                                              [n=[p=p.n.a q=(b p.n.a q.n.a)] l=$(a l.a) r=$(a r.a)]

                                                                                              Examples

                                                                                              > =a `(map @ @)`(malt ~[[1 1] [2 2] [3 3] [4 4] [5 5]])
                                                                                              > =b |= [k=@ v=@]
                                                                                              ?: (gth v 2)
                                                                                              (mul k v)
                                                                                              v
                                                                                              > `(map @ @)`(~(rut by a) b)
                                                                                              {[p=5 q=25] [p=1 q=1] [p=2 q=2] [p=3 q=9] [p=4 q=16]}

                                                                                              ++tap:by

                                                                                              Listify pairs

                                                                                              Produces the list of all elements in map a.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              Produces

                                                                                              A list.

                                                                                              Source

                                                                                              ++ tap
                                                                                              =< $
                                                                                              ~/ %tap
                                                                                              =+ b=`(list _?>(?=(^ a) n.a))`~
                                                                                              |. ^+ b
                                                                                              ?~ a
                                                                                              b
                                                                                              $(a r.a, b [n.a $(a l.a)])

                                                                                              Examples

                                                                                              > =a `(map @ @)`(malt ~[[1 1] [2 2] [3 3] [4 4] [5 5]])
                                                                                              > ~(tap by a)
                                                                                              ~[[p=4 q=4] [p=3 q=3] [p=2 q=2] [p=1 q=1] [p=5 q=5]]

                                                                                              ++uni:by

                                                                                              Union, merge

                                                                                              Produces a map of the union between the keys of a and b. If b shares a key with a, the tuple from b is preserved.

                                                                                              Accepts

                                                                                              a is a map, and is the sample +by.

                                                                                              b is a map.

                                                                                              Produces

                                                                                              A map.

                                                                                              Source

                                                                                              ++ uni
                                                                                              ~/ %uni
                                                                                              =+ b=a
                                                                                              |@
                                                                                              ++ $
                                                                                              |- ^+ a
                                                                                              ?~ b
                                                                                              a
                                                                                              ?~ a
                                                                                              b
                                                                                              ?: =(p.n.b p.n.a)
                                                                                              b(l $(a l.a, b l.b), r $(a r.a, b r.b))
                                                                                              ?: (mor p.n.a p.n.b)
                                                                                              ?: (gor p.n.b p.n.a)
                                                                                              $(l.a $(a l.a, r.b ~), b r.b)
                                                                                              $(r.a $(a r.a, l.b ~), b l.b)
                                                                                              ?: (gor p.n.a p.n.b)
                                                                                              $(l.b $(b l.b, r.a ~), a r.a)
                                                                                              $(r.b $(b r.b, l.a ~), a l.a)
                                                                                              --

                                                                                              Examples

                                                                                              > =a `(map @ @)`(malt ~[[1 1] [2 2] [3 3]])
                                                                                              > =b `(map @ @)`(malt ~[[3 300] [4 400] [5 500]])
                                                                                              > a
                                                                                              {[p=1 q=1] [p=2 q=2] [p=3 q=3]}
                                                                                              > b
                                                                                              {[p=5 q=500] [p=3 q=300] [p=4 q=400]}
                                                                                              > `(map @ @)`(~(uni by a) b)
                                                                                              {[p=5 q=500] [p=1 q=1] [p=2 q=2] [p=3 q=300] [p=4 q=400]}

                                                                                              ++uno:by

                                                                                              General union

                                                                                              Produces a map of the union between the keys of a and b. If b shares a key with a, gate meg is applied to both and its product is used as the new value of the key in question.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              b is a map, and is the sample of ~(uno by a).

                                                                                              meg is a gate, and is the sample of (~(uno by a) b).

                                                                                              Produces

                                                                                              A map.

                                                                                              Source

                                                                                              ++ uno
                                                                                              =+ b=a
                                                                                              |@
                                                                                              ++ $
                                                                                              |= meg=$-([_p:node _q:node _q:node] _q:node)
                                                                                              |- ^+ a
                                                                                              ?~ b
                                                                                              a
                                                                                              ?~ a
                                                                                              b
                                                                                              ?: =(p.n.b p.n.a)
                                                                                              :+ [p.n.a (meg p.n.a q.n.a q.n.b)]
                                                                                              $(b l.b, a l.a)
                                                                                              $(b r.b, a r.a)
                                                                                              ?: (mor p.n.a p.n.b)
                                                                                              ?: (gor p.n.b p.n.a)
                                                                                              $(l.a $(a l.a, r.b ~), b r.b)
                                                                                              $(r.a $(a r.a, l.b ~), b l.b)
                                                                                              ?: (gor p.n.a p.n.b)
                                                                                              $(l.b $(b l.b, r.a ~), a r.a)
                                                                                              $(r.b $(b r.b, l.a ~), a l.a)
                                                                                              --

                                                                                              Examples

                                                                                              > =a `(map @ @)`(malt ~[[1 1] [2 2] [3 3]])
                                                                                              > =b `(map @ @)`(malt ~[[3 3] [4 4] [5 5]])
                                                                                              > a
                                                                                              {[p=1 q=1] [p=2 q=2] [p=3 q=3]}
                                                                                              > b
                                                                                              {[p=5 q=5] [p=3 q=3] [p=4 q=4]}
                                                                                              > `(map @ @)`((~(uno by a) b) |=([k=@ v=@ w=@] (add v w)))
                                                                                              {[p=5 q=5] [p=1 q=1] [p=2 q=2] [p=3 q=6] [p=4 q=4]}

                                                                                              ++urn:by

                                                                                              Turn (with key)

                                                                                              Iterates over every value in map a using gate b, which accepts both the key and the value of each element as its sample.

                                                                                              Accepts

                                                                                              a is a map.

                                                                                              b is a gate that accepts two nouns.

                                                                                              Produces

                                                                                              A map.

                                                                                              Source

                                                                                              ++ urn
                                                                                              ~/ %urn
                                                                                              |* b=$-([* *] *)
                                                                                              |-
                                                                                              ?~ a ~
                                                                                              a(n n.a(q (b p.n.a q.n.a)), l $(a l.a), r $(a r.a))

                                                                                              Examples

                                                                                              > =a `(map @ @)`(malt ~[[1 1] [2 2] [3 3]])
                                                                                              > a
                                                                                              {[p=1 q=1] [p=2 q=2] [p=3 q=3]}
                                                                                              > (~(urn by a) |=([k=@ v=@] (pow v 2)))
                                                                                              {[p=1 q=1] [p=2 q=4] [p=3 q=9]}

                                                                                              ++wyt:by

                                                                                              Depth

                                                                                              Produce the size of the tree map a.

                                                                                              Accepts

                                                                                              a is a map, and is the sample of +by.

                                                                                              Produces

                                                                                              An atom.

                                                                                              Source

                                                                                              ++ wyt
                                                                                              =< $
                                                                                              ~% %wyt + ~
                                                                                              |. ^- @
                                                                                              ?~(a 0 +((add $(a l.a) $(a r.a))))

                                                                                              Examples

                                                                                              > =a `(map @ @)`(malt ~[[1 1] [2 2] [3 3]])
                                                                                              > =b `(map @ @)`(malt ~[[1 1] [2 2] [3 3] [4 4] [5 5]])
                                                                                              > a
                                                                                              {[p=1 q=1] [p=2 q=2] [p=3 q=3]}
                                                                                              > b
                                                                                              {[p=5 q=5] [p=1 q=1] [p=2 q=2] [p=3 q=3] [p=4 q=4]}
                                                                                              > ~(wyt by a)
                                                                                              3
                                                                                              > ~(wyt by b)
                                                                                              5

                                                                                              ++val:by

                                                                                              List of values

                                                                                              Produces a list of all values in map a.

                                                                                              Accepts

                                                                                              a is a map.

                                                                                              Produces

                                                                                              A list.

                                                                                              Source

                                                                                              ++ val
                                                                                              =+ b=`(list _?>(?=(^ a) q.n.a))`~
                                                                                              |- ^+ b
                                                                                              ?~ a b
                                                                                              $(a r.a, b [q.n.a $(a l.a)])

                                                                                              Examples

                                                                                              > =a `(map @t @)`(malt ~[['a' 1] ['b' 2] ['c' 3]])
                                                                                              > a
                                                                                              {[p='b' q=2] [p='a' q=1] [p='c' q=3]}
                                                                                              > ~(val by a)
                                                                                              ~[3 1 2]

                                                                                              <-

                                                                                              2h: Set Logic

                                                                                              2j: Jar and Jug Logic

                                                                                              ->

                                                                                              Edit this page on GitHub

                                                                                              Last modified June 13, 2023