From 9cdfe3496f45c4f8e593d4d2b4fb657b93887e5a Mon Sep 17 00:00:00 2001 From: wakou Date: Wed, 24 May 2000 07:10:25 +0000 Subject: Wed May 24 16:03:06 2000 Wakou Aoyama * lib/cgi.rb bug fix: CGI::escape(), CGI::Cookie::new() * lib/net/telnet.rb improve: binmode(), telnetmode() interface git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@711 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- lib/net/telnet.rb | 82 ++++++++++++++++++++++++++++++++++++++++++------------- 1 file changed, 63 insertions(+), 19 deletions(-) (limited to 'lib/net/telnet.rb') diff --git a/lib/net/telnet.rb b/lib/net/telnet.rb index 30e2e4c5d1..6476a645d7 100644 --- a/lib/net/telnet.rb +++ b/lib/net/telnet.rb @@ -5,7 +5,7 @@ $Date$ net/telnet.rb -Version 1.32 +Version 1.40 Wakou Aoyama @@ -91,18 +91,18 @@ of cource, set sync=true or flush is necessary. # == host.write("string\n") -=== TURN TELNET COMMAND INTERPRETATION +=== TOGGLE TELNET COMMAND INTERPRETATION - host.telnetmode # turn on/off - host.telnetmode(true) # on - host.telnetmode(false) # off + host.telnetmode # return the current status (true or false) + host.telnetmode = true # do telnet command interpretation (default) + host.telnetmode = false # don't telnet command interpretation === TOGGLE NEWLINE TRANSLATION - host.binmode # turn true/false - host.binmode(true) # no translate newline - host.binmode(false) # translate newline + host.binmode # return the current status (true or false) + host.binmode = true # no translate newline + host.binmode = false # translate newline (default) === LOGIN @@ -157,6 +157,13 @@ of cource, set sync=true or flush is necessary. == HISTORY +=== Version 1.40 + +2000/05/24 06:57:38 + +- improve: binmode(), telnetmode() interface + thanks to Dave Thomas + === Version 1.32 2000/05/09 22:02:56 @@ -450,19 +457,32 @@ module Net EOL = CR + LF v = $-v $-v = false - VERSION = "1.32" + VERSION = "1.40" RELEASE_DATE = "$Date$" $-v = v def initialize(options) @options = options - @options["Binmode"] = false unless @options.has_key?("Binmode") @options["Host"] = "localhost" unless @options.has_key?("Host") @options["Port"] = 23 unless @options.has_key?("Port") @options["Prompt"] = /[$%#>] \z/n unless @options.has_key?("Prompt") - @options["Telnetmode"] = true unless @options.has_key?("Telnetmode") @options["Timeout"] = 10 unless @options.has_key?("Timeout") @options["Waittime"] = 0 unless @options.has_key?("Waittime") + unless @options.has_key?("Binmode") + @options["Binmode"] = false + else + unless (true == @options["Binmode"] or false == @options["Binmode"]) + raise ArgumentError, "Binmode option required true or false" + end + end + + unless @options.has_key?("Telnetmode") + @options["Telnetmode"] = true + else + unless (true == @options["Telnetmode"] or false == @options["Telnetmode"]) + raise ArgumentError, "Telnetmode option required true or false" + end + end @telnet_option = { "SGA" => false, "BINARY" => false } @@ -542,19 +562,43 @@ module Net attr :sock - def telnetmode(mode = 'turn') - if 'turn' == mode - @options["Telnetmode"] = @options["Telnetmode"] ? false : true + def telnetmode(mode = nil) + if mode + if (true == mode or false == mode) + @options["Telnetmode"] = mode + else + raise ArgumentError, "required true or false" + end + else + @options["Telnetmode"] + end + end + + def telnetmode=(mode) + if (true == mode or false == mode) + @options["Telnetmode"] = mode + else + raise ArgumentError, "required true or false" + end + end + + def binmode(mode = nil) + if mode + if (true == mode or false == mode) + @options["Binmode"] = mode + else + raise ArgumentError, "required true or false" + end else - @options["Telnetmode"] = mode ? true : false + @options["Binmode"] end end - def binmode(mode = 'turn') - if 'turn' == mode - @options["Binmode"] = @options["Binmode"] ? false : true + def binmode=(mode) + if (true == mode or false == mode) + @options["Binmode"] = mode else - @options["Binmode"] = mode ? true : false + raise ArgumentError, "required true or false" end end -- cgit v1.2.3