urbit/base/pub/doc/hoon/runes/sm/smcn.md
Anton Dyudin 6cbb6b060d Revert "remove docs for demo", "remove odds and ends", "demo network", "DEMO ONLY: root beak as %demo.", "DEMO ONLY: don't show doznec flapping.", "Prinrtf."
This reverts commit 8e1e40d75b3ab15c194b6bf9570f3edc46e2de58.
This reverts commit f073c490f9fd7c5abc033af4857df92229877de7.
This reverts commit f187d2d7e01a54823f3e979af9bbd148b398e7e9.
This reverts commit bc272862a73cfce1b118586ca39d3a377d841f1b.
This reverts commit 30a397513f8890a3406dc7ab91c6e067e3bbfbbb.
This reverts commit 4fc6856fb50d88c20a0f533392ca606641c5f38f.

Conflicts:
	urb/urbit.pill
	urb/zod/base/lib/drum.hoon
2015-06-15 18:10:02 -07:00

2.0 KiB

semcen, ;%

++sail list

;% is a virtual rune used within ++sail for passing a list of child nodes to a gate. ;% is used for transforming a list of child elements inside a ++manx.

See also

The %e case inside of ++tuna.

Produces

Twig: ++marl

Sample

p is a twig.

Tall form

;%  p

Wide form

%{p}

(within quoted form)

Irregular form

None

Examples

~zod/try=> 
;div:"%{|=(a=marl (weld a a))} repeat"
[ [%div ~]
  ~[
    [g=[n=%$ a=~[[n=%$ v=" repeat"]]] c=~]
    [g=[n=%$ a=~[[n=%$ v=" repeat"]]] c=~]
  ]
]
~zod/try=> 
(poxo ;div:"%{|=(a=marl (weld a a))} repeat")
"<div> repeat repeat</div>"

In this simple example we use a gate, |=(a=marl (weld a a)) that produces a ++marl twice. Using the irregular form of ;% we produce a repeated child node 'repeat'. ++poxo prints our result in XML.

~zod/try=> 
;=
  ;%  |=(a=marl (turn a |=(b=manx ;script(src (poxo b));)))
  ; /gep/hart.js
  ; /main/lib/urb.js
  ; //cdnjs.cloudflare.com/ajax/libs/jquery/2.1.1/jquery.js
==
~[
  [[%script [%src "/gep/hart.js
"] ~] ~]
  [[%script [%src "/main/lib/urb.js
"] ~] ~]
  [ [ %script
      [%src "//cdnjs.cloudflare.com/ajax/libs/jquery/2.1.1/jquery.js
"]
      ~
    ]
    ~
  ]
]
~zod/try=> 
%-  many:poxo  :_  ~
;=
  ;%  |=(a=marl (turn a |=(b=manx ;script(src (poxo b));)))
  ; /gep/hart.js
  ; /main/lib/urb.js
  ; //cdnjs.cloudflare.com/ajax/libs/jquery/2.1.1/jquery.js
==
"<script src="/gep/hart.js"></script><script src="/main/lib/urb.js"></script><script src="//cdnjs.cloudflare.com/ajax/libs/jquery/2.1.1/jquery.js"></script>" 

Here we go through a similar example, passing a list of urls for a script tag to a gate that produces a <script> tag. Since we produce multiple tags, we use many:poxo to print our result as XML.