chiark
/
gitweb
/
~mdw
/
clg
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
|
inline
| side by side (parent:
d4ddcf2
)
CONTAINER-FORALL addedand DO-CONTAINER removed
author
espen
<espen>
Wed, 29 Dec 2004 21:14:23 +0000
(21:14 +0000)
committer
espen
<espen>
Wed, 29 Dec 2004 21:14:23 +0000
(21:14 +0000)
gtk/gtkcontainer.lisp
patch
|
blob
|
blame
|
history
diff --git
a/gtk/gtkcontainer.lisp
b/gtk/gtkcontainer.lisp
index 1ac33b28757a280b1f8e4701769eee71d5291b89..010fca1c1440e73a67fe5a8ef2ef5fa8973e855d 100644
(file)
--- a/
gtk/gtkcontainer.lisp
+++ b/
gtk/gtkcontainer.lisp
@@
-15,7
+15,7
@@
;; License along with this library; if not, write to the Free Software
;; Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
;; License along with this library; if not, write to the Free Software
;; Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
-;; $Id: gtkcontainer.lisp,v 1.1
4 2004/12/20 20:09:54
espen Exp $
+;; $Id: gtkcontainer.lisp,v 1.1
5 2004/12/29 21:14:23
espen Exp $
(in-package "GTK")
(in-package "GTK")
@@
-81,6
+81,15
@@
(defun container-foreach (container function)
(with-callback-function (id function)
(%container-foreach container id)))
(with-callback-function (id function)
(%container-foreach container id)))
+(defbinding %container-forall (container callback-id) nil
+ (container container)
+ ((callback %foreach-callback) pointer)
+ (callback-id unsigned-int))
+
+(defun container-forall (container function)
+ (with-callback-function (id function)
+ (%container-forall container id)))
+
(defun map-container (seqtype func container)
(case seqtype
((nil)
(defun map-container (seqtype func container)
(case seqtype
((nil)
@@
-103,31
+112,14
@@
(defun map-container (seqtype func container)
(incf index)))
seq))))
(incf index)))
seq))))
-(defmacro do-container ((var container &optional (result nil)) &body body)
- (let ((continue (make-symbol "CONTINUE")))
- `(let ((,continue t))
- (container-foreach
- ,container
- #'(lambda (,var)
- (when ,continue
- (setq ,continue nil)
- (block nil
- ,@body
- (setq ,continue t)))))
- ,result)))
-
-;; (defbinding %container-get-children () (glist widget)
-;; (container container))
-
(defmethod container-children ((container container))
(defmethod container-children ((container container))
-;; (%container-get-children container)
(map-container 'list #'identity container))
(defmethod (setf container-children) (children (container container))
(dolist (child (container-children container))
(container-remove container child))
(dolist (child children)
(map-container 'list #'identity container))
(defmethod (setf container-children) (children (container container))
(dolist (child (container-children container))
(container-remove container child))
(dolist (child children)
- (
container-add container child
))
+ (
apply #'container-add container (mklist child)
))
children)
(defun container-length (container)
children)
(defun container-length (container)