diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2018-10-26 07:33:03 -0700 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2018-10-26 07:33:03 -0700 |
commit | e15727cf2ad6ebe2503f9ea0e16dccf118bc93ff (patch) | |
tree | 66f2a97bd0d786f8b5eb95e86bc1ce3ab1d68912 /unwind.h | |
parent | 9733bb6dad3b0c430a82b2592d5519383479cb86 (diff) | |
download | txr-e15727cf2ad6ebe2503f9ea0e16dccf118bc93ff.tar.gz txr-e15727cf2ad6ebe2503f9ea0e16dccf118bc93ff.tar.bz2 txr-e15727cf2ad6ebe2503f9ea0e16dccf118bc93ff.zip |
defvar: warn about prior lexical uses.
Now that the compiler has a more efficient treatment of global
lexical variables, code which accesses global variables that
have not yet been defined will misbehave if the intent is to
for those variables to be dynamically scoped.
There is such a bug in the op expander, in fact.
* eval.c (me_def_variable): When defvar/defparm are expanding,
they now check whether there is an outstanding unbound warning
against the variable. If so, then a warning is issued that the
variable was previously used lexically and is now being marked
special.
* unwind.c (uw_warning_exists): New function.
* unwind.h (uw_warning_exists): Declared.
Diffstat (limited to 'unwind.h')
-rw-r--r-- | unwind.h | 1 |
1 files changed, 1 insertions, 0 deletions
@@ -137,6 +137,7 @@ noreturn val uw_throwfv(val sym, val fmt, struct args *); noreturn val uw_errorf(val fmt, ...); noreturn val uw_errorfv(val fmt, struct args *args); val uw_defer_warning(val args); +val uw_warning_exists(val tag); val uw_dump_deferred_warnings(val stream); val uw_release_deferred_warnings(void); val uw_purge_deferred_warning(val tag); |