| Age | Commit message (Collapse) | Author | Files | Lines | 
|---|
|  | it became apparent, that something like this is very useful,
when constructing the contents of a q-register without
editing it.
I have decided against introducing another modifier for toggling
string building. Most commands have string building enabled and it
doesn't hurt. For the few exceptions, an alternative variant can
be introduced. | 
|  | * main motivation is to have a way of getting the number of buffers
   in the ring. "EJ" or "1EJ" will do that.
   This simplifies macros that will have to iterate all the buffers.
   They no longer have to close the existing buffers to do that.
 * "0EJ" will get the current user interface. This is useful to select
   a different color scheme in the startup profile depending on the UI,
   for instance. | 
|  | * implements the same globbing as the EB command already did
 * uses Globber helper class that behaves more like UNIX glob().
   glib only has a glob-style pattern matcher.
 * The Globber class may be extended later to provide more
   UNIX-like globbing.
 * lexer.tes has been updated to make use of globbing.
   Now, lexers can be automatically loaded and registered at
   startup. To install a new lexer, it's sufficient to copy
   a file to the lexers/ directory. | 
|  |  | 
|  | introduced Error::set_coord() | 
|  | This is only a problem if the macro created the local Q-Register table
(i.e. not when called with ":M") but resulted in segfaults.
Since we do not want to save in a Q-Reg whether it is local
(and that wouldn't suffice anyway), we do it in the Q-Register table
cleanup. The corresponding QRegisterTable::clear() must be called
explicitly, since the RBTree::clear() called on destruction does not
and cannot throw errors.
If QRegisterTable::clear() has been called successfully, the default object
destructor will not do much. If it has thrown an error, the destructor
will clean up the remaining Q-Registers. | 
|  | it was not possible to inherit the parser state of the last command in
a macro. However, it was possible to exit the macro when its
last command was not properly terminated.
There is no useful conscious application of this behaviour.
 * If something like an uncomplete E-Command was last in the
   macro, there was absolutely no effect. However this points
   to a macro programming error.
 * If the last command started a string parameter but did not
   terminate it, the command might be (partially) executed.
   However the State's done() method wasn't called, which means
   that some commands will not execute at all. Again there's
   no useful application of this.
When on the other hand, the last command was not terminated
by accident, this was not reported to the user. | 
|  | this eases handling of the "*" register | 
|  | * allowed me to remove some obscure global functions and methods like
   QRegister::update_string().
 * Document updating is concentrated in qregisters.cpp now
 * also fixes some bugs introduced earlier, like undo tokens being
   generated for non-undo registers (resulting in segfaults on rubout) | 
|  | Template Pattern.
 * without the one-view-per-buffer designs, many Scintilla send message (SSM)
   calls could be inlined
 * with the new design, this was no longer possible using the abstract
   base classes. the CRT pattern allows inlining again but introduces
   a strange level of code obscurity.
 * tests suggest that at high optimization levels, the one-view-per-buffer
   design and the CRT pattern reduces typical macro runtimes by 30%
   (e.g. for symbols-extract.tes).
 * only updated the NCurses UI for the time being | 
|  | The user interface provides a Scintilla view abstraction and
every buffer is based on a view. All Q-Register strings use
a single dedicated view to save memory and initialization time
when using many string registers.
 * this means we can finally implement a working lexer configuration
   and it only has to be done once when the buffer is first added
   to the ring. It is unnecessary to magically restore the lexer
   styles upon rubout of EB (very hard to implement anyway). It
   is also not necessary to rerun the lexer configuration macro
   upon rubout which would be hard to reconcile with SciTECO's
   basic design since every side-effect should be attached to a
   character.
 * this means that opening buffers is slightly slower now
   because of the view initialization
 * on the other hand, macros with many string q-reg operations
   are faster now, since the document must no longer be changed
   on the buffer's view and restored later on.
 * also now we can make a difference between editing a document
   in a view and changing the current view, which reduces UI calls
 * the Document class has been retained as an abstraction about
   Scintilla documents, used by QRegister Strings.
   It had to be made virtual, so the view on which the document
   is created can be specified by a virtual function.
   There is no additional space overhead for Documents. | 
|  | also changed precedence of + operator (higher than minus).
the effects of this should be minimal | 
|  | * the GError expection has been renamed to GlibError, to avoid
   nameclashes when working from the SciTECO namespace | 
|  | normally, since SciTECO is not a library, this is not strictly
necessary since every library should use proper name prefixes
or namespaces for all global declarations to avoid name clashes.
However
 * you cannot always rely on that
 * Scintilla does violate the practice of using prefixes or namespaces.
   The public APIs are OK, but it does define global functions/methods,
   e.g. for "Document" that clashed with SciTECO's "TECODocument" class at
   link-time.
   Scintilla can put its definitions in a namespace, but this feature
   cannot be easily enabled without patching Scintilla.
 * a "SciTECO" namespace will be necessary if "SciTECO" is ever to be
   turned into a library. Even if this library will have only a C-linkage
   API, it must ensure it doesn't clutter the global namespace.
So the old "TECODocument" class was renamed back to "Document"
(SciTECO::Document). | 
|  |  | 
|  |  | 
|  | current document
if the current document is a local q-register from a macro call,
we must not generate undo tokens, since the local documents
are discarded on macro termination. | 
|  |  | 
|  |  | 
|  | powerful command for filtering a SciTECO buffer through an external
program. It will be described in the sciteco(7) man pages.
The implementation uses an asynchronous background process with
pipes but is platform independant thanks to glib's g_spawn functions,
GIOChannels and event loops.
There are however platform differences in how the operating system
command is interpreted/parsed. | 
|  | the question remains what to do then.
FIXME: consult TECO standard | 
|  | * referencing temporaries is unreliable/buggy in GNU C++, at least since v4.7
 * in higher optimization levels it resulted in massive memory corruptions
 * this is responsible for the build issues (PPA build issues)
 * instead, always declare a buffer on the stack which guarantees that the
   variable lives long enough
 * the g_strdup(CHR2STR(x)) idiom has been replaced with String::chrdup(x) | 
|  |  | 
|  |  | 
|  | * results in better error messages, e.g. when opening files
 * the case that a file to be opened (EB) exists but is not readably is handled for the first time | 
|  | * might throw other exceptions that must be associated with the parent macro level's (stack frame)
 * add position information to "label not found" errors
 * Error copy constructors | 
|  | * specifications resulted in runtime errors (unexpected exception) when bad_alloc ocurred
 * specs should be used scarcely: only when the errors that may be thrown are all known
   and for documentary purposes | 
|  | bad_allocs and convert them to State::Error
 * will allow some degree of OOM handling
 * currently does not work since the exception specifications prevent bad_allocs from propagating.
   exception specification usage must be completely revised | 
|  | * use to get line and column into a stack frame | 
|  | * when an error is thrown, stack frames are collected on clean up, up to
   the toplevel macro
 * the toplevel macro decides how to display the error
 * now errors in interactive and batch mode are displayed differently
   * in batch mode, a backtrace is displayed as a sequence of messages
 * Execute::file() forwards errors correctly
   * the correct error in the file is displayed in interactive mode
   * necessary to build the stack trace | 
|  | register
I felt the urge to implement that after accidentally rubbing out my entire commandline
(the work of an hour) just by pressing "}"... | 
|  | * fixes compilation on g++ 4.7 where compound literals are suddenly
   temporaries (from which you cannot get a pointer)
 * the compound statement (also GCC extension) should ensure that
   the string is allocated on the stack with automatic lifetime | 
|  |  | 
|  | * compiler does not warn by default: this actually makes sense
 * so we don't need any unused-attributes
 * less GCC-extension based
 * on older GCCs I think -Wunused-parameters was enabled by -Wall
   we should add -Wno-unused-parameters if that's the case | 
|  | * new Expressions::format()
 * may be used format numbers as part of arrays (Q-Register names) | 
|  | of success/failure booleans
 * for the S and T conditions, nothing changes effectively (were testing for < 0 already)
 * the F and U conditions were testing for equality to zero which worked for condition booleans
   returned by commands but not for any failure condition (defined as >= 0)
 * may be different in classic TECOs but makes more sense IMHO | 
|  | * flow control and other structures have not been documented this ways.
   I have not yet decided whether they should be documented in separate
   sections or use the documentation tool. | 
|  | * also updated sciteco(7): add SEE ALSO and AUTHORS | 
|  |  | 
|  | * useful for using macro libraries | 
|  | * storage size should always be 64 (gint64) to aid macro portability
 * however, for performance reasons users compiling from source might
   explicitly compile with 32 bit integers | 
|  |  | 
|  |  | 
|  | string-building commands
 * allows referring to long Q-Register names in string arguments
 * currently, long names specified this way use their own string building char parsing
   (I'm unsure whether this makes any sense) | 
|  | base class
 * uses label pointers instead of state-enum and switch case
   (both faster and shorter to write)
 * common interface for all micro state machines: makes them reusable | 
|  | cmdline and cmdline_pos is no longer modified by code executed by step()
instead it is modified at the outermost macro level (commandline macro level) | 
|  | * allows us to switch between buffers/registers when editing the
   commandline | 
|  | allows commandline editing scripted by macros | 
|  | * simplified traditional commandline editing. no need to extend cmdline string one character
   at a time when inserting multiple. instead there's a marker (cmdline_pos) specifying the macro
   length to execute in a "step" and also the anchor for generating undo tokens
 * implementation does not yet work in macro calls
 * while editing the commandline, other buffers/registers may not be edited
   (need push-down-list and auxiliary q-register) | 
|  | * there was a dependency on interface initialization.
   it did not cause issues because destruction order was
   by chance.
 * introduced INIT_PRIO and PRIO_* macros to easy initialization order declaration
   (using a PRIO_* formula makes code self-documenting)
 * also used this to clean up QRegisterTable initialization
   (we do not need the explicit initialize() method)
 * also used to clean up symbols initialization |