diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2014-02-19 00:38:06 -0800 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2014-02-19 00:38:06 -0800 |
commit | 916b0f4a081b26ebb4b58afbcb651fc74dbe23cc (patch) | |
tree | 37c7bee6911880d1196d543f07a8e4758f516ebf /mpi-patches/config-types | |
parent | c720098b5f0eb58eef01fef4acbeccde00af2c75 (diff) | |
download | txr-916b0f4a081b26ebb4b58afbcb651fc74dbe23cc.tar.gz txr-916b0f4a081b26ebb4b58afbcb651fc74dbe23cc.tar.bz2 txr-916b0f4a081b26ebb4b58afbcb651fc74dbe23cc.zip |
Fixing a long-running issue in the TXR pattern language: premature
opening of files, prior to directives that actually need data.
The documentation basically lied that this is the case: namely,
the text "A file isn't opened until the query demands material from
that file, and then the contents are read on demand, not all at
once." This is now a fact.
* match.c (non_matching_directive_table): New global variable.
(open_data_source): New static function. Contains an almost
verbatim migration of the source-opening logic that used
to be in match_files. The useless assignment to c->nil is gone,
and c->data == t is explicitly tested for. Instead of assuming
that only the @(next) directive does not need to have a data source
open, the table of non-matching directives is consulted. Opening
the data source is now skipped for numerous directives.
(match_files): Call open_data_source within the loop. This
means that even after processing numerous non-matching directives,
we will still correctly set up the data lazy list.
(dir_tables_init): Initialize non_matching_directive_table,
protect from GC and populate with numerous directives.
* txr.1: Improved documentation for @(next :args), and removed
a description of the hack that a single @(next) at the top of the
query suppressed the opening of the data source.
Diffstat (limited to 'mpi-patches/config-types')
0 files changed, 0 insertions, 0 deletions