Artifact
56888b9d5ba3a18f2663aa961ec0f356d9ecb017:
- File
lmdb/guardian.ss
— part of check-in
[b358a80757]
at
2016-09-04 14:50:46
on branch trunk
— added missing file changes
(user:
aldo
size: 1481)
;;
;; Copyright 2016 Aldo Nicolas Bruno
;;
;; Licensed under the Apache License, Version 2.0 (the "License");
;; you may not use this file except in compliance with the License.
;; You may obtain a copy of the License at
;;
;; http://www.apache.org/licenses/LICENSE-2.0
;;
;; Unless required by applicable law or agreed to in writing, software
;; distributed under the License is distributed on an "AS IS" BASIS,
;; WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
;; See the License for the specific language governing permissions and
;; limitations under the License.
(define mdb-guardian (make-guardian))
(define (mdb-guard-pointer obj)
(mdb-free-garbage)
;(printf "guarding pointer ~d~n" obj)
(mdb-guardian obj)
obj)
(define (mdb-free-garbage)
(define addr ftype-pointer-address)
(define (free-ptr p) (foreign-free (addr p)))
(let loop ([p (mdb-guardian)])
(when p
(when (ftype-pointer? p)
;(printf "mdb-free-garbage: freeing memory at ~x\n" p)
;;[(ftype-pointer? usb-device*-array p)
(cond
[(ftype-pointer? mdb-txn* p) (free-ptr p)]
[(ftype-pointer? mdb-env* p) (free-ptr p)]
;; [(ftype-pointer? mdb-txn p) (mdb-txn-abort p)]
[(ftype-pointer? mdb-env p) (mdb-env-close p)]
[(ftype-pointer? mdb-cursor p) (mdb-cursor-close p)]
;;[(ftype-pointer? mdb-dbi p) (mdb-dbi-close env! p)]
[else
(foreign-free (ftype-pointer-address p))]
))
(loop (mdb-guardian)))))