As strange as it may seem, the parenthesed expression returns an operator, which is then applied to the function on the left.
GNU APL does not support first-class functions (and operators) so this syntax is not an option for us. Regards, Elias On 23 Jun 2016 8:08 pm, "Louis Chretien" <lchret...@mac.com> wrote: > Since Dyalog has created those ⎕R and ⎕S, it might be a good starting > point. > > But i am always baffled by the syntax of using parenthesis to group on the > function on the left and have it applied to the right argument, like Dialog > shows on their webpage: > > R←{X} (A ⎕R B) Y > > On Jun 22, 2016, at 14:12, Juergen Sauermann < > juergen.sauerm...@t-online.de> wrote: > > Hi, > > I believe regular expressions would be a useful and reasonable thing and I > would > not object to making it a ⎕-function. I can provide the framework for the > ⎕-part of > it (class definition, parser etc) if somebody wants to fill in the rest. > > I would need to know its name, and how it is called (monadic, dyadic, > axis, function > argument(s) etc). > > Please also provide a testcase file to check if (and demonstrate how) it > works. > > /// Jürgen > > > On 06/22/2016 05:41 AM, Elias Mårtenson wrote: > > Sure, that shouldn't be a problem at all. > > Regards, > Elias > > On 22 June 2016 at 11:10, Christian Robert <christian.rob...@polymtl.ca> > wrote: > >> Oh yes, would be nice. (pcre would be as nice as regex, may be more) >> >> make it a ⎕regex or ⎕pcre so, no need to load a specific .so file or )lib >> to use it ;-) >> >> Ideal would be to be able to not only scan but be able to compile a pcre, >> find patterns, search & replace ... >> >> I am dreaming, but still awake ... >> >> Xtian. >> >> >> On 2016-06-21 22:39, Elias Mårtenson wrote: >> >>> Would anyone be interested if I actually implemented support regex by >>> calling into the C library? >>> >>> I'm envisioning something like this: >>> >>> * "^([a-z]+):([0-9]+)$" regex∆scan "foo:123"* >>> ┏→━━━━━━━━━━┓ >>> ┃"foo" "123"┃ >>> ┗∊━━━━━━━━━━┛ >>> >>> Regards, >>> Elias >>> >>> On 22 June 2016 at 10:35, Xiao-Yong Jin <jinxiaoy...@gmail.com <mailto: >>> jinxiaoy...@gmail.com>> wrote: >>> >>> At some point I really wanted to implement the simplest editor, >>> namely ed (it would be much better than any APL system has offered), in >>> APL, but I never finished the regex part. Perhaps it would be a nice >>> exercise for someone who’s interested in learning APL to actually implement >>> some of the most used Unix command line utilities. >>> >>> > On Jun 21, 2016, at 8:53 PM, Christian Robert < >>> christian.rob...@polymtl.ca <mailto:christian.rob...@polymtl.ca>> wrote: >>> > >>> > Hi, >>> > >>> > A more general purpose search&replace (some bug fixed), take (2), >>> was "snr". >>> > >>> > >>> > >>> > )sic >>> > )erase replace >>> > ∇z←s replace p;fr;to;P;i;⎕io >>> > ⍝ ------------- >>> > →(2≤≡s)/ForEach >>> > →(2≤⍴⍴s)/Matrix >>> > →Vector >>> > ⍝ ------------- >>> > ForEach: z←{⍵ replace p}¨s ◊ →0 >>> > Matrix: z←⊃ {⍵ replace p}¨ ⊂[2]s ◊ →0 >>> > ⍝ ------------- >>> > Vector: p←,¨p ◊ z←s←,s ⋄ ⎕io←1 >>> > Loop:→((⍴p)<2)/0 >>> > (fr to)←2↑p ◊ p←2↓p >>> > P←¯1↓∧/[1](¯1+⍳⍴fr)⌽fr∘.=z,⎕ucs 1 >>> > i←0 >>> > Sanitize: i←i+1 >>> > →(i>(⍴P)-⍴fr)/Substitute >>> > →(0=P[i])/Sanitize >>> > ((⊂ i+¯1+⍳⍴fr)⌷P)←(⍴fr)↑1 >>> > →Sanitize >>> > Substitute: P←⌽(P/⍳⍴P) >>> > ⊣ {z←((¯1+⍵)↑z),to,(¯1+⍵+⍴fr)↓z}¨P >>> > →Loop >>> > ∇ >>> > >>> > It should be vector, matrix and embedded objects "aware" (as long >>> as it is all text) >>> > >>> > Syntax: >>> > >>> > source replace "this" "by_that" "this" "by_that" [...] (eg: >>> pairs of "from" and "to") >>> > >>> > Examples: >>> > >>> > (⎕cr 'replace') replace 'replace' 'snr' 'ForEach' "Each" >>> "Substitute" "Subst" "Sanitize" "Sane" >>> > z←s snr p;fr;to;P;i;⎕io >>> > ⍝ ------------- >>> > →(2≤≡s)/Each >>> > →(2≤⍴⍴s)/Matrix >>> > →Vector >>> > ⍝ ------------- >>> > Each: z←{⍵ snr p}¨s ◊ →0 >>> > Matrix: z←⊃ {⍵ snr p}¨ ⊂[2]s ◊ →0 >>> > ⍝ ------------- >>> > Vector: p←,¨p ◊ z←s←,s ⋄ ⎕io←1 >>> > Loop:→((⍴p)<2)/0 >>> > (fr to)←2↑p ◊ p←2↓p >>> > P←¯1↓∧/[1](¯1+⍳⍴fr)⌽fr∘.=z,⎕ucs 1 >>> > i←0 >>> > Sane: i←i+1 >>> > →(i>(⍴P)-⍴fr)/Subst >>> > →(0=P[i])/Sane >>> > ((⊂ i+¯1+⍳⍴fr)⌷P)←(⍴fr)↑1 >>> > →Sane >>> > Subst: P←⌽(P/⍳⍴P) >>> > ⊣ {z←((¯1+⍵)↑z),to,(¯1+⍵+⍴fr)↓z}¨P >>> > →Loop >>> > >>> > >>> > You can even try "⎕fx" the result if it looks like Ok. (ps: always >>> check the result before committing) >>> > >>> > Substitutions are done in pair sequence for each >>> /vector/matrix/embedded obj. >>> > >>> > So replace order is *very* important. >>> > >>> > It must still have some bugs, report them to me, with examples if >>> so. Will do my best but no promises. >>> > >>> > Purpose: well, not sure, it was an exercise. I used it on itself >>> to finally rename the function and change some variables/labels names. >>> > >>> > >>> > Features: would be fun to pass parameters to each of the /from/to/ >>> like maximum number of substitutions to do per line ... >>> > whole words only (taking apl characters as blanks) ... so >>> variable "s" won't match last character of variable "pairs" >>> > ... no limits >>> > >>> > >>> > Xtian. >>> > >>> > >>> > On 2016-06-21 12:27, Juergen Sauermann wrote: >>> >> Hi Xtian, >>> >> >>> >> how about this: >>> >> >>> >> * >>> **s←"444This4is4a4444test44with44444lot4of4blanks4444at4beginning4and444end444444"** >>> >> from←"444"** >>> >> ** to←"5"** >>> >> ** >>> >> ** ↑⍎')HOST echo "',s,'" | sed s/',from,'/',to,'/g'** >>> >> **5This4is4a54test44with544lot4of4blanks54at4beginning4and5end55** >>> >> ** ** >>> >> *I have replaced the *^* in your example because it (and some >>> other characters) have a special meaning in >>> >> regular expressions. But the special characters can be easily >>> quoted in APL if needed, for example: >>> >> >>> >> * >>> s←"^^^This^is^a^^^^test^^with^^^^^lot^of^blanks^^^^at^beginning^and^^^end^^^^^^" >>> ** >>> >> ** ((s='^')/s)←⊂'\^'** >>> >> ** ⊃,/s** >>> >> >>> **\^\^\^This\^is\^a\^\^\^\^test\^\^with\^\^\^\^\^lot\^of\^blanks\^\^\^\^at\^beginning\^and\^\^\^end\^\^\^\^\^\^** >>> >> * >>> >> /// Jürgen >>> >> >>> >> >>> >> On 06/21/2016 05:12 AM, Christian Robert wrote: >>> >>> Hi, it's not a bug but a request for help, >>> >>> >>> >>> >>> >>> suppose >>> s="^^^This^is^a^^^^test^^with^^^^^lot^of^blanks^^^^at^beginning^and^^^end^^^^^^" >>> >>> suppose from="^^^" >>> >>> suppose to="^" >>> >>> >>> >>> I need a function who can replace ("^^^" to "^"), or ("^" to >>> "^^^^^^^^") or ("" to "blabla" with limits of source size) ie: without >>> being lost in infinite loop. >>> >>> >>> >>> >>> >>> >>> >>> "s" is a character vector, "from" is a character vector, and >>> "to" is a character vector, >>> >>> both "s", "from" and "to" can be "". >>> >>> >>> >>> >>> >>> >>> >>> I'm pretty sure this idiom already exist. >>> >>> >>> >>> if you can help me, please do. >>> >>> >>> >>> Xtian. >>> >>> >>> >>> >>> >>> >>> >>> >>> >>> >>> >>> >>> >> >>> >>> >>> >>> > > > > --- > Louis Chrétien > lchret...@mac.com > > > > >