| Age | Commit message (Collapse) | Author | Files | Lines | 
|---|
|  | * use libtool convenience libraries as much as possible
   (for all static libraries except Scintilla)
 * improves separation of language and user interface implementations
   (e.g. the Gtk widgets are not interesting for the rest of SciTECO)
 * the Curses popup widget can now be factored out of interface-curses.cpp
 * some common CPPFLAGS are now defined by ./configure via AM_CPPFLAGS,
   so they don't have to be repeated in each submodule.
 * fixed building the Curses UI: GTK_FLOW_BOX_FALLBACK conditional
   must always be defined. | 
|  | * depend on Gtk+ 3.10. If necessary older versions should also
   be supportable. GtkOverlay was already introduced in v3.2
 * A fallback for GtkFlowBox is compiled in if the Gtk installation
   is too old. This applies even to Ubuntu 14.04 which still runs
   Gtk v3.10.
 * the threading the Gtk UI is left as it is for the time being
   even though the synchronization mechanism has been deprecated.
   Alternative approaches have to be tried out and benchmarked.
 * Completely revamped the GtkInfoPopup widget.
   It is now as powerful as the Curses UI's popup widget.
   * A GtkOverlay is used instead of the top-level window hack
     in the Gtk2 version.
   * GtkFlowBox is used to lay out the columns of the popup.
   * I had to work around restrictions of GtkScrolledWindow
     by writing my own poor-mans scrolled window which handles
     size requests correctly.
   * The popup window no longer overflows the screen size,
     instead we scroll.
   * Scrolling pagewise is finally supported. Wraps at the
     end of a list just like the Curses UI.
   * Instead of using only two stock icons, we now use
     GIO to get file and directory icons for the current theme.
     This looks even better.
   * The GtkFlowBox allows selections which can be used for mouse
     interaction later. But this is not yet implemented.
 * Theming of the popup widget and command line is still
   not performed correctly. | 
|  |  | 
|  | * ^FCLOSE is inserted when the "Close" key is pressed.
   It is used by the GTK+ UI to deliver window close requests
   and SIGTERM occurrences.
   (this replaces the "Break" key used before in the GTK+ UI).
 * The default action of ^FCLOSE is to quit SciTECO, therefore
   window closing is possible even in --no-profile mode for instance.
 * fixed a minor memleak in Cmdline::fnmacro()
 * added ^FCLOSE implementation to fnkeys.tes to insert EX.
   This currently has the disadvantage of overwriting
   the error message with syntax errors if there are modified buffers
   but it will at least not close the window if there are modified
   buffers.
 * SIGTERM will now be similar to SIGINT by default instead of
   terminating SciTECO right away.
 * the GTK+ UI handles SIGTERM by emulating the "close" key while
   still interrupting like SIGINT.
 * GTK+: SIGTERM and ^C will interrupt by sending SIGINT to the
   entire process group instead of simply setting `sigint_occurred`.
   This fixes interrupting EC and EG commands with long-running
   or hanging programs and is relevant to the solution of #4. | 
|  |  | 
|  | * it is installed into the package's data dir.
   It is always installed, even for Curses builds.
   This means when packaging for Debian, the icon could
   be part of the "sciteco-common" package.
   If there will ever be more GTK-specific files that
   need to be installed, this will probably change and
   the icon will be installed for GTK builds only and
   become part of the "sciteco-gtk" Debian package.
 * if the icon could not be loaded, we fail silently.
 * will not work with windows builds. On Windows, we
   should just use the icon resource linked into the binary
   rather than loading the image from file. | 
|  | * the Curses UI does that too | 
|  | * this has long been broken in the GTK UI.
   It must not be possible to let Scintilla react to mouse and
   keyboard events since all side-effects on the buffer state
   must be via the SciTECO language. | 
