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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
|
(defun sys:name-str (kind sym-or-string)
(cond
((symbolp sym-or-string) (symbol-name sym-or-string))
((stringp sym-or-string) sym-or-string)
(t (throw 'eval-error "~s: ~s isn't a valid ~a name"
'defpackage sym-or-string kind))))
(defmacro defpackage (name . clauses)
(let* ((pkg (gensym "pkg-"))
(nstr (sys:name-str 'package name))
(exp-clauses (append-each ((c clauses))
(tree-case c
((keyword package . rest)
(caseql keyword
(:use-from
^((let ((p (find-package ',package)))
(unless p
(throwf 'eval-error
"~s: no such package: ~s"
'defpackage ',package))
(each ((n ',(mapcar (op sys:name-str 'symbol)
rest)))
(let ((s (intern n p)))
(unless (eq (symbol-package s) p)
(throwf 'eval-error
"~s: won't use non-local ~s from ~s"
'defpackage s p))
(use-sym s ,pkg))))))
(t :)))
((keyword . rest)
(caseql keyword
(:use
(if rest ^((use-package ',rest ,pkg))))
(:use-syms
^((each ((s ',rest))
(use-sym s ,pkg))))
(:local
^((each ((n ',(mapcar (op sys:name-str 'symbol)
rest)))
(let ((s (intern n ,pkg)))
(unless (eq (symbol-package s) ,pkg)
(unuse-sym s ,pkg)
(intern n ,pkg))))))
(:fallback
(if rest ^((set-package-fallback-list ,pkg
',rest))))
(:use-from
(throwf 'eval-error
"~s: :use-from clause needs package argument"
'defpackage))
(t :)))
(atom
(throwf 'eval-error "~s: invalid clause: ~s"
'defpackage atom))))))
^(let ((,pkg (or (find-package ,nstr)
(make-package ,nstr))))
,*exp-clauses
,pkg)))
(defmacro in-package (pkg)
(unless (or (symbolp pkg) (stringp pkg))
(throwf 'eval-error "~s: ~s isn't a package name" 'in-package pkg))
^(set *package* (or (find-package ',pkg)
(throwf 'eval-error "~s: no such package: ~s"
'in-package ',pkg))))
|