mirror of
git://git.code.sf.net/p/zsh/code
synced 2025-01-01 05:16:05 +01:00
141 lines
3.3 KiB
C
141 lines
3.3 KiB
C
/*
|
|
* deltochar.c - ZLE module implementing Emacs' zap-to-char
|
|
*
|
|
* This file is part of zsh, the Z shell.
|
|
*
|
|
* Copyright (c) 1996-1997 Peter Stephenson
|
|
* All rights reserved.
|
|
*
|
|
* Permission is hereby granted, without written agreement and without
|
|
* license or royalty fees, to use, copy, modify, and distribute this
|
|
* software and to distribute modified versions of this software for any
|
|
* purpose, provided that the above copyright notice and the following
|
|
* two paragraphs appear in all copies of this software.
|
|
*
|
|
* In no event shall Peter Stephenson or the Zsh Development Group be liable
|
|
* to any party for direct, indirect, special, incidental, or consequential
|
|
* damages arising out of the use of this software and its documentation,
|
|
* even if Peter Stephenson and the Zsh Development Group have been advised of
|
|
* the possibility of such damage.
|
|
*
|
|
* Peter Stephenson and the Zsh Development Group specifically disclaim any
|
|
* warranties, including, but not limited to, the implied warranties of
|
|
* merchantability and fitness for a particular purpose. The software
|
|
* provided hereunder is on an "as is" basis, and Peter Stephenson and the
|
|
* Zsh Development Group have no obligation to provide maintenance,
|
|
* support, updates, enhancements, or modifications.
|
|
*
|
|
*/
|
|
|
|
#include "deltochar.mdh"
|
|
#include "deltochar.pro"
|
|
|
|
static Widget w_deletetochar;
|
|
static Widget w_zaptochar;
|
|
|
|
/**/
|
|
static int
|
|
deltochar(UNUSED(char **args))
|
|
{
|
|
ZLE_INT_T c = getfullchar(0);
|
|
int dest = zlecs, ok = 0, n = zmult;
|
|
int zap = (bindk->widget == w_zaptochar);
|
|
|
|
if (n > 0) {
|
|
while (n-- && dest != zlell) {
|
|
while (dest != zlell && (ZLE_INT_T)zleline[dest] != c)
|
|
INCPOS(dest);
|
|
if (dest != zlell) {
|
|
if (!zap || n > 0)
|
|
INCPOS(dest);
|
|
if (!n) {
|
|
forekill(dest - zlecs, CUT_RAW);
|
|
ok++;
|
|
}
|
|
}
|
|
}
|
|
} else {
|
|
/* ignore character cursor is on when scanning backwards */
|
|
if (dest)
|
|
DECPOS(dest);
|
|
while (n++ && dest != 0) {
|
|
while (dest != 0 && (ZLE_INT_T)zleline[dest] != c)
|
|
DECPOS(dest);
|
|
if ((ZLE_INT_T)zleline[dest] == c) {
|
|
if (!n) {
|
|
/* HERE adjust zap for trailing combining chars */
|
|
backkill(zlecs - dest - zap, CUT_RAW|CUT_FRONT);
|
|
ok++;
|
|
}
|
|
if (dest)
|
|
DECPOS(dest);
|
|
}
|
|
}
|
|
}
|
|
return !ok;
|
|
}
|
|
|
|
|
|
static struct features module_features = {
|
|
NULL, 0,
|
|
NULL, 0,
|
|
NULL, 0,
|
|
NULL, 0,
|
|
0
|
|
};
|
|
|
|
|
|
/**/
|
|
int
|
|
setup_(UNUSED(Module m))
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
/**/
|
|
int
|
|
features_(Module m, char ***features)
|
|
{
|
|
*features = featuresarray(m, &module_features);
|
|
return 0;
|
|
}
|
|
|
|
/**/
|
|
int
|
|
enables_(Module m, int **enables)
|
|
{
|
|
return handlefeatures(m, &module_features, enables);
|
|
}
|
|
|
|
/**/
|
|
int
|
|
boot_(Module m)
|
|
{
|
|
w_deletetochar = addzlefunction("delete-to-char", deltochar,
|
|
ZLE_KILL | ZLE_KEEPSUFFIX);
|
|
if (w_deletetochar) {
|
|
w_zaptochar = addzlefunction("zap-to-char", deltochar,
|
|
ZLE_KILL | ZLE_KEEPSUFFIX);
|
|
if (w_zaptochar)
|
|
return 0;
|
|
deletezlefunction(w_deletetochar);
|
|
}
|
|
zwarnnam(m->node.nam, "deltochar: name clash when adding ZLE functions");
|
|
return -1;
|
|
}
|
|
|
|
/**/
|
|
int
|
|
cleanup_(Module m)
|
|
{
|
|
deletezlefunction(w_deletetochar);
|
|
deletezlefunction(w_zaptochar);
|
|
return setfeatureenables(m, &module_features, NULL);
|
|
}
|
|
|
|
/**/
|
|
int
|
|
finish_(UNUSED(Module m))
|
|
{
|
|
return 0;
|
|
}
|