I already figured out a great finalizer, I could just use help on one thing.
The below finalizer is for the %mat defcfun below that.
How do I update the finalizer below to be for the mat-data defcfun at the 
bottom of the page. So where do I put the rows cols params, there seems 
to be no place for them in the defstruct wwhere %mat is called. Any
help is appreciated 
 
 
 
(defstruct (cvmatrix (:constructor %make-cvmatrix)) 
  (sap (%mat) :type sb-sys:system-area-pointer :read-only t)) 
 
 (defun make-cvmatrix (&optional enable-finalizer) 
  (let* ((matrix (%make-cvmatrix)) 
          (sap (cvmatrix-sap matrix))) 
(when enable-finalizer 
    (tg:finalize matrix (lambda () (del-mat sap)))) 
    sap)) 

 
(defcfun ("cv_create_Mat" %mat) (:pointer mat) 
  "MAT constructor") 
 
;; Mat::Mat(int rows, int cols, int type, void* data)  
;; Mat* cv_create_Mat_with_data(int rows, int cols, int type, void* data) 
(defcfun ("cv_create_Mat_with_data" mat-data) (:pointer mat) 
  (rows :int) 
  (cols :int) 
  (type :int) 
  (data :pointer)) 


On Sunday, April 13, 2014 12:28 AM, Willem Rein Oudshoorn <wouds...@xs4all.nl> 
wrote:
 
Joeish W <joeish80...@yahoo.com> writes:
>
>> I have Lisp functions that wrap C wrappers for C++ functions that
>> contain a new operator. The C wrappers have to stay the same I can't
>> change those but I was advised to update my method of GC.
>
>As already mentioned before, use the package 'trivial-garbage'.
>
>The cl-git package that wraps the libgit2 C code might be a good
>example.  
>
>The cl-git code tries the handle automatic freeing by the garbage
>collector, but also allows you to free manually.  
>In addition it keeps track of dependencies, e.g. in cl-git 
>a 'commit' is only valid as long as the 'repository' is open.
>
>It is not much code and might give some inspiration.  
>
>Disclaimer, I was quite involved in this bit of cl-git, the 
>project is on github:
>
>https://github.com/russell/cl-git
>
>
>As an additional question, maybe not well suited for this list.
>I see you are wrapping the OpenCV code.  There are already two 
>other wrappers.  So I am curious what are the deficiencies of the 
>existing wrappers that your wrapper tries to solve?
>
>Wim Oudshoorn.
>
>
>_______________________________________________
>Cffi-devel mailing list
>Cffi-devel@common-lisp.net
>http://common-lisp.net/cgi-bin/mailman/listinfo/cffi-devel
>
>
>
_______________________________________________
Cffi-devel mailing list
Cffi-devel@common-lisp.net
http://common-lisp.net/cgi-bin/mailman/listinfo/cffi-devel

Reply via email to