ruby_on_ruby 0.0.1
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +18 -0
- data/.rvmrc +1 -0
- data/Gemfile +6 -0
- data/LICENSE +22 -0
- data/README.md +66 -0
- data/Rakefile +1 -0
- data/lib/ruby_on_ruby.rb +5 -0
- data/lib/ruby_on_ruby/console.rb +7 -0
- data/lib/ruby_on_ruby/context.rb +33 -0
- data/lib/ruby_on_ruby/file_loader.rb +31 -0
- data/lib/ruby_on_ruby/ruby_stream.rb +27 -0
- data/lib/ruby_on_ruby/version.rb +3 -0
- data/lib/rubyonruby.rb +1 -0
- data/ruby_in_ruby.gemspec +19 -0
- data/vendor/javascripts/emscripted-ruby/lib/.document +106 -0
- data/vendor/javascripts/emscripted-ruby/lib/English.rb +155 -0
- data/vendor/javascripts/emscripted-ruby/lib/Env.rb +18 -0
- data/vendor/javascripts/emscripted-ruby/lib/README +96 -0
- data/vendor/javascripts/emscripted-ruby/lib/abbrev.rb +103 -0
- data/vendor/javascripts/emscripted-ruby/lib/base64.rb +133 -0
- data/vendor/javascripts/emscripted-ruby/lib/benchmark.rb +572 -0
- data/vendor/javascripts/emscripted-ruby/lib/cgi-lib.rb +272 -0
- data/vendor/javascripts/emscripted-ruby/lib/cgi.rb +2308 -0
- data/vendor/javascripts/emscripted-ruby/lib/cgi/.document +2 -0
- data/vendor/javascripts/emscripted-ruby/lib/cgi/session.rb +498 -0
- data/vendor/javascripts/emscripted-ruby/lib/cgi/session/pstore.rb +111 -0
- data/vendor/javascripts/emscripted-ruby/lib/complex.rb +663 -0
- data/vendor/javascripts/emscripted-ruby/lib/csv.rb +992 -0
- data/vendor/javascripts/emscripted-ruby/lib/date.rb +1767 -0
- data/vendor/javascripts/emscripted-ruby/lib/date/format.rb +1190 -0
- data/vendor/javascripts/emscripted-ruby/lib/date2.rb +5 -0
- data/vendor/javascripts/emscripted-ruby/lib/debug.rb +947 -0
- data/vendor/javascripts/emscripted-ruby/lib/delegate.rb +337 -0
- data/vendor/javascripts/emscripted-ruby/lib/drb.rb +2 -0
- data/vendor/javascripts/emscripted-ruby/lib/drb/acl.rb +146 -0
- data/vendor/javascripts/emscripted-ruby/lib/drb/drb.rb +1782 -0
- data/vendor/javascripts/emscripted-ruby/lib/drb/eq.rb +16 -0
- data/vendor/javascripts/emscripted-ruby/lib/drb/extserv.rb +64 -0
- data/vendor/javascripts/emscripted-ruby/lib/drb/extservm.rb +89 -0
- data/vendor/javascripts/emscripted-ruby/lib/drb/gw.rb +122 -0
- data/vendor/javascripts/emscripted-ruby/lib/drb/invokemethod.rb +36 -0
- data/vendor/javascripts/emscripted-ruby/lib/drb/observer.rb +22 -0
- data/vendor/javascripts/emscripted-ruby/lib/drb/ssl.rb +190 -0
- data/vendor/javascripts/emscripted-ruby/lib/drb/timeridconv.rb +91 -0
- data/vendor/javascripts/emscripted-ruby/lib/drb/unix.rb +108 -0
- data/vendor/javascripts/emscripted-ruby/lib/e2mmap.rb +195 -0
- data/vendor/javascripts/emscripted-ruby/lib/erb.rb +880 -0
- data/vendor/javascripts/emscripted-ruby/lib/eregex.rb +37 -0
- data/vendor/javascripts/emscripted-ruby/lib/fileutils.rb +1591 -0
- data/vendor/javascripts/emscripted-ruby/lib/finalize.rb +193 -0
- data/vendor/javascripts/emscripted-ruby/lib/find.rb +79 -0
- data/vendor/javascripts/emscripted-ruby/lib/forwardable.rb +218 -0
- data/vendor/javascripts/emscripted-ruby/lib/ftools.rb +261 -0
- data/vendor/javascripts/emscripted-ruby/lib/generator.rb +418 -0
- data/vendor/javascripts/emscripted-ruby/lib/getoptlong.rb +621 -0
- data/vendor/javascripts/emscripted-ruby/lib/getopts.rb +127 -0
- data/vendor/javascripts/emscripted-ruby/lib/gserver.rb +253 -0
- data/vendor/javascripts/emscripted-ruby/lib/importenv.rb +33 -0
- data/vendor/javascripts/emscripted-ruby/lib/ipaddr.rb +814 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb.rb +346 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/cmd/chws.rb +33 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/cmd/fork.rb +39 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/cmd/help.rb +34 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/cmd/load.rb +67 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/cmd/nop.rb +39 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/cmd/pushws.rb +39 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/cmd/subirb.rb +43 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/completion.rb +205 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/context.rb +255 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/ext/change-ws.rb +62 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/ext/history.rb +110 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/ext/loader.rb +120 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/ext/math-mode.rb +37 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/ext/multi-irb.rb +241 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/ext/save-history.rb +85 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/ext/tracer.rb +61 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/ext/use-loader.rb +65 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/ext/workspaces.rb +56 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/extend-command.rb +264 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/frame.rb +67 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/help.rb +33 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/init.rb +259 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/input-method.rb +120 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/lc/error.rb +30 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/lc/help-message +35 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/lc/ja/error.rb +27 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/lc/ja/help-message +36 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/locale.rb +184 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/notifier.rb +145 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/output-method.rb +85 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/ruby-lex.rb +1149 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/ruby-token.rb +273 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/slex.rb +285 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/version.rb +16 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/workspace.rb +107 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/ws-for-case-2.rb +15 -0
- data/vendor/javascripts/emscripted-ruby/lib/irb/xmp.rb +86 -0
- data/vendor/javascripts/emscripted-ruby/lib/jcode.rb +220 -0
- data/vendor/javascripts/emscripted-ruby/lib/logger.rb +703 -0
- data/vendor/javascripts/emscripted-ruby/lib/mailread.rb +62 -0
- data/vendor/javascripts/emscripted-ruby/lib/mathn.rb +308 -0
- data/vendor/javascripts/emscripted-ruby/lib/matrix.rb +1278 -0
- data/vendor/javascripts/emscripted-ruby/lib/mkmf.rb +1811 -0
- data/vendor/javascripts/emscripted-ruby/lib/monitor.rb +352 -0
- data/vendor/javascripts/emscripted-ruby/lib/mutex_m.rb +122 -0
- data/vendor/javascripts/emscripted-ruby/lib/net/ftp.rb +927 -0
- data/vendor/javascripts/emscripted-ruby/lib/net/http.rb +2277 -0
- data/vendor/javascripts/emscripted-ruby/lib/net/https.rb +173 -0
- data/vendor/javascripts/emscripted-ruby/lib/net/imap.rb +3371 -0
- data/vendor/javascripts/emscripted-ruby/lib/net/pop.rb +999 -0
- data/vendor/javascripts/emscripted-ruby/lib/net/protocol.rb +392 -0
- data/vendor/javascripts/emscripted-ruby/lib/net/smtp.rb +1014 -0
- data/vendor/javascripts/emscripted-ruby/lib/net/telnet.rb +756 -0
- data/vendor/javascripts/emscripted-ruby/lib/observer.rb +192 -0
- data/vendor/javascripts/emscripted-ruby/lib/open-uri.rb +678 -0
- data/vendor/javascripts/emscripted-ruby/lib/open3.rb +101 -0
- data/vendor/javascripts/emscripted-ruby/lib/optparse.rb +1790 -0
- data/vendor/javascripts/emscripted-ruby/lib/optparse/date.rb +17 -0
- data/vendor/javascripts/emscripted-ruby/lib/optparse/shellwords.rb +6 -0
- data/vendor/javascripts/emscripted-ruby/lib/optparse/time.rb +10 -0
- data/vendor/javascripts/emscripted-ruby/lib/optparse/uri.rb +6 -0
- data/vendor/javascripts/emscripted-ruby/lib/optparse/version.rb +70 -0
- data/vendor/javascripts/emscripted-ruby/lib/ostruct.rb +146 -0
- data/vendor/javascripts/emscripted-ruby/lib/parsearg.rb +87 -0
- data/vendor/javascripts/emscripted-ruby/lib/parsedate.rb +53 -0
- data/vendor/javascripts/emscripted-ruby/lib/pathname.rb +1062 -0
- data/vendor/javascripts/emscripted-ruby/lib/ping.rb +64 -0
- data/vendor/javascripts/emscripted-ruby/lib/pp.rb +654 -0
- data/vendor/javascripts/emscripted-ruby/lib/prettyprint.rb +896 -0
- data/vendor/javascripts/emscripted-ruby/lib/profile.rb +6 -0
- data/vendor/javascripts/emscripted-ruby/lib/profiler.rb +59 -0
- data/vendor/javascripts/emscripted-ruby/lib/pstore.rb +395 -0
- data/vendor/javascripts/emscripted-ruby/lib/racc/parser.rb +442 -0
- data/vendor/javascripts/emscripted-ruby/lib/rational.rb +564 -0
- data/vendor/javascripts/emscripted-ruby/lib/readbytes.rb +41 -0
- data/vendor/javascripts/emscripted-ruby/lib/resolv-replace.rb +62 -0
- data/vendor/javascripts/emscripted-ruby/lib/resolv.rb +2210 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/attlistdecl.rb +62 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/attribute.rb +185 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/cdata.rb +67 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/child.rb +96 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/comment.rb +80 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/doctype.rb +271 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/document.rb +208 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/dtd/attlistdecl.rb +10 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/dtd/dtd.rb +51 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/dtd/elementdecl.rb +17 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/dtd/entitydecl.rb +56 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/dtd/notationdecl.rb +39 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/element.rb +1227 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/encoding.rb +71 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/encodings/CP-1252.rb +103 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/encodings/EUC-JP.rb +35 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/encodings/ICONV.rb +22 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/encodings/ISO-8859-1.rb +7 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/encodings/ISO-8859-15.rb +72 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/encodings/SHIFT-JIS.rb +37 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/encodings/SHIFT_JIS.rb +1 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/encodings/UNILE.rb +34 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/encodings/US-ASCII.rb +30 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/encodings/UTF-16.rb +35 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/encodings/UTF-8.rb +18 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/entity.rb +165 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/formatters/default.rb +109 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/formatters/pretty.rb +137 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/formatters/transitive.rb +56 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/functions.rb +382 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/instruction.rb +70 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/light/node.rb +196 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/namespace.rb +47 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/node.rb +75 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/output.rb +24 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/parent.rb +166 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/parseexception.rb +51 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/parsers/baseparser.rb +503 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/parsers/lightparser.rb +60 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/parsers/pullparser.rb +196 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/parsers/sax2parser.rb +238 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/parsers/streamparser.rb +46 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/parsers/treeparser.rb +97 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/parsers/ultralightparser.rb +56 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/parsers/xpathparser.rb +698 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/quickpath.rb +266 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/rexml.rb +32 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/sax2listener.rb +97 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/source.rb +251 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/streamlistener.rb +92 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/syncenumerator.rb +33 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/text.rb +344 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/undefinednamespaceexception.rb +8 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/validation/relaxng.rb +559 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/validation/validation.rb +155 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/validation/validationexception.rb +9 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/xmldecl.rb +119 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/xmltokens.rb +18 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/xpath.rb +66 -0
- data/vendor/javascripts/emscripted-ruby/lib/rexml/xpath_parser.rb +792 -0
- data/vendor/javascripts/emscripted-ruby/lib/rinda/rinda.rb +283 -0
- data/vendor/javascripts/emscripted-ruby/lib/rinda/ring.rb +271 -0
- data/vendor/javascripts/emscripted-ruby/lib/rinda/tuplespace.rb +642 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss.rb +19 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/0.9.rb +428 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/1.0.rb +452 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/2.0.rb +111 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/atom.rb +749 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/content.rb +31 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/content/1.0.rb +10 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/content/2.0.rb +12 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/converter.rb +162 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/dublincore.rb +161 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/dublincore/1.0.rb +13 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/dublincore/2.0.rb +13 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/dublincore/atom.rb +17 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/image.rb +193 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/itunes.rb +410 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/maker.rb +44 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/maker/0.9.rb +467 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/maker/1.0.rb +434 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/maker/2.0.rb +223 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/maker/atom.rb +172 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/maker/base.rb +868 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/maker/content.rb +21 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/maker/dublincore.rb +124 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/maker/entry.rb +163 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/maker/feed.rb +429 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/maker/image.rb +111 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/maker/itunes.rb +242 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/maker/slash.rb +33 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/maker/syndication.rb +18 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/maker/taxonomy.rb +118 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/maker/trackback.rb +61 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/parser.rb +541 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/rexmlparser.rb +54 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/rss.rb +1312 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/slash.rb +49 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/syndication.rb +67 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/taxonomy.rb +145 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/trackback.rb +288 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/utils.rb +111 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/xml-stylesheet.rb +105 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/xml.rb +71 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/xmlparser.rb +93 -0
- data/vendor/javascripts/emscripted-ruby/lib/rss/xmlscanner.rb +121 -0
- data/vendor/javascripts/emscripted-ruby/lib/rubyunit.rb +6 -0
- data/vendor/javascripts/emscripted-ruby/lib/runit/assert.rb +73 -0
- data/vendor/javascripts/emscripted-ruby/lib/runit/cui/testrunner.rb +51 -0
- data/vendor/javascripts/emscripted-ruby/lib/runit/error.rb +9 -0
- data/vendor/javascripts/emscripted-ruby/lib/runit/testcase.rb +45 -0
- data/vendor/javascripts/emscripted-ruby/lib/runit/testresult.rb +44 -0
- data/vendor/javascripts/emscripted-ruby/lib/runit/testsuite.rb +26 -0
- data/vendor/javascripts/emscripted-ruby/lib/runit/topublic.rb +8 -0
- data/vendor/javascripts/emscripted-ruby/lib/scanf.rb +702 -0
- data/vendor/javascripts/emscripted-ruby/lib/securerandom.rb +137 -0
- data/vendor/javascripts/emscripted-ruby/lib/set.rb +1233 -0
- data/vendor/javascripts/emscripted-ruby/lib/shell.rb +269 -0
- data/vendor/javascripts/emscripted-ruby/lib/shell/builtin-command.rb +154 -0
- data/vendor/javascripts/emscripted-ruby/lib/shell/command-processor.rb +592 -0
- data/vendor/javascripts/emscripted-ruby/lib/shell/error.rb +26 -0
- data/vendor/javascripts/emscripted-ruby/lib/shell/filter.rb +110 -0
- data/vendor/javascripts/emscripted-ruby/lib/shell/process-controller.rb +260 -0
- data/vendor/javascripts/emscripted-ruby/lib/shell/system-command.rb +168 -0
- data/vendor/javascripts/emscripted-ruby/lib/shell/version.rb +16 -0
- data/vendor/javascripts/emscripted-ruby/lib/shellwords.rb +172 -0
- data/vendor/javascripts/emscripted-ruby/lib/singleton.rb +360 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/attachment.rb +107 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/baseData.rb +942 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/element.rb +258 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/encodingstyle/aspDotNetHandler.rb +213 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/encodingstyle/handler.rb +100 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/encodingstyle/literalHandler.rb +226 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/encodingstyle/soapHandler.rb +582 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/generator.rb +268 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/header/handler.rb +57 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/header/handlerset.rb +70 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/header/simplehandler.rb +44 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/httpconfigloader.rb +119 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/mapping.rb +10 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/mapping/factory.rb +355 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/mapping/mapping.rb +381 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/mapping/registry.rb +541 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/mapping/rubytypeFactory.rb +475 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/mapping/typeMap.rb +50 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/mapping/wsdlencodedregistry.rb +280 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/mapping/wsdlliteralregistry.rb +418 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/marshal.rb +59 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/mimemessage.rb +240 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/netHttpClient.rb +190 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/parser.rb +251 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/processor.rb +66 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/property.rb +333 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/rpc/cgistub.rb +206 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/rpc/driver.rb +254 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/rpc/element.rb +325 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/rpc/httpserver.rb +129 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/rpc/proxy.rb +497 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/rpc/router.rb +594 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/rpc/rpc.rb +25 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/rpc/soaplet.rb +162 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/rpc/standaloneServer.rb +43 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/soap.rb +140 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/streamHandler.rb +229 -0
- data/vendor/javascripts/emscripted-ruby/lib/soap/wsdlDriver.rb +575 -0
- data/vendor/javascripts/emscripted-ruby/lib/sync.rb +311 -0
- data/vendor/javascripts/emscripted-ruby/lib/tempfile.rb +209 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit.rb +280 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/assertionfailederror.rb +14 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/assertions.rb +622 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/autorunner.rb +220 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/collector.rb +43 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/collector/dir.rb +107 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/collector/objectspace.rb +34 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/error.rb +56 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/failure.rb +51 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/testcase.rb +160 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/testresult.rb +80 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/testsuite.rb +76 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/ui/console/testrunner.rb +127 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/ui/fox/testrunner.rb +268 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/ui/gtk/testrunner.rb +416 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/ui/gtk2/testrunner.rb +465 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/ui/testrunnermediator.rb +68 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/ui/testrunnerutilities.rb +46 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/ui/tk/testrunner.rb +260 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/util/backtracefilter.rb +40 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/util/observable.rb +90 -0
- data/vendor/javascripts/emscripted-ruby/lib/test/unit/util/procwrapper.rb +48 -0
- data/vendor/javascripts/emscripted-ruby/lib/thread.rb +479 -0
- data/vendor/javascripts/emscripted-ruby/lib/thwait.rb +169 -0
- data/vendor/javascripts/emscripted-ruby/lib/time.rb +797 -0
- data/vendor/javascripts/emscripted-ruby/lib/timeout.rb +122 -0
- data/vendor/javascripts/emscripted-ruby/lib/tmpdir.rb +130 -0
- data/vendor/javascripts/emscripted-ruby/lib/tracer.rb +167 -0
- data/vendor/javascripts/emscripted-ruby/lib/tsort.rb +290 -0
- data/vendor/javascripts/emscripted-ruby/lib/un.rb +235 -0
- data/vendor/javascripts/emscripted-ruby/lib/uri.rb +29 -0
- data/vendor/javascripts/emscripted-ruby/lib/uri/common.rb +611 -0
- data/vendor/javascripts/emscripted-ruby/lib/uri/ftp.rb +198 -0
- data/vendor/javascripts/emscripted-ruby/lib/uri/generic.rb +1122 -0
- data/vendor/javascripts/emscripted-ruby/lib/uri/http.rb +100 -0
- data/vendor/javascripts/emscripted-ruby/lib/uri/https.rb +20 -0
- data/vendor/javascripts/emscripted-ruby/lib/uri/ldap.rb +190 -0
- data/vendor/javascripts/emscripted-ruby/lib/uri/ldaps.rb +12 -0
- data/vendor/javascripts/emscripted-ruby/lib/uri/mailto.rb +266 -0
- data/vendor/javascripts/emscripted-ruby/lib/weakref.rb +100 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick.rb +29 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/accesslog.rb +67 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/cgi.rb +257 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/compat.rb +15 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/config.rb +97 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/cookie.rb +110 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/htmlutils.rb +25 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpauth.rb +45 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpauth/authenticator.rb +79 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpauth/basicauth.rb +65 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpauth/digestauth.rb +343 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpauth/htdigest.rb +91 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpauth/htgroup.rb +61 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpauth/htpasswd.rb +83 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpauth/userdb.rb +29 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpproxy.rb +254 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httprequest.rb +365 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpresponse.rb +327 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/https.rb +63 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpserver.rb +210 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpservlet.rb +22 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpservlet/abstract.rb +71 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpservlet/cgi_runner.rb +47 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpservlet/cgihandler.rb +108 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpservlet/erbhandler.rb +54 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpservlet/filehandler.rb +435 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpservlet/prochandler.rb +33 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpstatus.rb +126 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httputils.rb +399 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/httpversion.rb +49 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/log.rb +88 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/server.rb +200 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/ssl.rb +126 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/utils.rb +100 -0
- data/vendor/javascripts/emscripted-ruby/lib/webrick/version.rb +13 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/binding.rb +65 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/data.rb +64 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/definitions.rb +250 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/documentation.rb +32 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/import.rb +80 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/importer.rb +38 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/info.rb +39 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/message.rb +54 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/operation.rb +130 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/operationBinding.rb +108 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/param.rb +85 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/parser.rb +163 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/part.rb +52 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/port.rb +84 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/portType.rb +73 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/service.rb +61 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/address.rb +40 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/binding.rb +49 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/body.rb +56 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/cgiStubCreator.rb +76 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/classDefCreator.rb +314 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/classDefCreatorSupport.rb +126 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/clientSkeltonCreator.rb +78 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/complexType.rb +161 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/data.rb +42 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/definitions.rb +149 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/driverCreator.rb +95 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/element.rb +28 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/fault.rb +56 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/header.rb +86 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/headerfault.rb +56 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/mappingRegistryCreator.rb +92 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/methodDefCreator.rb +228 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/operation.rb +122 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/servantSkeltonCreator.rb +67 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/standaloneServerStubCreator.rb +85 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/soap/wsdl2ruby.rb +176 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/types.rb +43 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/wsdl.rb +23 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/all.rb +69 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/annotation.rb +34 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/any.rb +56 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/attribute.rb +127 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/choice.rb +69 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/complexContent.rb +92 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/complexType.rb +139 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/content.rb +96 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/data.rb +80 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/element.rb +154 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/enumeration.rb +36 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/import.rb +65 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/importer.rb +87 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/include.rb +54 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/length.rb +35 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/parser.rb +166 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/pattern.rb +36 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/schema.rb +143 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/sequence.rb +69 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/simpleContent.rb +65 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/simpleExtension.rb +54 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/simpleRestriction.rb +73 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/simpleType.rb +73 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/unique.rb +34 -0
- data/vendor/javascripts/emscripted-ruby/lib/wsdl/xmlSchema/xsd2ruby.rb +107 -0
- data/vendor/javascripts/emscripted-ruby/lib/xmlrpc/.document +1 -0
- data/vendor/javascripts/emscripted-ruby/lib/xmlrpc/README.txt +31 -0
- data/vendor/javascripts/emscripted-ruby/lib/xmlrpc/base64.rb +81 -0
- data/vendor/javascripts/emscripted-ruby/lib/xmlrpc/client.rb +624 -0
- data/vendor/javascripts/emscripted-ruby/lib/xmlrpc/config.rb +40 -0
- data/vendor/javascripts/emscripted-ruby/lib/xmlrpc/create.rb +290 -0
- data/vendor/javascripts/emscripted-ruby/lib/xmlrpc/datetime.rb +142 -0
- data/vendor/javascripts/emscripted-ruby/lib/xmlrpc/httpserver.rb +178 -0
- data/vendor/javascripts/emscripted-ruby/lib/xmlrpc/marshal.rb +76 -0
- data/vendor/javascripts/emscripted-ruby/lib/xmlrpc/parser.rb +813 -0
- data/vendor/javascripts/emscripted-ruby/lib/xmlrpc/server.rb +780 -0
- data/vendor/javascripts/emscripted-ruby/lib/xmlrpc/utils.rb +165 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/charset.rb +187 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/codegen.rb +12 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/codegen/classdef.rb +203 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/codegen/commentdef.rb +34 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/codegen/gensupport.rb +166 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/codegen/methoddef.rb +63 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/codegen/moduledef.rb +191 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/datatypes.rb +1269 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/datatypes1999.rb +20 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/iconvcharset.rb +33 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/mapping.rb +42 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/namedelements.rb +95 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/ns.rb +140 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/qname.rb +78 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/xmlparser.rb +61 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/xmlparser/parser.rb +96 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/xmlparser/rexmlparser.rb +54 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/xmlparser/xmlparser.rb +50 -0
- data/vendor/javascripts/emscripted-ruby/lib/xsd/xmlparser/xmlscanner.rb +147 -0
- data/vendor/javascripts/emscripted-ruby/lib/yaml.rb +440 -0
- data/vendor/javascripts/emscripted-ruby/lib/yaml/baseemitter.rb +247 -0
- data/vendor/javascripts/emscripted-ruby/lib/yaml/basenode.rb +216 -0
- data/vendor/javascripts/emscripted-ruby/lib/yaml/constants.rb +45 -0
- data/vendor/javascripts/emscripted-ruby/lib/yaml/dbm.rb +111 -0
- data/vendor/javascripts/emscripted-ruby/lib/yaml/encoding.rb +33 -0
- data/vendor/javascripts/emscripted-ruby/lib/yaml/error.rb +34 -0
- data/vendor/javascripts/emscripted-ruby/lib/yaml/loader.rb +14 -0
- data/vendor/javascripts/emscripted-ruby/lib/yaml/rubytypes.rb +408 -0
- data/vendor/javascripts/emscripted-ruby/lib/yaml/store.rb +43 -0
- data/vendor/javascripts/emscripted-ruby/lib/yaml/stream.rb +40 -0
- data/vendor/javascripts/emscripted-ruby/lib/yaml/stringio.rb +83 -0
- data/vendor/javascripts/emscripted-ruby/lib/yaml/syck.rb +19 -0
- data/vendor/javascripts/emscripted-ruby/lib/yaml/tag.rb +91 -0
- data/vendor/javascripts/emscripted-ruby/lib/yaml/types.rb +192 -0
- data/vendor/javascripts/emscripted-ruby/lib/yaml/yamlnode.rb +54 -0
- data/vendor/javascripts/emscripted-ruby/lib/yaml/ypath.rb +52 -0
- data/vendor/javascripts/emscripted-ruby/ruby.closure.js +7201 -0
- metadata +554 -0
@@ -0,0 +1,122 @@
|
|
1
|
+
#--
|
2
|
+
# = timeout.rb
|
3
|
+
#
|
4
|
+
# execution timeout
|
5
|
+
#
|
6
|
+
# = Copyright
|
7
|
+
#
|
8
|
+
# Copyright:: (C) 2000 Network Applied Communication Laboratory, Inc.
|
9
|
+
# Copyright:: (C) 2000 Information-technology Promotion Agency, Japan
|
10
|
+
#
|
11
|
+
#++
|
12
|
+
#
|
13
|
+
# = Description
|
14
|
+
#
|
15
|
+
# A way of performing a potentially long-running operation in a thread, and
|
16
|
+
# terminating it's execution if it hasn't finished within fixed amount of
|
17
|
+
# time.
|
18
|
+
#
|
19
|
+
# Previous versions of timeout didn't use a module for namespace. This version
|
20
|
+
# provides both Timeout.timeout, and a backwards-compatible #timeout.
|
21
|
+
#
|
22
|
+
# = Synopsis
|
23
|
+
#
|
24
|
+
# require 'timeout'
|
25
|
+
# status = Timeout::timeout(5) {
|
26
|
+
# # Something that should be interrupted if it takes too much time...
|
27
|
+
# }
|
28
|
+
#
|
29
|
+
|
30
|
+
module Timeout
|
31
|
+
|
32
|
+
##
|
33
|
+
# Raised by Timeout#timeout when the block times out.
|
34
|
+
|
35
|
+
class Error < Interrupt
|
36
|
+
end
|
37
|
+
class ExitException < ::Exception # :nodoc:
|
38
|
+
end
|
39
|
+
|
40
|
+
THIS_FILE = /\A#{Regexp.quote(__FILE__)}:/o
|
41
|
+
CALLER_OFFSET = ((c = caller[0]) && THIS_FILE =~ c) ? 1 : 0
|
42
|
+
|
43
|
+
##
|
44
|
+
# Executes the method's block. If the block execution terminates before +sec+
|
45
|
+
# seconds has passed, it returns true. If not, it terminates the execution
|
46
|
+
# and raises +exception+ (which defaults to Timeout::Error).
|
47
|
+
#
|
48
|
+
# Note that this is both a method of module Timeout, so you can 'include
|
49
|
+
# Timeout' into your classes so they have a #timeout method, as well as a
|
50
|
+
# module method, so you can call it directly as Timeout.timeout().
|
51
|
+
|
52
|
+
def timeout(sec, klass = nil)
|
53
|
+
return yield if sec == nil or sec.zero?
|
54
|
+
raise ThreadError, "timeout within critical session" if Thread.critical
|
55
|
+
exception = klass || Class.new(ExitException)
|
56
|
+
begin
|
57
|
+
x = Thread.current
|
58
|
+
y = Thread.start {
|
59
|
+
sleep sec
|
60
|
+
x.raise exception, "execution expired" if x.alive?
|
61
|
+
}
|
62
|
+
yield sec
|
63
|
+
# return true
|
64
|
+
rescue exception => e
|
65
|
+
rej = /\A#{Regexp.quote(__FILE__)}:#{__LINE__-4}\z/o
|
66
|
+
(bt = e.backtrace).reject! {|m| rej =~ m}
|
67
|
+
level = -caller(CALLER_OFFSET).size
|
68
|
+
while THIS_FILE =~ bt[level]
|
69
|
+
bt.delete_at(level)
|
70
|
+
level += 1
|
71
|
+
end
|
72
|
+
raise if klass # if exception class is specified, it
|
73
|
+
# would be expected outside.
|
74
|
+
raise Error, e.message, e.backtrace
|
75
|
+
ensure
|
76
|
+
y.kill if y and y.alive?
|
77
|
+
end
|
78
|
+
end
|
79
|
+
|
80
|
+
module_function :timeout
|
81
|
+
|
82
|
+
end
|
83
|
+
|
84
|
+
##
|
85
|
+
# Identical to:
|
86
|
+
#
|
87
|
+
# Timeout::timeout(n, e, &block).
|
88
|
+
#
|
89
|
+
# Defined for backwards compatibility with earlier versions of timeout.rb, see
|
90
|
+
# Timeout#timeout.
|
91
|
+
|
92
|
+
def timeout(n, e = nil, &block) # :nodoc:
|
93
|
+
Timeout::timeout(n, e, &block)
|
94
|
+
end
|
95
|
+
|
96
|
+
##
|
97
|
+
# Another name for Timeout::Error, defined for backwards compatibility with
|
98
|
+
# earlier versions of timeout.rb.
|
99
|
+
|
100
|
+
TimeoutError = Timeout::Error # :nodoc:
|
101
|
+
|
102
|
+
if __FILE__ == $0
|
103
|
+
p timeout(5) {
|
104
|
+
45
|
105
|
+
}
|
106
|
+
p timeout(5, TimeoutError) {
|
107
|
+
45
|
108
|
+
}
|
109
|
+
p timeout(nil) {
|
110
|
+
54
|
111
|
+
}
|
112
|
+
p timeout(0) {
|
113
|
+
54
|
114
|
+
}
|
115
|
+
p timeout(5) {
|
116
|
+
loop {
|
117
|
+
p 10
|
118
|
+
sleep 1
|
119
|
+
}
|
120
|
+
}
|
121
|
+
end
|
122
|
+
|
@@ -0,0 +1,130 @@
|
|
1
|
+
#
|
2
|
+
# tmpdir - retrieve temporary directory path
|
3
|
+
#
|
4
|
+
# $Id: tmpdir.rb 13762 2007-10-24 06:03:48Z akr $
|
5
|
+
#
|
6
|
+
|
7
|
+
require 'fileutils'
|
8
|
+
|
9
|
+
class Dir
|
10
|
+
|
11
|
+
@@systmpdir = '/tmp'
|
12
|
+
|
13
|
+
begin
|
14
|
+
require 'Win32API'
|
15
|
+
max_pathlen = 260
|
16
|
+
windir = ' '*(max_pathlen+1)
|
17
|
+
begin
|
18
|
+
getdir = Win32API.new('kernel32', 'GetSystemWindowsDirectory', 'PL', 'L')
|
19
|
+
rescue RuntimeError
|
20
|
+
getdir = Win32API.new('kernel32', 'GetWindowsDirectory', 'PL', 'L')
|
21
|
+
end
|
22
|
+
len = getdir.call(windir, windir.size)
|
23
|
+
windir = File.expand_path(windir[0, len])
|
24
|
+
temp = File.join(windir, 'temp')
|
25
|
+
@@systmpdir = temp if File.directory?(temp) and File.writable?(temp)
|
26
|
+
rescue LoadError
|
27
|
+
end
|
28
|
+
|
29
|
+
##
|
30
|
+
# Returns the operating system's temporary file path.
|
31
|
+
|
32
|
+
def Dir::tmpdir
|
33
|
+
tmp = '.'
|
34
|
+
if $SAFE > 0
|
35
|
+
tmp = @@systmpdir
|
36
|
+
else
|
37
|
+
for dir in [ENV['TMPDIR'], ENV['TMP'], ENV['TEMP'],
|
38
|
+
ENV['USERPROFILE'], @@systmpdir, '/tmp']
|
39
|
+
if dir and File.directory?(dir) and File.writable?(dir)
|
40
|
+
tmp = dir
|
41
|
+
break
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
45
|
+
File.expand_path(tmp)
|
46
|
+
end
|
47
|
+
|
48
|
+
# Dir.mktmpdir creates a temporary directory.
|
49
|
+
#
|
50
|
+
# The directory is created with 0700 permission.
|
51
|
+
#
|
52
|
+
# The prefix and suffix of the name of the directory is specified by
|
53
|
+
# the optional first argument, <i>prefix_suffix</i>.
|
54
|
+
# - If it is not specified or nil, "d" is used as the prefix and no suffix is used.
|
55
|
+
# - If it is a string, it is used as the prefix and no suffix is used.
|
56
|
+
# - If it is an array, first element is used as the prefix and second element is used as a suffix.
|
57
|
+
#
|
58
|
+
# Dir.mktmpdir {|dir| dir is ".../d..." }
|
59
|
+
# Dir.mktmpdir("foo") {|dir| dir is ".../foo..." }
|
60
|
+
# Dir.mktmpdir(["foo", "bar"]) {|dir| dir is ".../foo...bar" }
|
61
|
+
#
|
62
|
+
# The directory is created under Dir.tmpdir or
|
63
|
+
# the optional second argument <i>tmpdir</i> if non-nil value is given.
|
64
|
+
#
|
65
|
+
# Dir.mktmpdir {|dir| dir is "#{Dir.tmpdir}/d..." }
|
66
|
+
# Dir.mktmpdir(nil, "/var/tmp") {|dir| dir is "/var/tmp/d..." }
|
67
|
+
#
|
68
|
+
# If a block is given,
|
69
|
+
# it is yielded with the path of the directory.
|
70
|
+
# The directory and its contents are removed
|
71
|
+
# using FileUtils.remove_entry_secure before Dir.mktmpdir returns.
|
72
|
+
# The value of the block is returned.
|
73
|
+
#
|
74
|
+
# Dir.mktmpdir {|dir|
|
75
|
+
# # use the directory...
|
76
|
+
# open("#{dir}/foo", "w") { ... }
|
77
|
+
# }
|
78
|
+
#
|
79
|
+
# If a block is not given,
|
80
|
+
# The path of the directory is returned.
|
81
|
+
# In this case, Dir.mktmpdir doesn't remove the directory.
|
82
|
+
#
|
83
|
+
# dir = Dir.mktmpdir
|
84
|
+
# begin
|
85
|
+
# # use the directory...
|
86
|
+
# open("#{dir}/foo", "w") { ... }
|
87
|
+
# ensure
|
88
|
+
# # remove the directory.
|
89
|
+
# FileUtils.remove_entry_secure dir
|
90
|
+
# end
|
91
|
+
#
|
92
|
+
def Dir.mktmpdir(prefix_suffix=nil, tmpdir=nil)
|
93
|
+
case prefix_suffix
|
94
|
+
when nil
|
95
|
+
prefix = "d"
|
96
|
+
suffix = ""
|
97
|
+
when String
|
98
|
+
prefix = prefix_suffix
|
99
|
+
suffix = ""
|
100
|
+
when Array
|
101
|
+
prefix = prefix_suffix[0]
|
102
|
+
suffix = prefix_suffix[1]
|
103
|
+
else
|
104
|
+
raise ArgumentError, "unexpected prefix_suffix: #{prefix_suffix.inspect}"
|
105
|
+
end
|
106
|
+
tmpdir ||= Dir.tmpdir
|
107
|
+
t = Time.now.strftime("%Y%m%d")
|
108
|
+
n = nil
|
109
|
+
begin
|
110
|
+
path = "#{tmpdir}/#{prefix}#{t}-#{$$}-#{rand(0x100000000).to_s(36)}"
|
111
|
+
path << "-#{n}" if n
|
112
|
+
path << suffix
|
113
|
+
Dir.mkdir(path, 0700)
|
114
|
+
rescue Errno::EEXIST
|
115
|
+
n ||= 0
|
116
|
+
n += 1
|
117
|
+
retry
|
118
|
+
end
|
119
|
+
|
120
|
+
if block_given?
|
121
|
+
begin
|
122
|
+
yield path
|
123
|
+
ensure
|
124
|
+
FileUtils.remove_entry_secure path
|
125
|
+
end
|
126
|
+
else
|
127
|
+
path
|
128
|
+
end
|
129
|
+
end
|
130
|
+
end
|
@@ -0,0 +1,167 @@
|
|
1
|
+
#
|
2
|
+
# tracer.rb -
|
3
|
+
# $Release Version: 0.2$
|
4
|
+
# $Revision: 1.8 $
|
5
|
+
# $Date: 1998/05/19 03:42:49 $
|
6
|
+
# by Keiju ISHITSUKA(Nippon Rational Inc.)
|
7
|
+
#
|
8
|
+
# --
|
9
|
+
#
|
10
|
+
#
|
11
|
+
#
|
12
|
+
|
13
|
+
#
|
14
|
+
# tracer main class
|
15
|
+
#
|
16
|
+
class Tracer
|
17
|
+
@RCS_ID='-$Id: tracer.rb,v 1.8 1998/05/19 03:42:49 keiju Exp keiju $-'
|
18
|
+
|
19
|
+
@stdout = STDOUT
|
20
|
+
@verbose = false
|
21
|
+
class << self
|
22
|
+
attr :verbose, true
|
23
|
+
alias verbose? verbose
|
24
|
+
attr :stdout, true
|
25
|
+
end
|
26
|
+
|
27
|
+
EVENT_SYMBOL = {
|
28
|
+
"line" => "-",
|
29
|
+
"call" => ">",
|
30
|
+
"return" => "<",
|
31
|
+
"class" => "C",
|
32
|
+
"end" => "E",
|
33
|
+
"c-call" => ">",
|
34
|
+
"c-return" => "<",
|
35
|
+
}
|
36
|
+
|
37
|
+
def initialize
|
38
|
+
@threads = Hash.new
|
39
|
+
if defined? Thread.main
|
40
|
+
@threads[Thread.main.object_id] = 0
|
41
|
+
else
|
42
|
+
@threads[Thread.current.object_id] = 0
|
43
|
+
end
|
44
|
+
|
45
|
+
@get_line_procs = {}
|
46
|
+
|
47
|
+
@filters = []
|
48
|
+
end
|
49
|
+
|
50
|
+
def stdout
|
51
|
+
Tracer.stdout
|
52
|
+
end
|
53
|
+
|
54
|
+
def on
|
55
|
+
if block_given?
|
56
|
+
on
|
57
|
+
begin
|
58
|
+
yield
|
59
|
+
ensure
|
60
|
+
off
|
61
|
+
end
|
62
|
+
else
|
63
|
+
set_trace_func method(:trace_func).to_proc
|
64
|
+
stdout.print "Trace on\n" if Tracer.verbose?
|
65
|
+
end
|
66
|
+
end
|
67
|
+
|
68
|
+
def off
|
69
|
+
set_trace_func nil
|
70
|
+
stdout.print "Trace off\n" if Tracer.verbose?
|
71
|
+
end
|
72
|
+
|
73
|
+
def add_filter(p = proc)
|
74
|
+
@filters.push p
|
75
|
+
end
|
76
|
+
|
77
|
+
def set_get_line_procs(file, p = proc)
|
78
|
+
@get_line_procs[file] = p
|
79
|
+
end
|
80
|
+
|
81
|
+
def get_line(file, line)
|
82
|
+
if p = @get_line_procs[file]
|
83
|
+
return p.call(line)
|
84
|
+
end
|
85
|
+
|
86
|
+
unless list = SCRIPT_LINES__[file]
|
87
|
+
begin
|
88
|
+
f = open(file)
|
89
|
+
begin
|
90
|
+
SCRIPT_LINES__[file] = list = f.readlines
|
91
|
+
ensure
|
92
|
+
f.close
|
93
|
+
end
|
94
|
+
rescue
|
95
|
+
SCRIPT_LINES__[file] = list = []
|
96
|
+
end
|
97
|
+
end
|
98
|
+
|
99
|
+
if l = list[line - 1]
|
100
|
+
l
|
101
|
+
else
|
102
|
+
"-\n"
|
103
|
+
end
|
104
|
+
end
|
105
|
+
|
106
|
+
def get_thread_no
|
107
|
+
if no = @threads[Thread.current.object_id]
|
108
|
+
no
|
109
|
+
else
|
110
|
+
@threads[Thread.current.object_id] = @threads.size
|
111
|
+
end
|
112
|
+
end
|
113
|
+
|
114
|
+
def trace_func(event, file, line, id, binding, klass, *)
|
115
|
+
return if file == __FILE__
|
116
|
+
|
117
|
+
for p in @filters
|
118
|
+
return unless p.call event, file, line, id, binding, klass
|
119
|
+
end
|
120
|
+
|
121
|
+
saved_crit = Thread.critical
|
122
|
+
Thread.critical = true
|
123
|
+
stdout.printf("#%d:%s:%d:%s:%s: %s",
|
124
|
+
get_thread_no,
|
125
|
+
file,
|
126
|
+
line,
|
127
|
+
klass || '',
|
128
|
+
EVENT_SYMBOL[event],
|
129
|
+
get_line(file, line))
|
130
|
+
Thread.critical = saved_crit
|
131
|
+
end
|
132
|
+
|
133
|
+
Single = new
|
134
|
+
def Tracer.on
|
135
|
+
if block_given?
|
136
|
+
Single.on{yield}
|
137
|
+
else
|
138
|
+
Single.on
|
139
|
+
end
|
140
|
+
end
|
141
|
+
|
142
|
+
def Tracer.off
|
143
|
+
Single.off
|
144
|
+
end
|
145
|
+
|
146
|
+
def Tracer.set_get_line_procs(file_name, p = proc)
|
147
|
+
Single.set_get_line_procs(file_name, p)
|
148
|
+
end
|
149
|
+
|
150
|
+
def Tracer.add_filter(p = proc)
|
151
|
+
Single.add_filter(p)
|
152
|
+
end
|
153
|
+
|
154
|
+
end
|
155
|
+
|
156
|
+
SCRIPT_LINES__ = {} unless defined? SCRIPT_LINES__
|
157
|
+
|
158
|
+
if $0 == __FILE__
|
159
|
+
# direct call
|
160
|
+
|
161
|
+
$0 = ARGV[0]
|
162
|
+
ARGV.shift
|
163
|
+
Tracer.on
|
164
|
+
require $0
|
165
|
+
elsif caller(0).size == 1
|
166
|
+
Tracer.on
|
167
|
+
end
|
@@ -0,0 +1,290 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
#--
|
3
|
+
# tsort.rb - provides a module for topological sorting and strongly connected components.
|
4
|
+
#++
|
5
|
+
#
|
6
|
+
|
7
|
+
#
|
8
|
+
# TSort implements topological sorting using Tarjan's algorithm for
|
9
|
+
# strongly connected components.
|
10
|
+
#
|
11
|
+
# TSort is designed to be able to be used with any object which can be
|
12
|
+
# interpreted as a directed graph.
|
13
|
+
#
|
14
|
+
# TSort requires two methods to interpret an object as a graph,
|
15
|
+
# tsort_each_node and tsort_each_child.
|
16
|
+
#
|
17
|
+
# * tsort_each_node is used to iterate for all nodes over a graph.
|
18
|
+
# * tsort_each_child is used to iterate for child nodes of a given node.
|
19
|
+
#
|
20
|
+
# The equality of nodes are defined by eql? and hash since
|
21
|
+
# TSort uses Hash internally.
|
22
|
+
#
|
23
|
+
# == A Simple Example
|
24
|
+
#
|
25
|
+
# The following example demonstrates how to mix the TSort module into an
|
26
|
+
# existing class (in this case, Hash). Here, we're treating each key in
|
27
|
+
# the hash as a node in the graph, and so we simply alias the required
|
28
|
+
# #tsort_each_node method to Hash's #each_key method. For each key in the
|
29
|
+
# hash, the associated value is an array of the node's child nodes. This
|
30
|
+
# choice in turn leads to our implementation of the required #tsort_each_child
|
31
|
+
# method, which fetches the array of child nodes and then iterates over that
|
32
|
+
# array using the user-supplied block.
|
33
|
+
#
|
34
|
+
# require 'tsort'
|
35
|
+
#
|
36
|
+
# class Hash
|
37
|
+
# include TSort
|
38
|
+
# alias tsort_each_node each_key
|
39
|
+
# def tsort_each_child(node, &block)
|
40
|
+
# fetch(node).each(&block)
|
41
|
+
# end
|
42
|
+
# end
|
43
|
+
#
|
44
|
+
# {1=>[2, 3], 2=>[3], 3=>[], 4=>[]}.tsort
|
45
|
+
# #=> [3, 2, 1, 4]
|
46
|
+
#
|
47
|
+
# {1=>[2], 2=>[3, 4], 3=>[2], 4=>[]}.strongly_connected_components
|
48
|
+
# #=> [[4], [2, 3], [1]]
|
49
|
+
#
|
50
|
+
# == A More Realistic Example
|
51
|
+
#
|
52
|
+
# A very simple `make' like tool can be implemented as follows:
|
53
|
+
#
|
54
|
+
# require 'tsort'
|
55
|
+
#
|
56
|
+
# class Make
|
57
|
+
# def initialize
|
58
|
+
# @dep = {}
|
59
|
+
# @dep.default = []
|
60
|
+
# end
|
61
|
+
#
|
62
|
+
# def rule(outputs, inputs=[], &block)
|
63
|
+
# triple = [outputs, inputs, block]
|
64
|
+
# outputs.each {|f| @dep[f] = [triple]}
|
65
|
+
# @dep[triple] = inputs
|
66
|
+
# end
|
67
|
+
#
|
68
|
+
# def build(target)
|
69
|
+
# each_strongly_connected_component_from(target) {|ns|
|
70
|
+
# if ns.length != 1
|
71
|
+
# fs = ns.delete_if {|n| Array === n}
|
72
|
+
# raise TSort::Cyclic.new("cyclic dependencies: #{fs.join ', '}")
|
73
|
+
# end
|
74
|
+
# n = ns.first
|
75
|
+
# if Array === n
|
76
|
+
# outputs, inputs, block = n
|
77
|
+
# inputs_time = inputs.map {|f| File.mtime f}.max
|
78
|
+
# begin
|
79
|
+
# outputs_time = outputs.map {|f| File.mtime f}.min
|
80
|
+
# rescue Errno::ENOENT
|
81
|
+
# outputs_time = nil
|
82
|
+
# end
|
83
|
+
# if outputs_time == nil ||
|
84
|
+
# inputs_time != nil && outputs_time <= inputs_time
|
85
|
+
# sleep 1 if inputs_time != nil && inputs_time.to_i == Time.now.to_i
|
86
|
+
# block.call
|
87
|
+
# end
|
88
|
+
# end
|
89
|
+
# }
|
90
|
+
# end
|
91
|
+
#
|
92
|
+
# def tsort_each_child(node, &block)
|
93
|
+
# @dep[node].each(&block)
|
94
|
+
# end
|
95
|
+
# include TSort
|
96
|
+
# end
|
97
|
+
#
|
98
|
+
# def command(arg)
|
99
|
+
# print arg, "\n"
|
100
|
+
# system arg
|
101
|
+
# end
|
102
|
+
#
|
103
|
+
# m = Make.new
|
104
|
+
# m.rule(%w[t1]) { command 'date > t1' }
|
105
|
+
# m.rule(%w[t2]) { command 'date > t2' }
|
106
|
+
# m.rule(%w[t3]) { command 'date > t3' }
|
107
|
+
# m.rule(%w[t4], %w[t1 t3]) { command 'cat t1 t3 > t4' }
|
108
|
+
# m.rule(%w[t5], %w[t4 t2]) { command 'cat t4 t2 > t5' }
|
109
|
+
# m.build('t5')
|
110
|
+
#
|
111
|
+
# == Bugs
|
112
|
+
#
|
113
|
+
# * 'tsort.rb' is wrong name because this library uses
|
114
|
+
# Tarjan's algorithm for strongly connected components.
|
115
|
+
# Although 'strongly_connected_components.rb' is correct but too long.
|
116
|
+
#
|
117
|
+
# == References
|
118
|
+
#
|
119
|
+
# R. E. Tarjan, "Depth First Search and Linear Graph Algorithms",
|
120
|
+
# <em>SIAM Journal on Computing</em>, Vol. 1, No. 2, pp. 146-160, June 1972.
|
121
|
+
#
|
122
|
+
|
123
|
+
module TSort
|
124
|
+
class Cyclic < StandardError
|
125
|
+
end
|
126
|
+
|
127
|
+
#
|
128
|
+
# Returns a topologically sorted array of nodes.
|
129
|
+
# The array is sorted from children to parents, i.e.
|
130
|
+
# the first element has no child and the last node has no parent.
|
131
|
+
#
|
132
|
+
# If there is a cycle, TSort::Cyclic is raised.
|
133
|
+
#
|
134
|
+
def tsort
|
135
|
+
result = []
|
136
|
+
tsort_each {|element| result << element}
|
137
|
+
result
|
138
|
+
end
|
139
|
+
|
140
|
+
#
|
141
|
+
# The iterator version of the #tsort method.
|
142
|
+
# <tt><em>obj</em>.tsort_each</tt> is similar to <tt><em>obj</em>.tsort.each</tt>, but
|
143
|
+
# modification of _obj_ during the iteration may lead to unexpected results.
|
144
|
+
#
|
145
|
+
# #tsort_each returns +nil+.
|
146
|
+
# If there is a cycle, TSort::Cyclic is raised.
|
147
|
+
#
|
148
|
+
def tsort_each # :yields: node
|
149
|
+
each_strongly_connected_component {|component|
|
150
|
+
if component.size == 1
|
151
|
+
yield component.first
|
152
|
+
else
|
153
|
+
raise Cyclic.new("topological sort failed: #{component.inspect}")
|
154
|
+
end
|
155
|
+
}
|
156
|
+
end
|
157
|
+
|
158
|
+
#
|
159
|
+
# Returns strongly connected components as an array of arrays of nodes.
|
160
|
+
# The array is sorted from children to parents.
|
161
|
+
# Each elements of the array represents a strongly connected component.
|
162
|
+
#
|
163
|
+
def strongly_connected_components
|
164
|
+
result = []
|
165
|
+
each_strongly_connected_component {|component| result << component}
|
166
|
+
result
|
167
|
+
end
|
168
|
+
|
169
|
+
#
|
170
|
+
# The iterator version of the #strongly_connected_components method.
|
171
|
+
# <tt><em>obj</em>.each_strongly_connected_component</tt> is similar to
|
172
|
+
# <tt><em>obj</em>.strongly_connected_components.each</tt>, but
|
173
|
+
# modification of _obj_ during the iteration may lead to unexpected results.
|
174
|
+
#
|
175
|
+
#
|
176
|
+
# #each_strongly_connected_component returns +nil+.
|
177
|
+
#
|
178
|
+
def each_strongly_connected_component # :yields: nodes
|
179
|
+
id_map = {}
|
180
|
+
stack = []
|
181
|
+
tsort_each_node {|node|
|
182
|
+
unless id_map.include? node
|
183
|
+
each_strongly_connected_component_from(node, id_map, stack) {|c|
|
184
|
+
yield c
|
185
|
+
}
|
186
|
+
end
|
187
|
+
}
|
188
|
+
nil
|
189
|
+
end
|
190
|
+
|
191
|
+
#
|
192
|
+
# Iterates over strongly connected component in the subgraph reachable from
|
193
|
+
# _node_.
|
194
|
+
#
|
195
|
+
# Return value is unspecified.
|
196
|
+
#
|
197
|
+
# #each_strongly_connected_component_from doesn't call #tsort_each_node.
|
198
|
+
#
|
199
|
+
def each_strongly_connected_component_from(node, id_map={}, stack=[]) # :yields: nodes
|
200
|
+
minimum_id = node_id = id_map[node] = id_map.size
|
201
|
+
stack_length = stack.length
|
202
|
+
stack << node
|
203
|
+
|
204
|
+
tsort_each_child(node) {|child|
|
205
|
+
if id_map.include? child
|
206
|
+
child_id = id_map[child]
|
207
|
+
minimum_id = child_id if child_id && child_id < minimum_id
|
208
|
+
else
|
209
|
+
sub_minimum_id =
|
210
|
+
each_strongly_connected_component_from(child, id_map, stack) {|c|
|
211
|
+
yield c
|
212
|
+
}
|
213
|
+
minimum_id = sub_minimum_id if sub_minimum_id < minimum_id
|
214
|
+
end
|
215
|
+
}
|
216
|
+
|
217
|
+
if node_id == minimum_id
|
218
|
+
component = stack.slice!(stack_length .. -1)
|
219
|
+
component.each {|n| id_map[n] = nil}
|
220
|
+
yield component
|
221
|
+
end
|
222
|
+
|
223
|
+
minimum_id
|
224
|
+
end
|
225
|
+
|
226
|
+
#
|
227
|
+
# Should be implemented by a extended class.
|
228
|
+
#
|
229
|
+
# #tsort_each_node is used to iterate for all nodes over a graph.
|
230
|
+
#
|
231
|
+
def tsort_each_node # :yields: node
|
232
|
+
raise NotImplementedError.new
|
233
|
+
end
|
234
|
+
|
235
|
+
#
|
236
|
+
# Should be implemented by a extended class.
|
237
|
+
#
|
238
|
+
# #tsort_each_child is used to iterate for child nodes of _node_.
|
239
|
+
#
|
240
|
+
def tsort_each_child(node) # :yields: child
|
241
|
+
raise NotImplementedError.new
|
242
|
+
end
|
243
|
+
end
|
244
|
+
|
245
|
+
if __FILE__ == $0
|
246
|
+
require 'test/unit'
|
247
|
+
|
248
|
+
class TSortHash < Hash # :nodoc:
|
249
|
+
include TSort
|
250
|
+
alias tsort_each_node each_key
|
251
|
+
def tsort_each_child(node, &block)
|
252
|
+
fetch(node).each(&block)
|
253
|
+
end
|
254
|
+
end
|
255
|
+
|
256
|
+
class TSortArray < Array # :nodoc:
|
257
|
+
include TSort
|
258
|
+
alias tsort_each_node each_index
|
259
|
+
def tsort_each_child(node, &block)
|
260
|
+
fetch(node).each(&block)
|
261
|
+
end
|
262
|
+
end
|
263
|
+
|
264
|
+
class TSortTest < Test::Unit::TestCase # :nodoc:
|
265
|
+
def test_dag
|
266
|
+
h = TSortHash[{1=>[2, 3], 2=>[3], 3=>[]}]
|
267
|
+
assert_equal([3, 2, 1], h.tsort)
|
268
|
+
assert_equal([[3], [2], [1]], h.strongly_connected_components)
|
269
|
+
end
|
270
|
+
|
271
|
+
def test_cycle
|
272
|
+
h = TSortHash[{1=>[2], 2=>[3, 4], 3=>[2], 4=>[]}]
|
273
|
+
assert_equal([[4], [2, 3], [1]],
|
274
|
+
h.strongly_connected_components.map {|nodes| nodes.sort})
|
275
|
+
assert_raise(TSort::Cyclic) { h.tsort }
|
276
|
+
end
|
277
|
+
|
278
|
+
def test_array
|
279
|
+
a = TSortArray[[1], [0], [0], [2]]
|
280
|
+
assert_equal([[0, 1], [2], [3]],
|
281
|
+
a.strongly_connected_components.map {|nodes| nodes.sort})
|
282
|
+
|
283
|
+
a = TSortArray[[], [0]]
|
284
|
+
assert_equal([[0], [1]],
|
285
|
+
a.strongly_connected_components.map {|nodes| nodes.sort})
|
286
|
+
end
|
287
|
+
end
|
288
|
+
|
289
|
+
end
|
290
|
+
|