jbarnette-johnson 1.0.0.200806240111 → 1.0.0.200807291507

Sign up to get free protection for your applications and to get access to all the features.
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
+