highline 1.6.8 → 1.6.9

Sign up to get free protection for your applications and to get access to all the features.
data/.gitignore ADDED
@@ -0,0 +1,2 @@
1
+ doc
2
+ pkg
data/AUTHORS ADDED
@@ -0,0 +1,3 @@
1
+ James Edward Gray II:: {james@grayproductions.net}[mailto:james@grayproductions.net]
2
+ Gregory Brown:: {gregory.t.brown@gmail.com}[mailto:gregory.t.brown@gmail.com]
3
+ Richard LeBer:: {richard.leber@gmail.com}[mailto:richard.leber@gmail.com]
data/CHANGELOG CHANGED
@@ -2,6 +2,13 @@
2
2
 
3
3
  Below is a complete listing of changes for each revision of HighLine.
4
4
 
5
+ == 1.6.9
6
+
7
+ * The new list modes now properly ignore escapes when sizing.
8
+ * Added a project gemspec file.
9
+ * Fixed a bug that prevented the use of termios (by tomdz).
10
+ * Switch to JLine to provide better echo support on JRuby (by tomdz).
11
+
5
12
  == 1.6.8
6
13
 
7
14
  * Fix missing <tt>ERASE_CHAR</tt> reference (by Aaron Gifford).
data/COPYING ADDED
@@ -0,0 +1,340 @@
1
+ GNU GENERAL PUBLIC LICENSE
2
+ Version 2, June 1991
3
+
4
+ Copyright (C) 1989, 1991 Free Software Foundation, Inc.
5
+ 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
6
+ Everyone is permitted to copy and distribute verbatim copies
7
+ of this license document, but changing it is not allowed.
8
+
9
+ Preamble
10
+
11
+ The licenses for most software are designed to take away your
12
+ freedom to share and change it. By contrast, the GNU General Public
13
+ License is intended to guarantee your freedom to share and change free
14
+ software--to make sure the software is free for all its users. This
15
+ General Public License applies to most of the Free Software
16
+ Foundation's software and to any other program whose authors commit to
17
+ using it. (Some other Free Software Foundation software is covered by
18
+ the GNU Library General Public License instead.) You can apply it to
19
+ your programs, too.
20
+
21
+ When we speak of free software, we are referring to freedom, not
22
+ price. Our General Public Licenses are designed to make sure that you
23
+ have the freedom to distribute copies of free software (and charge for
24
+ this service if you wish), that you receive source code or can get it
25
+ if you want it, that you can change the software or use pieces of it
26
+ in new free programs; and that you know you can do these things.
27
+
28
+ To protect your rights, we need to make restrictions that forbid
29
+ anyone to deny you these rights or to ask you to surrender the rights.
30
+ These restrictions translate to certain responsibilities for you if you
31
+ distribute copies of the software, or if you modify it.
32
+
33
+ For example, if you distribute copies of such a program, whether
34
+ gratis or for a fee, you must give the recipients all the rights that
35
+ you have. You must make sure that they, too, receive or can get the
36
+ source code. And you must show them these terms so they know their
37
+ rights.
38
+
39
+ We protect your rights with two steps: (1) copyright the software, and
40
+ (2) offer you this license which gives you legal permission to copy,
41
+ distribute and/or modify the software.
42
+
43
+ Also, for each author's protection and ours, we want to make certain
44
+ that everyone understands that there is no warranty for this free
45
+ software. If the software is modified by someone else and passed on, we
46
+ want its recipients to know that what they have is not the original, so
47
+ that any problems introduced by others will not reflect on the original
48
+ authors' reputations.
49
+
50
+ Finally, any free program is threatened constantly by software
51
+ patents. We wish to avoid the danger that redistributors of a free
52
+ program will individually obtain patent licenses, in effect making the
53
+ program proprietary. To prevent this, we have made it clear that any
54
+ patent must be licensed for everyone's free use or not licensed at all.
55
+
56
+ The precise terms and conditions for copying, distribution and
57
+ modification follow.
58
+
59
+ GNU GENERAL PUBLIC LICENSE
60
+ TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
61
+
62
+ 0. This License applies to any program or other work which contains
63
+ a notice placed by the copyright holder saying it may be distributed
64
+ under the terms of this General Public License. The "Program", below,
65
+ refers to any such program or work, and a "work based on the Program"
66
+ means either the Program or any derivative work under copyright law:
67
+ that is to say, a work containing the Program or a portion of it,
68
+ either verbatim or with modifications and/or translated into another
69
+ language. (Hereinafter, translation is included without limitation in
70
+ the term "modification".) Each licensee is addressed as "you".
71
+
72
+ Activities other than copying, distribution and modification are not
73
+ covered by this License; they are outside its scope. The act of
74
+ running the Program is not restricted, and the output from the Program
75
+ is covered only if its contents constitute a work based on the
76
+ Program (independent of having been made by running the Program).
77
+ Whether that is true depends on what the Program does.
78
+
79
+ 1. You may copy and distribute verbatim copies of the Program's
80
+ source code as you receive it, in any medium, provided that you
81
+ conspicuously and appropriately publish on each copy an appropriate
82
+ copyright notice and disclaimer of warranty; keep intact all the
83
+ notices that refer to this License and to the absence of any warranty;
84
+ and give any other recipients of the Program a copy of this License
85
+ along with the Program.
86
+
87
+ You may charge a fee for the physical act of transferring a copy, and
88
+ you may at your option offer warranty protection in exchange for a fee.
89
+
90
+ 2. You may modify your copy or copies of the Program or any portion
91
+ of it, thus forming a work based on the Program, and copy and
92
+ distribute such modifications or work under the terms of Section 1
93
+ above, provided that you also meet all of these conditions:
94
+
95
+ a) You must cause the modified files to carry prominent notices
96
+ stating that you changed the files and the date of any change.
97
+
98
+ b) You must cause any work that you distribute or publish, that in
99
+ whole or in part contains or is derived from the Program or any
100
+ part thereof, to be licensed as a whole at no charge to all third
101
+ parties under the terms of this License.
102
+
103
+ c) If the modified program normally reads commands interactively
104
+ when run, you must cause it, when started running for such
105
+ interactive use in the most ordinary way, to print or display an
106
+ announcement including an appropriate copyright notice and a
107
+ notice that there is no warranty (or else, saying that you provide
108
+ a warranty) and that users may redistribute the program under
109
+ these conditions, and telling the user how to view a copy of this
110
+ License. (Exception: if the Program itself is interactive but
111
+ does not normally print such an announcement, your work based on
112
+ the Program is not required to print an announcement.)
113
+
114
+ These requirements apply to the modified work as a whole. If
115
+ identifiable sections of that work are not derived from the Program,
116
+ and can be reasonably considered independent and separate works in
117
+ themselves, then this License, and its terms, do not apply to those
118
+ sections when you distribute them as separate works. But when you
119
+ distribute the same sections as part of a whole which is a work based
120
+ on the Program, the distribution of the whole must be on the terms of
121
+ this License, whose permissions for other licensees extend to the
122
+ entire whole, and thus to each and every part regardless of who wrote it.
123
+
124
+ Thus, it is not the intent of this section to claim rights or contest
125
+ your rights to work written entirely by you; rather, the intent is to
126
+ exercise the right to control the distribution of derivative or
127
+ collective works based on the Program.
128
+
129
+ In addition, mere aggregation of another work not based on the Program
130
+ with the Program (or with a work based on the Program) on a volume of
131
+ a storage or distribution medium does not bring the other work under
132
+ the scope of this License.
133
+
134
+ 3. You may copy and distribute the Program (or a work based on it,
135
+ under Section 2) in object code or executable form under the terms of
136
+ Sections 1 and 2 above provided that you also do one of the following:
137
+
138
+ a) Accompany it with the complete corresponding machine-readable
139
+ source code, which must be distributed under the terms of Sections
140
+ 1 and 2 above on a medium customarily used for software interchange; or,
141
+
142
+ b) Accompany it with a written offer, valid for at least three
143
+ years, to give any third party, for a charge no more than your
144
+ cost of physically performing source distribution, a complete
145
+ machine-readable copy of the corresponding source code, to be
146
+ distributed under the terms of Sections 1 and 2 above on a medium
147
+ customarily used for software interchange; or,
148
+
149
+ c) Accompany it with the information you received as to the offer
150
+ to distribute corresponding source code. (This alternative is
151
+ allowed only for noncommercial distribution and only if you
152
+ received the program in object code or executable form with such
153
+ an offer, in accord with Subsection b above.)
154
+
155
+ The source code for a work means the preferred form of the work for
156
+ making modifications to it. For an executable work, complete source
157
+ code means all the source code for all modules it contains, plus any
158
+ associated interface definition files, plus the scripts used to
159
+ control compilation and installation of the executable. However, as a
160
+ special exception, the source code distributed need not include
161
+ anything that is normally distributed (in either source or binary
162
+ form) with the major components (compiler, kernel, and so on) of the
163
+ operating system on which the executable runs, unless that component
164
+ itself accompanies the executable.
165
+
166
+ If distribution of executable or object code is made by offering
167
+ access to copy from a designated place, then offering equivalent
168
+ access to copy the source code from the same place counts as
169
+ distribution of the source code, even though third parties are not
170
+ compelled to copy the source along with the object code.
171
+
172
+ 4. You may not copy, modify, sublicense, or distribute the Program
173
+ except as expressly provided under this License. Any attempt
174
+ otherwise to copy, modify, sublicense or distribute the Program is
175
+ void, and will automatically terminate your rights under this License.
176
+ However, parties who have received copies, or rights, from you under
177
+ this License will not have their licenses terminated so long as such
178
+ parties remain in full compliance.
179
+
180
+ 5. You are not required to accept this License, since you have not
181
+ signed it. However, nothing else grants you permission to modify or
182
+ distribute the Program or its derivative works. These actions are
183
+ prohibited by law if you do not accept this License. Therefore, by
184
+ modifying or distributing the Program (or any work based on the
185
+ Program), you indicate your acceptance of this License to do so, and
186
+ all its terms and conditions for copying, distributing or modifying
187
+ the Program or works based on it.
188
+
189
+ 6. Each time you redistribute the Program (or any work based on the
190
+ Program), the recipient automatically receives a license from the
191
+ original licensor to copy, distribute or modify the Program subject to
192
+ these terms and conditions. You may not impose any further
193
+ restrictions on the recipients' exercise of the rights granted herein.
194
+ You are not responsible for enforcing compliance by third parties to
195
+ this License.
196
+
197
+ 7. If, as a consequence of a court judgment or allegation of patent
198
+ infringement or for any other reason (not limited to patent issues),
199
+ conditions are imposed on you (whether by court order, agreement or
200
+ otherwise) that contradict the conditions of this License, they do not
201
+ excuse you from the conditions of this License. If you cannot
202
+ distribute so as to satisfy simultaneously your obligations under this
203
+ License and any other pertinent obligations, then as a consequence you
204
+ may not distribute the Program at all. For example, if a patent
205
+ license would not permit royalty-free redistribution of the Program by
206
+ all those who receive copies directly or indirectly through you, then
207
+ the only way you could satisfy both it and this License would be to
208
+ refrain entirely from distribution of the Program.
209
+
210
+ If any portion of this section is held invalid or unenforceable under
211
+ any particular circumstance, the balance of the section is intended to
212
+ apply and the section as a whole is intended to apply in other
213
+ circumstances.
214
+
215
+ It is not the purpose of this section to induce you to infringe any
216
+ patents or other property right claims or to contest validity of any
217
+ such claims; this section has the sole purpose of protecting the
218
+ integrity of the free software distribution system, which is
219
+ implemented by public license practices. Many people have made
220
+ generous contributions to the wide range of software distributed
221
+ through that system in reliance on consistent application of that
222
+ system; it is up to the author/donor to decide if he or she is willing
223
+ to distribute software through any other system and a licensee cannot
224
+ impose that choice.
225
+
226
+ This section is intended to make thoroughly clear what is believed to
227
+ be a consequence of the rest of this License.
228
+
229
+ 8. If the distribution and/or use of the Program is restricted in
230
+ certain countries either by patents or by copyrighted interfaces, the
231
+ original copyright holder who places the Program under this License
232
+ may add an explicit geographical distribution limitation excluding
233
+ those countries, so that distribution is permitted only in or among
234
+ countries not thus excluded. In such case, this License incorporates
235
+ the limitation as if written in the body of this License.
236
+
237
+ 9. The Free Software Foundation may publish revised and/or new versions
238
+ of the General Public License from time to time. Such new versions will
239
+ be similar in spirit to the present version, but may differ in detail to
240
+ address new problems or concerns.
241
+
242
+ Each version is given a distinguishing version number. If the Program
243
+ specifies a version number of this License which applies to it and "any
244
+ later version", you have the option of following the terms and conditions
245
+ either of that version or of any later version published by the Free
246
+ Software Foundation. If the Program does not specify a version number of
247
+ this License, you may choose any version ever published by the Free Software
248
+ Foundation.
249
+
250
+ 10. If you wish to incorporate parts of the Program into other free
251
+ programs whose distribution conditions are different, write to the author
252
+ to ask for permission. For software which is copyrighted by the Free
253
+ Software Foundation, write to the Free Software Foundation; we sometimes
254
+ make exceptions for this. Our decision will be guided by the two goals
255
+ of preserving the free status of all derivatives of our free software and
256
+ of promoting the sharing and reuse of software generally.
257
+
258
+ NO WARRANTY
259
+
260
+ 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
261
+ FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
262
+ OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
263
+ PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
264
+ OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
265
+ MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
266
+ TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
267
+ PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
268
+ REPAIR OR CORRECTION.
269
+
270
+ 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
271
+ WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
272
+ REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
273
+ INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
274
+ OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
275
+ TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
276
+ YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
277
+ PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
278
+ POSSIBILITY OF SUCH DAMAGES.
279
+
280
+ END OF TERMS AND CONDITIONS
281
+
282
+ How to Apply These Terms to Your New Programs
283
+
284
+ If you develop a new program, and you want it to be of the greatest
285
+ possible use to the public, the best way to achieve this is to make it
286
+ free software which everyone can redistribute and change under these terms.
287
+
288
+ To do so, attach the following notices to the program. It is safest
289
+ to attach them to the start of each source file to most effectively
290
+ convey the exclusion of warranty; and each file should have at least
291
+ the "copyright" line and a pointer to where the full notice is found.
292
+
293
+ <one line to give the program's name and a brief idea of what it does.>
294
+ Copyright (C) <year> <name of author>
295
+
296
+ This program is free software; you can redistribute it and/or modify
297
+ it under the terms of the GNU General Public License as published by
298
+ the Free Software Foundation; either version 2 of the License, or
299
+ (at your option) any later version.
300
+
301
+ This program is distributed in the hope that it will be useful,
302
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
303
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
304
+ GNU General Public License for more details.
305
+
306
+ You should have received a copy of the GNU General Public License
307
+ along with this program; if not, write to the Free Software
308
+ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
309
+
310
+
311
+ Also add information on how to contact you by electronic and paper mail.
312
+
313
+ If the program is interactive, make it output a short notice like this
314
+ when it starts in an interactive mode:
315
+
316
+ Gnomovision version 69, Copyright (C) year name of author
317
+ Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
318
+ This is free software, and you are welcome to redistribute it
319
+ under certain conditions; type `show c' for details.
320
+
321
+ The hypothetical commands `show w' and `show c' should show the appropriate
322
+ parts of the General Public License. Of course, the commands you use may
323
+ be called something other than `show w' and `show c'; they could even be
324
+ mouse-clicks or menu items--whatever suits your program.
325
+
326
+ You should also get your employer (if you work as a programmer) or your
327
+ school, if any, to sign a "copyright disclaimer" for the program, if
328
+ necessary. Here is a sample; alter the names:
329
+
330
+ Yoyodyne, Inc., hereby disclaims all copyright interest in the program
331
+ `Gnomovision' (which makes passes at compilers) written by James Hacker.
332
+
333
+ <signature of Ty Coon>, 1 April 1989
334
+ Ty Coon, President of Vice
335
+
336
+ This General Public License does not permit incorporating your program into
337
+ proprietary programs. If your program is a subroutine library, you may
338
+ consider it more useful to permit linking proprietary applications with the
339
+ library. If this is what you want to do, use the GNU Library General
340
+ Public License instead of this License.
data/Rakefile CHANGED
@@ -34,38 +34,9 @@ task :upload_docs => [:rdoc] do
34
34
  "bbazzarrakk@rubyforge.org:/var/www/gforge-projects/highline/"
35
35
  end
36
36
 
37
- spec = Gem::Specification.new do |spec|
38
- spec.name = "highline"
39
- spec.version = version
40
- spec.platform = Gem::Platform::RUBY
41
- spec.summary = "HighLine is a high-level command-line IO library."
42
- spec.files = Dir.glob("{examples,lib,test}/**/*.rb").
43
- delete_if { |item| item.include?("CVS") } +
44
- ["Rakefile", "setup.rb"]
45
-
46
- spec.test_files = "test/ts_all.rb"
47
- spec.has_rdoc = true
48
- spec.extra_rdoc_files = %w{README INSTALL TODO CHANGELOG LICENSE}
49
- spec.rdoc_options << '--title' << 'HighLine Documentation' <<
50
- '--main' << 'README'
51
-
52
- spec.require_path = 'lib'
53
-
54
- spec.author = "James Edward Gray II"
55
- spec.email = "james@grayproductions.net"
56
- spec.rubyforge_project = "highline"
57
- spec.homepage = "http://highline.rubyforge.org"
58
- spec.description = <<END_DESC
59
- A high-level IO library that provides validation, type conversion, and more for
60
- command-line interfaces. HighLine also includes a complete menu system that can
61
- crank out anything from simple list selection to complete shells with just
62
- minutes of work.
63
- END_DESC
64
- end
65
-
66
- Gem::PackageTask.new(spec) do |pkg|
67
- pkg.need_zip = true
68
- pkg.need_tar = true
37
+ load(File.join(File.dirname(__FILE__), "highline.gemspec"))
38
+ Gem::PackageTask.new(SPEC) do |package|
39
+ # do nothing: I just need a gem but this block is required
69
40
  end
70
41
 
71
42
  desc "Show library's code statistics"
data/doc/.cvsignore ADDED
@@ -0,0 +1 @@
1
+ html
data/highline.gemspec ADDED
@@ -0,0 +1,36 @@
1
+ DIR = File.dirname(__FILE__)
2
+ LIB = File.join(DIR, *%w[lib highline.rb])
3
+ VERSION = open(LIB) { |lib|
4
+ lib.each { |line|
5
+ if v = line[/^\s*VERSION\s*=\s*(['"])(\d\.\d\.\d)\1/, 2]
6
+ break v
7
+ end
8
+ }
9
+ }
10
+
11
+ SPEC = Gem::Specification.new do |spec|
12
+ spec.name = "highline"
13
+ spec.version = VERSION
14
+ spec.platform = Gem::Platform::RUBY
15
+ spec.summary = "HighLine is a high-level command-line IO library."
16
+ spec.files = `git ls-files`.split("\n")
17
+
18
+ spec.test_files = `git ls-files -- test/*.rb`.split("\n")
19
+ spec.has_rdoc = true
20
+ spec.extra_rdoc_files = %w{README INSTALL TODO CHANGELOG LICENSE}
21
+ spec.rdoc_options << '--title' << 'HighLine Documentation' <<
22
+ '--main' << 'README'
23
+
24
+ spec.require_path = 'lib'
25
+
26
+ spec.author = "James Edward Gray II"
27
+ spec.email = "james@graysoftinc.com"
28
+ spec.rubyforge_project = "highline"
29
+ spec.homepage = "http://highline.rubyforge.org"
30
+ spec.description = <<END_DESC
31
+ A high-level IO library that provides validation, type conversion, and more for
32
+ command-line interfaces. HighLine also includes a complete menu system that can
33
+ crank out anything from simple list selection to complete shells with just
34
+ minutes of work.
35
+ END_DESC
36
+ end
@@ -61,7 +61,6 @@ class HighLine
61
61
  end
62
62
  rescue LoadError # If we're not on Windows try...
63
63
  begin
64
- raise LoadError
65
64
  require "termios" # Unix, first choice termios.
66
65
 
67
66
  CHARACTER_MODE = "termios" # For Debugging purposes only.
@@ -97,7 +96,7 @@ class HighLine
97
96
  CHARACTER_MODE = "ncurses" # For Debugging purposes only.
98
97
 
99
98
  #
100
- # ncurses savvy getc(). (JRuby choice.)
99
+ # ncurses savvy getc().
101
100
  #
102
101
  def get_character( input = STDIN )
103
102
  FFI::NCurses.initscr
@@ -111,13 +110,6 @@ class HighLine
111
110
  end
112
111
 
113
112
  rescue LoadError => e # If the ffi-ncurses choice fails, try using stty
114
- if JRUBY
115
- if e.message =~ /^no such file to load/
116
- STDERR.puts "\n*** Using highline effectively in JRuby requires manually installing the ffi-ncurses gem.\n*** jruby -S gem install ffi-ncurses"
117
- else
118
- raise
119
- end
120
- end
121
113
  CHARACTER_MODE = "stty" # For Debugging purposes only.
122
114
 
123
115
  #
data/lib/highline.rb CHANGED
@@ -30,7 +30,7 @@ require "highline/style"
30
30
  #
31
31
  class HighLine
32
32
  # The version of the installed library.
33
- VERSION = "1.6.8".freeze
33
+ VERSION = "1.6.9".freeze
34
34
 
35
35
  # An internal HighLine error. User code does not need to trap this.
36
36
  class QuestionError < StandardError
@@ -179,6 +179,21 @@ class HighLine
179
179
  wrap_at = nil, page_at = nil )
180
180
  @input = input
181
181
  @output = output
182
+ if JRUBY
183
+ require 'java'
184
+ java_import 'java.io.OutputStreamWriter'
185
+ java_import 'java.nio.channels.Channels'
186
+ java_import 'jline.ConsoleReader'
187
+ java_import 'jline.Terminal'
188
+
189
+ @java_input = Channels.newInputStream($stdin.to_channel)
190
+ @java_output = OutputStreamWriter.new(Channels.newOutputStream($stdout.to_channel))
191
+ @java_terminal = Terminal.getTerminal
192
+ @java_console = ConsoleReader.new(@java_input, @java_output)
193
+ @java_console.setUseHistory(false)
194
+ @java_console.setBellEnabled(true)
195
+ @java_console.setUsePagination(false)
196
+ end
182
197
 
183
198
  self.wrap_at = wrap_at
184
199
  self.page_at = page_at
@@ -449,8 +464,8 @@ class HighLine
449
464
  option = (limit + 2) / (max_length + 2)
450
465
  end
451
466
 
452
- items = items.map do |item|
453
- pad = max_length + (item.length - actual_length(item))
467
+ items = items.map do |item|
468
+ pad = max_length + (item.to_s.length - actual_length(item))
454
469
  "%-#{pad}s" % item
455
470
  end
456
471
  row_count = (items.size / option.to_f).ceil
@@ -488,7 +503,7 @@ class HighLine
488
503
  widths = Array.new(column_count, 0)
489
504
  rows.each do |row|
490
505
  row.each_with_index do |field, column|
491
- size = field.size
506
+ size = actual_length(field)
492
507
  widths[column] = size if size > widths[column]
493
508
  end
494
509
  end
@@ -496,8 +511,9 @@ class HighLine
496
511
  if column_count == 1 or
497
512
  widths.inject(0) { |sum, n| sum + n + 2 } <= limit + 2
498
513
  return rows.map { |row|
499
- row.zip(widths).map { |field, i| "%-#{i}s" % field }.
500
- join(" ") + "\n"
514
+ row.zip(widths).map { |field, i|
515
+ "%-#{i + (field.to_s.length - actual_length(field))}s" % field
516
+ }.join(" ") + "\n"
501
517
  }.join
502
518
  end
503
519
  end
@@ -511,14 +527,15 @@ class HighLine
511
527
  widths = Array.new(option, 0)
512
528
  rows.each do |row|
513
529
  row.each_with_index do |field, column|
514
- size = field.size
530
+ size = actual_length(field)
515
531
  widths[column] = size if size > widths[column]
516
532
  end
517
533
  end
518
534
 
519
535
  return rows.map { |row|
520
- row.zip(widths).map { |field, i| "%-#{i}s" % field }.join(" ") +
521
- "\n"
536
+ row.zip(widths).map { |field, i|
537
+ "%-#{i + (field.to_s.length - actual_length(field))}s" % field
538
+ }.join(" ") + "\n"
522
539
  }.join
523
540
  end
524
541
  when :uneven_columns_down
@@ -534,7 +551,7 @@ class HighLine
534
551
  widths = Array.new(column_count, 0)
535
552
  columns.each_with_index do |column, i|
536
553
  column.each do |field|
537
- size = field.size
554
+ size = actual_length(field)
538
555
  widths[i] = size if size > widths[i]
539
556
  end
540
557
  end
@@ -543,10 +560,11 @@ class HighLine
543
560
  widths.inject(0) { |sum, n| sum + n + 2 } <= limit + 2
544
561
  list = ""
545
562
  columns.first.size.times do |index|
546
- list << columns.zip(widths).
547
- map { |column, width| "%-#{width}s" %
548
- column[index] }.
549
- compact.join(" ").strip + "\n"
563
+ list << columns.zip(widths).map { |column, width|
564
+ field = column[index]
565
+ "%-#{width + (field.to_s.length - actual_length(field))}s" %
566
+ field
567
+ }.compact.join(" ").strip + "\n"
550
568
  end
551
569
  return list
552
570
  end
@@ -561,17 +579,17 @@ class HighLine
561
579
  widths = Array.new(option, 0)
562
580
  columns.each_with_index do |column, i|
563
581
  column.each do |field|
564
- size = field.size
582
+ size = actual_length(field)
565
583
  widths[i] = size if size > widths[i]
566
584
  end
567
585
  end
568
586
 
569
587
  list = ""
570
588
  columns.first.size.times do |index|
571
- list << columns.zip(widths).
572
- map { |column, width| "%-#{width}s" %
573
- column[index] }.
574
- compact.join(" ").strip + "\n"
589
+ list << columns.zip(widths).map { |column, width|
590
+ field = column[index]
591
+ "%-#{width + (field.to_s.length - actual_length(field))}s" % field
592
+ }.compact.join(" ").strip + "\n"
575
593
  end
576
594
  return list
577
595
  end
@@ -755,13 +773,34 @@ class HighLine
755
773
 
756
774
  answer
757
775
  else
758
- raise EOFError, "The input stream is exhausted." if @@track_eof and
759
- @input.eof?
776
+ if JRUBY
777
+ enable_echo_afterwards = @java_terminal.isEchoEnabled
778
+ @java_terminal.disableEcho
779
+ begin
780
+ raw_answer = @java_console.readLine(nil, nil)
781
+ ensure
782
+ @java_terminal.enableEcho if enable_echo_afterwards
783
+ end
784
+ else
785
+ raise EOFError, "The input stream is exhausted." if @@track_eof and
786
+ @input.eof?
787
+ raw_answer = @input.gets
788
+ end
760
789
 
761
- @question.change_case(@question.remove_whitespace(@input.gets))
790
+ @question.change_case(@question.remove_whitespace(raw_answer))
762
791
  end
763
792
  end
764
-
793
+
794
+ def get_single_character(is_stty)
795
+ if JRUBY
796
+ @java_console.readVirtualKey
797
+ elsif is_stty
798
+ @input.getbyte
799
+ else
800
+ get_character(@input)
801
+ end
802
+ end
803
+
765
804
  #
766
805
  # Return a line or character of input, as requested for this question.
767
806
  # Character input will be returned as a single character String,
@@ -773,18 +812,25 @@ class HighLine
773
812
  #
774
813
  def get_response( )
775
814
  return @question.first_answer if @question.first_answer?
776
-
815
+
816
+ stty = (CHARACTER_MODE == "stty")
817
+
777
818
  if @question.character.nil?
778
819
  if @question.echo == true and @question.limit.nil?
779
820
  get_line
780
821
  else
781
- raw_no_echo_mode if stty = CHARACTER_MODE == "stty"
782
-
822
+ if JRUBY
823
+ enable_echo_afterwards = @java_terminal.isEchoEnabled
824
+ @java_terminal.disableEcho
825
+ elsif stty
826
+ raw_no_echo_mode
827
+ end
828
+
783
829
  line = ""
784
830
  backspace_limit = 0
785
831
  begin
786
832
 
787
- while character = (stty ? @input.getbyte : get_character(@input))
833
+ while character = get_single_character(stty)
788
834
  # honor backspace and delete
789
835
  if character == 127 or character == 8
790
836
  line.slice!(-1, 1)
@@ -795,17 +841,16 @@ class HighLine
795
841
  end
796
842
  # looking for carriage return (decimal 13) or
797
843
  # newline (decimal 10) in raw input
798
- break if character == 13 or character == 10 or
799
- (@question.limit and line.size == @question.limit)
844
+ break if character == 13 or character == 10
800
845
  if @question.echo != false
801
- if character == 127 or character == 8
802
- # only backspace if we have characters on the line to
803
- # eliminate, otherwise we'll tromp over the prompt
804
- if backspace_limit >= 0 then
805
- @output.print("\b#{HighLine.Style(:erase_char).code}")
806
- else
807
- # do nothing
808
- end
846
+ if character == 127 or character == 8
847
+ # only backspace if we have characters on the line to
848
+ # eliminate, otherwise we'll tromp over the prompt
849
+ if backspace_limit >= 0 then
850
+ @output.print("\b#{HighLine.Style(:erase_char).code}")
851
+ else
852
+ # do nothing
853
+ end
809
854
  else
810
855
  if @question.echo == true
811
856
  @output.print(character.chr)
@@ -815,9 +860,14 @@ class HighLine
815
860
  end
816
861
  @output.flush
817
862
  end
863
+ break if @question.limit and line.size == @question.limit
818
864
  end
819
865
  ensure
820
- restore_mode if stty
866
+ if JRUBY
867
+ @java_terminal.enableEcho if enable_echo_afterwards
868
+ elsif stty
869
+ restore_mode
870
+ end
821
871
  end
822
872
  if @question.overwrite
823
873
  @output.print("\r#{HighLine.Style(:erase_line).code}")
@@ -825,25 +875,37 @@ class HighLine
825
875
  else
826
876
  say("\n")
827
877
  end
828
-
878
+
829
879
  @question.change_case(@question.remove_whitespace(line))
830
880
  end
831
- elsif @question.character == :getc
832
- @question.change_case(@input.getbyte.chr)
833
881
  else
834
- response = get_character(@input).chr
835
- if @question.overwrite
836
- @output.print("\r#{HighLine.Style(:erase_line).code}")
837
- @output.flush
838
- else
839
- echo = if @question.echo == true
840
- response
841
- elsif @question.echo != false
842
- @question.echo
882
+ if JRUBY
883
+ enable_echo_afterwards = @java_terminal.isEchoEnabled
884
+ @java_terminal.disableEcho
885
+ end
886
+ begin
887
+ if @question.character == :getc
888
+ response = get_single_character(true).chr
843
889
  else
844
- ""
890
+ response = get_single_character(stty).chr
891
+ if @question.overwrite
892
+ @output.print("\r#{HighLine.Style(:erase_line).code}")
893
+ @output.flush
894
+ else
895
+ echo = if @question.echo == true
896
+ response
897
+ elsif @question.echo != false
898
+ @question.echo
899
+ else
900
+ ""
901
+ end
902
+ say("#{echo}\n")
903
+ end
904
+ end
905
+ ensure
906
+ if JRUBY
907
+ @java_terminal.enableEcho if enable_echo_afterwards
845
908
  end
846
- say("#{echo}\n")
847
909
  end
848
910
  @question.change_case(response)
849
911
  end
@@ -908,7 +970,7 @@ class HighLine
908
970
  # sequence escapes.
909
971
  #
910
972
  def actual_length( string_with_escapes )
911
- string_with_escapes.gsub(/\e\[\d{1,2}m/, "").length
973
+ string_with_escapes.to_s.gsub(/\e\[\d{1,2}m/, "").length
912
974
  end
913
975
  end
914
976
 
data/site/.cvsignore ADDED
@@ -0,0 +1 @@
1
+ .DS_Store
data/site/highline.css ADDED
@@ -0,0 +1,65 @@
1
+ body {
2
+ margin: 0;
3
+ padding: 0;
4
+ text-align: center;
5
+ background: #abc;
6
+ font: 13px Trebuchet MS, Lucida Sans Unicode, Arial, sans-serif;
7
+ }
8
+
9
+ #container {
10
+ margin: 0 auto;
11
+ margin-top: 10px;
12
+ position: relative;
13
+ width: 785px;
14
+ background: #fff repeat;
15
+ padding-top: 20px;
16
+ }
17
+
18
+ #container #header {
19
+ padding-top: 20px;
20
+ height: 141px;
21
+ width: 785px;
22
+ background: url(images/logo.png) center no-repeat;
23
+ }
24
+
25
+ #container #content {
26
+ text-align: left;
27
+ margin-left: 230px;
28
+ width: 500px;
29
+ }
30
+
31
+ #container #sidebar {
32
+ text-align: left;
33
+ position: absolute;
34
+ top: 181px;
35
+ left: 0;
36
+ width: 170px;
37
+ margin-right: 25px;
38
+ }
39
+
40
+ #container #footer {
41
+ font: 9px Arial;
42
+ padding: 4px;
43
+ border-top: 1px solid;
44
+ color: #aaa;
45
+ }
46
+
47
+ ul {
48
+ list-style: none;
49
+ }
50
+
51
+ li {
52
+ border-bottom: 1px solid #e8e8e8;
53
+ padding-top: 10px;
54
+ }
55
+
56
+ a {
57
+ text-decoration: none;
58
+ color: #15528a;
59
+ }
60
+
61
+ pre {
62
+ padding: 5px;
63
+ padding-left: 20px;
64
+ font: 11px Courier;
65
+ }
Binary file
data/site/index.html ADDED
@@ -0,0 +1,58 @@
1
+ <html>
2
+ <head>
3
+ <title> HighLine </title>
4
+ <style type="text/css"> @import url(highline.css); </style>
5
+ </head>
6
+ <body>
7
+ <div id="container">
8
+ <div id="header"></div>
9
+ <div id="content">
10
+ <h2>HighLine is about&#8230;</h2>
11
+
12
+
13
+ <h3>Saving time.</h3>
14
+
15
+
16
+ <p>Command line interfaces are meant to be easy. So why shouldn&#8217;t building
17
+ them be easy, too? HighLine provides a solid toolset to help you get
18
+ the job done cleanly so you can focus on the real task at hand,
19
+ <em>your task.</em></p>
20
+
21
+
22
+ <h3>Clean and intuitive design.</h3>
23
+
24
+
25
+ <p>Want to get a taste for how HighLine is used? Take a look at this simple
26
+ example, which asks a user for a zip code, automatically does validation,
27
+ and returns the result:</p>
28
+
29
+
30
+ <pre><code>zip = ask("Zip? ") { |q| q.validate = /\A\d{5}(?:-?\d{4})?\Z/ }</code></pre>
31
+
32
+
33
+ <h3>Hassle-free Installation.</h3>
34
+
35
+
36
+ <p>Installation is easy via RubyGems. Simply enter the command:</p>
37
+
38
+
39
+ <pre><code>sudo gem install highline</code></pre>
40
+
41
+
42
+ <p>and you&#8217;ll be on your way! Of course, manual installation is an option,
43
+ too.</p>
44
+ </div>
45
+ <div id="sidebar">
46
+ <ul>
47
+ <li><a href="http://rubyforge.org/projects/highline">Project Page</a></li>
48
+ <li><a href="http://highline.rubyforge.org/doc">Documentation</a></li>
49
+ <li><a href="https://github.com/JEG2/highline">Source</a></li>
50
+ <li><a href="mailto:james@grayproductions.net">Contact</a></li>
51
+ </ul>
52
+ </div>
53
+ <div id="footer">
54
+ Created by James Edward Gray II and Gregory Brown
55
+ </div>
56
+ </div>
57
+ </body>
58
+ </html>
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: highline
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.6.8
4
+ version: 1.6.9
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -9,7 +9,7 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2011-11-14 00:00:00.000000000 Z
12
+ date: 2011-12-18 00:00:00.000000000 Z
13
13
  dependencies: []
14
14
  description: ! 'A high-level IO library that provides validation, type conversion,
15
15
  and more for
@@ -21,7 +21,7 @@ description: ! 'A high-level IO library that provides validation, type conversio
21
21
  minutes of work.
22
22
 
23
23
  '
24
- email: james@grayproductions.net
24
+ email: james@graysoftinc.com
25
25
  executables: []
26
26
  extensions: []
27
27
  extra_rdoc_files:
@@ -31,6 +31,16 @@ extra_rdoc_files:
31
31
  - CHANGELOG
32
32
  - LICENSE
33
33
  files:
34
+ - .gitignore
35
+ - AUTHORS
36
+ - CHANGELOG
37
+ - COPYING
38
+ - INSTALL
39
+ - LICENSE
40
+ - README
41
+ - Rakefile
42
+ - TODO
43
+ - doc/.cvsignore
34
44
  - examples/ansi_colors.rb
35
45
  - examples/asking_for_arrays.rb
36
46
  - examples/basic_usage.rb
@@ -42,6 +52,8 @@ files:
42
52
  - examples/password.rb
43
53
  - examples/trapping_eof.rb
44
54
  - examples/using_readline.rb
55
+ - highline.gemspec
56
+ - lib/highline.rb
45
57
  - lib/highline/color_scheme.rb
46
58
  - lib/highline/compatibility.rb
47
59
  - lib/highline/import.rb
@@ -50,7 +62,11 @@ files:
50
62
  - lib/highline/string_extensions.rb
51
63
  - lib/highline/style.rb
52
64
  - lib/highline/system_extensions.rb
53
- - lib/highline.rb
65
+ - setup.rb
66
+ - site/.cvsignore
67
+ - site/highline.css
68
+ - site/images/logo.png
69
+ - site/index.html
54
70
  - test/string_methods.rb
55
71
  - test/tc_color_scheme.rb
56
72
  - test/tc_highline.rb
@@ -60,13 +76,6 @@ files:
60
76
  - test/tc_string_highline.rb
61
77
  - test/tc_style.rb
62
78
  - test/ts_all.rb
63
- - Rakefile
64
- - setup.rb
65
- - README
66
- - INSTALL
67
- - TODO
68
- - CHANGELOG
69
- - LICENSE
70
79
  homepage: http://highline.rubyforge.org
71
80
  licenses: []
72
81
  post_install_message:
@@ -96,4 +105,12 @@ signing_key:
96
105
  specification_version: 3
97
106
  summary: HighLine is a high-level command-line IO library.
98
107
  test_files:
108
+ - test/string_methods.rb
109
+ - test/tc_color_scheme.rb
110
+ - test/tc_highline.rb
111
+ - test/tc_import.rb
112
+ - test/tc_menu.rb
113
+ - test/tc_string_extension.rb
114
+ - test/tc_string_highline.rb
115
+ - test/tc_style.rb
99
116
  - test/ts_all.rb