jbarnette-johnson 1.0.0.200806240111 → 1.0.0.200807291507

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (269) hide show
  1. data/MANIFEST +1 -0
  2. data/Rakefile +3 -10
  3. data/bin/johnson +2 -1
  4. data/ext/spidermonkey/context.c +3 -4
  5. data/ext/spidermonkey/context.h +1 -1
  6. data/ext/spidermonkey/conversions.c +39 -33
  7. data/ext/spidermonkey/debugger.c +5 -5
  8. data/ext/spidermonkey/immutable_node.c.erb +11 -11
  9. data/ext/spidermonkey/jroot.h +4 -4
  10. data/ext/spidermonkey/js_land_proxy.c +9 -8
  11. data/ext/spidermonkey/ruby_land_proxy.c +5 -4
  12. data/ext/spidermonkey/runtime.c +1 -1
  13. data/johnson.gemspec +36 -0
  14. data/lib/hoe.rb +0 -7
  15. data/lib/johnson/cli/options.rb +10 -4
  16. data/lib/johnson/spidermonkey/runtime.rb +2 -2
  17. data/lib/johnson/version.rb +4 -2
  18. data/lib/johnson.rb +1 -0
  19. data/test/johnson/runtime_test.rb +11 -0
  20. data/test/johnson/spidermonkey/ruby_land_proxy_test.rb +6 -0
  21. data/vendor/spidermonkey/.cvsignore +9 -0
  22. data/vendor/spidermonkey/Makefile.in +462 -0
  23. data/vendor/spidermonkey/Makefile.ref +364 -0
  24. data/vendor/spidermonkey/README.html +820 -0
  25. data/vendor/spidermonkey/SpiderMonkey.rsp +12 -0
  26. data/vendor/spidermonkey/Y.js +19 -0
  27. data/vendor/spidermonkey/build.mk +43 -0
  28. data/vendor/spidermonkey/config/AIX4.1.mk +65 -0
  29. data/vendor/spidermonkey/config/AIX4.2.mk +64 -0
  30. data/vendor/spidermonkey/config/AIX4.3.mk +65 -0
  31. data/vendor/spidermonkey/config/Darwin.mk +83 -0
  32. data/vendor/spidermonkey/config/Darwin1.3.mk +81 -0
  33. data/vendor/spidermonkey/config/Darwin1.4.mk +41 -0
  34. data/vendor/spidermonkey/config/Darwin5.2.mk +81 -0
  35. data/vendor/spidermonkey/config/Darwin5.3.mk +81 -0
  36. data/vendor/spidermonkey/config/HP-UXB.10.10.mk +77 -0
  37. data/vendor/spidermonkey/config/HP-UXB.10.20.mk +77 -0
  38. data/vendor/spidermonkey/config/HP-UXB.11.00.mk +80 -0
  39. data/vendor/spidermonkey/config/IRIX.mk +87 -0
  40. data/vendor/spidermonkey/config/IRIX5.3.mk +44 -0
  41. data/vendor/spidermonkey/config/IRIX6.1.mk +44 -0
  42. data/vendor/spidermonkey/config/IRIX6.2.mk +44 -0
  43. data/vendor/spidermonkey/config/IRIX6.3.mk +44 -0
  44. data/vendor/spidermonkey/config/IRIX6.5.mk +44 -0
  45. data/vendor/spidermonkey/config/Linux_All.mk +103 -0
  46. data/vendor/spidermonkey/config/Mac_OS10.0.mk +82 -0
  47. data/vendor/spidermonkey/config/OSF1V4.0.mk +72 -0
  48. data/vendor/spidermonkey/config/OSF1V5.0.mk +69 -0
  49. data/vendor/spidermonkey/config/SunOS4.1.4.mk +101 -0
  50. data/vendor/spidermonkey/config/SunOS5.10.mk +50 -0
  51. data/vendor/spidermonkey/config/SunOS5.3.mk +91 -0
  52. data/vendor/spidermonkey/config/SunOS5.4.mk +92 -0
  53. data/vendor/spidermonkey/config/SunOS5.5.1.mk +44 -0
  54. data/vendor/spidermonkey/config/SunOS5.5.mk +87 -0
  55. data/vendor/spidermonkey/config/SunOS5.6.mk +89 -0
  56. data/vendor/spidermonkey/config/SunOS5.7.mk +44 -0
  57. data/vendor/spidermonkey/config/SunOS5.8.mk +44 -0
  58. data/vendor/spidermonkey/config/SunOS5.9.mk +44 -0
  59. data/vendor/spidermonkey/config/WINNT4.0.mk +117 -0
  60. data/vendor/spidermonkey/config/WINNT5.0.mk +117 -0
  61. data/vendor/spidermonkey/config/WINNT5.1.mk +117 -0
  62. data/vendor/spidermonkey/config/WINNT5.2.mk +117 -0
  63. data/vendor/spidermonkey/config/WINNT6.0.mk +117 -0
  64. data/vendor/spidermonkey/config/dgux.mk +64 -0
  65. data/vendor/spidermonkey/config.mk +192 -0
  66. data/vendor/spidermonkey/editline/Makefile.ref +144 -0
  67. data/vendor/spidermonkey/editline/README +83 -0
  68. data/vendor/spidermonkey/editline/editline.3 +175 -0
  69. data/vendor/spidermonkey/editline/editline.c +1369 -0
  70. data/vendor/spidermonkey/editline/editline.h +135 -0
  71. data/vendor/spidermonkey/editline/sysunix.c +182 -0
  72. data/vendor/spidermonkey/editline/unix.h +82 -0
  73. data/vendor/spidermonkey/fdlibm/.cvsignore +7 -0
  74. data/vendor/spidermonkey/fdlibm/Makefile.in +127 -0
  75. data/vendor/spidermonkey/fdlibm/Makefile.ref +192 -0
  76. data/vendor/spidermonkey/fdlibm/e_acos.c +147 -0
  77. data/vendor/spidermonkey/fdlibm/e_acosh.c +105 -0
  78. data/vendor/spidermonkey/fdlibm/e_asin.c +156 -0
  79. data/vendor/spidermonkey/fdlibm/e_atan2.c +165 -0
  80. data/vendor/spidermonkey/fdlibm/e_atanh.c +110 -0
  81. data/vendor/spidermonkey/fdlibm/e_cosh.c +133 -0
  82. data/vendor/spidermonkey/fdlibm/e_exp.c +202 -0
  83. data/vendor/spidermonkey/fdlibm/e_fmod.c +184 -0
  84. data/vendor/spidermonkey/fdlibm/e_gamma.c +71 -0
  85. data/vendor/spidermonkey/fdlibm/e_gamma_r.c +70 -0
  86. data/vendor/spidermonkey/fdlibm/e_hypot.c +173 -0
  87. data/vendor/spidermonkey/fdlibm/e_j0.c +524 -0
  88. data/vendor/spidermonkey/fdlibm/e_j1.c +523 -0
  89. data/vendor/spidermonkey/fdlibm/e_jn.c +315 -0
  90. data/vendor/spidermonkey/fdlibm/e_lgamma.c +71 -0
  91. data/vendor/spidermonkey/fdlibm/e_lgamma_r.c +347 -0
  92. data/vendor/spidermonkey/fdlibm/e_log.c +184 -0
  93. data/vendor/spidermonkey/fdlibm/e_log10.c +134 -0
  94. data/vendor/spidermonkey/fdlibm/e_pow.c +386 -0
  95. data/vendor/spidermonkey/fdlibm/e_rem_pio2.c +222 -0
  96. data/vendor/spidermonkey/fdlibm/e_remainder.c +120 -0
  97. data/vendor/spidermonkey/fdlibm/e_scalb.c +89 -0
  98. data/vendor/spidermonkey/fdlibm/e_sinh.c +122 -0
  99. data/vendor/spidermonkey/fdlibm/e_sqrt.c +497 -0
  100. data/vendor/spidermonkey/fdlibm/fdlibm.h +273 -0
  101. data/vendor/spidermonkey/fdlibm/fdlibm.mak +1453 -0
  102. data/vendor/spidermonkey/fdlibm/fdlibm.mdp +0 -0
  103. data/vendor/spidermonkey/fdlibm/k_cos.c +135 -0
  104. data/vendor/spidermonkey/fdlibm/k_rem_pio2.c +354 -0
  105. data/vendor/spidermonkey/fdlibm/k_sin.c +114 -0
  106. data/vendor/spidermonkey/fdlibm/k_standard.c +785 -0
  107. data/vendor/spidermonkey/fdlibm/k_tan.c +170 -0
  108. data/vendor/spidermonkey/fdlibm/s_asinh.c +101 -0
  109. data/vendor/spidermonkey/fdlibm/s_atan.c +175 -0
  110. data/vendor/spidermonkey/fdlibm/s_cbrt.c +133 -0
  111. data/vendor/spidermonkey/fdlibm/s_ceil.c +120 -0
  112. data/vendor/spidermonkey/fdlibm/s_copysign.c +72 -0
  113. data/vendor/spidermonkey/fdlibm/s_cos.c +118 -0
  114. data/vendor/spidermonkey/fdlibm/s_erf.c +356 -0
  115. data/vendor/spidermonkey/fdlibm/s_expm1.c +267 -0
  116. data/vendor/spidermonkey/fdlibm/s_fabs.c +70 -0
  117. data/vendor/spidermonkey/fdlibm/s_finite.c +71 -0
  118. data/vendor/spidermonkey/fdlibm/s_floor.c +121 -0
  119. data/vendor/spidermonkey/fdlibm/s_frexp.c +99 -0
  120. data/vendor/spidermonkey/fdlibm/s_ilogb.c +85 -0
  121. data/vendor/spidermonkey/fdlibm/s_isnan.c +74 -0
  122. data/vendor/spidermonkey/fdlibm/s_ldexp.c +66 -0
  123. data/vendor/spidermonkey/fdlibm/s_lib_version.c +73 -0
  124. data/vendor/spidermonkey/fdlibm/s_log1p.c +211 -0
  125. data/vendor/spidermonkey/fdlibm/s_logb.c +79 -0
  126. data/vendor/spidermonkey/fdlibm/s_matherr.c +64 -0
  127. data/vendor/spidermonkey/fdlibm/s_modf.c +132 -0
  128. data/vendor/spidermonkey/fdlibm/s_nextafter.c +124 -0
  129. data/vendor/spidermonkey/fdlibm/s_rint.c +131 -0
  130. data/vendor/spidermonkey/fdlibm/s_scalbn.c +107 -0
  131. data/vendor/spidermonkey/fdlibm/s_signgam.c +40 -0
  132. data/vendor/spidermonkey/fdlibm/s_significand.c +68 -0
  133. data/vendor/spidermonkey/fdlibm/s_sin.c +118 -0
  134. data/vendor/spidermonkey/fdlibm/s_tan.c +112 -0
  135. data/vendor/spidermonkey/fdlibm/s_tanh.c +122 -0
  136. data/vendor/spidermonkey/fdlibm/w_acos.c +78 -0
  137. data/vendor/spidermonkey/fdlibm/w_acosh.c +78 -0
  138. data/vendor/spidermonkey/fdlibm/w_asin.c +80 -0
  139. data/vendor/spidermonkey/fdlibm/w_atan2.c +79 -0
  140. data/vendor/spidermonkey/fdlibm/w_atanh.c +81 -0
  141. data/vendor/spidermonkey/fdlibm/w_cosh.c +77 -0
  142. data/vendor/spidermonkey/fdlibm/w_exp.c +88 -0
  143. data/vendor/spidermonkey/fdlibm/w_fmod.c +78 -0
  144. data/vendor/spidermonkey/fdlibm/w_gamma.c +85 -0
  145. data/vendor/spidermonkey/fdlibm/w_gamma_r.c +81 -0
  146. data/vendor/spidermonkey/fdlibm/w_hypot.c +78 -0
  147. data/vendor/spidermonkey/fdlibm/w_j0.c +105 -0
  148. data/vendor/spidermonkey/fdlibm/w_j1.c +106 -0
  149. data/vendor/spidermonkey/fdlibm/w_jn.c +128 -0
  150. data/vendor/spidermonkey/fdlibm/w_lgamma.c +85 -0
  151. data/vendor/spidermonkey/fdlibm/w_lgamma_r.c +81 -0
  152. data/vendor/spidermonkey/fdlibm/w_log.c +78 -0
  153. data/vendor/spidermonkey/fdlibm/w_log10.c +81 -0
  154. data/vendor/spidermonkey/fdlibm/w_pow.c +99 -0
  155. data/vendor/spidermonkey/fdlibm/w_remainder.c +77 -0
  156. data/vendor/spidermonkey/fdlibm/w_scalb.c +95 -0
  157. data/vendor/spidermonkey/fdlibm/w_sinh.c +77 -0
  158. data/vendor/spidermonkey/fdlibm/w_sqrt.c +77 -0
  159. data/vendor/spidermonkey/javascript-trace.d +73 -0
  160. data/vendor/spidermonkey/js.c +3951 -0
  161. data/vendor/spidermonkey/js.mak +4438 -0
  162. data/vendor/spidermonkey/js.mdp +0 -0
  163. data/vendor/spidermonkey/js.msg +307 -0
  164. data/vendor/spidermonkey/js.pkg +2 -0
  165. data/vendor/spidermonkey/js3240.rc +79 -0
  166. data/vendor/spidermonkey/jsOS240.def +654 -0
  167. data/vendor/spidermonkey/jsapi.c +5836 -0
  168. data/vendor/spidermonkey/jsapi.h +2624 -0
  169. data/vendor/spidermonkey/jsarena.c +450 -0
  170. data/vendor/spidermonkey/jsarena.h +318 -0
  171. data/vendor/spidermonkey/jsarray.c +2988 -0
  172. data/vendor/spidermonkey/jsarray.h +124 -0
  173. data/vendor/spidermonkey/jsatom.c +1045 -0
  174. data/vendor/spidermonkey/jsatom.h +442 -0
  175. data/vendor/spidermonkey/jsbit.h +253 -0
  176. data/vendor/spidermonkey/jsbool.c +176 -0
  177. data/vendor/spidermonkey/jsbool.h +73 -0
  178. data/vendor/spidermonkey/jsclist.h +139 -0
  179. data/vendor/spidermonkey/jscntxt.c +1348 -0
  180. data/vendor/spidermonkey/jscntxt.h +1120 -0
  181. data/vendor/spidermonkey/jscompat.h +57 -0
  182. data/vendor/spidermonkey/jsconfig.h +248 -0
  183. data/vendor/spidermonkey/jsconfig.mk +181 -0
  184. data/vendor/spidermonkey/jscpucfg.c +383 -0
  185. data/vendor/spidermonkey/jscpucfg.h +212 -0
  186. data/vendor/spidermonkey/jsdate.c +2398 -0
  187. data/vendor/spidermonkey/jsdate.h +124 -0
  188. data/vendor/spidermonkey/jsdbgapi.c +1799 -0
  189. data/vendor/spidermonkey/jsdbgapi.h +464 -0
  190. data/vendor/spidermonkey/jsdhash.c +868 -0
  191. data/vendor/spidermonkey/jsdhash.h +592 -0
  192. data/vendor/spidermonkey/jsdtoa.c +3167 -0
  193. data/vendor/spidermonkey/jsdtoa.h +130 -0
  194. data/vendor/spidermonkey/jsdtracef.c +317 -0
  195. data/vendor/spidermonkey/jsdtracef.h +77 -0
  196. data/vendor/spidermonkey/jsemit.c +6909 -0
  197. data/vendor/spidermonkey/jsemit.h +741 -0
  198. data/vendor/spidermonkey/jsexn.c +1371 -0
  199. data/vendor/spidermonkey/jsexn.h +96 -0
  200. data/vendor/spidermonkey/jsfile.c +2736 -0
  201. data/vendor/spidermonkey/jsfile.h +56 -0
  202. data/vendor/spidermonkey/jsfile.msg +90 -0
  203. data/vendor/spidermonkey/jsfun.c +2634 -0
  204. data/vendor/spidermonkey/jsfun.h +254 -0
  205. data/vendor/spidermonkey/jsgc.c +3554 -0
  206. data/vendor/spidermonkey/jsgc.h +403 -0
  207. data/vendor/spidermonkey/jshash.c +476 -0
  208. data/vendor/spidermonkey/jshash.h +151 -0
  209. data/vendor/spidermonkey/jsify.pl +485 -0
  210. data/vendor/spidermonkey/jsinterp.c +6981 -0
  211. data/vendor/spidermonkey/jsinterp.h +521 -0
  212. data/vendor/spidermonkey/jsinvoke.c +43 -0
  213. data/vendor/spidermonkey/jsiter.c +1067 -0
  214. data/vendor/spidermonkey/jsiter.h +122 -0
  215. data/vendor/spidermonkey/jskeyword.tbl +124 -0
  216. data/vendor/spidermonkey/jskwgen.c +460 -0
  217. data/vendor/spidermonkey/jslibmath.h +266 -0
  218. data/vendor/spidermonkey/jslock.c +1309 -0
  219. data/vendor/spidermonkey/jslock.h +313 -0
  220. data/vendor/spidermonkey/jslocko.asm +60 -0
  221. data/vendor/spidermonkey/jslog2.c +94 -0
  222. data/vendor/spidermonkey/jslong.c +264 -0
  223. data/vendor/spidermonkey/jslong.h +412 -0
  224. data/vendor/spidermonkey/jsmath.c +568 -0
  225. data/vendor/spidermonkey/jsmath.h +57 -0
  226. data/vendor/spidermonkey/jsnum.c +1228 -0
  227. data/vendor/spidermonkey/jsnum.h +283 -0
  228. data/vendor/spidermonkey/jsobj.c +5266 -0
  229. data/vendor/spidermonkey/jsobj.h +709 -0
  230. data/vendor/spidermonkey/jsopcode.c +5245 -0
  231. data/vendor/spidermonkey/jsopcode.h +394 -0
  232. data/vendor/spidermonkey/jsopcode.tbl +523 -0
  233. data/vendor/spidermonkey/jsotypes.h +202 -0
  234. data/vendor/spidermonkey/jsparse.c +6680 -0
  235. data/vendor/spidermonkey/jsparse.h +511 -0
  236. data/vendor/spidermonkey/jsprf.c +1262 -0
  237. data/vendor/spidermonkey/jsprf.h +150 -0
  238. data/vendor/spidermonkey/jsproto.tbl +128 -0
  239. data/vendor/spidermonkey/jsprvtd.h +267 -0
  240. data/vendor/spidermonkey/jspubtd.h +744 -0
  241. data/vendor/spidermonkey/jsregexp.c +4352 -0
  242. data/vendor/spidermonkey/jsregexp.h +183 -0
  243. data/vendor/spidermonkey/jsreops.tbl +145 -0
  244. data/vendor/spidermonkey/jsscan.c +2003 -0
  245. data/vendor/spidermonkey/jsscan.h +387 -0
  246. data/vendor/spidermonkey/jsscope.c +1948 -0
  247. data/vendor/spidermonkey/jsscope.h +418 -0
  248. data/vendor/spidermonkey/jsscript.c +1832 -0
  249. data/vendor/spidermonkey/jsscript.h +287 -0
  250. data/vendor/spidermonkey/jsshell.msg +50 -0
  251. data/vendor/spidermonkey/jsstddef.h +83 -0
  252. data/vendor/spidermonkey/jsstr.c +5004 -0
  253. data/vendor/spidermonkey/jsstr.h +641 -0
  254. data/vendor/spidermonkey/jstypes.h +475 -0
  255. data/vendor/spidermonkey/jsutil.c +345 -0
  256. data/vendor/spidermonkey/jsutil.h +157 -0
  257. data/vendor/spidermonkey/jsxdrapi.c +800 -0
  258. data/vendor/spidermonkey/jsxdrapi.h +218 -0
  259. data/vendor/spidermonkey/jsxml.c +8471 -0
  260. data/vendor/spidermonkey/jsxml.h +349 -0
  261. data/vendor/spidermonkey/lock_SunOS.s +119 -0
  262. data/vendor/spidermonkey/perfect.js +39 -0
  263. data/vendor/spidermonkey/plify_jsdhash.sed +36 -0
  264. data/vendor/spidermonkey/prmjtime.c +846 -0
  265. data/vendor/spidermonkey/prmjtime.h +103 -0
  266. data/vendor/spidermonkey/resource.h +15 -0
  267. data/vendor/spidermonkey/rules.mk +197 -0
  268. data/vendor/spidermonkey/win32.order +384 -0
  269. metadata +4 -3
