File: setf.l

package info (click to toggle)
picolisp 3.1.0.7-1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 4,100 kB
  • sloc: ansic: 14,205; lisp: 795; makefile: 290; sh: 13
file content (49 lines) | stat: -rw-r--r-- 819 bytes parent folder | download | duplicates (4)
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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
# 31jan08abu
# (c) Software Lab. Alexander Burger

# 'setf' is the most perverse concept ever introduced into Lisp
(de setf "Args"
   (let "P" (car "Args")
      (set
         (if (atom "P")
            "P"
            (let (: ::  get prop  car prog  cadr cdr  caddr cadr  cadddr caddr)
               (eval "P") ) )
         (eval (cadr "Args")) ) ) )

### Test ###
(test 7
   (use A
      (setf A 7)
      A ) )

(test (7 2 3)
   (let L (1 2 3)
      (setf (car L) 7)
      L ) )

(test (1 7 3)
   (let L (1 2 3)
      (setf (cadr L) 7)
      L ) )

(test 7
   (put 'A 'a 1)
   (setf (get 'A 'a) 7)
   (get 'A 'a) )

(test 7
   (put 'A 'a 1)
   (with 'A
      (setf (: a) 7)
      (: a) ) )

# But also:
(undef 'foo)
(de foo (X)
   (cadr X) )

(test (1 7 3)
   (let L (1 2 3) (setf (foo L) 7) L) )

# vi:et:ts=3:sw=3