-;; Common Lisp bindings for GTK+ v2.0
-;; Copyright (C) 1999-2000 Espen S. Johnsen <espejohn@online.no>
+;; Common Lisp bindings for GTK+ v2.x
+;; Copyright 1999-2005 Espen S. Johnsen <espen@users.sf.net>
;;
-;; This library is free software; you can redistribute it and/or
-;; modify it under the terms of the GNU Lesser General Public
-;; License as published by the Free Software Foundation; either
-;; version 2 of the License, or (at your option) any later version.
+;; Permission is hereby granted, free of charge, to any person obtaining
+;; a copy of this software and associated documentation files (the
+;; "Software"), to deal in the Software without restriction, including
+;; without limitation the rights to use, copy, modify, merge, publish,
+;; distribute, sublicense, and/or sell copies of the Software, and to
+;; permit persons to whom the Software is furnished to do so, subject to
+;; the following conditions:
;;
-;; This library is distributed in the hope that it will be useful,
-;; but WITHOUT ANY WARRANTY; without even the implied warranty of
-;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
-;; Lesser General Public License for more details.
+;; The above copyright notice and this permission notice shall be
+;; included in all copies or substantial portions of the Software.
;;
-;; You should have received a copy of the GNU Lesser General Public
-;; License along with this library; if not, write to the Free Software
-;; Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+;; THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+;; EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+;; MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
+;; IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
+;; CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
+;; TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
+;; SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
-;; $Id: utils.lisp,v 1.1 2004-10-27 14:50:15 espen Exp $
+;; $Id: utils.lisp,v 1.5 2005-04-23 16:48:51 espen Exp $
(in-package "GLIB")
(defun type-expand-1 (form)
(let ((def (cond ((symbolp form)
- (kernel::info type expander form))
+ #+cmu(kernel::info type expander form)
+ #+sbcl(sb-impl::info :type :expander form))
((and (consp form) (symbolp (car form)))
- (kernel::info type expander (car form)))
+ #+cmu(kernel::info type expander (car form))
+ #+sbcl(sb-impl::info :type :expander (car form)))
(t nil))))
(if def
(values (funcall def (if (consp form) form (list form))) t)
(expand form)))
(defmacro with-gc-disabled (&body body)
- (let ((gc-inhibit (make-symbol "GC-INHIBIT")))
- `(progn
- (let ((,gc-inhibit lisp::*gc-inhibit*))
- (ext:gc-off)
- (unwind-protect
- ,@body
- (unless ,gc-inhibit
- (ext:gc-on)))))))
+ #+cmu`(system:without-gcing ,@body)
+ #+sbcl`(sb-impl::without-gcing ,@body))
(defun mklist (obj)
- (if (atom obj) (list obj) obj))
+ (if (and obj (atom obj)) (list obj) obj))
(defun namep (obj)
(and (symbolp obj) (not (member obj '(t nil)))))
(defun split-string (string delimiter)
(declare (simple-string string) (character delimiter))
- (check-type string string)
- (check-type delimiter character)
(let ((pos (position delimiter string)))
(if (not pos)
(list string)
(defun split-string-if (string predicate)
(declare (simple-string string))
- (check-type string string)
- (check-type predicate (or symbol function))
(let ((pos (position-if predicate string :start 1)))
(if (not pos)
(list string)