@@ -0,0 +1,144 @@
1
+ # -*- Mode: makefile -*-
2
+ #
3
+ # ***** BEGIN LICENSE BLOCK *****
4
+ # Version: MPL 1.1/GPL 2.0/LGPL 2.1
5
+ #
6
+ # The contents of this file are subject to the Mozilla Public License Version
7
+ # 1.1 (the "License"); you may not use this file except in compliance with
8
+ # the License. You may obtain a copy of the License at
9
+ # http://www.mozilla.org/MPL/
10
+ #
11
+ # Software distributed under the License is distributed on an "AS IS" basis,
12
+ # WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
13
+ # for the specific language governing rights and limitations under the
14
+ # License.
15
+ #
16
+ # The Original Code is Mozilla Communicator client code, released
17
+ # March 31, 1998.
18
+ #
19
+ # The Initial Developer of the Original Code is
20
+ # Simmule Turner and Rich Salz.
21
+ # Portions created by the Initial Developer are Copyright (C) 1998
22
+ # the Initial Developer. All Rights Reserved.
23
+ #
24
+ # Contributor(s):
25
+ #
26
+ # Alternatively, the contents of this file may be used under the terms of
27
+ # either the GNU General Public License Version 2 or later (the "GPL"), or
28
+ # the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
29
+ # in which case the provisions of the GPL or the LGPL are applicable instead
30
+ # of those above. If you wish to allow use of your version of this file only
31
+ # under the terms of either the GPL or the LGPL, and not to allow others to
32
+ # use your version of this file under the terms of the MPL, indicate your
33
+ # decision by deleting the provisions above and replace them with the notice
34
+ # and other provisions required by the GPL or the LGPL. If you do not delete
35
+ # the provisions above, a recipient may use your version of this file under
36
+ # the terms of any one of the MPL, the GPL or the LGPL.
37
+ #
38
+ # ***** END LICENSE BLOCK *****
39
+
40
+ #
41
+ # Copyright 1992,1993 Simmule Turner and Rich Salz. All rights reserved.
42
+ #
43
+ # This software is not subject to any license of the American Telephone
44
+ # and Telegraph Company or of the Regents of the University of California.
45
+ #
46
+ # Permission is granted to anyone to use this software for any purpose on
47
+ # any computer system, and to alter it and redistribute it freely, subject
48
+ # to the following restrictions:
49
+ # 1. The authors are not responsible for the consequences of use of this
50
+ # software, no matter how awful, even if they arise from flaws in it.
51
+ # 2. The origin of this software must not be misrepresented, either by
52
+ # explicit claim or by omission. Since few users ever read sources,
53
+ # credits must appear in the documentation.
54
+ # 3. Altered versions must be plainly marked as such, and must not be
55
+ # misrepresented as being the original software. Since few users
56
+ # ever read sources, credits must appear in the documentation.
57
+ # 4. This notice may not be removed or altered.
58
+ #
59
+
60
+ #
61
+ # Unix makefile for editline library.
62
+ #
63
+
64
+ ## Set your options:
65
+ ## -DANSI_ARROWS ANSI arrows keys work like emacs.
66
+ ## -DHAVE_STDLIB Have <stdlib.h>.
67
+ ## -DHAVE_TCGETATTR Have tcgetattr(), tcsetattr().
68
+ ## -DHAVE_TERMIO Have "struct termio" and <termio.h>
69
+ ## (If neither of above two, we use <sgttyb.h> and BSD ioctl's)
70
+ ## -DHIDE Make static functions static (non debug).
71
+ ## -DHIST_SIZE=n History size.
72
+ ## -DNEED_STRDUP Don't have strdup().
73
+ ## -DUNIQUE_HISTORY Don't save command if same as last one.
74
+ ## -DUSE_DIRENT Use <dirent.h>, not <sys/dir.h>?
75
+ ## -DUSE_TERMCAP Use the termcap library for terminal size
76
+ ## see LDFLAGS, below, if you set this.
77
+ ## -DNEED_PERROR Don't have perror() (used in testit)
78
+
79
+ ## If you have -DUSE_TERMCAP, set this as appropriate:
80
+ #LDFLAGS = -ltermlib
81
+ #LDFLAGS = -ltermcap
82
+
83
+ DEFS = -DANSI_ARROWS -DHAVE_TCGETATTR -DHIDE -DUSE_DIRENT -DSYS_UNIX \
84
+ -DHAVE_STDLIB -DUNIQUE_HISTORY
85
+
86
+ DEPTH = ..
87
+
88
+ include $(DEPTH)/config.mk
89
+
90
+ #
91
+ # Default IEEE libm
92
+ #
93
+ CFLAGS += -DXP_UNIX $(OPTIMIZER) $(OS_CFLAGS) $(DEFINES) $(INCLUDES) \
94
+ -DJSFILE $(XCFLAGS) $(DEFS)
95
+
96
+ INCFILES = editline.h
97
+ .INIT: $(INCFILES)
98
+ .KEEP_STATE:
99
+ EDITLINE_CFILES = editline.c sysunix.c
100
+
101
+ EDITLINE_OBJS = $(addprefix $(OBJDIR)/, $(EDITLINE_CFILES:.c=.o))
102
+
103
+ LIBRARY = $(OBJDIR)/libedit.a
104
+
105
+ define MAKE_OBJDIR
106
+ if test ! -d $(@D); then rm -rf $(@D); mkdir $(@D); fi
107
+ endef
108
+
109
+ all: $(LIBRARY)
110
+
111
+ export:
112
+
113
+ $(OBJDIR)/%: %.c
114
+ @$(MAKE_OBJDIR)
115
+ $(CC) -o $@ $(CFLAGS) $*.c $(LDFLAGS)
116
+
117
+ $(OBJDIR)/%.o: %.c
118
+ @$(MAKE_OBJDIR)
119
+ $(CC) -o $@ -c $(CFLAGS) $*.c
120
+
121
+ $(OBJDIR)/%.o: %.s
122
+ @$(MAKE_OBJDIR)
123
+ $(AS) -o $@ $(ASFLAGS) $*.s
124
+
125
+ $(LIBRARY): $(EDITLINE_OBJS)
126
+ $(AR) rv $@ $?
127
+ $(RANLIB) $@
128
+
129
+ #libedit.a : $(EDITLINE_OBJS)
130
+ # $(AR) cru $(OBJDIR)/libedit.a $(EDITLINE_OBJS)
131
+ # $(RANLIB) $(OBJDIR)/libedit.a
132
+
133
+ clean:
134
+ rm -rf $(EDITLINE_OBJS)
135
+
136
+ clobber:
137
+ rm -rf $(EDITLINE_OBJS) $(LIBRARY) $(DEPENDENCIES)
138
+
139
+ SUFFIXES: .i
140
+ %.i: %.c
141
+ $(CC) -C -E $(CFLAGS) $< > $*.i
142
+
143
+
144
+
@@ -0,0 +1,83 @@
1
+ The files in this directory provide simple line-editing and history
2
+ support for the standalone javascript engine, through the 'editline'
3
+ library.
4
+
5
+ editline has only been enabled for those platforms on which it is
6
+ known to build; to try it on a different platform, define JS_EDITLINE
7
+ before building. Line editing (and js.c) is not a supported feature
8
+ of the javascript library, so your mileage my vary.
9
+
10
+ The editline API is a compatible subset of the FSF readline API; if
11
+ you have readline installed and would like to link to that instead,
12
+ define JS_READLINE. Note that the readline library is distributed
13
+ under the GPL, so any resulting binaries are not legally
14
+ distributable.
15
+
16
+ The editline files used here have been modified to work with the js
17
+ build system and to quiet some compiler warnings, and also to remove
18
+ filename-completion support.
19
+
20
+ If anyone knows of a more recent version of these files, or a site on
21
+ which they are being maintained, please let me know!
22
+
23
+ Mike McCabe, mccabe@netscape.com
24
+
25
+
26
+ The original README file distributed with the editline library follows.
27
+
28
+
29
+
30
+ This is a line-editing library. It can be linked into almost any
31
+ program to provide command-line editing and recall.
32
+
33
+ It is call-compatible with the FSF readline library, but it is a
34
+ fraction of the size (and offers fewer features). It does not use
35
+ standard I/O. It is distributed under a "C News-like" copyright.
36
+
37
+ Configuration is done in the Makefile. Type "make testit" to get
38
+ a small slow shell for testing.
39
+
40
+ An earlier version was distributed with Byron's rc. Principal
41
+ changes over that version include:
42
+ Faster.
43
+ Is eight-bit clean (thanks to brendan@cs.widener.edu)
44
+ Written in K&R C, but ANSI compliant (gcc all warnings)
45
+ Propagates EOF properly; rc trip test now passes
46
+ Doesn't need or use or provide memmove.
47
+ More robust
48
+ Calling sequence changed to be compatible with readline.
49
+ Test program, new manpage, better configuration
50
+ More system-independant; includes Unix and OS-9 support.
51
+
52
+ This contains some changes since the posting to comp.sources.misc:
53
+ Bugfix for completion on absolute pathnames.
54
+ Better handling of M-n versus showing raw 8bit chars.
55
+ Better signal handling.
56
+ Now supports termios/termio/sgttyb ioctl's.
57
+ Add M-m command to toggle how 8bit data is displayed.
58
+
59
+ There is one known bug:
60
+ History-searching redraws the line wrong if the text
61
+ retrieved is shorter then the prompt.
62
+
63
+ Enjoy,
64
+ Rich $alz
65
+ <rsalz@osf.org>
66
+
67
+ Copyright 1992,1993 Simmule Turner and Rich Salz. All rights reserved.
68
+
69
+ This software is not subject to any license of the American Telephone
70
+ and Telegraph Company or of the Regents of the University of California.
71
+
72
+ Permission is granted to anyone to use this software for any purpose on
73
+ any computer system, and to alter it and redistribute it freely, subject
74
+ to the following restrictions:
75
+ 1. The authors are not responsible for the consequences of use of this
76
+ software, no matter how awful, even if they arise from flaws in it.
77
+ 2. The origin of this software must not be misrepresented, either by
78
+ explicit claim or by omission. Since few users ever read sources,
79
+ credits must appear in the documentation.
80
+ 3. Altered versions must be plainly marked as such, and must not be
81
+ misrepresented as being the original software. Since few users
82
+ ever read sources, credits must appear in the documentation.
83
+ 4. This notice may not be removed or altered.
@@ -0,0 +1,175 @@
1
+ .TH EDITLINE 3
2
+ .SH NAME
3
+ editline \- command-line editing library with history
4
+ .SH SYNOPSIS
5
+ .nf
6
+ .B "char *"
7
+ .B "readline(prompt)"
8
+ .B " char *prompt;"
9
+
10
+ .B "void"
11
+ .B "add_history(line)"
12
+ .B " char *line;"
13
+ .fi
14
+ .SH DESCRIPTION
15
+ .I Editline
16
+ is a library that provides an line-editing interface with text recall.
17
+ It is intended to be compatible with the
18
+ .I readline
19
+ library provided by the Free Software Foundation, but much smaller.
20
+ The bulk of this manual page describes the user interface.
21
+ .PP
22
+ The
23
+ .I readline
24
+ routine returns a line of text with the trailing newline removed.
25
+ The data is returned in a buffer allocated with
26
+ .IR malloc (3),
27
+ so the space should be released with
28
+ .IR free (3)
29
+ when the calling program is done with it.
30
+ Before accepting input from the user, the specified
31
+ .I prompt
32
+ is displayed on the terminal.
33
+ .PP
34
+ The
35
+ .I add_history
36
+ routine makes a copy of the specified
37
+ .I line
38
+ and adds it to the internal history list.
39
+ .SS "User Interface"
40
+ A program that uses this library provides a simple emacs-like editing
41
+ interface to its users.
42
+ A line may be edited before it is sent to the calling program by typing either
43
+ control characters or escape sequences.
44
+ A control character, shown as a caret followed by a letter, is typed by
45
+ holding down the ``control'' key while the letter is typed.
46
+ For example, ``^A'' is a control-A.
47
+ An escape sequence is entered by typing the ``escape'' key followed by one or
48
+ more characters.
49
+ The escape key is abbreviated as ``ESC.''
50
+ Note that unlike control keys, case matters in escape sequences; ``ESC\ F''
51
+ is not the same as ``ESC\ f''.
52
+ .PP
53
+ An editing command may be typed anywhere on the line, not just at the
54
+ beginning.
55
+ In addition, a return may also be typed anywhere on the line, not just at
56
+ the end.
57
+ .PP
58
+ Most editing commands may be given a repeat count,
59
+ .IR n ,
60
+ where
61
+ .I n
62
+ is a number.
63
+ To enter a repeat count, type the escape key, the number, and then
64
+ the command to execute.
65
+ For example, ``ESC\ 4\ ^f'' moves forward four characters.
66
+ If a command may be given a repeat count then the text ``[n]'' is given at the
67
+ end of its description.
68
+ .PP
69
+ The following control characters are accepted:
70
+ .RS
71
+ .nf
72
+ .ta \w'ESC DEL 'u
73
+ ^A Move to the beginning of the line
74
+ ^B Move left (backwards) [n]
75
+ ^D Delete character [n]
76
+ ^E Move to end of line
77
+ ^F Move right (forwards) [n]
78
+ ^G Ring the bell
79
+ ^H Delete character before cursor (backspace key) [n]
80
+ ^I Complete filename (tab key); see below
81
+ ^J Done with line (return key)
82
+ ^K Kill to end of line (or column [n])
83
+ ^L Redisplay line
84
+ ^M Done with line (alternate return key)
85
+ ^N Get next line from history [n]
86
+ ^P Get previous line from history [n]
87
+ ^R Search backward (forward if [n]) through history for text;
88
+ \& must start line if text begins with an uparrow
89
+ ^T Transpose characters
90
+ ^V Insert next character, even if it is an edit command
91
+ ^W Wipe to the mark
92
+ ^X^X Exchange current location and mark
93
+ ^Y Yank back last killed text
94
+ ^[ Start an escape sequence (escape key)
95
+ ^]c Move forward to next character ``c''
96
+ ^? Delete character before cursor (delete key) [n]
97
+ .fi
98
+ .RE
99
+ .PP
100
+ The following escape sequences are provided.
101
+ .RS
102
+ .nf
103
+ .ta \w'ESC DEL 'u
104
+ ESC\ ^H Delete previous word (backspace key) [n]
105
+ ESC\ DEL Delete previous word (delete key) [n]
106
+ ESC\ SP Set the mark (space key); see ^X^X and ^Y above
107
+ ESC\ \. Get the last (or [n]'th) word from previous line
108
+ ESC\ \? Show possible completions; see below
109
+ ESC\ < Move to start of history
110
+ ESC\ > Move to end of history
111
+ ESC\ b Move backward a word [n]
112
+ ESC\ d Delete word under cursor [n]
113
+ ESC\ f Move forward a word [n]
114
+ ESC\ l Make word lowercase [n]
115
+ ESC\ m Toggle if 8bit chars display normally or with ``M\-'' prefix
116
+ ESC\ u Make word uppercase [n]
117
+ ESC\ y Yank back last killed text
118
+ ESC\ v Show library version
119
+ ESC\ w Make area up to mark yankable
120
+ ESC\ nn Set repeat count to the number nn
121
+ ESC\ C Read from environment variable ``_C_'', where C is
122
+ \& an uppercase letter
123
+ .fi
124
+ .RE
125
+ .PP
126
+ The
127
+ .I editline
128
+ library has a small macro facility.
129
+ If you type the escape key followed by an uppercase letter,
130
+ .IR C ,
131
+ then the contents of the environment variable
132
+ .I _C_
133
+ are read in as if you had typed them at the keyboard.
134
+ For example, if the variable
135
+ .I _L_
136
+ contains the following:
137
+ .RS
138
+ ^A^Kecho '^V^[[H^V^[[2J'^M
139
+ .RE
140
+ Then typing ``ESC L'' will move to the beginning of the line, kill the
141
+ entire line, enter the echo command needed to clear the terminal (if your
142
+ terminal is like a VT-100), and send the line back to the shell.
143
+ .PP
144
+ The
145
+ .I editline
146
+ library also does filename completion.
147
+ Suppose the root directory has the following files in it:
148
+ .RS
149
+ .nf
150
+ .ta \w'core 'u
151
+ bin vmunix
152
+ core vmunix.old
153
+ .fi
154
+ .RE
155
+ If you type ``rm\ /v'' and then the tab key.
156
+ .I Editline
157
+ will then finish off as much of the name as possible by adding ``munix''.
158
+ Because the name is not unique, it will then beep.
159
+ If you type the escape key and a question mark, it will display the
160
+ two choices.
161
+ If you then type a period and a tab, the library will finish off the filename
162
+ for you:
163
+ .RS
164
+ .nf
165
+ .RI "rm /v[TAB]" munix .TAB old
166
+ .fi
167
+ .RE
168
+ The tab key is shown by ``[TAB]'' and the automatically-entered text
169
+ is shown in italics.
170
+ .SH "BUGS AND LIMITATIONS"
171
+ Cannot handle lines more than 80 columns.
172
+ .SH AUTHORS
173
+ Simmule R. Turner <uunet.uu.net!capitol!sysgo!simmy>
174
+ and Rich $alz <rsalz@osf.org>.
175
+ Original manual page by DaviD W. Sanderson <dws@ssec.wisc.edu>.
@@ -0,0 +1,1369 @@
1
+ /* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2
+ *
3
+ * ***** BEGIN LICENSE BLOCK *****
4
+ * Version: MPL 1.1/GPL 2.0/LGPL 2.1
5
+ *
6
+ * The contents of this file are subject to the Mozilla Public License Version
7
+ * 1.1 (the "License"); you may not use this file except in compliance with
8
+ * the License. You may obtain a copy of the License at
9
+ * http://www.mozilla.org/MPL/
10
+ *
11
+ * Software distributed under the License is distributed on an "AS IS" basis,
12
+ * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
13
+ * for the specific language governing rights and limitations under the
14
+ * License.
15
+ *
16
+ * The Original Code is Mozilla Communicator client code, released
17
+ * March 31, 1998.
18
+ *
19
+ * The Initial Developer of the Original Code is
20
+ * Simmule Turner and Rich Salz.
21
+ * Portions created by the Initial Developer are Copyright (C) 1998
22
+ * the Initial Developer. All Rights Reserved.
23
+ *
24
+ * Contributor(s):
25
+ *
26
+ * Alternatively, the contents of this file may be used under the terms of
27
+ * either the GNU General Public License Version 2 or later (the "GPL"), or
28
+ * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
29
+ * in which case the provisions of the GPL or the LGPL are applicable instead
30
+ * of those above. If you wish to allow use of your version of this file only
31
+ * under the terms of either the GPL or the LGPL, and not to allow others to
32
+ * use your version of this file under the terms of the MPL, indicate your
33
+ * decision by deleting the provisions above and replace them with the notice
34
+ * and other provisions required by the GPL or the LGPL. If you do not delete
35
+ * the provisions above, a recipient may use your version of this file under
36
+ * the terms of any one of the MPL, the GPL or the LGPL.
37
+ *
38
+ * ***** END LICENSE BLOCK ***** */
39
+
40
+ /*
41
+ * Copyright 1992,1993 Simmule Turner and Rich Salz. All rights reserved.
42
+ *
43
+ * This software is not subject to any license of the American Telephone
44
+ * and Telegraph Company or of the Regents of the University of California.
45
+ *
46
+ * Permission is granted to anyone to use this software for any purpose on
47
+ * any computer system, and to alter it and redistribute it freely, subject
48
+ * to the following restrictions:
49
+ * 1. The authors are not responsible for the consequences of use of this
50
+ * software, no matter how awful, even if they arise from flaws in it.
51
+ * 2. The origin of this software must not be misrepresented, either by
52
+ * explicit claim or by omission. Since few users ever read sources,
53
+ * credits must appear in the documentation.
54
+ * 3. Altered versions must be plainly marked as such, and must not be
55
+ * misrepresented as being the original software. Since few users
56
+ * ever read sources, credits must appear in the documentation.
57
+ * 4. This notice may not be removed or altered.
58
+ */
59
+
60
+
61
+ /*
62
+ ** Main editing routines for editline library.
63
+ */
64
+ #include "editline.h"
65
+ #include <signal.h>
66
+ #include <ctype.h>
67
+
68
+ /*
69
+ ** Manifest constants.
70
+ */
71
+ #define SCREEN_WIDTH 80
72
+ #define SCREEN_ROWS 24
73
+ #define NO_ARG (-1)
74
+ #define DEL 127
75
+ #define CTL(x) ((x) & 0x1F)
76
+ #define ISCTL(x) ((x) && (x) < ' ')
77
+ #define UNCTL(x) ((x) + 64)
78
+ #define META(x) ((x) | 0x80)
79
+ #define ISMETA(x) ((x) & 0x80)
80
+ #define UNMETA(x) ((x) & 0x7F)
81
+ #if !defined(HIST_SIZE)
82
+ #define HIST_SIZE 20
83
+ #endif /* !defined(HIST_SIZE) */
84
+
85
+ /*
86
+ ** Command status codes.
87
+ */
88
+ typedef enum _STATUS {
89
+ CSdone, CSeof, CSmove, CSdispatch, CSstay, CSsignal
90
+ } STATUS;
91
+
92
+ /*
93
+ ** The type of case-changing to perform.
94
+ */
95
+ typedef enum _CASE {
96
+ TOupper, TOlower
97
+ } CASE;
98
+
99
+ /*
100
+ ** Key to command mapping.
101
+ */
102
+ typedef struct _KEYMAP {
103
+ CHAR Key;
104
+ STATUS (*Function)();
105
+ } KEYMAP;
106
+
107
+ /*
108
+ ** Command history structure.
109
+ */
110
+ typedef struct _HISTORY {
111
+ int Size;
112
+ int Pos;
113
+ CHAR *Lines[HIST_SIZE];
114
+ } HISTORY;
115
+
116
+ /*
117
+ ** Globals.
118
+ */
119
+ int rl_eof;
120
+ int rl_erase;
121
+ int rl_intr;
122
+ int rl_kill;
123
+ int rl_quit;
124
+
125
+ STATIC CHAR NIL[] = "";
126
+ STATIC CONST CHAR *Input = NIL;
127
+ STATIC CHAR *Line;
128
+ STATIC CONST char *Prompt;
129
+ STATIC CHAR *Yanked;
130
+ STATIC char *Screen;
131
+ STATIC char NEWLINE[]= CRLF;
132
+ STATIC HISTORY H;
133
+ STATIC int Repeat;
134
+ STATIC int End;
135
+ STATIC int Mark;
136
+ STATIC int OldPoint;
137
+ STATIC int Point;
138
+ STATIC int PushBack;
139
+ STATIC int Pushed;
140
+ STATIC int Signal;
141
+ FORWARD KEYMAP Map[32];
142
+ FORWARD KEYMAP MetaMap[16];
143
+ STATIC SIZE_T Length;
144
+ STATIC SIZE_T ScreenCount;
145
+ STATIC SIZE_T ScreenSize;
146
+ STATIC char *backspace;
147
+ STATIC int TTYwidth;
148
+ STATIC int TTYrows;
149
+
150
+ /* Display print 8-bit chars as `M-x' or as the actual 8-bit char? */
151
+ int rl_meta_chars = 0;
152
+
153
+ /*
154
+ ** Declarations.
155
+ */
156
+ STATIC CHAR *editinput();
157
+ extern int read();
158
+ extern int write();
159
+ #if defined(USE_TERMCAP)
160
+ extern char *getenv();
161
+ extern char *tgetstr();
162
+ extern int tgetent();
163
+ #endif /* defined(USE_TERMCAP) */
164
+
165
+ /*
166
+ ** TTY input/output functions.
167
+ */
168
+
169
+ STATIC void
170
+ TTYflush()
171
+ {
172
+ if (ScreenCount) {
173
+ (void)write(1, Screen, ScreenCount);
174
+ ScreenCount = 0;
175
+ }
176
+ }
177
+
178
+ STATIC void
179
+ TTYput(c)
180
+ CHAR c;
181
+ {
182
+ Screen[ScreenCount] = c;
183
+ if (++ScreenCount >= ScreenSize - 1) {
184
+ ScreenSize += SCREEN_INC;
185
+ RENEW(Screen, char, ScreenSize);
186
+ }
187
+ }
188
+
189
+ STATIC void
190
+ TTYputs(p)
191
+ CHAR *p;
192
+ {
193
+ while (*p)
194
+ TTYput(*p++);
195
+ }
196
+
197
+ STATIC void
198
+ TTYshow(c)
199
+ CHAR c;
200
+ {
201
+ if (c == DEL) {
202
+ TTYput('^');
203
+ TTYput('?');
204
+ }
205
+ else if (ISCTL(c)) {
206
+ TTYput('^');
207
+ TTYput(UNCTL(c));
208
+ }
209
+ else if (rl_meta_chars && ISMETA(c)) {
210
+ TTYput('M');
211
+ TTYput('-');
212
+ TTYput(UNMETA(c));
213
+ }
214
+ else
215
+ TTYput(c);
216
+ }
217
+
218
+ STATIC void
219
+ TTYstring(p)
220
+ CHAR *p;
221
+ {
222
+ while (*p)
223
+ TTYshow(*p++);
224
+ }
225
+
226
+ STATIC unsigned int
227
+ TTYget()
228
+ {
229
+ CHAR c;
230
+
231
+ TTYflush();
232
+ if (Pushed) {
233
+ Pushed = 0;
234
+ return PushBack;
235
+ }
236
+ if (*Input)
237
+ return *Input++;
238
+ return read(0, &c, (SIZE_T)1) == 1 ? c : EOF;
239
+ }
240
+
241
+ #define TTYback() (backspace ? TTYputs((CHAR *)backspace) : TTYput('\b'))
242
+
243
+ STATIC void
244
+ TTYbackn(n)
245
+ int n;
246
+ {
247
+ while (--n >= 0)
248
+ TTYback();
249
+ }
250
+
251
+ STATIC void
252
+ TTYinfo()
253
+ {
254
+ static int init;
255
+ #if defined(USE_TERMCAP)
256
+ char *term;
257
+ char buff[2048];
258
+ char *bp, *p;
259
+ #endif /* defined(USE_TERMCAP) */
260
+ #if defined(TIOCGWINSZ)
261
+ struct winsize W;
262
+ #endif /* defined(TIOCGWINSZ) */
263
+
264
+ if (init) {
265
+ #if defined(TIOCGWINSZ)
266
+ /* Perhaps we got resized. */
267
+ if (ioctl(0, TIOCGWINSZ, &W) >= 0
268
+ && W.ws_col > 0 && W.ws_row > 0) {
269
+ TTYwidth = (int)W.ws_col;
270
+ TTYrows = (int)W.ws_row;
271
+ }
272
+ #endif /* defined(TIOCGWINSZ) */
273
+ return;
274
+ }
275
+ init++;
276
+
277
+ TTYwidth = TTYrows = 0;
278
+ #if defined(USE_TERMCAP)
279
+ bp = &buff[0];
280
+ if ((term = getenv("TERM")) == NULL)
281
+ term = "dumb";
282
+ if (tgetent(buff, term) < 0) {
283
+ TTYwidth = SCREEN_WIDTH;
284
+ TTYrows = SCREEN_ROWS;
285
+ return;
286
+ }
287
+ p = tgetstr("le", &bp);
288
+ backspace = p ? strdup(p) : NULL;
289
+ TTYwidth = tgetnum("co");
290
+ TTYrows = tgetnum("li");
291
+ #endif /* defined(USE_TERMCAP) */
292
+
293
+ #if defined(TIOCGWINSZ)
294
+ if (ioctl(0, TIOCGWINSZ, &W) >= 0) {
295
+ TTYwidth = (int)W.ws_col;
296
+ TTYrows = (int)W.ws_row;
297
+ }
298
+ #endif /* defined(TIOCGWINSZ) */
299
+
300
+ if (TTYwidth <= 0 || TTYrows <= 0) {
301
+ TTYwidth = SCREEN_WIDTH;
302
+ TTYrows = SCREEN_ROWS;
303
+ }
304
+ }
305
+
306
+
307
+ STATIC void
308
+ reposition()
309
+ {
310
+ int i;
311
+ CHAR *p;
312
+
313
+ TTYput('\r');
314
+ TTYputs((CONST CHAR *)Prompt);
315
+ for (i = Point, p = Line; --i >= 0; p++)
316
+ TTYshow(*p);
317
+ }
318
+
319
+ STATIC void
320
+ left(Change)
321
+ STATUS Change;
322
+ {
323
+ TTYback();
324
+ if (Point) {
325
+ if (ISCTL(Line[Point - 1]))
326
+ TTYback();
327
+ else if (rl_meta_chars && ISMETA(Line[Point - 1])) {
328
+ TTYback();
329
+ TTYback();
330
+ }
331
+ }
332
+ if (Change == CSmove)
333
+ Point--;
334
+ }
335
+
336
+ STATIC void
337
+ right(Change)
338
+ STATUS Change;
339
+ {
340
+ TTYshow(Line[Point]);
341
+ if (Change == CSmove)
342
+ Point++;
343
+ }
344
+
345
+ STATIC STATUS
346
+ ring_bell()
347
+ {
348
+ TTYput('\07');
349
+ TTYflush();
350
+ return CSstay;
351
+ }
352
+
353
+ STATIC STATUS
354
+ do_macro(c)
355
+ unsigned int c;
356
+ {
357
+ CHAR name[4];
358
+
359
+ name[0] = '_';
360
+ name[1] = c;
361
+ name[2] = '_';
362
+ name[3] = '\0';
363
+
364
+ if ((Input = (CHAR *)getenv((char *)name)) == NULL) {
365
+ Input = NIL;
366
+ return ring_bell();
367
+ }
368
+ return CSstay;
369
+ }
370
+
371
+ STATIC STATUS
372
+ do_forward(move)
373
+ STATUS move;
374
+ {
375
+ int i;
376
+ CHAR *p;
377
+
378
+ i = 0;
379
+ do {
380
+ p = &Line[Point];
381
+ for ( ; Point < End && (*p == ' ' || !isalnum(*p)); Point++, p++)
382
+ if (move == CSmove)
383
+ right(CSstay);
384
+
385
+ for (; Point < End && isalnum(*p); Point++, p++)
386
+ if (move == CSmove)
387
+ right(CSstay);
388
+
389
+ if (Point == End)
390
+ break;
391
+ } while (++i < Repeat);
392
+
393
+ return CSstay;
394
+ }
395
+
396
+ STATIC STATUS
397
+ do_case(type)
398
+ CASE type;
399
+ {
400
+ int i;
401
+ int end;
402
+ int count;
403
+ CHAR *p;
404
+
405
+ (void)do_forward(CSstay);
406
+ if (OldPoint != Point) {
407
+ if ((count = Point - OldPoint) < 0)
408
+ count = -count;
409
+ Point = OldPoint;
410
+ if ((end = Point + count) > End)
411
+ end = End;
412
+ for (i = Point, p = &Line[i]; i < end; i++, p++) {
413
+ if (type == TOupper) {
414
+ if (islower(*p))
415
+ *p = toupper(*p);
416
+ }
417
+ else if (isupper(*p))
418
+ *p = tolower(*p);
419
+ right(CSmove);
420
+ }
421
+ }
422
+ return CSstay;
423
+ }
424
+
425
+ STATIC STATUS
426
+ case_down_word()
427
+ {
428
+ return do_case(TOlower);
429
+ }
430
+
431
+ STATIC STATUS
432
+ case_up_word()
433
+ {
434
+ return do_case(TOupper);
435
+ }
436
+
437
+ STATIC void
438
+ ceol()
439
+ {
440
+ int extras;
441
+ int i;
442
+ CHAR *p;
443
+
444
+ for (extras = 0, i = Point, p = &Line[i]; i <= End; i++, p++) {
445
+ TTYput(' ');
446
+ if (ISCTL(*p)) {
447
+ TTYput(' ');
448
+ extras++;
449
+ }
450
+ else if (rl_meta_chars && ISMETA(*p)) {
451
+ TTYput(' ');
452
+ TTYput(' ');
453
+ extras += 2;
454
+ }
455
+ }
456
+
457
+ for (i += extras; i > Point; i--)
458
+ TTYback();
459
+ }
460
+
461
+ STATIC void
462
+ clear_line()
463
+ {
464
+ Point = -strlen(Prompt);
465
+ TTYput('\r');
466
+ ceol();
467
+ Point = 0;
468
+ End = 0;
469
+ Line[0] = '\0';
470
+ }
471
+
472
+ STATIC STATUS
473
+ insert_string(p)
474
+ CHAR *p;
475
+ {
476
+ SIZE_T len;
477
+ int i;
478
+ CHAR *new;
479
+ CHAR *q;
480
+
481
+ len = strlen((char *)p);
482
+ if (End + len >= Length) {
483
+ if ((new = NEW(CHAR, Length + len + MEM_INC)) == NULL)
484
+ return CSstay;
485
+ if (Length) {
486
+ COPYFROMTO(new, Line, Length);
487
+ DISPOSE(Line);
488
+ }
489
+ Line = new;
490
+ Length += len + MEM_INC;
491
+ }
492
+
493
+ for (q = &Line[Point], i = End - Point; --i >= 0; )
494
+ q[len + i] = q[i];
495
+ COPYFROMTO(&Line[Point], p, len);
496
+ End += len;
497
+ Line[End] = '\0';
498
+ TTYstring(&Line[Point]);
499
+ Point += len;
500
+
501
+ return Point == End ? CSstay : CSmove;
502
+ }
503
+
504
+ STATIC STATUS
505
+ redisplay()
506
+ {
507
+ TTYputs((CONST CHAR *)NEWLINE);
508
+ TTYputs((CONST CHAR *)Prompt);
509
+ TTYstring(Line);
510
+ return CSmove;
511
+ }
512
+
513
+ STATIC STATUS
514
+ toggle_meta_mode()
515
+ {
516
+ rl_meta_chars = ! rl_meta_chars;
517
+ return redisplay();
518
+ }
519
+
520
+
521
+ STATIC CHAR *
522
+ next_hist()
523
+ {
524
+ return H.Pos >= H.Size - 1 ? NULL : H.Lines[++H.Pos];
525
+ }
526
+
527
+ STATIC CHAR *
528
+ prev_hist()
529
+ {
530
+ return H.Pos == 0 ? NULL : H.Lines[--H.Pos];
531
+ }
532
+
533
+ STATIC STATUS
534
+ do_insert_hist(p)
535
+ CHAR *p;
536
+ {
537
+ if (p == NULL)
538
+ return ring_bell();
539
+ Point = 0;
540
+ reposition();
541
+ ceol();
542
+ End = 0;
543
+ return insert_string(p);
544
+ }
545
+
546
+ STATIC STATUS
547
+ do_hist(move)
548
+ CHAR *(*move)();
549
+ {
550
+ CHAR *p;
551
+ int i;
552
+
553
+ i = 0;
554
+ do {
555
+ if ((p = (*move)()) == NULL)
556
+ return ring_bell();
557
+ } while (++i < Repeat);
558
+ return do_insert_hist(p);
559
+ }
560
+
561
+ STATIC STATUS
562
+ h_next()
563
+ {
564
+ return do_hist(next_hist);
565
+ }
566
+
567
+ STATIC STATUS
568
+ h_prev()
569
+ {
570
+ return do_hist(prev_hist);
571
+ }
572
+
573
+ STATIC STATUS
574
+ h_first()
575
+ {
576
+ return do_insert_hist(H.Lines[H.Pos = 0]);
577
+ }
578
+
579
+ STATIC STATUS
580
+ h_last()
581
+ {
582
+ return do_insert_hist(H.Lines[H.Pos = H.Size - 1]);
583
+ }
584
+
585
+ /*
586
+ ** Return zero if pat appears as a substring in text.
587
+ */
588
+ STATIC int
589
+ substrcmp(text, pat, len)
590
+ char *text;
591
+ char *pat;
592
+ int len;
593
+ {
594
+ char c;
595
+
596
+ if ((c = *pat) == '\0')
597
+ return *text == '\0';
598
+ for ( ; *text; text++)
599
+ if (*text == c && strncmp(text, pat, len) == 0)
600
+ return 0;
601
+ return 1;
602
+ }
603
+
604
+ STATIC CHAR *
605
+ search_hist(search, move)
606
+ CHAR *search;
607
+ CHAR *(*move)();
608
+ {
609
+ static CHAR *old_search;
610
+ int len;
611
+ int pos;
612
+ int (*match)();
613
+ char *pat;
614
+
615
+ /* Save or get remembered search pattern. */
616
+ if (search && *search) {
617
+ if (old_search)
618
+ DISPOSE(old_search);
619
+ old_search = (CHAR *)strdup((char *)search);
620
+ }
621
+ else {
622
+ if (old_search == NULL || *old_search == '\0')
623
+ return NULL;
624
+ search = old_search;
625
+ }
626
+
627
+ /* Set up pattern-finder. */
628
+ if (*search == '^') {
629
+ match = strncmp;
630
+ pat = (char *)(search + 1);
631
+ }
632
+ else {
633
+ match = substrcmp;
634
+ pat = (char *)search;
635
+ }
636
+ len = strlen(pat);
637
+
638
+ for (pos = H.Pos; (*move)() != NULL; )
639
+ if ((*match)((char *)H.Lines[H.Pos], pat, len) == 0)
640
+ return H.Lines[H.Pos];
641
+ H.Pos = pos;
642
+ return NULL;
643
+ }
644
+
645
+ STATIC STATUS
646
+ h_search()
647
+ {
648
+ static int Searching;
649
+ CONST char *old_prompt;
650
+ CHAR *(*move)();
651
+ CHAR *p;
652
+
653
+ if (Searching)
654
+ return ring_bell();
655
+ Searching = 1;
656
+
657
+ clear_line();
658
+ old_prompt = Prompt;
659
+ Prompt = "Search: ";
660
+ TTYputs((CONST CHAR *)Prompt);
661
+ move = Repeat == NO_ARG ? prev_hist : next_hist;
662
+ p = editinput();
663
+ Prompt = old_prompt;
664
+ Searching = 0;
665
+ TTYputs((CONST CHAR *)Prompt);
666
+ if (p == NULL && Signal > 0) {
667
+ Signal = 0;
668
+ clear_line();
669
+ return redisplay();
670
+ }
671
+ p = search_hist(p, move);
672
+ clear_line();
673
+ if (p == NULL) {
674
+ (void)ring_bell();
675
+ return redisplay();
676
+ }
677
+ return do_insert_hist(p);
678
+ }
679
+
680
+ STATIC STATUS
681
+ fd_char()
682
+ {
683
+ int i;
684
+
685
+ i = 0;
686
+ do {
687
+ if (Point >= End)
688
+ break;
689
+ right(CSmove);
690
+ } while (++i < Repeat);
691
+ return CSstay;
692
+ }
693
+
694
+ STATIC void
695
+ save_yank(begin, i)
696
+ int begin;
697
+ int i;
698
+ {
699
+ if (Yanked) {
700
+ DISPOSE(Yanked);
701
+ Yanked = NULL;
702
+ }
703
+
704
+ if (i < 1)
705
+ return;
706
+
707
+ if ((Yanked = NEW(CHAR, (SIZE_T)i + 1)) != NULL) {
708
+ COPYFROMTO(Yanked, &Line[begin], i);
709
+ Yanked[i] = '\0';
710
+ }
711
+ }
712
+
713
+ STATIC STATUS
714
+ delete_string(count)
715
+ int count;
716
+ {
717
+ int i;
718
+ CHAR *p;
719
+
720
+ if (count <= 0 || End == Point)
721
+ return ring_bell();
722
+
723
+ if (count == 1 && Point == End - 1) {
724
+ /* Optimize common case of delete at end of line. */
725
+ End--;
726
+ p = &Line[Point];
727
+ i = 1;
728
+ TTYput(' ');
729
+ if (ISCTL(*p)) {
730
+ i = 2;
731
+ TTYput(' ');
732
+ }
733
+ else if (rl_meta_chars && ISMETA(*p)) {
734
+ i = 3;
735
+ TTYput(' ');
736
+ TTYput(' ');
737
+ }
738
+ TTYbackn(i);
739
+ *p = '\0';
740
+ return CSmove;
741
+ }
742
+ if (Point + count > End && (count = End - Point) <= 0)
743
+ return CSstay;
744
+
745
+ if (count > 1)
746
+ save_yank(Point, count);
747
+
748
+ for (p = &Line[Point], i = End - (Point + count) + 1; --i >= 0; p++)
749
+ p[0] = p[count];
750
+ ceol();
751
+ End -= count;
752
+ TTYstring(&Line[Point]);
753
+ return CSmove;
754
+ }
755
+
756
+ STATIC STATUS
757
+ bk_char()
758
+ {
759
+ int i;
760
+
761
+ i = 0;
762
+ do {
763
+ if (Point == 0)
764
+ break;
765
+ left(CSmove);
766
+ } while (++i < Repeat);
767
+
768
+ return CSstay;
769
+ }
770
+
771
+ STATIC STATUS
772
+ bk_del_char()
773
+ {
774
+ int i;
775
+
776
+ i = 0;
777
+ do {
778
+ if (Point == 0)
779
+ break;
780
+ left(CSmove);
781
+ } while (++i < Repeat);
782
+
783
+ return delete_string(i);
784
+ }
785
+
786
+ STATIC STATUS
787
+ kill_line()
788
+ {
789
+ int i;
790
+
791
+ if (Repeat != NO_ARG) {
792
+ if (Repeat < Point) {
793
+ i = Point;
794
+ Point = Repeat;
795
+ reposition();
796
+ (void)delete_string(i - Point);
797
+ }
798
+ else if (Repeat > Point) {
799
+ right(CSmove);
800
+ (void)delete_string(Repeat - Point - 1);
801
+ }
802
+ return CSmove;
803
+ }
804
+
805
+ save_yank(Point, End - Point);
806
+ Line[Point] = '\0';
807
+ ceol();
808
+ End = Point;
809
+ return CSstay;
810
+ }
811
+
812
+ STATIC STATUS
813
+ insert_char(c)
814
+ int c;
815
+ {
816
+ STATUS s;
817
+ CHAR buff[2];
818
+ CHAR *p;
819
+ CHAR *q;
820
+ int i;
821
+
822
+ if (Repeat == NO_ARG || Repeat < 2) {
823
+ buff[0] = c;
824
+ buff[1] = '\0';
825
+ return insert_string(buff);
826
+ }
827
+
828
+ if ((p = NEW(CHAR, Repeat + 1)) == NULL)
829
+ return CSstay;
830
+ for (i = Repeat, q = p; --i >= 0; )
831
+ *q++ = c;
832
+ *q = '\0';
833
+ Repeat = 0;
834
+ s = insert_string(p);
835
+ DISPOSE(p);
836
+ return s;
837
+ }
838
+
839
+ STATIC STATUS
840
+ meta()
841
+ {
842
+ unsigned int c;
843
+ KEYMAP *kp;
844
+
845
+ if ((c = TTYget()) == EOF)
846
+ return CSeof;
847
+ #if defined(ANSI_ARROWS)
848
+ /* Also include VT-100 arrows. */
849
+ if (c == '[' || c == 'O')
850
+ switch (c = TTYget()) {
851
+ default: return ring_bell();
852
+ case EOF: return CSeof;
853
+ case 'A': return h_prev();
854
+ case 'B': return h_next();
855
+ case 'C': return fd_char();
856
+ case 'D': return bk_char();
857
+ }
858
+ #endif /* defined(ANSI_ARROWS) */
859
+
860
+ if (isdigit(c)) {
861
+ for (Repeat = c - '0'; (c = TTYget()) != EOF && isdigit(c); )
862
+ Repeat = Repeat * 10 + c - '0';
863
+ Pushed = 1;
864
+ PushBack = c;
865
+ return CSstay;
866
+ }
867
+
868
+ if (isupper(c))
869
+ return do_macro(c);
870
+ for (OldPoint = Point, kp = MetaMap; kp->Function; kp++)
871
+ if (kp->Key == c)
872
+ return (*kp->Function)();
873
+
874
+ return ring_bell();
875
+ }
876
+
877
+ STATIC STATUS
878
+ emacs(c)
879
+ unsigned int c;
880
+ {
881
+ STATUS s;
882
+ KEYMAP *kp;
883
+
884
+ if (rl_meta_chars && ISMETA(c)) {
885
+ Pushed = 1;
886
+ PushBack = UNMETA(c);
887
+ return meta();
888
+ }
889
+ for (kp = Map; kp->Function; kp++)
890
+ if (kp->Key == c)
891
+ break;
892
+ s = kp->Function ? (*kp->Function)() : insert_char((int)c);
893
+ if (!Pushed)
894
+ /* No pushback means no repeat count; hacky, but true. */
895
+ Repeat = NO_ARG;
896
+ return s;
897
+ }
898
+
899
+ STATIC STATUS
900
+ TTYspecial(c)
901
+ unsigned int c;
902
+ {
903
+ if (ISMETA(c))
904
+ return CSdispatch;
905
+
906
+ if (c == rl_erase || c == DEL)
907
+ return bk_del_char();
908
+ if (c == rl_kill) {
909
+ if (Point != 0) {
910
+ Point = 0;
911
+ reposition();
912
+ }
913
+ Repeat = NO_ARG;
914
+ return kill_line();
915
+ }
916
+ if (c == rl_eof && Point == 0 && End == 0)
917
+ return CSeof;
918
+ if (c == rl_intr) {
919
+ Signal = SIGINT;
920
+ return CSsignal;
921
+ }
922
+ if (c == rl_quit) {
923
+ Signal = SIGQUIT;
924
+ return CSeof;
925
+ }
926
+
927
+ return CSdispatch;
928
+ }
929
+
930
+ STATIC CHAR *
931
+ editinput()
932
+ {
933
+ unsigned int c;
934
+
935
+ Repeat = NO_ARG;
936
+ OldPoint = Point = Mark = End = 0;
937
+ Line[0] = '\0';
938
+
939
+ Signal = -1;
940
+ while ((c = TTYget()) != EOF)
941
+ switch (TTYspecial(c)) {
942
+ case CSdone:
943
+ return Line;
944
+ case CSeof:
945
+ return NULL;
946
+ case CSsignal:
947
+ return (CHAR *)"";
948
+ case CSmove:
949
+ reposition();
950
+ break;
951
+ case CSdispatch:
952
+ switch (emacs(c)) {
953
+ case CSdone:
954
+ return Line;
955
+ case CSeof:
956
+ return NULL;
957
+ case CSsignal:
958
+ return (CHAR *)"";
959
+ case CSmove:
960
+ reposition();
961
+ break;
962
+ case CSdispatch:
963
+ case CSstay:
964
+ break;
965
+ }
966
+ break;
967
+ case CSstay:
968
+ break;
969
+ }
970
+ return NULL;
971
+ }
972
+
973
+ STATIC void
974
+ hist_add(p)
975
+ CHAR *p;
976
+ {
977
+ int i;
978
+
979
+ if ((p = (CHAR *)strdup((char *)p)) == NULL)
980
+ return;
981
+ if (H.Size < HIST_SIZE)
982
+ H.Lines[H.Size++] = p;
983
+ else {
984
+ DISPOSE(H.Lines[0]);
985
+ for (i = 0; i < HIST_SIZE - 1; i++)
986
+ H.Lines[i] = H.Lines[i + 1];
987
+ H.Lines[i] = p;
988
+ }
989
+ H.Pos = H.Size - 1;
990
+ }
991
+
992
+ /*
993
+ ** For compatibility with FSF readline.
994
+ */
995
+ /* ARGSUSED0 */
996
+ void
997
+ rl_reset_terminal(p)
998
+ char *p;
999
+ {
1000
+ }
1001
+
1002
+ void
1003
+ rl_initialize()
1004
+ {
1005
+ }
1006
+
1007
+ char *
1008
+ readline(prompt)
1009
+ CONST char *prompt;
1010
+ {
1011
+ CHAR *line;
1012
+ int s;
1013
+
1014
+ if (Line == NULL) {
1015
+ Length = MEM_INC;
1016
+ if ((Line = NEW(CHAR, Length)) == NULL)
1017
+ return NULL;
1018
+ }
1019
+
1020
+ TTYinfo();
1021
+ rl_ttyset(0);
1022
+ hist_add(NIL);
1023
+ ScreenSize = SCREEN_INC;
1024
+ Screen = NEW(char, ScreenSize);
1025
+ Prompt = prompt ? prompt : (char *)NIL;
1026
+ TTYputs((CONST CHAR *)Prompt);
1027
+ if ((line = editinput()) != NULL) {
1028
+ line = (CHAR *)strdup((char *)line);
1029
+ TTYputs((CHAR *)NEWLINE);
1030
+ TTYflush();
1031
+ }
1032
+ rl_ttyset(1);
1033
+ DISPOSE(Screen);
1034
+ DISPOSE(H.Lines[--H.Size]);
1035
+ if (Signal > 0) {
1036
+ s = Signal;
1037
+ Signal = 0;
1038
+ (void)kill(getpid(), s);
1039
+ }
1040
+ return (char *)line;
1041
+ }
1042
+
1043
+ void
1044
+ add_history(p)
1045
+ char *p;
1046
+ {
1047
+ if (p == NULL || *p == '\0')
1048
+ return;
1049
+
1050
+ #if defined(UNIQUE_HISTORY)
1051
+ if (H.Size && strcmp(p, H.Lines[H.Size - 1]) == 0)
1052
+ return;
1053
+ #endif /* defined(UNIQUE_HISTORY) */
1054
+ hist_add((CHAR *)p);
1055
+ }
1056
+
1057
+
1058
+ STATIC STATUS
1059
+ beg_line()
1060
+ {
1061
+ if (Point) {
1062
+ Point = 0;
1063
+ return CSmove;
1064
+ }
1065
+ return CSstay;
1066
+ }
1067
+
1068
+ STATIC STATUS
1069
+ del_char()
1070
+ {
1071
+ return delete_string(Repeat == NO_ARG ? 1 : Repeat);
1072
+ }
1073
+
1074
+ STATIC STATUS
1075
+ end_line()
1076
+ {
1077
+ if (Point != End) {
1078
+ Point = End;
1079
+ return CSmove;
1080
+ }
1081
+ return CSstay;
1082
+ }
1083
+
1084
+ STATIC STATUS
1085
+ accept_line()
1086
+ {
1087
+ Line[End] = '\0';
1088
+ return CSdone;
1089
+ }
1090
+
1091
+ STATIC STATUS
1092
+ transpose()
1093
+ {
1094
+ CHAR c;
1095
+
1096
+ if (Point) {
1097
+ if (Point == End)
1098
+ left(CSmove);
1099
+ c = Line[Point - 1];
1100
+ left(CSstay);
1101
+ Line[Point - 1] = Line[Point];
1102
+ TTYshow(Line[Point - 1]);
1103
+ Line[Point++] = c;
1104
+ TTYshow(c);
1105
+ }
1106
+ return CSstay;
1107
+ }
1108
+
1109
+ STATIC STATUS
1110
+ quote()
1111
+ {
1112
+ unsigned int c;
1113
+
1114
+ return (c = TTYget()) == EOF ? CSeof : insert_char((int)c);
1115
+ }
1116
+
1117
+ STATIC STATUS
1118
+ wipe()
1119
+ {
1120
+ int i;
1121
+
1122
+ if (Mark > End)
1123
+ return ring_bell();
1124
+
1125
+ if (Point > Mark) {
1126
+ i = Point;
1127
+ Point = Mark;
1128
+ Mark = i;
1129
+ reposition();
1130
+ }
1131
+
1132
+ return delete_string(Mark - Point);
1133
+ }
1134
+
1135
+ STATIC STATUS
1136
+ mk_set()
1137
+ {
1138
+ Mark = Point;
1139
+ return CSstay;
1140
+ }
1141
+
1142
+ STATIC STATUS
1143
+ exchange()
1144
+ {
1145
+ unsigned int c;
1146
+
1147
+ if ((c = TTYget()) != CTL('X'))
1148
+ return c == EOF ? CSeof : ring_bell();
1149
+
1150
+ if ((c = Mark) <= End) {
1151
+ Mark = Point;
1152
+ Point = c;
1153
+ return CSmove;
1154
+ }
1155
+ return CSstay;
1156
+ }
1157
+
1158
+ STATIC STATUS
1159
+ yank()
1160
+ {
1161
+ if (Yanked && *Yanked)
1162
+ return insert_string(Yanked);
1163
+ return CSstay;
1164
+ }
1165
+
1166
+ STATIC STATUS
1167
+ copy_region()
1168
+ {
1169
+ if (Mark > End)
1170
+ return ring_bell();
1171
+
1172
+ if (Point > Mark)
1173
+ save_yank(Mark, Point - Mark);
1174
+ else
1175
+ save_yank(Point, Mark - Point);
1176
+
1177
+ return CSstay;
1178
+ }
1179
+
1180
+ STATIC STATUS
1181
+ move_to_char()
1182
+ {
1183
+ unsigned int c;
1184
+ int i;
1185
+ CHAR *p;
1186
+
1187
+ if ((c = TTYget()) == EOF)
1188
+ return CSeof;
1189
+ for (i = Point + 1, p = &Line[i]; i < End; i++, p++)
1190
+ if (*p == c) {
1191
+ Point = i;
1192
+ return CSmove;
1193
+ }
1194
+ return CSstay;
1195
+ }
1196
+
1197
+ STATIC STATUS
1198
+ fd_word()
1199
+ {
1200
+ return do_forward(CSmove);
1201
+ }
1202
+
1203
+ STATIC STATUS
1204
+ fd_kill_word()
1205
+ {
1206
+ int i;
1207
+
1208
+ (void)do_forward(CSstay);
1209
+ if (OldPoint != Point) {
1210
+ i = Point - OldPoint;
1211
+ Point = OldPoint;
1212
+ return delete_string(i);
1213
+ }
1214
+ return CSstay;
1215
+ }
1216
+
1217
+ STATIC STATUS
1218
+ bk_word()
1219
+ {
1220
+ int i;
1221
+ CHAR *p;
1222
+
1223
+ i = 0;
1224
+ do {
1225
+ for (p = &Line[Point]; p > Line && !isalnum(p[-1]); p--)
1226
+ left(CSmove);
1227
+
1228
+ for (; p > Line && p[-1] != ' ' && isalnum(p[-1]); p--)
1229
+ left(CSmove);
1230
+
1231
+ if (Point == 0)
1232
+ break;
1233
+ } while (++i < Repeat);
1234
+
1235
+ return CSstay;
1236
+ }
1237
+
1238
+ STATIC STATUS
1239
+ bk_kill_word()
1240
+ {
1241
+ (void)bk_word();
1242
+ if (OldPoint != Point)
1243
+ return delete_string(OldPoint - Point);
1244
+ return CSstay;
1245
+ }
1246
+
1247
+ STATIC int
1248
+ argify(line, avp)
1249
+ CHAR *line;
1250
+ CHAR ***avp;
1251
+ {
1252
+ CHAR *c;
1253
+ CHAR **p;
1254
+ CHAR **new;
1255
+ int ac;
1256
+ int i;
1257
+
1258
+ i = MEM_INC;
1259
+ if ((*avp = p = NEW(CHAR*, i))== NULL)
1260
+ return 0;
1261
+
1262
+ for (c = line; isspace(*c); c++)
1263
+ continue;
1264
+ if (*c == '\n' || *c == '\0')
1265
+ return 0;
1266
+
1267
+ for (ac = 0, p[ac++] = c; *c && *c != '\n'; ) {
1268
+ if (isspace(*c)) {
1269
+ *c++ = '\0';
1270
+ if (*c && *c != '\n') {
1271
+ if (ac + 1 == i) {
1272
+ new = NEW(CHAR*, i + MEM_INC);
1273
+ if (new == NULL) {
1274
+ p[ac] = NULL;
1275
+ return ac;
1276
+ }
1277
+ COPYFROMTO(new, p, i * sizeof (char **));
1278
+ i += MEM_INC;
1279
+ DISPOSE(p);
1280
+ *avp = p = new;
1281
+ }
1282
+ p[ac++] = c;
1283
+ }
1284
+ }
1285
+ else
1286
+ c++;
1287
+ }
1288
+ *c = '\0';
1289
+ p[ac] = NULL;
1290
+ return ac;
1291
+ }
1292
+
1293
+ STATIC STATUS
1294
+ last_argument()
1295
+ {
1296
+ CHAR **av;
1297
+ CHAR *p;
1298
+ STATUS s;
1299
+ int ac;
1300
+
1301
+ if (H.Size == 1 || (p = H.Lines[H.Size - 2]) == NULL)
1302
+ return ring_bell();
1303
+
1304
+ if ((p = (CHAR *)strdup((char *)p)) == NULL)
1305
+ return CSstay;
1306
+ ac = argify(p, &av);
1307
+
1308
+ if (Repeat != NO_ARG)
1309
+ s = Repeat < ac ? insert_string(av[Repeat]) : ring_bell();
1310
+ else
1311
+ s = ac ? insert_string(av[ac - 1]) : CSstay;
1312
+
1313
+ if (ac)
1314
+ DISPOSE(av);
1315
+ DISPOSE(p);
1316
+ return s;
1317
+ }
1318
+
1319
+ STATIC KEYMAP Map[32] = {
1320
+ { CTL('@'), ring_bell },
1321
+ { CTL('A'), beg_line },
1322
+ { CTL('B'), bk_char },
1323
+ { CTL('D'), del_char },
1324
+ { CTL('E'), end_line },
1325
+ { CTL('F'), fd_char },
1326
+ { CTL('G'), ring_bell },
1327
+ { CTL('H'), bk_del_char },
1328
+ { CTL('J'), accept_line },
1329
+ { CTL('K'), kill_line },
1330
+ { CTL('L'), redisplay },
1331
+ { CTL('M'), accept_line },
1332
+ { CTL('N'), h_next },
1333
+ { CTL('O'), ring_bell },
1334
+ { CTL('P'), h_prev },
1335
+ { CTL('Q'), ring_bell },
1336
+ { CTL('R'), h_search },
1337
+ { CTL('S'), ring_bell },
1338
+ { CTL('T'), transpose },
1339
+ { CTL('U'), ring_bell },
1340
+ { CTL('V'), quote },
1341
+ { CTL('W'), wipe },
1342
+ { CTL('X'), exchange },
1343
+ { CTL('Y'), yank },
1344
+ { CTL('Z'), ring_bell },
1345
+ { CTL('['), meta },
1346
+ { CTL(']'), move_to_char },
1347
+ { CTL('^'), ring_bell },
1348
+ { CTL('_'), ring_bell },
1349
+ { 0, NULL }
1350
+ };
1351
+
1352
+ STATIC KEYMAP MetaMap[16]= {
1353
+ { CTL('H'), bk_kill_word },
1354
+ { DEL, bk_kill_word },
1355
+ { ' ', mk_set },
1356
+ { '.', last_argument },
1357
+ { '<', h_first },
1358
+ { '>', h_last },
1359
+ { 'b', bk_word },
1360
+ { 'd', fd_kill_word },
1361
+ { 'f', fd_word },
1362
+ { 'l', case_down_word },
1363
+ { 'm', toggle_meta_mode },
1364
+ { 'u', case_up_word },
1365
+ { 'y', yank },
1366
+ { 'w', copy_region },
1367
+ { 0, NULL }
1368
+ };
1369
+