fnrefs←{⎕IO ⎕ML←1                       ⍝ External refs from function ⍵.

    cmat←{                              ⍝ Canonical rep of function ⍵.
        rmqt←{(~≠\⍵='''')mcomp ⍵}       ⍝ Quoted strings removed
        rmcm←{(∧\'⍝'≠⍵)mcomp ⍵}         ⍝ Comments removed
        mcomp←{(⍴⍵)(,⍺)\(,⍺)/,⍵}       ⍝ Matrix compress
        rmcm rmqt ⍵                     ⍝ Cleaned canonical rep.
    }⎕CR ⍵

    alph←'#⎕',{(0≤⎕NC⍪⍵)/⍵}⎕AV~'⍺⍵∇'    ⍝ word alphabet
    xalphalph,'.',⎕D                   ⍝ + non-leading chars.
    sntxxalph,'⍺ ()←'                  ⍝ + assignment syntax.

    cvec←,cmat,'⍝'                      ⍝ Corresp. vec with '⍝' delimiter.

    words←{                             ⍝ Segment into 'words'
        comp←~0 0⍷⍺                     ⍝ Compression mask.
        (comp/⍺)comp/⍵                 ⍝ Word segments.
    }

    head←{                              ⍝ Header line (for trad fns).
        (⍵∊xalph)words ⍵
    }⊣⌿cmat

    labs←{                              ⍝ Labels.
        segs(⍵∊xalph,':')words ⍵       ⍝ Names, sysnames and numbers.
        ~∘':'¨(':'∊¨segs)/segs          ⍝ Labels and keywords.
    }cvec

    names←∪{                            ⍝ Names referenced from function.
        segs(⍵∊xalph)words ⍵           ⍝ Word segments.
        (~(⊃¨segs)∊⎕D,'.⎕:')/segs       ⍝ Without numbers & system names.
    }cvec

    vars←{                              ⍝ Names assigned in function.
        segs(⍵∊sntx)words ⍵            ⍝ Possible assignment segments.
        asegs('←'∊¨segs)/segs          ⍝ Assignment segments.
        trimd←{(~'  '⍷⍵)/⍵}¨asegs       ⍝ Superfluous blanks removed.
        lvals←{(∧\⍵≠'←')/⍵}¨trimd       ⍝ left of assign arrow.
        ↑,/{(⍵∊xalph)words ⍵}¨lvals     ⍝ Split into words.
    }'←',cvec

    names~vars,head,labs                ⍝ Approx external references.
}

code_colours

test script

Back to: notes

Back to: Workspaces