:: :::: /hoon#ask#ape :: /? 314 /+ sole [. sole] |% ++ card $% {$diff $sole-effect sole-effect} == -- !: |_ {bow/bowl adr/(set cord) sos/(map bone sole-share)} ++ peer-sole |= path ^- (quip {bone card} +>) ~| [%not-in-whitelist src.bow] ?> (~(has in (sa (limo ~zod our.bow ~talsur-todres ~))) src.bow) :_ +>.$(sos (~(put by sos) ost.bow *sole-share)) =- [(effect %mor pro#[& %$ ""] -)]~ =+ all=adrs [tan#(turn all message) (turn all put-mail)] :: ++ adrs (sort (~(tap by adr)) aor) ++ effect |=(fec/sole-effect [ost.bow %diff %sole-effect fec]) ++ message |=(ask/@t leaf#"ask: {(trip ask)}") ++ put-mail |=(ask/@t =+(pax=(rash ask unix-path) [%sav pax ''])) ++ unix-path :: split into path of "name" and "extension" ;~ (glue dot) (cook crip (star ;~(less dot next))) ;~(plug (cook crip (star next)) (easy ~)) == :: ++ poke-ask-mail |= ask/@t ^- (quip {bone card} +>) ~| have-mail#ask ?< (~(has in adr) ask) :_ +>.$(adr (~(put in adr) ask)) =+ [mez=[(message ask)]~ sav=(put-mail ask)] %+ turn (prey /sole bow) |=({ost/bone ^} (effect(ost.bow ost) %mor tan#mez sav ~)) :: ++ poke-sole-action |= act/sole-action ^- (quip {bone card} +>) ?- -.act $clr `+>.$ $ret [[(effect tan#(turn adrs message))]~ +>.$] :: re-print list $det :: reject all input =+ som=(~(got by sos) ost.bow) :: XX this code belongs in a library =^ inv som (~(transceive sole som) +.act) =^ det som (~(transmit sole som) inv) =. sos (~(put by sos) ost.bow som) [[(effect det#det)]~ +>.$] == --