File: caseq.mac

package info (click to toggle)
maxima 5.49.0-1~exp1
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 128,980 kB
  • sloc: lisp: 437,854; fortran: 14,665; tcl: 10,143; sh: 4,598; makefile: 2,204; ansic: 447; java: 374; python: 262; perl: 201; xml: 60; awk: 28; sed: 15; javascript: 2
file content (25 lines) | stat: -rw-r--r-- 768 bytes parent folder | download | duplicates (10)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
/*-*-Macsyma-*-*/


/*
CASEQ(<var>,'[<keys1>],<stmt1>,
            '[<keys2>],<stmt2>,
            ....,
            '[<keysn>],<stmtn>
            {,'otherwise,<code for no match>})

where the first <stmt> that has <var> as a member of the associated
<keys> is the one chosen to execute.  */


sstatus(feature,"gcook caseq")$

caseq(var,[pairs])::=
   if length(pairs)<=2 then
      block([keys:first(pairs),statement:last(pairs)],
         if keys=otherwise then buildq([var,statement],statement)
         else buildq([var,keys,statement],if member(var,'keys) then statement))
   else buildq([var,keys:first(pairs),statement:first(rest(pairs)),
                pairs:rest(rest(pairs))],
          if member(var,'keys) then statement else caseq(var,splice(pairs)))$