summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFrank Terbeck <ft@bewatermyfriend.org>2016-05-01 03:12:56 +0200
committerFrank Terbeck <ft@bewatermyfriend.org>2016-05-01 04:08:19 +0200
commit857153c507ce0fc0d0e4180aad9896a5eaefc442 (patch)
tree8f21fc754cf88bbe998b3c33e3e81b6bc9b6fc0b
parent276a690a2ea7f9a4cf20748c955eea4dbe2f2d02 (diff)
downloadzsh-857153c507ce0fc0d0e4180aad9896a5eaefc442.tar.gz
zsh-857153c507ce0fc0d0e4180aad9896a5eaefc442.zip
38381: Add completion for picocom utility
-rw-r--r--ChangeLog5
-rw-r--r--Completion/Unix/Command/_picocom80
2 files changed, 85 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index 190646841..caebae18e 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2016-05-01 Frank Terbeck <ft@bewatermyfriend.org>
+
+ * 38381: Completion/Unix/Command/_picocom: Add completion for
+ picocom utility
+
2016-04-29 Barton E. Schaefer <schaefer@zsh.org>
* unposted: Src/builtin.c: silence spurious compiler warning
diff --git a/Completion/Unix/Command/_picocom b/Completion/Unix/Command/_picocom
new file mode 100644
index 000000000..6653bc2a5
--- /dev/null
+++ b/Completion/Unix/Command/_picocom
@@ -0,0 +1,80 @@
+#compdef picocom
+
+# The following function uses a generated list; first find out where the B*
+# macros are defined:
+#
+# grep -r B115200 /usr/include
+#
+# Then generate the actual list:
+#
+# sed -ne '/^[ \t]*#define[ \t]*B[0-9][0-9]*/s,^.*B\([0-9][0-9]*\).*,\1,p' \
+# < /usr/include/asm-generic/termbits.h
+#
+# This one was generated on a Debian Stretch system, leaving out the "0" rate,
+# which is synonymous to "hang-up".
+function _picocom_baudrate () {
+ local expl
+ local -a rates
+ rates=( 50 75 110 134 150 200 300 600
+ 1200 1800 2400 4800 9600
+ 19200 38400 57600
+ 115200 230400 460800 500000 576000 921600
+ 1000000 1152000 1500000 2000000 2500000 3000000 3500000 4000000 )
+ # -1V removes dupes (which there shouldn't be) and otherwise leaves the
+ # order in the $rates array intact.
+ _wanted -1V baud-rate expl 'baud rate' compadd -a $expl -- rates
+}
+
+function _picocom_flowcontrol () {
+ local expl
+ local -a modes
+ modes=( x h n )
+ _wanted flow-ctrl-mode expl 'flow control mode' compadd -a $expl -- modes
+}
+
+function _picocom_paritymode () {
+ local expl
+ local -a modes
+ modes=( o e n )
+ _wanted parity-mode expl 'parity mode' compadd -a $expl -- modes
+}
+
+function _picocom_databits () {
+ local expl
+ local -a widths
+ widths=( 5 6 7 8 )
+ _wanted data-bits expl 'data bits' compadd -a $expl -- widths
+}
+
+function _picocom_escape () {
+ setopt localoptions braceccl
+ local expl
+ local -a ctrlchars
+ ctrlchars=( {a-z} _ '?' '[' '\' ']' '@' '^' )
+ _wanted escape-key expl 'escape key' compadd -a $expl -- ctrlchars
+}
+
+function _picocom () {
+ local -a args
+
+ args=( '(--baud -b)'{--baud,-b}'[define baud-rate to set the terminal to]:baud rate:_picocom_baudrate'
+ '(--flow -f)'{--flow,-f}'[define type of flow control to use]:flow control:_picocom_flowcontrol'
+ '(--parity -p)'{--parity,-p}'[define type of parity to use]:parity mode:_picocom_paritymode'
+ '(--databits -d)'{--databits,-d}'[define the number of databits per word]:data bits:_picocom_databits'
+ '(--escape -e)'{--escape,-e}'[define command mode character]:escape character:_picocom_escape'
+ '(--echo -c)'{--echo,-c}'[enable local echo]'
+ '(--noinit -i)'{--noinit,-i}'[do not initialise serial port]'
+ '(--noreset -r)'{--noreset,-r}'[do not reset serial port]'
+ '(--nolock -l)'{--nolock,-l}'[do not lock serial port]'
+ '(--send-cmd -s)'{--send-cmd,-s}'[define file send command]:file send command:_cmdstring'
+ '(--receive-cmd -v)'{--receive-cmd,-v}'[define file receive command]:file receive command:_cmdstring'
+ '--imap[define input character map]:input character map:'
+ '--omap[define output character map]:output character map:'
+ '--emap[define local echo character map]:local echo character map:'
+ '(--help -h)'{--help,-h}'[display help message]'
+ '*:device:_files -g "*(%c)"' )
+
+ _arguments -C : "${args[@]}"
+}
+
+_picocom "$@"