From 2e244d781b1b1096cddfd0df558ec7cee19b33a1 Mon Sep 17 00:00:00 2001 From: Matthias Benkard Date: Fri, 15 Feb 2008 10:44:10 +0100 Subject: System refactoring. darcs-hash:961c2ecf3be60a2a4abcfd15f3e51b5ccfb163c0 --- Lisp/libobjcl.lisp | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) (limited to 'Lisp/libobjcl.lisp') diff --git a/Lisp/libobjcl.lisp b/Lisp/libobjcl.lisp index 0858cb9..89930b8 100644 --- a/Lisp/libobjcl.lisp +++ b/Lisp/libobjcl.lisp @@ -375,6 +375,22 @@ conventional case for namespace identifiers in Objective-C." (cffi:pointer-eq pointer (objcl-get-nil)))) +(defun objc-null (value) + (or (null value) + (and (typep value 'c-pointer-wrapper) + (objc-pointer-null (pointer-to value))))) + + +(defmacro objc-or (&rest forms) + (let ((sym (gensym))) + `(let ((,sym ,(first forms))) + (if (objc-null ,sym) + ,(if (rest forms) + `(objc-or ,@(rest forms)) + 'nil) + ,sym)))) + + (declaim (ftype (function (string) (or null selector)) find-selector-by-name)) (defun find-selector-by-name (selector-name) -- cgit v1.2.3