(n :int))
(defun draw-points (drawable gc points)
- (let ((n (length points)))
- (with-foreign-object (points-ptr 'point-cstruct n)
- (let ((i 0))
- (map nil
- (lambda (pt)
- (gobject::copy-slots-to-native
- pt
- (inc-pointer points-ptr (* i (foreign-type-size 'point-cstruct)))
- (gobject::g-boxed-cstruct-wrapper-info-cstruct-description (gobject::get-g-boxed-foreign-info 'point)))
- (incf i))
- points))
- (gdk-draw-points drawable gc points-ptr n))))
+ (with-foreign-boxed-array (n points-ptr point points)
+ (gdk-draw-points drawable gc points-ptr n)))
(export 'draw-points)
(n :int))
(defun draw-lines (drawable gc points)
- (let ((n (length points)))
- (with-foreign-object (points-ptr 'point-cstruct n)
- (let ((i 0))
- (map nil
- (lambda (pt)
- (gobject::copy-slots-to-native
- pt
- (inc-pointer points-ptr (* i (foreign-type-size 'point-cstruct)))
- (gobject::g-boxed-cstruct-wrapper-info-cstruct-description (gobject::get-g-boxed-foreign-info 'point)))
- (incf i))
- points))
- (gdk-draw-lines drawable gc points-ptr n))))
+ (with-foreign-boxed-array (n points-ptr point points)
+ (gdk-draw-lines drawable gc points-ptr n)))
(export 'draw-lines)
(n-segments :int))
(defun draw-segments (drawable gc segments)
- (let ((n (length segments)))
- (with-foreign-object (segments-ptr 'segment-cstruct n)
- (let ((i 0))
- (map nil
- (lambda (segment)
- (gobject::copy-slots-to-native
- segment
- (inc-pointer segments-ptr (* i (foreign-type-size 'segment-cstruct)))
- (gobject::g-boxed-cstruct-wrapper-info-cstruct-description (gobject::get-g-boxed-foreign-info 'segment)))
- (incf i))
- segments))
- (gdk-draw-segments drawable gc segments-ptr n))))
+ (with-foreign-boxed-array (n segments-ptr segment segments)
+ (gdk-draw-segments drawable gc segments-ptr n)))
(export 'draw-segments)
(n-points :int))
(defun draw-polygon (drawable gc filled points)
- (let ((n (length points)))
- (with-foreign-object (points-ptr 'point-cstruct n)
- (let ((i 0))
- (map nil
- (lambda (point)
- (gobject::copy-slots-to-native
- point
- (inc-pointer points-ptr (* i (foreign-type-size 'point-cstruct)))
- (gobject::g-boxed-cstruct-wrapper-info-cstruct-description (gobject::get-g-boxed-foreign-info 'point)))
- (incf i))
- points))
- (gdk-draw-polygon drawable gc filled points-ptr n))))
+ (with-foreign-boxed-array (n points-ptr point points)
+ (gdk-draw-polygon drawable gc filled points-ptr n)))
(export 'draw-polygon)
(n :int))
(defun draw-trapezoids (drawable gc trapezoids)
- (let ((n (length trapezoids)))
- (with-foreign-object (trapezoids-ptr 'trapezoid-cstruct n)
- (let ((i 0))
- (map nil
- (lambda (trapezoid)
- (gobject::copy-slots-to-native
- trapezoid
- (inc-pointer trapezoids-ptr (* i (foreign-type-size 'trapezoid-cstruct)))
- (gobject::g-boxed-cstruct-wrapper-info-cstruct-description (gobject::get-g-boxed-foreign-info 'trapezoid)))
- (incf i))
- trapezoids))
- (gdk-draw-trapezoids drawable gc trapezoids-ptr n))))
+ (with-foreign-boxed-array (n trapezoids-ptr trapezoid trapezoids)
+ (gdk-draw-trapezoids drawable gc trapezoids-ptr n)))
(export 'draw-trapezoids)
(fill-rule gdk-fill-rule))
(defun region-from-polygon (points fill-rule)
- (let ((n (length points)))
- (with-foreign-object (pts 'point-cstruct n)
- (let ((i 0))
- (map nil (lambda (pt)
- (gobject::copy-slots-to-native
- pt
- (inc-pointer pts (* i (foreign-type-size 'point-cstruct)))
- (gobject::g-boxed-cstruct-wrapper-info-cstruct-description (gobject::get-g-boxed-foreign-info 'point)))
- (incf i))
- points))
- (gdk-region-polygon pts n fill-rule))))
+ (with-foreign-boxed-array (n pts point points)
+ (gdk-region-polygon pts n fill-rule)))
(export 'region-from-polygon)
(data :pointer))
(defun region-spans-intersect-foreach (region spans sorted fn)
- (let ((n (length spans)))
- (with-stable-pointer (ptr fn)
- (with-foreign-object (spans-ptr 'span-cstruct n)
- (let ((i 0))
- (map nil
- (lambda (span)
- (gobject::copy-slots-to-native
- span
- (inc-pointer spans-ptr (* i (foreign-type-size 'span-cstruct)))
- (gobject::g-boxed-cstruct-wrapper-info-cstruct-description (gobject::get-g-boxed-foreign-info 'span)))
- (incf i))
- spans))
- (gdk-region-spans-intersect-foreach region spans-ptr n sorted (callback gdk-region-spans-intersect-foreach) ptr)))))
+ (with-stable-pointer (ptr fn)
+ (with-foreign-boxed-array (n spans-ptr span spans)
+ (gdk-region-spans-intersect-foreach region spans-ptr n sorted (callback gdk-region-spans-intersect-foreach) ptr))))
(export 'region-spans-intersect-foreach)