malysz87-highline 1.5.2 → 1.5.4

Sign up to get free protection for your applications and to get access to all the features.
data/CHANGELOG ADDED
@@ -0,0 +1,209 @@
1
+ = Change Log
2
+
3
+ Below is a complete listing of changes for each revision of HighLine.
4
+
5
+ == 1.5.0
6
+
7
+ * Added the ability to pass a block to HighLine#agree().
8
+ (patch by Yaohan Chen)
9
+
10
+ == 1.4.0
11
+
12
+ * Made the code grabbing terminal size a little more cross-platform by
13
+ adding support for Solaris. (patch by Ronald Braswell and Coey Minear)
14
+
15
+ == 1.2.9
16
+
17
+ * Additional work on the backspacing issue. (patch by Jeremy Hinegardner)
18
+ * Fixed Readline prompt bug. (patch by Jeremy Hinegardner)
19
+
20
+ == 1.2.8
21
+
22
+ * Fixed backspacing past the prompt and interrupting a prompt bugs.
23
+ (patch by Jeremy Hinegardner)
24
+
25
+ == 1.2.7
26
+
27
+ * Fixed the stty indent bug.
28
+ * Fixed the echo backspace bug.
29
+ * Added HighLine::track_eof=() setting to work are threaded eof?() calls.
30
+
31
+ == 1.2.6
32
+
33
+ Patch by Jeremy Hinegardner:
34
+
35
+ * Added ColorScheme support.
36
+ * Added HighLine::Question.overwrite mode.
37
+ * Various documentation fixes.
38
+
39
+ == 1.2.5
40
+
41
+ * Really fixed the bug I tried to fix in 1.2.4.
42
+
43
+ == 1.2.4
44
+
45
+ * Fixed a crash causing bug when using menus, reported by Patrick Hof.
46
+
47
+ == 1.2.3
48
+
49
+ * Treat Cygwin like a Posix OS, instead of a native Windows environment.
50
+
51
+ == 1.2.2
52
+
53
+ * Minor documentation corrections.
54
+ * Applied Thomas Werschleiln's patch to fix termio buffering on Solaris.
55
+ * Applied Justin Bailey's patch to allow canceling paged output.
56
+ * Fixed a documentation bug in the description of character case settings.
57
+ * Added a notice about termios in HighLine::Question#echo.
58
+ * Finally working around the infamous "fast typing" bug
59
+
60
+ == 1.2.1
61
+
62
+ * Applied Justin Bailey's fix for the page_print() infinite loop bug.
63
+ * Made a SystemExtensions module to expose OS level functionality other
64
+ libraries may want to access.
65
+ * Publicly exposed the get_character() method, per user requests.
66
+ * Added terminal_size(), output_cols(), and output_rows() methods.
67
+ * Added :auto setting for warp_at=() and page_at=().
68
+
69
+ == 1.2.0
70
+
71
+ * Improved RubyForge and gem spec project descriptions.
72
+ * Added basic examples to README.
73
+ * Added a VERSION constant.
74
+ * Added support for hidden menu commands.
75
+ * Added Object.or_ask() when using highline/import.
76
+
77
+ == 1.0.4
78
+
79
+ * Moved the HighLine project to Subversion.
80
+ * HighLine's color escapes can now be disabled.
81
+ * Fixed EOF bug introduced in the last release.
82
+ * Updated HighLine web page.
83
+ * Moved to a forked development/stable version numbering.
84
+
85
+ == 1.0.2
86
+
87
+ * Removed old and broken help tests.
88
+ * Fixed test case typo found by David A. Black.
89
+ * Added ERb escapes processing to lists, for coloring list items. Color escapes
90
+ do not add to list element size.
91
+ * HighLine now throws EOFError when input is exhausted.
92
+
93
+ == 1.0.1
94
+
95
+ * Minor bug fix: Moved help initialization to before response building, so help
96
+ would show up in the default responses.
97
+
98
+ == 1.0.0
99
+
100
+ * Fixed documentation typo pointed out by Gavin Kistner.
101
+ * Added <tt>gather = ...</tt> option to question for fetching entire Arrays or
102
+ Hashes filled with answers. You can set +gather+ to a count of answers to
103
+ collect, a String or Regexp matching the end of input, or a Hash where each
104
+ key can be used in a new question.
105
+ * Added File support to HighLine.ask(). You can specify a _directory_ and a
106
+ _glob_ pattern that combine into a list of file choices the user can select
107
+ from. You can choose to receive the user's answer as an open filehandle or as
108
+ a Pathname object.
109
+ * Added Readline support for history and editing.
110
+ * Added tab completion for menu and file selection selection (requires
111
+ Readline).
112
+ * Added an optional character limit for input.
113
+ * Added a complete help system to HighLine's shell menu creation tools.
114
+
115
+ == 0.6.1
116
+
117
+ * Removed termios dependancy in gem, to fix Windows' install.
118
+
119
+ == 0.6.0
120
+
121
+ * Implemented HighLine.choose() for menu handling.
122
+ * Provided shortcut <tt>choose(item1, item2, ...)</tt> for simple menus.
123
+ * Allowed Ruby code to be attached to each menu item, to create a complete
124
+ menu solution.
125
+ * Provided for total customization of the menu layout.
126
+ * Allowed for menu selection by index, name or both.
127
+ * Added a _shell_ mode to allow menu selection with additional details
128
+ following the name.
129
+ * Added a list() utility method that can be invoked just like color(). It can
130
+ layout Arrays for you in any output in the modes <tt>:columns_across</tt>,
131
+ <tt>:columns_down</tt>, <tt>:inline</tt> and <tt>:rows</tt>
132
+ * Added support for <tt>echo = "*"</tt> style settings. User code can now
133
+ choose the echo character this way.
134
+ * Modified HighLine to user the "termios" library for character input, if
135
+ available. Will return to old behavior (using "stty"), if "termios" cannot be
136
+ loaded.
137
+ * Improved "stty" state restoring code.
138
+ * Fixed "stty" code to handle interrupt signals.
139
+ * Improved the default auto-complete error message and exposed this message
140
+ through the +responses+ interface as <tt>:no_completion</tt>.
141
+
142
+ == 0.5.0
143
+
144
+ * Implemented <tt>echo = false</tt> for HighLine::Question objects, primarily to
145
+ make fetching passwords trivial.
146
+ * Fixed an auto-complete bug that could cause a crash when the user gave an
147
+ answer that didn't complete to any valid choice.
148
+ * Implemented +case+ for HighLine::Question objects to provide character case
149
+ conversions on given answers. Can be set to <tt>:up</tt>, <tt>:down</tt>, or
150
+ <tt>:capitalize</tt>.
151
+ * Exposed <tt>@answer</tt> to the response system, to allow response that are
152
+ aware of incorrect input.
153
+ * Implemented +confirm+ for HighLine::Question objects to allow for verification
154
+ for sensitive user choices. If set to +true+, user will have to answer an
155
+ "Are you sure? " question. Can also be set to the question to confirm with
156
+ the user.
157
+
158
+ == 0.4.0
159
+
160
+ * Added <tt>@wrap_at</tt> and <tt>@page_at</tt> settings and accessors to
161
+ HighLine, to control text flow.
162
+ * Implemented line wrapping with adjustable limit.
163
+ * Implemented paged printing with adjustable limit.
164
+
165
+ == 0.3.0
166
+
167
+ * Added support for installing with setup.rb.
168
+ * All output is now treated as an ERb sequence, allowing Ruby code to be
169
+ embedded in output strings.
170
+ * Added support for ANSI color sequences in say(). (And everything else
171
+ by extension.)
172
+ * Added whitespace handling for answers. Can be set to <tt>:strip</tt>,
173
+ <tt>:chomp</tt>, <tt>:collapse</tt>, <tt>:strip_and_collapse</tt>,
174
+ <tt>:chomp_and_collapse</tt>, <tt>:remove</tt>, or <tt>:none</tt>.
175
+ * Exposed question details to ERb completion through @question, to allow for
176
+ intelligent responses.
177
+ * Simplified HighLine internals using @question.
178
+ * Added support for fetching single character input either with getc() or
179
+ HighLine's own cross-platform terminal input routine.
180
+ * Improved type conversion to handle user defined classes.
181
+
182
+ == 0.2.0
183
+
184
+ * Added Unit Tests to cover an already fixed output bug in the future.
185
+ * Added Rakefile and setup test action (default).
186
+ * Renamed HighLine::Answer to HighLine::Question to better illustrate its role.
187
+ * Renamed fetch_line() to get_response() to better define its goal.
188
+ * Simplified explain_error in terms of the Question object.
189
+ * Renamed accept?() to in_range?() to better define purpose.
190
+ * Reworked valid?() into valid_answer?() to better fit Question object.
191
+ * Reworked <tt>@member</tt> into <tt>@in</tt>, to make it easier to remember and
192
+ switched implementation to include?().
193
+ * Added range checks for @above and @below.
194
+ * Fixed the bug causing ask() to swallow NoMethodErrors.
195
+ * Rolled ask_on_error() into responses.
196
+ * Redirected imports to Kernel from Object.
197
+ * Added support for <tt>validate = lambda { ... }</tt>.
198
+ * Added default answer support.
199
+ * Fixed bug that caused ask() to die with an empty question.
200
+ * Added complete documentation.
201
+ * Improve the implemetation of agree() to be the intended "yes" or "no" only
202
+ question.
203
+ * Added Rake tasks for documentation and packaging.
204
+ * Moved project to RubyForge.
205
+
206
+ == 0.1.0
207
+
208
+ * Initial release as the solution to
209
+ {Ruby Quiz #29}[http://www.rubyquiz.com/quiz29.html].
data/INSTALL ADDED
@@ -0,0 +1,35 @@
1
+ = Installing HighLine
2
+
3
+ RubyGems is the preferred easy install method for HighLine. However, you can
4
+ install HighLine manually as described below.
5
+
6
+ == Installing the Gem
7
+
8
+ HighLine is intended to be installed via the
9
+ RubyGems[http://rubyforge.org/projects/rubygems/] system. To get the latest
10
+ version, simply enter the following into your command prompt:
11
+
12
+ $ sudo gem install highline
13
+
14
+ You must have RubyGems[http://rubyforge.org/projects/rubygems/] installed for
15
+ the above to work.
16
+
17
+ == Installing Manually
18
+
19
+ Download the latest version of HighLine from the
20
+ {RubyForge project page}[http://rubyforge.org/frs/?group_id=683]. Navigate to
21
+ the root project directory and enter:
22
+
23
+ $ sudo ruby setup.rb
24
+
25
+ == Using termios
26
+
27
+ While not a requirement, HighLine will take advantage of the termios library if
28
+ installed (on Unix). This slightly improves HighLine's character reading
29
+ capabilities and thus is recommended for all Unix users.
30
+
31
+ If using the HighLine gem, you should be able to add termios as easily as:
32
+
33
+ $ sudo gem install termios
34
+
35
+ For manual installs, consult the termios documentation.
data/LICENSE ADDED
@@ -0,0 +1,7 @@
1
+ = License Terms
2
+
3
+ Distributed under the user's choice of the {GPL Version 2}[http://www.gnu.org/licenses/old-licenses/gpl-2.0.html] (see COPYING for details) or the
4
+ {Ruby software license}[http://www.ruby-lang.org/en/LICENSE.txt] by
5
+ James Edward Gray II and Greg Brown.
6
+
7
+ Please email James[mailto:james@grayproductions.net] with any questions.
data/README ADDED
@@ -0,0 +1,63 @@
1
+ = Read Me
2
+
3
+ by James Edward Gray II
4
+
5
+ == Description
6
+
7
+ Welcome to HighLine.
8
+
9
+ HighLine was designed to ease the tedious tasks of doing console input and
10
+ output with low-level methods like gets() and puts(). HighLine provides a
11
+ robust system for requesting data from a user, without needing to code all the
12
+ error checking and validation rules and without needing to convert the typed
13
+ Strings into what your program really needs. Just tell HighLine what you're
14
+ after, and let it do all the work.
15
+
16
+ == Documentation
17
+
18
+ See HighLine and HighLine::Question for documentation.
19
+
20
+ == Examples
21
+
22
+ Basic usage:
23
+
24
+ ask("Company? ") { |q| q.default = "none" }
25
+
26
+ Validation:
27
+
28
+ ask("Age? ", Integer) { |q| q.in = 0..105 }
29
+ ask("Name? (last, first) ") { |q| q.validate = /\A\w+, ?\w+\Z/ }
30
+
31
+ Type conversion for answers:
32
+
33
+ ask("Birthday? ", Date)
34
+ ask("Interests? (comma sep list) ", lambda { |str| str.split(/,\s*/) })
35
+
36
+ Reading passwords:
37
+
38
+ ask("Enter your password: ") { |q| q.echo = false }
39
+ ask("Enter your password: ") { |q| q.echo = "x" }
40
+
41
+ ERb based output (with HighLine's ANSI color tools):
42
+
43
+ say("This should be <%= color('bold', BOLD) %>!")
44
+
45
+ Menus:
46
+
47
+ choose do |menu|
48
+ menu.prompt = "Please choose your favorite programming language? "
49
+
50
+ menu.choice(:ruby) { say("Good choice!") }
51
+ menu.choices(:python, :perl) { say("Not from around here, are you?") }
52
+ end
53
+
54
+ For more examples see the examples/ directory of this project.
55
+
56
+ == Installing
57
+
58
+ See the INSTALL file for instructions.
59
+
60
+ == Questions and/or Comments
61
+
62
+ Feel free to email {James Edward Gray II}[mailto:james@grayproductions.net] or
63
+ {Gregory Brown}[mailto:gregory.t.brown@gmail.com] with any questions.
data/Rakefile ADDED
@@ -0,0 +1,82 @@
1
+ require "rake/rdoctask"
2
+ require "rake/testtask"
3
+ require "rake/gempackagetask"
4
+
5
+ require "rubygems"
6
+
7
+ dir = File.dirname(__FILE__)
8
+ lib = File.join(dir, "lib", "highline.rb")
9
+ version = File.read(lib)[/^\s*VERSION\s*=\s*(['"])(\d\.\d\.\d)\1/, 2]
10
+
11
+ task :default => [:test]
12
+
13
+ Rake::TestTask.new do |test|
14
+ test.libs << "test"
15
+ test.test_files = [ "test/ts_all.rb" ]
16
+ test.verbose = true
17
+ end
18
+
19
+ Rake::RDocTask.new do |rdoc|
20
+ rdoc.rdoc_files.include( "README", "INSTALL",
21
+ "TODO", "CHANGELOG",
22
+ "AUTHORS", "COPYING",
23
+ "LICENSE", "lib/" )
24
+ rdoc.main = "README"
25
+ rdoc.rdoc_dir = "doc/html"
26
+ rdoc.title = "HighLine Documentation"
27
+ end
28
+
29
+ desc "Upload current documentation to Rubyforge"
30
+ task :upload_docs => [:rdoc] do
31
+ sh "scp -r doc/html/* " +
32
+ "bbazzarrakk@rubyforge.org:/var/www/gforge-projects/highline/doc/"
33
+ sh "scp -r site/* " +
34
+ "bbazzarrakk@rubyforge.org:/var/www/gforge-projects/highline/"
35
+ end
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_suite_file = "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
+ Rake::GemPackageTask.new(spec) do |pkg|
67
+ pkg.need_zip = true
68
+ pkg.need_tar = true
69
+ end
70
+
71
+ desc "Show library's code statistics"
72
+ task :stats do
73
+ require 'code_statistics'
74
+ CodeStatistics.new( ["HighLine", "lib"],
75
+ ["Functionals", "examples"],
76
+ ["Units", "test"] ).to_s
77
+ end
78
+
79
+ desc "Add new files to Subversion"
80
+ task :add_to_svn do
81
+ sh %Q{svn status | ruby -nae 'system "svn add \#{$F[1]}" if $F[0] == "?"' }
82
+ end
data/TODO ADDED
@@ -0,0 +1,6 @@
1
+ = To Do List
2
+
3
+ The following is a list of planned expansions for HighLine, in no particular
4
+ order.
5
+
6
+ * Rent this space.
@@ -0,0 +1,38 @@
1
+ #!/usr/local/bin/ruby -w
2
+
3
+ # ansi_colors.rb
4
+ #
5
+ # Created by James Edward Gray II on 2005-05-03.
6
+ # Copyright 2005 Gray Productions. All rights reserved.
7
+
8
+ require "rubygems"
9
+ require "highline/import"
10
+
11
+ # Supported color sequences.
12
+ colors = %w{black red green yellow blue magenta cyan white}
13
+
14
+ # Using color() with symbols.
15
+ colors.each_with_index do |c, i|
16
+ say("This should be <%= color('#{c}', :#{c}) %>!")
17
+ if i == 0
18
+ say( "This should be " +
19
+ "<%= color('white on #{c}', :white, :on_#{c}) %>!")
20
+ else
21
+ say( "This should be " +
22
+ "<%= color( '#{colors[i - 1]} on #{c}',
23
+ :#{colors[i - 1]}, :on_#{c} ) %>!")
24
+ end
25
+ end
26
+
27
+ # Using color with constants.
28
+ say("This should be <%= color('bold', BOLD) %>!")
29
+ say("This should be <%= color('underlined', UNDERLINE) %>!")
30
+
31
+ # Using constants only.
32
+ say("This might even <%= BLINK %>blink<%= CLEAR %>!")
33
+
34
+ # It even works with list wrapping.
35
+ erb_digits = %w{Zero One Two Three Four} +
36
+ ["<%= color('Five', :blue) %%>"] +
37
+ %w{Six Seven Eight Nine}
38
+ say("<%= list(#{erb_digits.inspect}, :columns_down, 3) %>")
@@ -0,0 +1,18 @@
1
+ #!/usr/local/bin/ruby -w
2
+
3
+ # asking_for_arrays.rb
4
+ #
5
+ # Created by James Edward Gray II on 2005-07-05.
6
+ # Copyright 2005 Gray Productions. All rights reserved.
7
+
8
+ require "rubygems"
9
+ require "highline/import"
10
+ require "pp"
11
+
12
+ grades = ask( "Enter test scores (or a blank line to quit):",
13
+ lambda { |ans| ans =~ /^-?\d+$/ ? Integer(ans) : ans} ) do |q|
14
+ q.gather = ""
15
+ end
16
+
17
+ say("Grades:")
18
+ pp grades
@@ -0,0 +1,75 @@
1
+ #!/usr/local/bin/ruby -w
2
+
3
+ # basic_usage.rb
4
+ #
5
+ # Created by James Edward Gray II on 2005-04-28.
6
+ # Copyright 2005 Gray Productions. All rights reserved.
7
+
8
+ require "rubygems"
9
+ require "highline/import"
10
+ require "yaml"
11
+
12
+ contacts = [ ]
13
+
14
+ class NameClass
15
+ def self.parse( string )
16
+ if string =~ /^\s*(\w+),\s*(\w+)\s*$/
17
+ self.new($2, $1)
18
+ else
19
+ raise ArgumentError, "Invalid name format."
20
+ end
21
+ end
22
+
23
+ def initialize(first, last)
24
+ @first, @last = first, last
25
+ end
26
+
27
+ attr_reader :first, :last
28
+ end
29
+
30
+ begin
31
+ entry = Hash.new
32
+
33
+ # basic output
34
+ say("Enter a contact:")
35
+
36
+ # basic input
37
+ entry[:name] = ask("Name? (last, first) ", NameClass) do |q|
38
+ q.validate = /\A\w+, ?\w+\Z/
39
+ end
40
+ entry[:company] = ask("Company? ") { |q| q.default = "none" }
41
+ entry[:address] = ask("Address? ")
42
+ entry[:city] = ask("City? ")
43
+ entry[:state] = ask("State? ") do |q|
44
+ q.case = :up
45
+ q.validate = /\A[A-Z]{2}\Z/
46
+ end
47
+ entry[:zip] = ask("Zip? ") do |q|
48
+ q.validate = /\A\d{5}(?:-?\d{4})?\Z/
49
+ end
50
+ entry[:phone] = ask( "Phone? ",
51
+ lambda { |p| p.delete("^0-9").
52
+ sub(/\A(\d{3})/, '(\1) ').
53
+ sub(/(\d{4})\Z/, '-\1') } ) do |q|
54
+ q.validate = lambda { |p| p.delete("^0-9").length == 10 }
55
+ q.responses[:not_valid] = "Enter a phone numer with area code."
56
+ end
57
+ entry[:age] = ask("Age? ", Integer) { |q| q.in = 0..105 }
58
+ entry[:birthday] = ask("Birthday? ", Date)
59
+ entry[:interests] = ask( "Interests? (comma separated list) ",
60
+ lambda { |str| str.split(/,\s*/) } )
61
+ entry[:description] = ask("Enter a description for this contact.") do |q|
62
+ q.whitespace = :strip_and_collapse
63
+ end
64
+
65
+ contacts << entry
66
+ # shortcut for yes and no questions
67
+ end while agree("Enter another contact? ", true)
68
+
69
+ if agree("Save these contacts? ", true)
70
+ file_name = ask("Enter a file name: ") do |q|
71
+ q.validate = /\A\w+\Z/
72
+ q.confirm = true
73
+ end
74
+ File.open("#{file_name}.yaml", "w") { |file| YAML.dump(contacts, file) }
75
+ end
@@ -0,0 +1,32 @@
1
+ #!/usr/bin/env ruby -w
2
+
3
+ # color_scheme.rb
4
+ #
5
+ # Created by Jeremy Hinegardner on 2007-01-24
6
+ # Copyright 2007 Jeremy Hinegardner. All rights reserved
7
+
8
+ require 'rubygems'
9
+ require 'highline/import'
10
+
11
+ # Create a color scheme, naming color patterns with symbol names.
12
+ ft = HighLine::ColorScheme.new do |cs|
13
+ cs[:headline] = [ :bold, :yellow, :on_black ]
14
+ cs[:horizontal_line] = [ :bold, :white, :on_blue]
15
+ cs[:even_row] = [ :green ]
16
+ cs[:odd_row] = [ :magenta ]
17
+ end
18
+
19
+ # Assign that color scheme to HighLine...
20
+ HighLine.color_scheme = ft
21
+
22
+ # ...and use it.
23
+ say("<%= color('Headline', :headline) %>")
24
+ say("<%= color('-'*20, :horizontal_line) %>")
25
+
26
+ # Setup a toggle for rows.
27
+ i = true
28
+ ("A".."D").each do |row|
29
+ row_color = i ? :even_row : :odd_row
30
+ say("<%= color('#{row}', '#{row_color}') %>")
31
+ i = !i
32
+ end
data/examples/menus.rb ADDED
@@ -0,0 +1,65 @@
1
+ #!/usr/local/bin/ruby -w
2
+
3
+ require "rubygems"
4
+ require "highline/import"
5
+
6
+ # The old way, using ask() and say()...
7
+ choices = %w{ruby python perl}
8
+ say("This is the old way using ask() and say()...")
9
+ say("Please choose your favorite programming language:")
10
+ say(choices.map { |c| " #{c}\n" }.join)
11
+
12
+ case ask("? ", choices)
13
+ when "ruby"
14
+ say("Good choice!")
15
+ else
16
+ say("Not from around here, are you?")
17
+ end
18
+
19
+ # The new and improved choose()...
20
+ say("\nThis is the new mode (default)...")
21
+ choose do |menu|
22
+ menu.prompt = "Please choose your favorite programming language? "
23
+
24
+ menu.choice :ruby do say("Good choice!") end
25
+ menu.choices(:python, :perl) do say("Not from around here, are you?") end
26
+ end
27
+
28
+ say("\nThis is letter indexing...")
29
+ choose do |menu|
30
+ menu.index = :letter
31
+ menu.index_suffix = ") "
32
+
33
+ menu.prompt = "Please choose your favorite programming language? "
34
+
35
+ menu.choice :ruby do say("Good choice!") end
36
+ menu.choices(:python, :perl) do say("Not from around here, are you?") end
37
+ end
38
+
39
+ say("\nThis is with a different layout...")
40
+ choose do |menu|
41
+ menu.layout = :one_line
42
+
43
+ menu.header = "Languages"
44
+ menu.prompt = "Favorite? "
45
+
46
+ menu.choice :ruby do say("Good choice!") end
47
+ menu.choices(:python, :perl) do say("Not from around here, are you?") end
48
+ end
49
+
50
+ say("\nYou can even build shells...")
51
+ loop do
52
+ choose do |menu|
53
+ menu.layout = :menu_only
54
+
55
+ menu.shell = true
56
+
57
+ menu.choice(:load, "Load a file.") do |command, details|
58
+ say("Loading file with options: #{details}...")
59
+ end
60
+ menu.choice(:save, "Save a file.") do |command, details|
61
+ say("Saving file with options: #{details}...")
62
+ end
63
+ menu.choice(:quit, "Exit program.") { exit }
64
+ end
65
+ end
@@ -0,0 +1,19 @@
1
+ #!/usr/local/bin/ruby -w
2
+
3
+ # overwrite.rb
4
+ #
5
+ # Created by Jeremy Hinegardner on 2007-01-24
6
+ # Copyright 2007 Jeremy Hinegardner. All rights reserved
7
+
8
+ require 'rubygems'
9
+ require 'highline/import'
10
+
11
+ prompt = "here is your password:"
12
+ ask(
13
+ "#{prompt} <%= color('mypassword', RED, BOLD) %> (Press Any Key to blank) "
14
+ ) do |q|
15
+ q.overwrite = true
16
+ q.echo = false # overwrite works best when echo is false.
17
+ q.character = true # if this is set to :getc then overwrite does not work
18
+ end
19
+ say("<%= color('Look! blanked out!', GREEN) %>")