mirror of
https://github.com/troglobit/editline.git
synced 2025-05-08 22:01:12 +08:00
Compare commits
No commits in common. "master" and "1.16.1" have entirely different histories.
@ -23,7 +23,7 @@ addons:
|
|||||||
description: "A small line editing library"
|
description: "A small line editing library"
|
||||||
notification_email: troglobit@gmail.com
|
notification_email: troglobit@gmail.com
|
||||||
build_command_prepend: "./autogen.sh && ./configure --enable-sigstop --enable-terminal-bell"
|
build_command_prepend: "./autogen.sh && ./configure --enable-sigstop --enable-terminal-bell"
|
||||||
build_command: "make clean all"
|
build_command: "make -j5"
|
||||||
branch_pattern: dev
|
branch_pattern: dev
|
||||||
|
|
||||||
# We don't store generated files (configure and Makefile) in GIT,
|
# We don't store generated files (configure and Makefile) in GIT,
|
||||||
@ -31,4 +31,4 @@ addons:
|
|||||||
script:
|
script:
|
||||||
- ./autogen.sh
|
- ./autogen.sh
|
||||||
- ./configure --enable-sigstop --enable-terminal-bell
|
- ./configure --enable-sigstop --enable-terminal-bell
|
||||||
- make clean all
|
- make -j5
|
||||||
|
41
ChangeLog.md
41
ChangeLog.md
@ -4,35 +4,8 @@ Change Log
|
|||||||
All notable changes to the project are documented in this file.
|
All notable changes to the project are documented in this file.
|
||||||
|
|
||||||
|
|
||||||
[1.17.1][] - 2020-02-23
|
[1.16.1] - 2019-06-07
|
||||||
-----------------------
|
---------------------
|
||||||
|
|
||||||
### Fixes
|
|
||||||
- Fix #38: Fix for multiline representing as one line
|
|
||||||
- Fix packaging, missing files in libeditline1, regression from 1.16.0
|
|
||||||
- Fix packaging, update to latest std version
|
|
||||||
- Fix formatting of function names in man page
|
|
||||||
- Restore tar.gz distribution, for usability on systems that do not
|
|
||||||
have xz in their default install
|
|
||||||
|
|
||||||
|
|
||||||
[1.17.0][] - 2020-01-05
|
|
||||||
-----------------------
|
|
||||||
|
|
||||||
### Changes
|
|
||||||
- Simple multi-line support by Dima Volynets, @dvolynets
|
|
||||||
|
|
||||||
### Fixes
|
|
||||||
- Fix return value from `read_history()` and `write_history()`, could
|
|
||||||
return `errno` instead of `EOF` to indicate error. Now both functions
|
|
||||||
have uniform return values on error
|
|
||||||
- Handle internal `realloc()` errors better. Now memory is not leaked
|
|
||||||
if `realloc()` fails
|
|
||||||
- Fix possible NULL pointer dereference in key binding lookup function
|
|
||||||
|
|
||||||
|
|
||||||
[1.16.1][] - 2019-06-07
|
|
||||||
-----------------------
|
|
||||||
|
|
||||||
### Changes
|
### Changes
|
||||||
- Major updates to the `editline.3` man page
|
- Major updates to the `editline.3` man page
|
||||||
@ -249,9 +222,7 @@ Adaptations to Debian editline package.
|
|||||||
- First version, forked from Minix current 2008-06-06
|
- First version, forked from Minix current 2008-06-06
|
||||||
|
|
||||||
|
|
||||||
[UNRELEASED]: https://github.com/troglobit/finit/compare/1.17.1...HEAD
|
[UNRELEASED]: https://github.com/troglobit/finit/compare/1.16.0...HEAD
|
||||||
[1.17.1]: https://github.com/troglobit/finit/compare/1.17.0...1.17.1
|
|
||||||
[1.17.0]: https://github.com/troglobit/finit/compare/1.16.1...1.17.0
|
|
||||||
[1.16.1]: https://github.com/troglobit/finit/compare/1.16.0...1.16.1
|
[1.16.1]: https://github.com/troglobit/finit/compare/1.16.0...1.16.1
|
||||||
[1.16.0]: https://github.com/troglobit/finit/compare/1.15.3...1.16.0
|
[1.16.0]: https://github.com/troglobit/finit/compare/1.15.3...1.16.0
|
||||||
[1.15.3]: https://github.com/troglobit/finit/compare/1.15.2...1.15.3
|
[1.15.3]: https://github.com/troglobit/finit/compare/1.15.2...1.15.3
|
||||||
@ -269,3 +240,9 @@ Adaptations to Debian editline package.
|
|||||||
[Travis-CI]: https://travis-ci.org/troglobit/uftpd
|
[Travis-CI]: https://travis-ci.org/troglobit/uftpd
|
||||||
[Coverity Scan]: https://scan.coverity.com/projects/2947
|
[Coverity Scan]: https://scan.coverity.com/projects/2947
|
||||||
[README.md]: https://github.com/troglobit/editline/blob/master/README.md
|
[README.md]: https://github.com/troglobit/editline/blob/master/README.md
|
||||||
|
|
||||||
|
<!--
|
||||||
|
-- Local Variables:
|
||||||
|
-- mode: markdown
|
||||||
|
-- End:
|
||||||
|
-->
|
||||||
|
10
Makefile.am
10
Makefile.am
@ -2,11 +2,11 @@ pkgconfigdir = $(libdir)/pkgconfig
|
|||||||
pkgconfig_DATA = libeditline.pc
|
pkgconfig_DATA = libeditline.pc
|
||||||
doc_DATA = README.md LICENSE
|
doc_DATA = README.md LICENSE
|
||||||
EXTRA_DIST = README.md LICENSE ChangeLog.md INSTALL.md
|
EXTRA_DIST = README.md LICENSE ChangeLog.md INSTALL.md
|
||||||
SUBDIRS = src include man
|
SUBDIRS = src include man examples
|
||||||
|
|
||||||
if ENABLE_EXAMPLES
|
## Generate .deb package
|
||||||
SUBDIRS += examples
|
package build-deb:
|
||||||
endif
|
@dpkg-buildpackage -uc -us
|
||||||
|
|
||||||
## Generate MD5 checksum file
|
## Generate MD5 checksum file
|
||||||
MD5 = md5sum
|
MD5 = md5sum
|
||||||
@ -39,7 +39,7 @@ package:
|
|||||||
dpkg-buildpackage -uc -us -B
|
dpkg-buildpackage -uc -us -B
|
||||||
|
|
||||||
## Target to run when building a release
|
## Target to run when building a release
|
||||||
release: release-hook distcheck md5-dist package
|
release: distcheck release-hook md5-dist package
|
||||||
@echo
|
@echo
|
||||||
@echo "Resulting release files:"
|
@echo "Resulting release files:"
|
||||||
@echo "========================================================================="
|
@echo "========================================================================="
|
||||||
|
@ -33,8 +33,6 @@ to use the library is available in the `examples/` directory.
|
|||||||
|
|
||||||
Editline is maintained collaboratively at [GitHub][].
|
Editline is maintained collaboratively at [GitHub][].
|
||||||
|
|
||||||
> **Note:** Windows is not a supported target for editline.
|
|
||||||
|
|
||||||
|
|
||||||
Example
|
Example
|
||||||
-------
|
-------
|
||||||
@ -58,7 +56,6 @@ sub-directory.
|
|||||||
e.g. `~/src/example.c`
|
e.g. `~/src/example.c`
|
||||||
|
|
||||||
```C
|
```C
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <editline.h>
|
#include <editline.h>
|
||||||
|
|
||||||
@ -198,7 +195,6 @@ current maintainer works exclusively on GNU/Linux systems, so it may use
|
|||||||
GCC and GNU Make specific extensions here and there. This is not on
|
GCC and GNU Make specific extensions here and there. This is not on
|
||||||
purpose and patches or pull requests to correct this are most welcome!
|
purpose and patches or pull requests to correct this are most welcome!
|
||||||
|
|
||||||
0. Call <kbd>./autogen.sh</kbd> if you build from git
|
|
||||||
1. Configure editline with default features: <kbd>./configure</kbd>
|
1. Configure editline with default features: <kbd>./configure</kbd>
|
||||||
2. Build the library and examples: <kbd>make all</kbd>
|
2. Build the library and examples: <kbd>make all</kbd>
|
||||||
3. Install using <kbd>make install</kbd>
|
3. Install using <kbd>make install</kbd>
|
||||||
|
39
configure.ac
39
configure.ac
@ -1,6 +1,5 @@
|
|||||||
AC_INIT(editline, 1.17.1, https://github.com/troglobit/editline/issues)
|
AC_INIT(editline, 1.16.1, https://github.com/troglobit/editline/issues)
|
||||||
AC_CONFIG_AUX_DIR(aux)
|
AM_INIT_AUTOMAKE([1.11 foreign no-dist-gzip dist-xz])
|
||||||
AM_INIT_AUTOMAKE([1.11 foreign dist-xz])
|
|
||||||
AM_SILENT_RULES([yes])
|
AM_SILENT_RULES([yes])
|
||||||
|
|
||||||
AC_CONFIG_MACRO_DIR([m4])
|
AC_CONFIG_MACRO_DIR([m4])
|
||||||
@ -61,35 +60,29 @@ AC_ARG_ENABLE(terminal-bell,
|
|||||||
AC_ARG_ENABLE(termcap,
|
AC_ARG_ENABLE(termcap,
|
||||||
AS_HELP_STRING([--enable-termcap], [Use termcap library to query terminal size.]))
|
AS_HELP_STRING([--enable-termcap], [Use termcap library to query terminal size.]))
|
||||||
|
|
||||||
AC_ARG_ENABLE([examples],
|
|
||||||
[AC_HELP_STRING([--enable-examples], [Build examples/ directory])],
|
|
||||||
[], [enable_examples=no])
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Check what features have been enabled
|
# Check what features have been enabled
|
||||||
#
|
#
|
||||||
AS_IF([test "x$enable_unique_history" != "xno"], [
|
AS_IF([test "x$enable_unique_history" != "xno"],
|
||||||
AC_DEFINE(CONFIG_UNIQUE_HISTORY, 1, [Define to skip duplicate lines in the scrollback history.])])
|
AC_DEFINE(CONFIG_UNIQUE_HISTORY, 1, [Define to skip duplicate lines in the scrollback history.]))
|
||||||
|
|
||||||
AS_IF([test "x$enable_terminal_bell" != "xno"], [
|
AS_IF([test "x$enable_terminal_bell" != "xno"],
|
||||||
AC_DEFINE(CONFIG_ANSI_ARROWS, 1, [Define to include ANSI arrow keys support.])])
|
AC_DEFINE(CONFIG_ANSI_ARROWS, 1, [Define to include ANSI arrow keys support.]))
|
||||||
|
|
||||||
AS_IF([test "x$enable_eof" != "xno"], [
|
AS_IF([test "x$enable_eof" != "xno"],
|
||||||
AC_DEFINE(CONFIG_EOF, 1, [Define to enable EOF (Ctrl-D) key.])])
|
AC_DEFINE(CONFIG_EOF, 1, [Define to enable EOF (Ctrl-D) key.]))
|
||||||
|
|
||||||
AS_IF([test "x$enable_sigint" != "xno"], [
|
AS_IF([test "x$enable_sigint" != "xno"],
|
||||||
AC_DEFINE(CONFIG_SIGINT, 1, [Define to enable SIGINT (Ctrl-C) key.])])
|
AC_DEFINE(CONFIG_SIGINT, 1, [Define to enable SIGINT (Ctrl-C) key.]))
|
||||||
|
|
||||||
AS_IF([test "x$enable_sigstop" = "xyes"], [
|
AS_IF([test "x$enable_sigstop" = "xyes"],
|
||||||
AC_DEFINE(CONFIG_SIGSTOP, 1, [Define to enable SIGSTOP (Ctrl-Z) key.])])
|
AC_DEFINE(CONFIG_SIGSTOP, 1, [Define to enable SIGSTOP (Ctrl-Z) key.]))
|
||||||
|
|
||||||
AS_IF([test "x$enable_terminal_bell" = "xyes"], [
|
AS_IF([test "x$enable_terminal_bell" = "xyes"],
|
||||||
AC_DEFINE(CONFIG_TERMINAL_BELL, 1, [Define to enable terminal bell on completion.])])
|
AC_DEFINE(CONFIG_TERMINAL_BELL, 1, [Define to enable terminal bell on completion.]))
|
||||||
|
|
||||||
AM_CONDITIONAL([ENABLE_EXAMPLES], [test "$enable_examples" = yes])
|
|
||||||
|
|
||||||
# Check for a termcap compatible library if enabled
|
# Check for a termcap compatible library if enabled
|
||||||
AS_IF([test "x$enable_termcap" = "xyes"], [
|
AS_IF([test "x$enable_termcap" = "xyes"],
|
||||||
AC_DEFINE(CONFIG_USE_TERMCAP, 1, [Define to use the termcap library for terminal size.])
|
AC_DEFINE(CONFIG_USE_TERMCAP, 1, [Define to use the termcap library for terminal size.])
|
||||||
AC_CHECK_LIB(terminfo, tgetent, , [
|
AC_CHECK_LIB(terminfo, tgetent, , [
|
||||||
AC_CHECK_LIB(termcap, tgetent, , [
|
AC_CHECK_LIB(termcap, tgetent, , [
|
||||||
@ -100,7 +93,7 @@ AS_IF([test "x$enable_termcap" = "xyes"], [
|
|||||||
])
|
])
|
||||||
])
|
])
|
||||||
])
|
])
|
||||||
])])
|
]))
|
||||||
|
|
||||||
# Generate all files
|
# Generate all files
|
||||||
AC_OUTPUT
|
AC_OUTPUT
|
||||||
|
17
debian/changelog
vendored
17
debian/changelog
vendored
@ -1,20 +1,3 @@
|
|||||||
editline (1.17.1) stable; urgency=medium
|
|
||||||
|
|
||||||
* Fix multiline representing as one line
|
|
||||||
* Fix missing content in libedtline1, introduced in 1.16.0
|
|
||||||
* Update packaging to latest std version
|
|
||||||
|
|
||||||
-- Joachim Nilsson <troglobit@gmail.com> Sun, 23 Feb 2020 18:46:41 +0100
|
|
||||||
|
|
||||||
editline (1.17.0) unstable; urgency=medium
|
|
||||||
|
|
||||||
* Simple multi-line support
|
|
||||||
* Handle internal realloc() errors better
|
|
||||||
* Fix return value from read_history() and write_history()
|
|
||||||
* Fix potential NULL pointer dereference in key binging lookup
|
|
||||||
|
|
||||||
-- Joachim Nilsson <troglobit@gmail.com> Sun, 05 Jan 2020 09:47:34 +0100
|
|
||||||
|
|
||||||
editline (1.16.1) unstable; urgency=medium
|
editline (1.16.1) unstable; urgency=medium
|
||||||
|
|
||||||
* Minor bug fix and documentation update release.
|
* Minor bug fix and documentation update release.
|
||||||
|
2
debian/compat
vendored
2
debian/compat
vendored
@ -1 +1 @@
|
|||||||
10
|
9
|
||||||
|
8
debian/control
vendored
8
debian/control
vendored
@ -1,9 +1,9 @@
|
|||||||
Source: editline
|
Source: editline
|
||||||
Section: devel
|
Section: devel
|
||||||
Priority: optional
|
Priority: optional
|
||||||
Build-Depends: debhelper (>= 10), libtool
|
Build-Depends: debhelper (>= 5.0), libtool
|
||||||
Maintainer: Joachim Wiberg <troglobit@gmail.com>
|
Maintainer: Joachim Nilsson <troglobit@gmail.com>
|
||||||
Standards-Version: 4.3.0
|
Standards-Version: 3.8.3
|
||||||
|
|
||||||
Package: libeditline-dev
|
Package: libeditline-dev
|
||||||
Architecture: any
|
Architecture: any
|
||||||
@ -21,7 +21,7 @@ Description: development files for libeditline
|
|||||||
Package: libeditline1
|
Package: libeditline1
|
||||||
Architecture: any
|
Architecture: any
|
||||||
Section: libs
|
Section: libs
|
||||||
Depends: ${shlibs:Depends}, ${misc:Depends}
|
Depends: ${misc:Depends}
|
||||||
Description: line editing library similar to readline
|
Description: line editing library similar to readline
|
||||||
This is a line-editing library. It can be linked into almost any program
|
This is a line-editing library. It can be linked into almost any program
|
||||||
to provide command-line editing and recall. It is call-compatible with a
|
to provide command-line editing and recall. It is call-compatible with a
|
||||||
|
25
debian/copyright
vendored
25
debian/copyright
vendored
@ -1,23 +1,17 @@
|
|||||||
Format: http://www.debian.org/doc/packaging-manuals/copyright-format/1.0/
|
This package was debianized by Jim Studt <jim@federated.com> on
|
||||||
Upstream-Name: editline
|
Fri, 5 May 2000 13:25:51 -0500.
|
||||||
Upstream-Contact: Joachim Wiberg <troglobit@gmail.com>
|
|
||||||
Source: http://github.com/troglobit/editline
|
|
||||||
Comment: This package was originally debianized by Jim Studt <jim@federated.com>
|
|
||||||
on Fri, 5 May 2000 13:25:51 -0500. It was received from, then upstream
|
|
||||||
author, Rich Salz <rsalz@shore.net>
|
|
||||||
|
|
||||||
Files: *
|
It was received from Rich Salz rsalz@shore.net
|
||||||
Copyright: 1992,1993 Simmule Turner and Rich Salz.
|
|
||||||
License: C-News
|
|
||||||
|
|
||||||
Files: debian/*
|
Upstream Author: Rich Salz rsalz@shore.net
|
||||||
Copyright: 2010-2020 Joachim Wiberg <troglobit@gmail.com>
|
|
||||||
License: BSD-2-clause
|
Copyright:
|
||||||
|
|
||||||
|
Copyright 1992,1993 Simmule Turner and Rich Salz. All rights reserved.
|
||||||
|
|
||||||
License: C-News
|
|
||||||
This software is not subject to any license of the American Telephone
|
This software is not subject to any license of the American Telephone
|
||||||
and Telegraph Company or of the Regents of the University of California.
|
and Telegraph Company or of the Regents of the University of California.
|
||||||
.
|
|
||||||
Permission is granted to anyone to use this software for any purpose on
|
Permission is granted to anyone to use this software for any purpose on
|
||||||
any computer system, and to alter it and redistribute it freely, subject
|
any computer system, and to alter it and redistribute it freely, subject
|
||||||
to the following restrictions:
|
to the following restrictions:
|
||||||
@ -30,3 +24,4 @@ License: C-News
|
|||||||
misrepresented as being the original software. Since few users
|
misrepresented as being the original software. Since few users
|
||||||
ever read sources, credits must appear in the documentation.
|
ever read sources, credits must appear in the documentation.
|
||||||
4. This notice may not be removed or altered.
|
4. This notice may not be removed or altered.
|
||||||
|
|
||||||
|
1
debian/libeditline-dev.install
vendored
1
debian/libeditline-dev.install
vendored
@ -1,5 +1,4 @@
|
|||||||
usr/include/*.h
|
usr/include/*.h
|
||||||
usr/lib/*/libeditline*.*a
|
usr/lib/*/libeditline*.*a
|
||||||
usr/lib/*/libeditline.so
|
|
||||||
usr/lib/*/pkgconfig/*
|
usr/lib/*/pkgconfig/*
|
||||||
usr/share/man/man3/*
|
usr/share/man/man3/*
|
||||||
|
1
debian/libeditline0.install
vendored
Normal file
1
debian/libeditline0.install
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
usr/lib/*/libeditline*.so*
|
1
debian/libeditline1.install
vendored
1
debian/libeditline1.install
vendored
@ -1 +0,0 @@
|
|||||||
usr/lib/*/libeditline.so.*
|
|
67
debian/libeditline1.symbols
vendored
67
debian/libeditline1.symbols
vendored
@ -1,67 +0,0 @@
|
|||||||
libeditline.so.1 libeditline1 #MINVER#
|
|
||||||
* Build-Depends-Package: libeditline-dev
|
|
||||||
add_history@Base 1.17.1
|
|
||||||
el_bind_key@Base 1.17.1
|
|
||||||
el_bind_key_in_metamap@Base 1.17.1
|
|
||||||
el_del_char@Base 1.17.1
|
|
||||||
el_filename_complete@Base 1.17.1
|
|
||||||
el_filename_list_possib@Base 1.17.1
|
|
||||||
el_find_word@Base 1.17.1
|
|
||||||
el_hist_size@Base 1.17.1
|
|
||||||
el_next_hist@Base 1.17.1
|
|
||||||
el_no_echo@Base 1.17.1
|
|
||||||
el_no_hist@Base 1.17.1
|
|
||||||
el_prev_hist@Base 1.17.1
|
|
||||||
el_print_columns@Base 1.17.1
|
|
||||||
el_ring_bell@Base 1.17.1
|
|
||||||
prompt_len@Base 1.17.1
|
|
||||||
read_history@Base 1.17.1
|
|
||||||
readline@Base 1.17.1
|
|
||||||
rl_add_slash@Base 1.17.1
|
|
||||||
rl_attempted_completion_function@Base 1.17.1
|
|
||||||
rl_attempted_completion_over@Base 1.17.1
|
|
||||||
rl_callback_handler_install@Base 1.17.1
|
|
||||||
rl_callback_handler_remove@Base 1.17.1
|
|
||||||
rl_callback_read_char@Base 1.17.1
|
|
||||||
rl_clear_message@Base 1.17.1
|
|
||||||
rl_complete@Base 1.17.1
|
|
||||||
rl_completion_entry_function@Base 1.17.1
|
|
||||||
rl_completion_matches@Base 1.17.1
|
|
||||||
rl_deprep_term_function@Base 1.17.1
|
|
||||||
rl_deprep_terminal@Base 1.17.1
|
|
||||||
rl_end@Base 1.17.1
|
|
||||||
rl_eof@Base 1.17.1
|
|
||||||
rl_erase@Base 1.17.1
|
|
||||||
rl_event_hook@Base 1.17.1
|
|
||||||
rl_filename_completion_function@Base 1.17.1
|
|
||||||
rl_forced_update_display@Base 1.17.1
|
|
||||||
rl_getc@Base 1.17.1
|
|
||||||
rl_getc_function@Base 1.17.1
|
|
||||||
rl_inhibit_complete@Base 1.17.1
|
|
||||||
rl_initialize@Base 1.17.1
|
|
||||||
rl_insert_text@Base 1.17.1
|
|
||||||
rl_instream@Base 1.17.1
|
|
||||||
rl_intr@Base 1.17.1
|
|
||||||
rl_kill@Base 1.17.1
|
|
||||||
rl_line_buffer@Base 1.17.1
|
|
||||||
rl_list_possib@Base 1.17.1
|
|
||||||
rl_mark@Base 1.17.1
|
|
||||||
rl_meta_chars@Base 1.17.1
|
|
||||||
rl_outstream@Base 1.17.1
|
|
||||||
rl_point@Base 1.17.1
|
|
||||||
rl_prep_term_function@Base 1.17.1
|
|
||||||
rl_prep_terminal@Base 1.17.1
|
|
||||||
rl_prompt@Base 1.17.1
|
|
||||||
rl_quit@Base 1.17.1
|
|
||||||
rl_readline_name@Base 1.17.1
|
|
||||||
rl_refresh_line@Base 1.17.1
|
|
||||||
rl_reset_terminal@Base 1.17.1
|
|
||||||
rl_restore_prompt@Base 1.17.1
|
|
||||||
rl_save_prompt@Base 1.17.1
|
|
||||||
rl_set_complete_func@Base 1.17.1
|
|
||||||
rl_set_getc_func@Base 1.17.1
|
|
||||||
rl_set_list_possib_func@Base 1.17.1
|
|
||||||
rl_set_prompt@Base 1.17.1
|
|
||||||
rl_ttyset@Base 1.17.1
|
|
||||||
rl_uninitialize@Base 1.17.1
|
|
||||||
write_history@Base 1.17.1
|
|
12
debian/rules
vendored
12
debian/rules
vendored
@ -1,16 +1,8 @@
|
|||||||
#!/usr/bin/make -f
|
#!/usr/bin/make -f
|
||||||
# export DH_VERBOSE=1
|
|
||||||
export DEB_BUILD_MAINT_OPTIONS = hardening=+all
|
|
||||||
export DEB_CFLAGS_MAINT_APPEND = -W -Wall -Wextra -O3
|
|
||||||
export DEB_LDFLAGS_MAINT_APPEND = -Wl,--as-needed
|
|
||||||
|
|
||||||
NUMJOBS = $(patsubst parallel=%,%,$(filter parallel=%,$(DEB_BUILD_OPTIONS)))
|
# Uncomment this to turn on verbose mode.
|
||||||
|
#export DH_VERBOSE=1
|
||||||
include /usr/share/dpkg/default.mk # provides DEB_VERSION
|
|
||||||
|
|
||||||
%:
|
%:
|
||||||
dh $@ --with autoreconf
|
dh $@ --with autoreconf
|
||||||
|
|
||||||
override_dh_installchangelogs:
|
|
||||||
dh_installchangelogs ChangeLog.md
|
|
||||||
|
|
||||||
|
@ -38,9 +38,9 @@ static char *my_rl_complete(char *token, int *match)
|
|||||||
int count = 0;
|
int count = 0;
|
||||||
|
|
||||||
for (i = 0; list[i]; i++) {
|
for (i = 0; list[i]; i++) {
|
||||||
int partlen = strlen(token); /* Part of token */
|
int partlen = strlen (token); /* Part of token */
|
||||||
|
|
||||||
if (!strncmp(list[i], token, partlen)) {
|
if (!strncmp (list[i], token, partlen)) {
|
||||||
index = i;
|
index = i;
|
||||||
matchlen = partlen;
|
matchlen = partlen;
|
||||||
count ++;
|
count ++;
|
||||||
@ -49,7 +49,7 @@ static char *my_rl_complete(char *token, int *match)
|
|||||||
|
|
||||||
if (count == 1) {
|
if (count == 1) {
|
||||||
*match = 1;
|
*match = 1;
|
||||||
return strdup(list[index] + matchlen);
|
return strdup (list[index] + matchlen);
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -64,14 +64,11 @@ static int my_rl_list_possib(char *token, char ***av)
|
|||||||
for (num = 0; list[num]; num++)
|
for (num = 0; list[num]; num++)
|
||||||
;
|
;
|
||||||
|
|
||||||
if (!num)
|
copy = (char **) malloc (num * sizeof(char *));
|
||||||
return 0;
|
|
||||||
|
|
||||||
copy = malloc(num * sizeof(char *));
|
|
||||||
for (i = 0; i < num; i++) {
|
for (i = 0; i < num; i++) {
|
||||||
if (!strncmp(list[i], token, strlen (token))) {
|
if (!strncmp (list[i], token, strlen (token))) {
|
||||||
copy[total] = strdup(list[i]);
|
copy[total] = strdup (list[i]);
|
||||||
total++;
|
total ++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
*av = copy;
|
*av = copy;
|
||||||
@ -109,41 +106,14 @@ el_status_t do_suspend(void)
|
|||||||
|
|
||||||
static void breakit(int signo)
|
static void breakit(int signo)
|
||||||
{
|
{
|
||||||
(void)signo;
|
|
||||||
puts("Got SIGINT");
|
puts("Got SIGINT");
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Use el_no_echo when reading passwords and similar */
|
|
||||||
static int unlock(const char *passwd)
|
|
||||||
{
|
|
||||||
char *prompt = "Enter password: ";
|
|
||||||
char *line;
|
|
||||||
int rc = 1;
|
|
||||||
|
|
||||||
el_no_echo = 1;
|
|
||||||
|
|
||||||
while ((line = readline(prompt))) {
|
|
||||||
rc = strncmp(line, passwd, strlen(passwd));
|
|
||||||
free(line);
|
|
||||||
|
|
||||||
if (rc) {
|
|
||||||
printf("\nWrong password, please try again, it's secret.\n");
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
printf("\nAchievement unlocked!\n");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
el_no_echo = 0;
|
|
||||||
|
|
||||||
return rc;
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(void)
|
int main(void)
|
||||||
{
|
{
|
||||||
char *line;
|
char *line;
|
||||||
char *prompt = "cli> ";
|
char *prompt = "cli> ";
|
||||||
|
char *passwd = "Enter password: ";
|
||||||
|
|
||||||
signal(SIGINT, breakit);
|
signal(SIGINT, breakit);
|
||||||
|
|
||||||
@ -156,12 +126,30 @@ int main(void)
|
|||||||
read_history(HISTORY);
|
read_history(HISTORY);
|
||||||
|
|
||||||
while ((line = readline(prompt))) {
|
while ((line = readline(prompt))) {
|
||||||
if (!strncmp(line, "unlock", 6) && unlock("secret")) {
|
int next = 0;
|
||||||
free(line);
|
|
||||||
fprintf(stderr, "\nSecurity breach, user logged out!\n");
|
/* Use el_no_echo when reading passwords and similar */
|
||||||
break;
|
if (!strncmp(line, "unlock", 6)) {
|
||||||
|
el_no_echo = 1;
|
||||||
|
while ((line = readline(passwd))) {
|
||||||
|
if (strncmp(line, "secret", 6)) {
|
||||||
|
printf("\nWrong password, please try again, it's secret.\n");
|
||||||
|
free(line);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
el_no_echo = 0;
|
||||||
|
|
||||||
|
printf("\nAchievement unlocked!\n");
|
||||||
|
free(line);
|
||||||
|
next = 1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (next)
|
||||||
|
continue;
|
||||||
|
|
||||||
if (*line != '\0')
|
if (*line != '\0')
|
||||||
printf("\t\t\t|%s|\n", line);
|
printf("\t\t\t|%s|\n", line);
|
||||||
free(line);
|
free(line);
|
||||||
|
@ -39,7 +39,6 @@ Jeff
|
|||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/select.h>
|
|
||||||
|
|
||||||
#ifdef HAVE_STDLIB_H
|
#ifdef HAVE_STDLIB_H
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
@ -7,7 +7,6 @@
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <assert.h>
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/file.h>
|
#include <sys/file.h>
|
||||||
@ -23,7 +22,7 @@
|
|||||||
#include "editline.h"
|
#include "editline.h"
|
||||||
|
|
||||||
void too_dangerous(char *caller);
|
void too_dangerous(char *caller);
|
||||||
void initialize_readline(const char *prompt);
|
void initialize_readline();
|
||||||
int execute_line(char *line);
|
int execute_line(char *line);
|
||||||
int valid_argument(char *caller, char *arg);
|
int valid_argument(char *caller, char *arg);
|
||||||
|
|
||||||
@ -62,15 +61,8 @@ struct cmd commands[] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/* Forward declarations. */
|
/* Forward declarations. */
|
||||||
char *stripwhite(char *string);
|
char *stripwhite();
|
||||||
struct cmd *find_command(char *name);
|
struct cmd *find_command();
|
||||||
|
|
||||||
/* ~/.fileman_history */
|
|
||||||
char *fileman_history;
|
|
||||||
|
|
||||||
/* Prompt base and current */
|
|
||||||
const char *prompt_init;
|
|
||||||
char *prompt_curr;
|
|
||||||
|
|
||||||
/* When non-zero, this means the user is done using this program. */
|
/* When non-zero, this means the user is done using this program. */
|
||||||
int done;
|
int done;
|
||||||
@ -80,11 +72,12 @@ int main(int argc, char **argv)
|
|||||||
char *line, *s;
|
char *line, *s;
|
||||||
|
|
||||||
setlocale(LC_CTYPE, "");
|
setlocale(LC_CTYPE, "");
|
||||||
initialize_readline("(FileMan)");
|
|
||||||
|
initialize_readline(); /* Bind our completer. */
|
||||||
|
|
||||||
/* Loop reading and executing lines until the user quits. */
|
/* Loop reading and executing lines until the user quits. */
|
||||||
for (; done == 0;) {
|
for (; done == 0;) {
|
||||||
line = readline(NULL);
|
line = readline("FileMan: ");
|
||||||
|
|
||||||
if (!line)
|
if (!line)
|
||||||
break;
|
break;
|
||||||
@ -114,10 +107,6 @@ int main(int argc, char **argv)
|
|||||||
free(line);
|
free(line);
|
||||||
}
|
}
|
||||||
|
|
||||||
puts("");
|
|
||||||
write_history(fileman_history);
|
|
||||||
free(fileman_history);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -199,58 +188,19 @@ char *stripwhite(char *string)
|
|||||||
|
|
||||||
char *command_generator(const char *, int);
|
char *command_generator(const char *, int);
|
||||||
char **fileman_completion(const char *, int, int);
|
char **fileman_completion(const char *, int, int);
|
||||||
void fileman_prompt(void);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Tell the GNU Readline library how to complete. We want to try to
|
* Tell the GNU Readline library how to complete. We want to try to
|
||||||
* complete on command names if this is the first word in the line, or
|
* complete on command names if this is the first word in the line, or
|
||||||
* on filenames if not.
|
* on filenames if not.
|
||||||
*/
|
*/
|
||||||
void initialize_readline(const char *prompt)
|
void initialize_readline(void)
|
||||||
{
|
{
|
||||||
const char *home;
|
|
||||||
size_t len;
|
|
||||||
|
|
||||||
/* Allow conditional parsing of the ~/.inputrc file. */
|
/* Allow conditional parsing of the ~/.inputrc file. */
|
||||||
rl_readline_name = "FileMan";
|
rl_readline_name = "FileMan";
|
||||||
|
|
||||||
/* Tell the completer that we want a crack first. */
|
/* Tell the completer that we want a crack first. */
|
||||||
rl_attempted_completion_function = fileman_completion;
|
rl_attempted_completion_function = fileman_completion;
|
||||||
|
|
||||||
/* Restore command history */
|
|
||||||
home = getenv("HOME");
|
|
||||||
len = (home ? strlen(home) : 0) + 14;
|
|
||||||
fileman_history = malloc(len);
|
|
||||||
assert(fileman_history);
|
|
||||||
snprintf(fileman_history, len, "%s/.fileman_history", home ? home : ".");
|
|
||||||
|
|
||||||
read_history(fileman_history);
|
|
||||||
|
|
||||||
/* Prompt is updated when moving around in the tree */
|
|
||||||
prompt_init = prompt;
|
|
||||||
fileman_prompt();
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Update prompt when changing directory. Use an allocated string to
|
|
||||||
* show off the rl_set_prompt() API for issue #51.
|
|
||||||
*/
|
|
||||||
void fileman_prompt(void)
|
|
||||||
{
|
|
||||||
char cwd[1024];
|
|
||||||
size_t len;
|
|
||||||
|
|
||||||
if (prompt_curr)
|
|
||||||
free(prompt_curr);
|
|
||||||
|
|
||||||
assert(getcwd(cwd, sizeof(cwd)));
|
|
||||||
len = strlen(prompt_init) + strlen(cwd) + 10;
|
|
||||||
prompt_curr = malloc(len);
|
|
||||||
assert(prompt_curr);
|
|
||||||
|
|
||||||
snprintf(prompt_curr, len, "%s %s/> ", prompt_init, cwd);
|
|
||||||
|
|
||||||
rl_set_prompt(prompt_curr);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -427,8 +377,7 @@ int com_cd(char *arg)
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
//com_pwd("");
|
com_pwd("");
|
||||||
fileman_prompt();
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,8 +21,6 @@
|
|||||||
#ifndef EDITLINE_H_
|
#ifndef EDITLINE_H_
|
||||||
#define EDITLINE_H_
|
#define EDITLINE_H_
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
/* Handy macros when binding keys. */
|
/* Handy macros when binding keys. */
|
||||||
#define CTL(x) ((x) & 0x1F)
|
#define CTL(x) ((x) & 0x1F)
|
||||||
#define ISCTL(x) ((x) && (x) < ' ')
|
#define ISCTL(x) ((x) && (x) < ' ')
|
||||||
@ -84,7 +82,6 @@ extern int rl_point;
|
|||||||
extern int rl_mark;
|
extern int rl_mark;
|
||||||
extern int rl_end;
|
extern int rl_end;
|
||||||
extern int rl_inhibit_complete;
|
extern int rl_inhibit_complete;
|
||||||
extern int rl_attempted_completion_over;
|
|
||||||
extern char *rl_line_buffer;
|
extern char *rl_line_buffer;
|
||||||
extern const char *rl_readline_name;
|
extern const char *rl_readline_name;
|
||||||
extern FILE *rl_instream; /* The stdio stream from which input is read. Defaults to stdin if NULL - Not supported yet! */
|
extern FILE *rl_instream; /* The stdio stream from which input is read. Defaults to stdin if NULL - Not supported yet! */
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
.Dd February 23, 2020
|
.Dd April 27, 2019
|
||||||
.Dt EDITLINE 3
|
.Dt EDITLINE 3
|
||||||
.Os
|
.Os
|
||||||
.Sh NAME
|
.Sh NAME
|
||||||
@ -8,22 +8,10 @@
|
|||||||
.Lb libeditline
|
.Lb libeditline
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In editline.h
|
.In editline.h
|
||||||
.Ft char *
|
.Fn "char *readline" "const char *prompt"
|
||||||
.Fo readline
|
.Fn "void add_history" "const char *line"
|
||||||
.Fa const char *prompt
|
.Fn "int read_history" "const char *filename"
|
||||||
.Fc
|
.Fn "int write_history" "const char *filename"
|
||||||
.Ft void
|
|
||||||
.Fo add_history
|
|
||||||
.Fa const char *line
|
|
||||||
.Fc
|
|
||||||
.Ft int
|
|
||||||
.Fo read_history
|
|
||||||
.Fa const char *filename
|
|
||||||
.Fc
|
|
||||||
.Ft int
|
|
||||||
.Fo write_history
|
|
||||||
.Fa const char *filename
|
|
||||||
.Fc
|
|
||||||
.Sh DESCRIPTION
|
.Sh DESCRIPTION
|
||||||
.Nm
|
.Nm
|
||||||
is a library that provides n line-editing interface with history. It
|
is a library that provides n line-editing interface with history. It
|
||||||
@ -275,13 +263,12 @@ int main(void)
|
|||||||
The original editline library was posted to comp.sources.unix newsgroup
|
The original editline library was posted to comp.sources.unix newsgroup
|
||||||
by created by Simmule R. Turner and Rich Salz in 1992. It now exists in
|
by created by Simmule R. Turner and Rich Salz in 1992. It now exists in
|
||||||
several forks: Debian, Minix, Heimdal, Festival speech tools, Mozilla,
|
several forks: Debian, Minix, Heimdal, Festival speech tools, Mozilla,
|
||||||
Google Gadgets for Linux, and many others. The original manual page was
|
Google Gadgets for Linux, and many other places. The original manual
|
||||||
made by David W. Sanderson.
|
page was made by David W. Sanderson.
|
||||||
.Pp
|
.Pp
|
||||||
This version stems from the Minix 2 sources, but has since evolved to
|
This version was originally based on the Minix 2 sources, but has since
|
||||||
include patches from all relevant forks. It is currently maintained by
|
evolved to include patches from all relevant forks. It is currently
|
||||||
.An Joachim Wiberg
|
maintained by Joachim Nilsson at GitHub,
|
||||||
at
|
.Aq http://github.com/troglobit/editline
|
||||||
.Lk https://github.com/troglobit/editline "GitHub" .
|
|
||||||
.Sh BUGS
|
.Sh BUGS
|
||||||
Does not handle multiple lines or unicode characters well.
|
Does not handle multiple lines or unicode characters well.
|
||||||
|
@ -3,4 +3,4 @@ libeditline_la_SOURCES = editline.c editline.h complete.c sysunix.c unix.h
|
|||||||
libeditline_la_CFLAGS = -std=gnu99
|
libeditline_la_CFLAGS = -std=gnu99
|
||||||
libeditline_la_CFLAGS += -W -Wall -Wextra -Wundef -Wunused -Wstrict-prototypes
|
libeditline_la_CFLAGS += -W -Wall -Wextra -Wundef -Wunused -Wstrict-prototypes
|
||||||
libeditline_la_CFLAGS += -Werror-implicit-function-declaration -Wshadow -Wcast-qual
|
libeditline_la_CFLAGS += -Werror-implicit-function-declaration -Wshadow -Wcast-qual
|
||||||
libeditline_la_LDFLAGS = $(AM_LDFLAGS) -version-info 1:2:0
|
libeditline_la_LDFLAGS = $(AM_LDFLAGS) -version-info 1:1:0
|
||||||
|
@ -40,7 +40,7 @@ static int compare(const void *p1, const void *p2)
|
|||||||
|
|
||||||
/* Fill in *avp with an array of names that match file, up to its length.
|
/* Fill in *avp with an array of names that match file, up to its length.
|
||||||
* Ignore . and .. . */
|
* Ignore . and .. . */
|
||||||
static int FindMatches(const char *dir, const char *file, char ***avp)
|
static int FindMatches(char *dir, char *file, char ***avp)
|
||||||
{
|
{
|
||||||
char **av;
|
char **av;
|
||||||
char **word;
|
char **word;
|
||||||
@ -128,7 +128,7 @@ static int FindMatches(const char *dir, const char *file, char ***avp)
|
|||||||
/* Split a pathname into allocated directory and trailing filename parts. */
|
/* Split a pathname into allocated directory and trailing filename parts. */
|
||||||
static int SplitPath(const char *path, char **dirpart, char **filepart)
|
static int SplitPath(const char *path, char **dirpart, char **filepart)
|
||||||
{
|
{
|
||||||
static const char DOT[] = ".";
|
static char DOT[] = ".";
|
||||||
char *dpart;
|
char *dpart;
|
||||||
char *fpart;
|
char *fpart;
|
||||||
|
|
||||||
@ -197,14 +197,14 @@ char *el_filename_complete(char *pathname, int *match)
|
|||||||
if (ac == 1) {
|
if (ac == 1) {
|
||||||
/* Exactly one match -- finish it off. */
|
/* Exactly one match -- finish it off. */
|
||||||
*match = 1;
|
*match = 1;
|
||||||
j = strlen(av[0]) - len + 1;
|
j = strlen(av[0]) - len + 2;
|
||||||
p = malloc(sizeof(char) * (j + 1));
|
p = malloc(sizeof(char) * (j + 1));
|
||||||
if (p) {
|
if (p) {
|
||||||
memcpy(p, av[0] + len, j);
|
memcpy(p, av[0] + len, j);
|
||||||
len = strlen(dir) + strlen(av[0]) + 2;
|
len = strlen(dir) + strlen(av[0]) + 2;
|
||||||
path = malloc(sizeof(char) * len);
|
path = malloc(sizeof(char) * len);
|
||||||
if (path) {
|
if (path) {
|
||||||
snprintf(path, len, "%s/%s", dir, av[0]);
|
snprintf(path, len, "%s/%s", dir, av[0]);
|
||||||
rl_add_slash(path, p);
|
rl_add_slash(path, p);
|
||||||
free(path);
|
free(path);
|
||||||
}
|
}
|
||||||
@ -243,7 +243,9 @@ char *el_filename_complete(char *pathname, int *match)
|
|||||||
|
|
||||||
char *rl_filename_completion_function(const char *text, int state)
|
char *rl_filename_completion_function(const char *text, int state)
|
||||||
{
|
{
|
||||||
static char **av, *dir, *file;
|
char *dir;
|
||||||
|
char *file;
|
||||||
|
static char **av;
|
||||||
static size_t i, ac;
|
static size_t i, ac;
|
||||||
|
|
||||||
if (!state) {
|
if (!state) {
|
||||||
@ -251,47 +253,32 @@ char *rl_filename_completion_function(const char *text, int state)
|
|||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
ac = FindMatches(dir, file, &av);
|
ac = FindMatches(dir, file, &av);
|
||||||
if (!ac) {
|
free(dir);
|
||||||
free(dir);
|
free(file);
|
||||||
free(file);
|
if (!ac)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
|
||||||
|
|
||||||
i = 0;
|
i = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (i < ac) {
|
if (i < ac)
|
||||||
size_t len = (dir ? strlen(dir) : 0) + strlen(av[i]) + 3;
|
return av[i++];
|
||||||
char *ptr = malloc(len);
|
|
||||||
|
|
||||||
if (ptr) {
|
|
||||||
snprintf(ptr, len, "%s%s", dir, av[i++]);
|
|
||||||
if (ac == 1)
|
|
||||||
rl_add_slash(ptr, ptr);
|
|
||||||
|
|
||||||
return ptr;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
do {
|
do {
|
||||||
free(av[--i]);
|
free(av[--i]);
|
||||||
} while (i > 0);
|
} while (i > 0);
|
||||||
|
|
||||||
free(av);
|
|
||||||
free(dir);
|
|
||||||
free(file);
|
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Similar to el_find_word(), but used by GNU Readline API */
|
/* Similar to el_find_word(), but used by GNU Readline API */
|
||||||
static char *rl_find_token(size_t *len)
|
static char *rl_find_token(size_t *len)
|
||||||
{
|
{
|
||||||
const char *ptr;
|
char *ptr;
|
||||||
int pos;
|
int pos;
|
||||||
|
|
||||||
for (pos = rl_point; pos < rl_end; pos++) {
|
for (pos = rl_point; pos < rl_end; pos++) {
|
||||||
if (isspace((unsigned char) rl_line_buffer[pos])) {
|
if (isspace(rl_line_buffer[pos])) {
|
||||||
if (pos > 0)
|
if (pos > 0)
|
||||||
pos--;
|
pos--;
|
||||||
break;
|
break;
|
||||||
@ -299,7 +286,7 @@ static char *rl_find_token(size_t *len)
|
|||||||
}
|
}
|
||||||
|
|
||||||
ptr = &rl_line_buffer[pos];
|
ptr = &rl_line_buffer[pos];
|
||||||
while (pos >= 0 && !isspace((unsigned char) rl_line_buffer[pos])) {
|
while (pos >= 0 && !isspace(rl_line_buffer[pos])) {
|
||||||
if (pos == 0)
|
if (pos == 0)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -380,12 +367,8 @@ static char *complete(char *token, int *match)
|
|||||||
|
|
||||||
free(word);
|
free(word);
|
||||||
word = NULL;
|
word = NULL;
|
||||||
|
if (words[0])
|
||||||
/* Exactly one match -- finish it off. */
|
|
||||||
if (words[0] && !words[1]) {
|
|
||||||
*match = 1;
|
|
||||||
word = strdup(words[0] + len);
|
word = strdup(words[0] + len);
|
||||||
}
|
|
||||||
|
|
||||||
while (words[i])
|
while (words[i])
|
||||||
free(words[i++]);
|
free(words[i++]);
|
||||||
@ -395,9 +378,6 @@ static char *complete(char *token, int *match)
|
|||||||
return word;
|
return word;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (word)
|
|
||||||
free(word);
|
|
||||||
|
|
||||||
fallback:
|
fallback:
|
||||||
return el_filename_complete(token, match);
|
return el_filename_complete(token, match);
|
||||||
}
|
}
|
||||||
|
688
src/editline.c
688
src/editline.c
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user