X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~mdw/git/clg/blobdiff_plain/c2cc3ad71223e68c6da23cdc7047547355df3045..refs/heads/cvs:/glib/gparam.lisp?ds=sidebyside diff --git a/glib/gparam.lisp b/glib/gparam.lisp index 906f0ac..c5d6794 100644 --- a/glib/gparam.lisp +++ b/glib/gparam.lisp @@ -20,7 +20,7 @@ ;; TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE ;; SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -;; $Id: gparam.lisp,v 1.26 2007/08/20 10:50:25 espen Exp $ +;; $Id: gparam.lisp,v 1.27 2008/11/04 03:22:23 espen Exp $ (in-package "GLIB") @@ -34,6 +34,9 @@ (defbinding (size-of-gvalue "size_of_gvalue") () unsigned-int)) (defconstant +gvalue-size+ (size-of-gvalue)) (defconstant +gvalue-value-offset+ (max (size-of 'type-number) (type-alignment '(unsigned-byte 64)))) +(defconstant +gvalue-flags-offset+ + (+ +gvalue-value-offset+ (size-of '(unsigned-byte 64)))) +(defconstant +gvalue-nocopy-contents-flag+ 27) (defbinding (%gvalue-init "g_value_init") () nil (value gvalue) @@ -76,6 +79,15 @@ (defun gvalue-type (gvalue) ;; This will signal an error if the type hierarchy is unknown (type-from-number type-number t)))))) +(let ((flags-reader nil)) + (defun gvalue-static-p (gvalue) + (unless flags-reader + (setf flags-reader (reader-function 'unsigned-int))) + (prog1 + (ldb-test (byte 1 +gvalue-nocopy-contents-flag+) + (funcall flags-reader gvalue +gvalue-flags-offset+)) + (force-output)))) + (defun gvalue-get (gvalue) (funcall (reader-function (gvalue-type gvalue)) gvalue +gvalue-value-offset+)) @@ -85,7 +97,8 @@ (defun gvalue-peek (gvalue) gvalue +gvalue-value-offset+)) (defun gvalue-take (gvalue) - (funcall (reader-function (gvalue-type gvalue) :ref :get) + (funcall (reader-function (gvalue-type gvalue) + :ref (if (gvalue-static-p gvalue) :peek :get)) gvalue +gvalue-value-offset+)) (defun gvalue-set (gvalue value)