0.9.5.58:
[sbcl.git] / src / code / defsetfs.lisp
1 ;;;; various DEFSETFs, pulled into one file for convenience in doing
2 ;;;; them as early in the build process as possible so as to avoid
3 ;;;; hassles with invoking SETF FOO before DEFSETF FOO and thus
4 ;;;; compiling a call to some nonexistent function #'(SETF FOO)
5
6 ;;;; This software is part of the SBCL system. See the README file for
7 ;;;; more information.
8 ;;;;
9 ;;;; This software is derived from the CMU CL system, which was
10 ;;;; written at Carnegie Mellon University and released into the
11 ;;;; public domain. The software is in the public domain and is
12 ;;;; provided with absolutely no warranty. See the COPYING and CREDITS
13 ;;;; files for more information.
14
15 (sb!int:/show0 "entering defsetfs.lisp")
16
17 ;;; from alieneval.lisp
18 (in-package "SB!ALIEN")
19 (defsetf slot %set-slot)
20 (defsetf deref (alien &rest indices) (value)
21   `(%set-deref ,alien ,value ,@indices))
22 (defsetf %heap-alien %set-heap-alien)
23
24 ;;; from bignum.lisp
25 (in-package "SB!BIGNUM")
26 (defsetf %bignum-ref %bignum-set)
27
28 ;;; from bit-bash.lisp
29 (in-package "SB!VM")
30 (defsetf word-sap-ref %set-word-sap-ref)
31
32 ;;; from debug-int.lisp
33 (in-package "SB!DI")
34 (defsetf stack-ref %set-stack-ref)
35 (defsetf debug-var-value %set-debug-var-value)
36 (defsetf debug-var-value %set-debug-var-value)
37 (defsetf breakpoint-info %set-breakpoint-info)
38
39 ;;; from defstruct.lisp
40 (in-package "SB!KERNEL")
41 (defsetf %instance-ref %instance-set)
42 (defsetf %raw-instance-ref/word %raw-instance-set/word)
43 (defsetf %raw-instance-ref/single %raw-instance-set/single)
44 (defsetf %raw-instance-ref/double %raw-instance-set/double)
45 (defsetf %raw-instance-ref/complex-single %raw-instance-set/complex-single)
46 (defsetf %raw-instance-ref/complex-double %raw-instance-set/complex-double)
47 (defsetf %raw-ref-single %raw-set-single)
48 (defsetf %raw-ref-double %raw-set-double)
49
50 (defsetf %raw-ref-complex-single %raw-set-complex-single)
51 (defsetf %raw-ref-complex-double %raw-set-complex-double)
52
53 (defsetf %instance-layout %set-instance-layout)
54 (defsetf %funcallable-instance-info %set-funcallable-instance-info)
55 (defsetf %funcallable-instance-layout %set-funcallable-instance-layout)
56
57 ;;; from early-setf.lisp
58 (in-package "SB!IMPL")
59
60 ;;; KLUDGE: Various of these (e.g. AREF and BIT) have DEFUN (SETF FOO) versions
61 ;;; too. Do we really need both? -- WHN 19990921
62 #-sb-xc-host (defsetf car %rplaca)
63 #-sb-xc-host (defsetf cdr %rplacd)
64 #-sb-xc-host (defsetf caar (x) (v) `(%rplaca (car ,x) ,v))
65 #-sb-xc-host (defsetf cadr (x) (v) `(%rplaca (cdr ,x) ,v))
66 #-sb-xc-host (defsetf cdar (x) (v) `(%rplacd (car ,x) ,v))
67 #-sb-xc-host (defsetf cddr (x) (v) `(%rplacd (cdr ,x) ,v))
68 #-sb-xc-host (defsetf caaar (x) (v) `(%rplaca (caar ,x) ,v))
69 #-sb-xc-host (defsetf cadar (x) (v) `(%rplaca (cdar ,x) ,v))
70 #-sb-xc-host (defsetf cdaar (x) (v) `(%rplacd (caar ,x) ,v))
71 #-sb-xc-host (defsetf cddar (x) (v) `(%rplacd (cdar ,x) ,v))
72 #-sb-xc-host (defsetf caadr (x) (v) `(%rplaca (cadr ,x) ,v))
73 #-sb-xc-host (defsetf caddr (x) (v) `(%rplaca (cddr ,x) ,v))
74 #-sb-xc-host (defsetf cdadr (x) (v) `(%rplacd (cadr ,x) ,v))
75 #-sb-xc-host (defsetf cdddr (x) (v) `(%rplacd (cddr ,x) ,v))
76 #-sb-xc-host (defsetf caaaar (x) (v) `(%rplaca (caaar ,x) ,v))
77 #-sb-xc-host (defsetf cadaar (x) (v) `(%rplaca (cdaar ,x) ,v))
78 #-sb-xc-host (defsetf cdaaar (x) (v) `(%rplacd (caaar ,x) ,v))
79 #-sb-xc-host (defsetf cddaar (x) (v) `(%rplacd (cdaar ,x) ,v))
80 #-sb-xc-host (defsetf caadar (x) (v) `(%rplaca (cadar ,x) ,v))
81 #-sb-xc-host (defsetf caddar (x) (v) `(%rplaca (cddar ,x) ,v))
82 #-sb-xc-host (defsetf cdadar (x) (v) `(%rplacd (cadar ,x) ,v))
83 #-sb-xc-host (defsetf cdddar (x) (v) `(%rplacd (cddar ,x) ,v))
84 #-sb-xc-host (defsetf caaadr (x) (v) `(%rplaca (caadr ,x) ,v))
85 #-sb-xc-host (defsetf cadadr (x) (v) `(%rplaca (cdadr ,x) ,v))
86 #-sb-xc-host (defsetf cdaadr (x) (v) `(%rplacd (caadr ,x) ,v))
87 #-sb-xc-host (defsetf cddadr (x) (v) `(%rplacd (cdadr ,x) ,v))
88 #-sb-xc-host (defsetf caaddr (x) (v) `(%rplaca (caddr ,x) ,v))
89 #-sb-xc-host (defsetf cadddr (x) (v) `(%rplaca (cdddr ,x) ,v))
90 #-sb-xc-host (defsetf cdaddr (x) (v) `(%rplacd (caddr ,x) ,v))
91 #-sb-xc-host (defsetf cddddr (x) (v) `(%rplacd (cdddr ,x) ,v))
92 #-sb-xc-host (defsetf first %rplaca)
93 #-sb-xc-host (defsetf second (x) (v) `(%rplaca (cdr ,x) ,v))
94 #-sb-xc-host (defsetf third (x) (v) `(%rplaca (cddr ,x) ,v))
95 #-sb-xc-host (defsetf fourth (x) (v) `(%rplaca (cdddr ,x) ,v))
96 #-sb-xc-host (defsetf fifth (x) (v) `(%rplaca (cddddr ,x) ,v))
97 #-sb-xc-host (defsetf sixth (x) (v) `(%rplaca (cdr (cddddr ,x)) ,v))
98 #-sb-xc-host (defsetf seventh (x) (v) `(%rplaca (cddr (cddddr ,x)) ,v))
99 #-sb-xc-host (defsetf eighth (x) (v) `(%rplaca (cdddr (cddddr ,x)) ,v))
100 #-sb-xc-host (defsetf ninth (x) (v) `(%rplaca (cddddr (cddddr ,x)) ,v))
101 #-sb-xc-host (defsetf tenth (x) (v) `(%rplaca (cdr (cddddr (cddddr ,x))) ,v))
102 #-sb-xc-host (defsetf rest %rplacd)
103 #-sb-xc-host (defsetf elt %setelt)
104 #-sb-xc-host (defsetf aref %aset)
105 #-sb-xc-host (defsetf row-major-aref %set-row-major-aref)
106 #-sb-xc-host (defsetf svref %svset)
107 #-sb-xc-host (defsetf char %charset)
108 #-sb-xc-host (defsetf bit %bitset)
109 #-sb-xc-host (defsetf schar %scharset)
110 #-sb-xc-host (defsetf sbit %sbitset)
111 (defsetf %array-dimension %set-array-dimension)
112 (defsetf sb!kernel:%raw-bits sb!kernel:%set-raw-bits)
113 (defsetf sb!kernel:%vector-raw-bits sb!kernel:%set-vector-raw-bits)
114 #-sb-xc-host (defsetf symbol-value set)
115 #-sb-xc-host (defsetf symbol-plist %set-symbol-plist)
116 #-sb-xc-host (defsetf nth %setnth)
117 #-sb-xc-host (defsetf fill-pointer %set-fill-pointer)
118 (defsetf sap-ref-8 %set-sap-ref-8)
119 (defsetf signed-sap-ref-8 %set-signed-sap-ref-8)
120 (defsetf sap-ref-16 %set-sap-ref-16)
121 (defsetf signed-sap-ref-16 %set-signed-sap-ref-16)
122 (defsetf sap-ref-32 %set-sap-ref-32)
123 (defsetf signed-sap-ref-32 %set-signed-sap-ref-32)
124 (defsetf sap-ref-64 %set-sap-ref-64)
125 (defsetf signed-sap-ref-64 %set-signed-sap-ref-64)
126 (defsetf sap-ref-word %set-sap-ref-word)
127 (defsetf signed-sap-ref-word %set-signed-sap-ref-word)
128 (defsetf sap-ref-sap %set-sap-ref-sap)
129 (defsetf sap-ref-single %set-sap-ref-single)
130 (defsetf sap-ref-double %set-sap-ref-double)
131 #!+long-float (defsetf sap-ref-long %set-sap-ref-long)
132 #-sb-xc-host (defsetf subseq (sequence start &optional (end nil)) (v)
133             `(progn (replace ,sequence ,v :start1 ,start :end1 ,end)
134                     ,v))
135
136 ;;; from fdefinition.lisp
137 (in-package "SB!IMPL")
138 #-sb-xc-host (defsetf fdefinition %set-fdefinition)
139
140 ;;; from kernel.lisp
141 (in-package "SB!KERNEL")
142 (defsetf code-header-ref code-header-set)
143 (defsetf %raw-bits %set-raw-bits)
144
145 ;;; from serve-event.lisp
146 (in-package "SB!IMPL")
147 (defsetf object-set-operation %set-object-set-operation
148   #!+sb-doc
149   "Set the handler function for an object set operation.")
150
151 ;;; from x86-vm.lisp
152 (in-package "SB!VM")
153 (defsetf context-register %set-context-register)
154 (defsetf context-float-register %set-context-float-register)
155
156 (sb!int:/show0 "leaving defsetfs.lisp")