diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2020-07-12 11:29:33 -0700 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2020-07-12 11:29:33 -0700 |
commit | 15740ae6b6c8476cd1a9323ffd50f85a3c8ea245 (patch) | |
tree | f5eac0226a4e57e1383771c862a23efc0eddfb93 /txr.1 | |
parent | a6f6072761d124c60793325bc512048b0f31f5a3 (diff) | |
download | txr-15740ae6b6c8476cd1a9323ffd50f85a3c8ea245.tar.gz txr-15740ae6b6c8476cd1a9323ffd50f85a3c8ea245.tar.bz2 txr-15740ae6b6c8476cd1a9323ffd50f85a3c8ea245.zip |
Support weak semantics in symbol packages.
A package is weak if it holds weak references to symbols,
meaning that if there are no references to a symbol other than
its entry in a weak package, it can be removed from the
package and reclaimed by the garbage collector.
* eval.c (eval_init): Update registrations for make-package
and sys:make-anon-package to reflect new optional argument.
* lib.c (make_package_common): New argument weak. If it is
true then both the hashes will have weak values.
(make_package, make_anon_package): New optional argument weak.
(obj_init): Add nil argument to calls to make_package. All the
standard packages are regular, not weak.
* lib.h (make_package, make_anon_package): Declarations
updated.
* txr.1: Documented.
Diffstat (limited to 'txr.1')
-rw-r--r-- | txr.1 | 20 |
1 files changed, 19 insertions, 1 deletions
@@ -54483,7 +54483,7 @@ uses to form the name of the new symbol. .coNP Function @ make-package .synb -.mets (make-package << name ) +.mets (make-package < name <> [ weak ]) .syne .desc The @@ -54499,6 +54499,24 @@ should be performed with the macro rather than by direct use of .codn make-package . +If the +.meta weak +parameter is given an argument which is a Boolean true, then the resulting +package holds symbols weakly, from a garbage collection point of view. If the +only reference to a symbol is that which occurs inside the weak package, then +that symbol may be removed from the package and reclaimed by the garbage +collector. + +Note: weak packages address the following problem. The application creates a +package for the purpose of reading Lisp data. Symbols occurring in that data +therefore are interned into the package. Subsequently, the application retains +references to some of the symbols, discarding the others. If the package isn't +weak, then because the application is retaining some of the symbols, and those +symbols hold a reference to the package, and the package holds a reference to +all symbols that were interned in it, all of the symbols are retained. If a +weak package is used, then the uninterested symbols are eligible for garbage +collection. + .coNP Function @ delete-package .synb .mets (delete-package << package ) |