|  | * the execution thread does not block the main thread (with
   the main loop).
 * therefore if SciTECO executes a long-running macro,
   the UI stays "responsive".
 * also this allows us to handle ^C interruptions.
   This is part of the solution to #4 for GTK+ UIs.
 * to speed up execution and avoid frequent UI redraws
   (now that we run concurrently, there are even more redraws),
   the view change is applied only after key presses.
 * also we freeze all UI updates on the view during SciTECO's
   key processing.
 * Closing the window, requests a graceful execution thread
   shut down. This may later be extended to allow programmable
   window close-behaviour using a special function key macro
   (e.g. mapped to the "Break" key). | 
|  |  | 
|  | * activated via bit 4 of the ED flag (enabled by default)
 * automatic EOL guessing on file loading and translation to LFs.
   * works with files that have inconsistent EOL sequences.
 * automatic translation to original EOL sequences on file saving
   * works with inconsistent EOL sequences in the buffer.
     This should usually not happen if the file was read in with
     automatic EOL translation enabled.
 * also works with the EC and EG commands
 * performance is OK, depending on the file being translated.
   When reading files with UNIX EOLs, the overhead is minimal
   typically-sized files. For DOS EOLs the overhead is larger
   but still acceptable.
 * Return (line feed) is now an immediate editing command.
   This centralizes EOL sequence insertion.
   Later, other features like auto-indent could be added to
   the editing command.
 * get_eol() has been moved to main.cpp (now called
   get_eol_seq()
 * Warn if file ownership could not be preserved when
   saving files.
 * IOView has been almost completely rewritten based
   on GIOChannels. The EOL translation code is also in IOView. | 
|  | * it is now redrawn once after each key press, even if the
   info line has not changed.
 * This is because Interface::update_info() is called very often
   in interactive mode, so it makes more sense to redraw it after user
   interaction (where even unnecessary delays are not noticed so easily),
   than thousands of times in a macro.
 * This is especially important since InterfaceCurses::update_info() now
   also sets the Window title on PDCurses - this is a very costly operation.
 * The same optimization was applied to InterfaceGtk where it is probably
   greatly responsible for the sluggishness of the UI.
   The GTK+ changes are currently UNTESTED. | 
|  | * use g_strconcat() instead of g_strdup_printf()
 * InterfaceGtk::info_update() now longer has an arbitrary
   255 byte limit on the length of the info line. | 
|  | * this relied on Curses' control character drawing on Curses.
   However it treats tab and line feed differently than other
   control characters, so registers like "^Mfoo" could not be displayed
   properly.
   Even if we can configure Curses to display them correctly, we need
   a "canonicalized", flat form of strings for other purposes (like setting
   window titles. This is form is different from the formatting used
   for command lines which may change anyway once we introduce Scintilla
   mini buffers.
 * therefore String::canonicalize_ctl() was introduced
 * also set window title on PDCurses | 
|  | * for historic reasons, the backspace key can be transmitted as
   ^H by the terminal. Some terminal emulators might do that - these
   are fixed by this commit.
 * Use CTL_KEY('H') instead of standard C '\b' as the former is less
   ambiguous given the confusion around the backspace character. | 
|  | CTL_KEY_ESC_STR
 * the reason for the CTL_KEY() macro is to get the control character
   resulting from a CTRL+Key press -- at least this is how SciTECO
   presents these key presses.
   It is also a macro and may be resolved to a constant expression,
   so it can be used in switch-case statements.
   Sometimes it is clearer to use standard C escape sequences (like '\t').
 * CTL_KEY('[') for escape is hard to read, so I always used '\x1B' which
   is even more cryptic. | 
|  | cleanup/refactoring
 * characters rubbed out are not totally removed from the command line,
   but only from the *effective* command line.
 * The rubbed out command line is displayed after the command line cursor.
   On Curses it is grey and underlined.
 * When characters are inserted that are on the rubbed out part of the command line,
   the cursor simply moves forward.
   NOTE: There's currently no immediate editing command for reinserting the
   next character/word from the rubbed out command line.
 * Characters resulting in errors are no longer simply discarded but rubbed out,
   so they will stay in the rubbed out part of the command line, reminding you
   which character caused the error.
 * Improved Cmdline formatting on Curses UI:
   * Asterisk is printed bold
   * Control characters are printed in REVERSE style, similar to what
     Scinterm does. The controll character formatting has thus been moved
     from macro_echo() in cmdline.cpp to the UI implementations.
 * Updated the GTK+ UI (UNTESTED): I did only, the most important API
   adaptions. The command line still does not use any colors.
 * Refactored entire command line handling:
   * The command line is now a class (Cmdline), and most functions
     in cmdline.cpp have been converted to methods.
   * Esp. process_edit_cmd() (now Cmdline::process_edit_cmd()) has been
     simplified. There is no longer the possibility of a buffer overflow
     because of static insertion buffer sizes
   * Cleaned up usage of the cmdline_pos variable (now Cmdline::pc) which
     is really a program counter that used a different origin as macro_pc
     which was really confusing.
   * The new Cmdline class is theoretically 8-bit clean. However all of this
     will change again when we introduce Scintilla views for the command line.
 * Added 8-bit clean (null-byte aware) versions of QRegisterData::set_string()
   and QRegisterData::append_string() | 
|  |  | 
|  | the QUIT hook is actually not that trivial and required
some architectural changes.
First, the QUIT hook execution and any error that might
occurr cannot always be attached to an existing error stack
frame. Thereforce, to give a stack frame for QUIT hooks and
to improve the readability of error traces for ED hooks in general,
a special EDHookFrame is added to every ED hook execution error.
Secondly, since QUIT hooks can themselves throw errors, we cannot
run it from an atexit() handler. Instead it's always called manually
before __successful__ program termination. An error in a QUIT hook
will result in a failure return code nevertheless.
Thirdly, errors in QUIT hooks should not prevent program termination
(in interactive mode), therefore they are only invoked from main()
and always in batch mode. I.e. if the interactive mode is terminated
(EX$$), SciTECO will switch back to batch mode and run the QUIT
hook there. This is also symmetric to program startup, which is
always in batch mode.
This means that Interface::event_loop() no longer runs indefinitely.
If it returns, this signals that the interface shut down and
batch mode may be restored by SciTECO. | 
|  | * it must be initialized after the UI (Interface::main), so I added
   a View::initialize() function
 * the old initialize() method was renamed to setup()
 * use a global instance of QRegister::view so it is guaranteed to
   be destroyed only after any QRegisters that could still need it
 * Document API adapted to work with ViewCurrent references | 
|  | it now works as good (or bad) as it did before.
 * fixed entering of the Escape character | 
|  | 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. | 
|  | 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). | 
|  |  | 
|  | * 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 | 
|  | init_priority attribute
 * we cannot use weak symbols in MinGW, so we avoid init_priority for symbol
   initialization by compiling the empty definitions into
   sciteco-minimal but the real ones into sciteco
   (had to add new file symbols-minimal.cpp)
 * this fixes compilation/linking on LLVM Clang AND Dragonegg
   since their init_priority attribute is broken!
   this will likely be fixed in the near future but broken versions
   will be around for some time | 
|  |  | 
|  | * also revised the way in which unhandled keys are interpreted
   (use gdk_keyval_to_unicode() instead of deprecated GdkEventKey::string)
 * keep in sync with Curses key handling | 
|  | * Scintilla is now initialized from main() using Interface::main()
 * Scintilla initialization depends on initialization of objects in the
   global namespace (otherwise the Lexer catalogue may not be filled
   properly and lexing may not work). Lexer modules were initialized
   after SciTECO interface initialization
 * merged Scintilla initialization (Interface::main()) with interface
   option parsing | 
|  | * 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 | 
|  | commandline macro)
 * only works as part of commandline macro,
 * at the beginning of other macros, it is treated like an arithmetic asterisk
 * variables defined in cmdline.cpp are now declared by new cmdline.h | 
|  |  | 
|  |  | 
|  |  | 
|  |  |