Skip to content

A standard interface to the various package lock implementations of Common Lisp.

License

Notifications You must be signed in to change notification settings

yitzchak/trivial-package-locks

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

21 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

trivial-package-locks

A standard interface to the various package lock implementations. Currently supported implementations are ACL, CLISP, CMUCL, ECL and SBCL. On all other implementations the following functions are exported but will evaluate to a NOOP where appropriate.

Package Locks Interface

Implementations that support this interface will have the keyword :package-locks present in *features*.

(package-locked-p &optional (package *package*)) => lock-state
(setf (package-locked-p &optional (package *package*)) new-lock-state)

Accesses the lock state of a package. t indicates that the package is locked and nil indicates that it is not locked.

(without-package-locks &body body) => results

Disables the checking of package locks during the evaluation of body. For implementations that do not have the ability to disable all package locks via a dynamic variable (list-all-packages) will be used to unlock each package before the evaluation of body and then relock each package that was locked after the evaluation of body. For implementations that do not have package locks but have some other mechanism to prevent changes to the kernel that mechanism will be disabled.

(with-unlocked-packages (&rest packages) &body body) => results

Unlocks and relocks each of the named packages around the evaluation of body.

(with-locked-packages (&rest packages) &body body) => results

Locks and then unlocks each of the named packages around the evaluation of body.

Implementation Packages Interface

Implementations that support this interface will have the keyword :implementation-packages present in *features*. Currently ACL and SBCL are the only implementations that support this interface.

(package-implementation-packages (&optional (package *package*)) => packages
(setf (package-implementation-packages &optional (package *package*)) packages)

Accesses the list of packages that are considered implementation packages of package.

(package-implements-package-p (implementation-package 
                               &optional (package *package*)) => state
(setf (package-implements-package-p implementation-package
                                    &optional (package *package*))
      new-state)

Access the implementation state of an individual package.

About

A standard interface to the various package lock implementations of Common Lisp.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Sponsor this project

 

Packages

No packages published