carats 0.3.0
Sign up to get free protection for your applications and to get access to all the features.
- data/ChangeLog +2 -0
- data/LICENSE +5 -0
- data/README +67 -0
- data/Reapfile +72 -0
- data/ToDo +24 -0
- data/bench/b_harray.rb +49 -0
- data/bench/b_range.rb +64 -0
- data/demo/ansicolor/cdiff.rb +20 -0
- data/demo/ansicolor/example.rb +82 -0
- data/demo/io-reactor/chatserver.rb +347 -0
- data/doc/classes/Array.html +172 -0
- data/doc/classes/BBCode.html +638 -0
- data/doc/classes/BinaryReader.html +675 -0
- data/doc/classes/Binding.html +223 -0
- data/doc/classes/ByteOrder.html +284 -0
- data/doc/classes/Class.html +189 -0
- data/doc/classes/Constant.html +785 -0
- data/doc/classes/Constant/CGS.html +609 -0
- data/doc/classes/Continuation.html +113 -0
- data/doc/classes/Coroutine.html +387 -0
- data/doc/classes/CountingSemaphore.html +337 -0
- data/doc/classes/CrossCase.html +561 -0
- data/doc/classes/DynamicMixin.html +185 -0
- data/doc/classes/EnumerableWithArgs.html +550 -0
- data/doc/classes/Expect.html +428 -0
- data/doc/classes/Expect/DefaultChain.html +113 -0
- data/doc/classes/Expect/SeparatedPattern.html +223 -0
- data/doc/classes/Expect/Timeout.html +167 -0
- data/doc/classes/Expect/UnmatchedMessage.html +160 -0
- data/doc/classes/FileList.html +833 -0
- data/doc/classes/FloatString.html +534 -0
- data/doc/classes/Functor.html +211 -0
- data/doc/classes/HArray.html +1872 -0
- data/doc/classes/HTML.html +328 -0
- data/doc/classes/Heap.html +683 -0
- data/doc/classes/Heap/EmptyHeapException.html +111 -0
- data/doc/classes/Heap/Max.html +176 -0
- data/doc/classes/Heap/Min.html +176 -0
- data/doc/classes/IO.html +108 -0
- data/doc/classes/IO/Reactor.html +790 -0
- data/doc/classes/IO/Redirect.html +289 -0
- data/doc/classes/Infinity.html +320 -0
- data/doc/classes/Interval.html +1014 -0
- data/doc/classes/InvalidNackError.html +161 -0
- data/doc/classes/Kernel.html +204 -0
- data/doc/classes/Lisp.html +1132 -0
- data/doc/classes/Lisp/DottedPair.html +379 -0
- data/doc/classes/Lisp/Format.html +178 -0
- data/doc/classes/Lisp/Format/ArgumentError.html +126 -0
- data/doc/classes/Lisp/Format/Directives.html +155 -0
- data/doc/classes/Lisp/Format/Directives/ArgJump.html +178 -0
- data/doc/classes/Lisp/Format/Directives/Ascii.html +119 -0
- data/doc/classes/Lisp/Format/Directives/BeginCaseConversion.html +185 -0
- data/doc/classes/Lisp/Format/Directives/BeginConditional.html +307 -0
- data/doc/classes/Lisp/Format/Directives/BeginIteration.html +338 -0
- data/doc/classes/Lisp/Format/Directives/Binary.html +157 -0
- data/doc/classes/Lisp/Format/Directives/Character.html +228 -0
- data/doc/classes/Lisp/Format/Directives/CharacterDirective.html +203 -0
- data/doc/classes/Lisp/Format/Directives/ClauseSeparator.html +166 -0
- data/doc/classes/Lisp/Format/Directives/Decimal.html +119 -0
- data/doc/classes/Lisp/Format/Directives/Directive.html +397 -0
- data/doc/classes/Lisp/Format/Directives/DollarFP.html +205 -0
- data/doc/classes/Lisp/Format/Directives/EndCaseConversion.html +174 -0
- data/doc/classes/Lisp/Format/Directives/EndConditional.html +159 -0
- data/doc/classes/Lisp/Format/Directives/EndIteration.html +163 -0
- data/doc/classes/Lisp/Format/Directives/ExpFP.html +252 -0
- data/doc/classes/Lisp/Format/Directives/FFFP.html +224 -0
- data/doc/classes/Lisp/Format/Directives/Factory.html +180 -0
- data/doc/classes/Lisp/Format/Directives/FreshLine.html +175 -0
- data/doc/classes/Lisp/Format/Directives/GeneralFP.html +265 -0
- data/doc/classes/Lisp/Format/Directives/Hexadecimal.html +157 -0
- data/doc/classes/Lisp/Format/Directives/Indirection.html +183 -0
- data/doc/classes/Lisp/Format/Directives/Literal.html +187 -0
- data/doc/classes/Lisp/Format/Directives/NewLine.html +158 -0
- data/doc/classes/Lisp/Format/Directives/NewPage.html +158 -0
- data/doc/classes/Lisp/Format/Directives/Number.html +243 -0
- data/doc/classes/Lisp/Format/Directives/Octal.html +157 -0
- data/doc/classes/Lisp/Format/Directives/Plural.html +177 -0
- data/doc/classes/Lisp/Format/Directives/Print.html +237 -0
- data/doc/classes/Lisp/Format/Directives/Radix.html +432 -0
- data/doc/classes/Lisp/Format/Directives/SExpression.html +157 -0
- data/doc/classes/Lisp/Format/Directives/SkipWhitespace.html +165 -0
- data/doc/classes/Lisp/Format/Directives/Tabulate.html +198 -0
- data/doc/classes/Lisp/Format/Directives/Tilde.html +158 -0
- data/doc/classes/Lisp/Format/Directives/UnknownDirectiveError.html +117 -0
- data/doc/classes/Lisp/Format/Formatter.html +193 -0
- data/doc/classes/Lisp/Format/IncompleteParameterError.html +119 -0
- data/doc/classes/Lisp/Format/IndexError.html +126 -0
- data/doc/classes/Lisp/Format/Lexer.html +479 -0
- data/doc/classes/Lisp/Format/MalformedError.html +119 -0
- data/doc/classes/Lisp/Format/MissingParameterError.html +119 -0
- data/doc/classes/Lisp/Format/ModifierError.html +119 -0
- data/doc/classes/Lisp/Format/Output.html +239 -0
- data/doc/classes/Lisp/Format/ParameterError.html +126 -0
- data/doc/classes/Lisp/Format/Parameters.html +123 -0
- data/doc/classes/Lisp/Format/Parameters/Argument.html +172 -0
- data/doc/classes/Lisp/Format/Parameters/ArgumentCount.html +159 -0
- data/doc/classes/Lisp/Format/Parameters/Character.html +119 -0
- data/doc/classes/Lisp/Format/Parameters/Default.html +120 -0
- data/doc/classes/Lisp/Format/Parameters/Integer.html +119 -0
- data/doc/classes/Lisp/Format/Parameters/Parameter.html +206 -0
- data/doc/classes/Lisp/Format/Parser.html +212 -0
- data/doc/classes/Lisp/Format/Positioned.html +166 -0
- data/doc/classes/Lisp/Format/State.html +455 -0
- data/doc/classes/Lisp/Format/SyntaxError.html +126 -0
- data/doc/classes/Method.html +274 -0
- data/doc/classes/Method/DuckHunter.html +281 -0
- data/doc/classes/Module.html +709 -0
- data/doc/classes/Multiton.html +284 -0
- data/doc/classes/Multiton/New.html +164 -0
- data/doc/classes/Multiton/Semi.html +155 -0
- data/doc/classes/NackClass.html +322 -0
- data/doc/classes/NilClass.html +231 -0
- data/doc/classes/NilComparable.html +179 -0
- data/doc/classes/NotCopyable.html +273 -0
- data/doc/classes/Object.html +261 -0
- data/doc/classes/OpenStructable.html +346 -0
- data/doc/classes/OrderedHash.html +939 -0
- data/doc/classes/Parser.html +515 -0
- data/doc/classes/Parser/Main.html +178 -0
- data/doc/classes/Parser/Marker.html +475 -0
- data/doc/classes/Parser/Registry.html +354 -0
- data/doc/classes/Parser/Token.html +399 -0
- data/doc/classes/Parser/UnitToken.html +222 -0
- data/doc/classes/Ref.html +230 -0
- data/doc/classes/SimpleStringIO.html +183 -0
- data/doc/classes/StaticHash.html +202 -0
- data/doc/classes/String.html +172 -0
- data/doc/classes/Struct.html +181 -0
- data/doc/classes/SuperStruct.html +382 -0
- data/doc/classes/Term.html +156 -0
- data/doc/classes/Term/ANSIColor.html +185 -0
- data/doc/classes/Text.html +138 -0
- data/doc/classes/Text/Soundex.html +222 -0
- data/doc/classes/TextTagIterator.html +911 -0
- data/doc/classes/Time.html +119 -0
- data/doc/classes/Time/Limit.html +303 -0
- data/doc/classes/Time/Limit/Dummy.html +181 -0
- data/doc/classes/Timer.html +351 -0
- data/doc/classes/TracePoint.html +532 -0
- data/doc/classes/Tuple.html +178 -0
- data/doc/classes/Uninheritable.html +213 -0
- data/doc/classes/Version.html +783 -0
- data/doc/created.rid +1 -0
- data/doc/files/LICENSE.html +113 -0
- data/doc/files/README.html +201 -0
- data/doc/files/lib/carat/1st_rb.html +107 -0
- data/doc/files/lib/carat/ansicolor_rb.html +146 -0
- data/doc/files/lib/carat/attr_rb.html +101 -0
- data/doc/files/lib/carat/bbcode_rb.html +152 -0
- data/doc/files/lib/carat/binaryreader_rb.html +114 -0
- data/doc/files/lib/carat/binding-of-caller_rb.html +108 -0
- data/doc/files/lib/carat/byteorder_rb.html +107 -0
- data/doc/files/lib/carat/constant_rb.html +167 -0
- data/doc/files/lib/carat/coroutine_rb.html +156 -0
- data/doc/files/lib/carat/crosscase_rb.html +224 -0
- data/doc/files/lib/carat/duckhunter_rb.html +165 -0
- data/doc/files/lib/carat/dynamic-mixin_rb.html +101 -0
- data/doc/files/lib/carat/enumerable-args_rb.html +140 -0
- data/doc/files/lib/carat/expect_rb.html +137 -0
- data/doc/files/lib/carat/filelist_rb.html +130 -0
- data/doc/files/lib/carat/floatstring_rb.html +126 -0
- data/doc/files/lib/carat/functor_rb.html +140 -0
- data/doc/files/lib/carat/harray_rb.html +128 -0
- data/doc/files/lib/carat/heap_rb.html +154 -0
- data/doc/files/lib/carat/html-helpers_rb.html +116 -0
- data/doc/files/lib/carat/infinity_rb.html +142 -0
- data/doc/files/lib/carat/init_rb.html +127 -0
- data/doc/files/lib/carat/interval_rb.html +162 -0
- data/doc/files/lib/carat/io-reactor_rb.html +211 -0
- data/doc/files/lib/carat/io-redirect_rb.html +132 -0
- data/doc/files/lib/carat/lisp-format_rb.html +187 -0
- data/doc/files/lib/carat/lisp_rb.html +152 -0
- data/doc/files/lib/carat/macro_rb.html +129 -0
- data/doc/files/lib/carat/multiton_rb.html +178 -0
- data/doc/files/lib/carat/nack_rb.html +193 -0
- data/doc/files/lib/carat/nil-comparable_rb.html +126 -0
- data/doc/files/lib/carat/nil-missing_rb.html +101 -0
- data/doc/files/lib/carat/notcopyable_rb.html +166 -0
- data/doc/files/lib/carat/orderedhash_rb.html +107 -0
- data/doc/files/lib/carat/ostructable_rb.html +157 -0
- data/doc/files/lib/carat/parser-old_rb.html +239 -0
- data/doc/files/lib/carat/parser_rb.html +244 -0
- data/doc/files/lib/carat/ref_rb.html +107 -0
- data/doc/files/lib/carat/semaphore_rb.html +132 -0
- data/doc/files/lib/carat/snapshot_rb.html +152 -0
- data/doc/files/lib/carat/soundex_rb.html +128 -0
- data/doc/files/lib/carat/sstruct_rb.html +142 -0
- data/doc/files/lib/carat/statichash_rb.html +150 -0
- data/doc/files/lib/carat/tagiter_rb.html +236 -0
- data/doc/files/lib/carat/timelimit_rb.html +136 -0
- data/doc/files/lib/carat/timer_rb.html +153 -0
- data/doc/files/lib/carat/tracepoint_rb.html +160 -0
- data/doc/files/lib/carat/tuple_rb.html +123 -0
- data/doc/files/lib/carat/uninheritable_rb.html +101 -0
- data/doc/files/lib/carat/version_rb.html +141 -0
- data/doc/fr_class_index.html +159 -0
- data/doc/fr_file_index.html +78 -0
- data/doc/fr_method_index.html +663 -0
- data/doc/index.html +24 -0
- data/doc/rdoc-style.css +208 -0
- data/lib/carat-dev/README +11 -0
- data/lib/carat-dev/access-blocks/access_blocks.rb +42 -0
- data/lib/carat-dev/association/association.rb +70 -0
- data/lib/carat-dev/blankslate/blankslate.rb +51 -0
- data/lib/carat-dev/breakpoint.rb +518 -0
- data/lib/carat-dev/class-constructor/constructor_methods.rb +78 -0
- data/lib/carat-dev/class-constructor/tc_constructor.rb +35 -0
- data/lib/carat-dev/closecall/closecall-test.rb +39 -0
- data/lib/carat-dev/closecall/closecall.rb +101 -0
- data/lib/carat-dev/commandrunner/commandrunner.rb +100 -0
- data/lib/carat-dev/conditional/conditionals.rb +106 -0
- data/lib/carat-dev/daemon/daemon.rb +70 -0
- data/lib/carat-dev/detach/detach.rb +363 -0
- data/lib/carat-dev/detach/tc_detach.rb +57 -0
- data/lib/carat-dev/import-module/import-module-0.81.tar.gz +0 -0
- data/lib/carat-dev/import-module/import-module-0.81/LICENSE +1 -0
- data/lib/carat-dev/import-module/import-module-0.81/Makefile +11 -0
- data/lib/carat-dev/import-module/import-module-0.81/README +4 -0
- data/lib/carat-dev/import-module/import-module-0.81/dev-lib/import-module-hash.rb +49 -0
- data/lib/carat-dev/import-module/import-module-0.81/dev-lib/import-module-pip.rb +71 -0
- data/lib/carat-dev/import-module/import-module-0.81/dev-lib/import-module-unbound-method.rb +36 -0
- data/lib/carat-dev/import-module/import-module-0.81/doc/README-ja.html +293 -0
- data/lib/carat-dev/import-module/import-module-0.81/doc/README-ja.rd +306 -0
- data/lib/carat-dev/import-module/import-module-0.81/doc/README.html +290 -0
- data/lib/carat-dev/import-module/import-module-0.81/doc/README.rd +303 -0
- data/lib/carat-dev/import-module/import-module-0.81/doc/style.css +85 -0
- data/lib/carat-dev/import-module/import-module-0.81/install.rb +99 -0
- data/lib/carat-dev/import-module/import-module-0.81/lib/import-module-single-thread.rb +84 -0
- data/lib/carat-dev/import-module/import-module-0.81/lib/import-module.rb +493 -0
- data/lib/carat-dev/import-module/import-module-0.81/test/Makefile +2 -0
- data/lib/carat-dev/import-module/import-module-0.81/test/test +91 -0
- data/lib/carat-dev/import-module/import-module-0.81/test/test-import-module.rb +936 -0
- data/lib/carat-dev/import-module/import-module-0.81/test/test-import_scope.rb +33 -0
- data/lib/carat-dev/import-module/import-module-0.81/test/test-scope_import.rb +33 -0
- data/lib/carat-dev/import-module/import-module-0.81/test/test-time.rb +184 -0
- data/lib/carat-dev/import-module/import-module-0.81/test/test.sh +91 -0
- data/lib/carat-dev/import-module/import-module-0.81/test/time.rb +135 -0
- data/lib/carat-dev/import-module/import-module-0.81/test/times-do.sh +10 -0
- data/lib/carat-dev/interface_work/SCRAP/i-contracts.rb +37 -0
- data/lib/carat-dev/interface_work/SCRAP/interface.rb +105 -0
- data/lib/carat-dev/interface_work/SCRAP/j-interface/interface-0.1.0.zip +0 -0
- data/lib/carat-dev/interface_work/SCRAP/j-interface/interface-0.1.0/CHANGES +3 -0
- data/lib/carat-dev/interface_work/SCRAP/j-interface/interface-0.1.0/MANIFEST +15 -0
- data/lib/carat-dev/interface_work/SCRAP/j-interface/interface-0.1.0/README +32 -0
- data/lib/carat-dev/interface_work/SCRAP/j-interface/interface-0.1.0/doc/interface.rd +73 -0
- data/lib/carat-dev/interface_work/SCRAP/j-interface/interface-0.1.0/doc/interface.txt +94 -0
- data/lib/carat-dev/interface_work/SCRAP/j-interface/interface-0.1.0/install.rb +16 -0
- data/lib/carat-dev/interface_work/SCRAP/j-interface/interface-0.1.0/lib/interface.rb +50 -0
- data/lib/carat-dev/interface_work/SCRAP/j-interface/interface-0.1.0/test/tc_interface.rb +51 -0
- data/lib/carat-dev/interface_work/SCRAP/j-interface/interface-0.1.0/test/test.rb +29 -0
- data/lib/carat-dev/interface_work/SCRAP/j-interface/interface-0.1.0/test/test_instance.rb +24 -0
- data/lib/carat-dev/interface_work/SCRAP/j-interface/interface-0.1.0/test/test_sub.rb +29 -0
- data/lib/carat-dev/interface_work/SCRAP/j-interface/interface-0.1.0/test/test_unrequire.rb +28 -0
- data/lib/carat-dev/interface_work/contracts/contract.zip +0 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/classes/Contract.html +376 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/classes/Contract.src/M000001.html +23 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/classes/Contract.src/M000002.html +18 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/classes/Contract.src/M000003.html +19 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/classes/Contract.src/M000004.html +29 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/classes/Contract.src/M000005.html +18 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/classes/Contract.src/M000006.html +18 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/classes/Contract/ContractError.html +142 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/classes/Contract/ContractException.html +153 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/classes/Contract/ContractMismatch.html +125 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/classes/Module.html +157 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/classes/Module.src/M000007.html +112 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/created.rid +1 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/files/lib/contract/assertions_rb.html +109 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/files/lib/contract/exception_rb.html +108 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/files/lib/contract/integration_rb.html +108 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/files/lib/contract/overrides_rb.html +109 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/files/lib/contract_rb.html +114 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/fr_class_index.html +31 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/fr_file_index.html +31 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/fr_method_index.html +33 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/index.html +24 -0
- data/lib/carat-dev/interface_work/contracts/contract/doc/rdoc-style.css +208 -0
- data/lib/carat-dev/interface_work/contracts/contract/lib/contract.rb +88 -0
- data/lib/carat-dev/interface_work/contracts/contract/lib/contract/assertions.rb +37 -0
- data/lib/carat-dev/interface_work/contracts/contract/lib/contract/exception.rb +92 -0
- data/lib/carat-dev/interface_work/contracts/contract/lib/contract/integration.rb +132 -0
- data/lib/carat-dev/interface_work/contracts/contract/lib/contract/overrides.rb +32 -0
- data/lib/carat-dev/interface_work/must.rb +37 -0
- data/lib/carat-dev/interface_work/type.rb +232 -0
- data/lib/carat-dev/main/tc_toplevel.rb +23 -0
- data/lib/carat-dev/main/toplevel.rb +33 -0
- data/lib/carat-dev/main/toplevel_test.rb +24 -0
- data/lib/carat-dev/misc/1.rb +40 -0
- data/lib/carat-dev/misc/misc.rb +44 -0
- data/lib/carat-dev/misc/sys.rb +186 -0
- data/lib/carat-dev/misc/temp.rb +1 -0
- data/lib/carat-dev/misc/utils.rb +518 -0
- data/lib/carat-dev/predicate/predicate.rb +109 -0
- data/lib/carat-dev/predicate/predicate_test.rb +67 -0
- data/lib/carat-dev/premshree.rb +40 -0
- data/lib/carat-dev/priority-queue/pqueue.rb +183 -0
- data/lib/carat-dev/priority-queue/priorityqueue.rb +84 -0
- data/lib/carat-dev/quaternion/quaternion.rb +529 -0
- data/lib/carat-dev/range.rb +259 -0
- data/lib/carat-dev/system/rubyinfo.rb +75 -0
- data/lib/carat-dev/system/system.rb +105 -0
- data/lib/carat-dev/tc_range.rb +118 -0
- data/lib/carat-dev/timer/timer-doc/classes/Timer.html +291 -0
- data/lib/carat-dev/timer/timer-doc/classes/Timer.src/M000001.html +26 -0
- data/lib/carat-dev/timer/timer-doc/classes/Timer.src/M000002.html +19 -0
- data/lib/carat-dev/timer/timer-doc/classes/Timer.src/M000003.html +18 -0
- data/lib/carat-dev/timer/timer-doc/classes/Timer.src/M000004.html +18 -0
- data/lib/carat-dev/timer/timer-doc/classes/Timer.src/M000005.html +21 -0
- data/lib/carat-dev/timer/timer-doc/classes/Timer.src/M000006.html +23 -0
- data/lib/carat-dev/timer/timer-doc/created.rid +1 -0
- data/lib/carat-dev/timer/timer-doc/files/timer_rb.html +144 -0
- data/lib/carat-dev/timer/timer-doc/fr_class_index.html +27 -0
- data/lib/carat-dev/timer/timer-doc/fr_file_index.html +27 -0
- data/lib/carat-dev/timer/timer-doc/fr_method_index.html +32 -0
- data/lib/carat-dev/timer/timer-doc/index.html +24 -0
- data/lib/carat-dev/timer/timer-doc/rdoc-style.css +208 -0
- data/lib/carat-dev/timer/timer.rb +160 -0
- data/lib/carat-dev/vars/vars.rb +62 -0
- data/lib/carat/1st.rb +58 -0
- data/lib/carat/ansicolor.rb +122 -0
- data/lib/carat/attr.rb +342 -0
- data/lib/carat/bbcode.rb +352 -0
- data/lib/carat/binaryreader.rb +170 -0
- data/lib/carat/binding-of-caller.rb +83 -0
- data/lib/carat/byteorder.rb +34 -0
- data/lib/carat/constant.rb +287 -0
- data/lib/carat/coroutine.rb +102 -0
- data/lib/carat/crosscase.rb +309 -0
- data/lib/carat/duckhunter.rb +158 -0
- data/lib/carat/dynamic-mixin.rb +71 -0
- data/lib/carat/enumerable-args.rb +125 -0
- data/lib/carat/expect.rb +192 -0
- data/lib/carat/filelist.rb +277 -0
- data/lib/carat/floatstring.rb +153 -0
- data/lib/carat/functor.rb +41 -0
- data/lib/carat/harray.rb +507 -0
- data/lib/carat/heap.rb +193 -0
- data/lib/carat/html-helpers.rb +82 -0
- data/lib/carat/infinity.rb +61 -0
- data/lib/carat/init.rb +33 -0
- data/lib/carat/interval.rb +248 -0
- data/lib/carat/io-reactor.rb +657 -0
- data/lib/carat/io-redirect.rb +99 -0
- data/lib/carat/lisp-format.rb +1832 -0
- data/lib/carat/lisp.rb +336 -0
- data/lib/carat/macro.rb +68 -0
- data/lib/carat/multiton.rb +153 -0
- data/lib/carat/nack.rb +115 -0
- data/lib/carat/nil-comparable.rb +67 -0
- data/lib/carat/nil-missing.rb +12 -0
- data/lib/carat/notcopyable.rb +68 -0
- data/lib/carat/orderedhash.rb +249 -0
- data/lib/carat/ostructable.rb +138 -0
- data/lib/carat/parser-old.rb +350 -0
- data/lib/carat/parser.rb +393 -0
- data/lib/carat/ref.rb +31 -0
- data/lib/carat/semaphore.rb +69 -0
- data/lib/carat/snapshot.rb +94 -0
- data/lib/carat/soundex.rb +104 -0
- data/lib/carat/sstruct.rb +223 -0
- data/lib/carat/statichash.rb +49 -0
- data/lib/carat/tagiter.rb +345 -0
- data/lib/carat/timelimit.rb +114 -0
- data/lib/carat/timer.rb +99 -0
- data/lib/carat/tracepoint.rb +154 -0
- data/lib/carat/tuple.rb +31 -0
- data/lib/carat/uninheritable.rb +68 -0
- data/lib/carat/version.rb +147 -0
- data/pub/doc/sstruct.txt +204 -0
- data/pub/doc/tagiter.html +145 -0
- data/setup.rb +1361 -0
- data/test/fixtures/filelist/testfile.txt +1 -0
- data/test/fixtures/filelist/testfile2.txt +1 -0
- data/test/tc_1st.rb +16 -0
- data/test/tc_ansicolor.rb +23 -0
- data/test/tc_attr.rb +46 -0
- data/test/tc_bbcode.rb +20 -0
- data/test/tc_binaryreader.rb +14 -0
- data/test/tc_binding_of_caller.rb +2 -0
- data/test/tc_byteorder.rb +41 -0
- data/test/tc_constant.rb +12 -0
- data/test/tc_coroutine.rb +50 -0
- data/test/tc_crosscase.rb +33 -0
- data/test/tc_duckhunter.rb +37 -0
- data/test/tc_dynamic-mixin.rb +66 -0
- data/test/tc_enumerable-args.rb +66 -0
- data/test/tc_expect.rb +83 -0
- data/test/tc_filelist.rb +17 -0
- data/test/tc_floatstring.rb +22 -0
- data/test/tc_functor.rb +18 -0
- data/test/tc_harray.rb +280 -0
- data/test/tc_heap.rb +6 -0
- data/test/tc_infinity.rb +23 -0
- data/test/tc_init.rb +29 -0
- data/test/tc_interval.rb +153 -0
- data/test/tc_io-reactor.rb +5 -0
- data/test/tc_io-redirect.rb +5 -0
- data/test/tc_lisp-format.rb +24 -0
- data/test/tc_lisp.rb +32 -0
- data/test/tc_macro.rb +48 -0
- data/test/tc_multiton.rb +188 -0
- data/test/tc_nack.rb +31 -0
- data/test/tc_nil-as-emptiness.rb +19 -0
- data/test/tc_nil-comparable.rb +29 -0
- data/test/tc_nil-missing.rb +0 -0
- data/test/tc_notcopyable.rb +64 -0
- data/test/tc_orderedhash.rb +36 -0
- data/test/tc_ostructable.rb +31 -0
- data/test/tc_semaphore.rb +5 -0
- data/test/tc_snapshot.rb +20 -0
- data/test/tc_soundex.rb +19 -0
- data/test/tc_sstruct.rb +313 -0
- data/test/tc_statichash.rb +24 -0
- data/test/tc_tagiter.rb +80 -0
- data/test/tc_timelimit.rb +47 -0
- data/test/tc_timer.rb +35 -0
- data/test/tc_tracepoint.rb +10 -0
- data/test/tc_tuple.rb +25 -0
- data/test/tc_uninheritable.rb +33 -0
- data/test/tc_version.rb +90 -0
- metadata +531 -0
@@ -0,0 +1,153 @@
|
|
1
|
+
=begin rdoc
|
2
|
+
|
3
|
+
= FloatString
|
4
|
+
|
5
|
+
FloatString allows unlimited string insertion between string segments.
|
6
|
+
|
7
|
+
Note: This is usable, it is still a very new idea, and therefore
|
8
|
+
has a much greater potential for change. If you decide it is useful
|
9
|
+
to you, please contribute to its improvement. Thanks.
|
10
|
+
|
11
|
+
== Author(s)
|
12
|
+
|
13
|
+
* Thomas Sawyer
|
14
|
+
|
15
|
+
== History
|
16
|
+
|
17
|
+
* 2005.04.11 Passes basic tests.
|
18
|
+
|
19
|
+
=end
|
20
|
+
|
21
|
+
class FloatString
|
22
|
+
|
23
|
+
def initialize( str )
|
24
|
+
@str = str
|
25
|
+
@float = {}
|
26
|
+
i = 0
|
27
|
+
while i < @str.length
|
28
|
+
@float[i.to_f] = @str[i,1]
|
29
|
+
i += 1
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
def undo
|
34
|
+
initialize( @str )
|
35
|
+
end
|
36
|
+
|
37
|
+
def re_enumerate
|
38
|
+
initialize( to_s )
|
39
|
+
end
|
40
|
+
|
41
|
+
def to_s
|
42
|
+
@float.to_a.sort_by{ |k,v| k }.collect{ |k,v| v }.join('')
|
43
|
+
end
|
44
|
+
|
45
|
+
def to_str
|
46
|
+
@float.to_a.sort_by{ |k,v| k }.collect{ |k,v| v }.join('')
|
47
|
+
end
|
48
|
+
|
49
|
+
# these should probably check the decimal and start there
|
50
|
+
# rather then startint at 0.5
|
51
|
+
|
52
|
+
def inner_insert(s, i)
|
53
|
+
n = 0.5; i = i.to_f - n
|
54
|
+
while @float.has_key?(i)
|
55
|
+
n = n/2
|
56
|
+
i += n
|
57
|
+
end
|
58
|
+
@float[i] = s
|
59
|
+
end
|
60
|
+
|
61
|
+
def outer_insert(s, i)
|
62
|
+
n = 0.5; i = i.to_f - 0.5
|
63
|
+
while @float.has_key?(i)
|
64
|
+
n = n/2
|
65
|
+
i -= n
|
66
|
+
end
|
67
|
+
@float[i] = s
|
68
|
+
end
|
69
|
+
|
70
|
+
def inner_append(s, i)
|
71
|
+
n = 0.5; i = i.to_f + 0.5
|
72
|
+
while @float.has_key?(i)
|
73
|
+
n = n/2
|
74
|
+
i -= n
|
75
|
+
end
|
76
|
+
@float[i] = s
|
77
|
+
end
|
78
|
+
|
79
|
+
def outer_append(s, i)
|
80
|
+
n = 0.5; i = i.to_f + 0.5
|
81
|
+
while @float.has_key?(i)
|
82
|
+
n = n/2
|
83
|
+
i += n
|
84
|
+
end
|
85
|
+
@float[i] = s
|
86
|
+
end
|
87
|
+
|
88
|
+
# an inner and outer wrap method would be nice
|
89
|
+
|
90
|
+
def [](arg)
|
91
|
+
if arg.kind_of?(Range)
|
92
|
+
#r = Range.new(arg.first.to_f, arg.last.to_f, arg.exclude_end?)
|
93
|
+
a = @float.to_a.sort_by{ |k,v| k }
|
94
|
+
s = a.index(a.find{ |e| e[0] == arg.first.to_f})
|
95
|
+
f = a.index(a.find{ |e| e[0] == arg.last.to_f})
|
96
|
+
a = arg.exclude_end? ? a[s...f] : a[s..f]
|
97
|
+
a.collect{ |k,v| v }.join('')
|
98
|
+
else
|
99
|
+
@float[arg.to_f]
|
100
|
+
end
|
101
|
+
end
|
102
|
+
|
103
|
+
def []=(arg,v)
|
104
|
+
@float[arg.to_f] = v
|
105
|
+
end
|
106
|
+
|
107
|
+
def fill(val, rng=0..-1)
|
108
|
+
a = @float.to_a.sort_by{ |k,v| k }
|
109
|
+
s = a.index( a.find{ |e| e[0] == rng.first.to_f } )
|
110
|
+
f = a.index( a.find{ |e| e[0] == rng.last.to_f } )
|
111
|
+
x = (rng.exclude_end? ? a[s...f] : a[s..f])
|
112
|
+
x.each{ |k,v| @float[k] = val.to_s }
|
113
|
+
self.to_s
|
114
|
+
end
|
115
|
+
|
116
|
+
def empty(rng)
|
117
|
+
fill('', rng)
|
118
|
+
end
|
119
|
+
|
120
|
+
def blank(rng)
|
121
|
+
fill(' ', rng)
|
122
|
+
end
|
123
|
+
|
124
|
+
end
|
125
|
+
|
126
|
+
|
127
|
+
=begin
|
128
|
+
# --- development testing ---
|
129
|
+
|
130
|
+
if $0 == __FILE__
|
131
|
+
|
132
|
+
require 'test/unit'
|
133
|
+
|
134
|
+
class TC_FloatString < Test::Unit::TestCase
|
135
|
+
|
136
|
+
def test_inner_inset
|
137
|
+
fs = FloatString.new( "Hello World!" )
|
138
|
+
fs.inner_insert("XXX", 4)
|
139
|
+
assert_equal("HellXXXo World!", fs.to_s)
|
140
|
+
fs.inner_insert("YYY", 4)
|
141
|
+
assert_equal("HellXXXYYYo World!", fs.to_s)
|
142
|
+
end
|
143
|
+
|
144
|
+
def test_fill
|
145
|
+
fs = FloatString.new( "Hello World!" )
|
146
|
+
fs.inner_insert("XXX", 4)
|
147
|
+
assert_equal("HeNNNN World!", fs.fill("N", 2..4))
|
148
|
+
end
|
149
|
+
|
150
|
+
end
|
151
|
+
|
152
|
+
end
|
153
|
+
=end
|
@@ -0,0 +1,41 @@
|
|
1
|
+
=begin rdoc
|
2
|
+
|
3
|
+
= Functor
|
4
|
+
|
5
|
+
By definition a Functor is simply a first class method, but these are common
|
6
|
+
in the form of Method and Proc. So here a Functor is a bit more specialied
|
7
|
+
as a 1st class _metafunction_. Essentally, a Functor can vary its behavior
|
8
|
+
accorrding to the operation applied to it.
|
9
|
+
|
10
|
+
== Synopsis
|
11
|
+
|
12
|
+
require 'carat/functor'
|
13
|
+
|
14
|
+
f = Functor.new { |op, x| x.send(op, x) }
|
15
|
+
f + 1 #=> 2
|
16
|
+
f + 2 #=> 4
|
17
|
+
f + 3 #=> 6
|
18
|
+
f * 1 #=> 1
|
19
|
+
f * 2 #=> 2
|
20
|
+
f * 3 #=> 9
|
21
|
+
|
22
|
+
== Notes
|
23
|
+
|
24
|
+
It would probably be a little better if we had a kernelless base object class.
|
25
|
+
Built-in public Object methods will not work in a Functor b/c of this.
|
26
|
+
Or perhaps this can improved via delegation.
|
27
|
+
|
28
|
+
== History
|
29
|
+
|
30
|
+
* 2005-04-11 Passed basic tests.
|
31
|
+
|
32
|
+
=end
|
33
|
+
|
34
|
+
class Functor
|
35
|
+
def initialize(&func)
|
36
|
+
@func = func
|
37
|
+
end
|
38
|
+
def method_missing(op, *args)
|
39
|
+
@func.call(op, *args)
|
40
|
+
end
|
41
|
+
end
|
data/lib/carat/harray.rb
ADDED
@@ -0,0 +1,507 @@
|
|
1
|
+
=begin rdoc
|
2
|
+
|
3
|
+
= HArray
|
4
|
+
|
5
|
+
HArray is an implemenation of the Array class using only Hashes.
|
6
|
+
Regular Arrays are never used except once to delegate the #pack method,
|
7
|
+
and for *args parameters (since there is no way around those is some cases).
|
8
|
+
HArray is for all practical purposes 100% compatible with Array.
|
9
|
+
|
10
|
+
HArray is slower then the built in Array class, but not as slow
|
11
|
+
as one might expect, since a Hash in general is faster than an Array.
|
12
|
+
It might be interesting to see how this would perform if it were
|
13
|
+
written in c. Not all that useful, but an interesting example.
|
14
|
+
|
15
|
+
== AUTHOR(s)
|
16
|
+
|
17
|
+
* Thamas Sawyer
|
18
|
+
|
19
|
+
=end
|
20
|
+
|
21
|
+
class HArray < Hash
|
22
|
+
|
23
|
+
def HArray.[](*args)
|
24
|
+
nha = HArray.new
|
25
|
+
args.each { |a| nha.set(nha.length,a) }
|
26
|
+
nha
|
27
|
+
end
|
28
|
+
|
29
|
+
def HArray.new_h(hsh)
|
30
|
+
nha=HArray.new
|
31
|
+
nha.replace(hsh)
|
32
|
+
#nha.reindex!
|
33
|
+
end
|
34
|
+
|
35
|
+
def initialize(i=0,e=nil)
|
36
|
+
if i > 0
|
37
|
+
i.times { self.set(self.length,e) }
|
38
|
+
end
|
39
|
+
end
|
40
|
+
|
41
|
+
def &(ha)
|
42
|
+
nha=HArray.new
|
43
|
+
(0..self.length-1).each do |i|
|
44
|
+
if ha.has_value?(self.fetch(i)) and !nha.has_value?(self.fetch(i))
|
45
|
+
nha.set(nha.length,self.fetch(i))
|
46
|
+
end
|
47
|
+
end
|
48
|
+
nha
|
49
|
+
end
|
50
|
+
|
51
|
+
def *(j)
|
52
|
+
if j.kind_of?(String)
|
53
|
+
return self.join(j)
|
54
|
+
else
|
55
|
+
nha = HArray.new
|
56
|
+
j.times { (0...self.length).each { |i| nha.set(nha.length,self.fetch(i)) } }
|
57
|
+
return nha
|
58
|
+
end
|
59
|
+
end
|
60
|
+
|
61
|
+
def +(ha)
|
62
|
+
nha = self.dup
|
63
|
+
(0..ha.length-1).each { |i| nha.set(nha.length,ha.fetch(i)) }
|
64
|
+
nha
|
65
|
+
end
|
66
|
+
|
67
|
+
def -(ha)
|
68
|
+
nha = HArray.new
|
69
|
+
self.each { |v| nha << v if !ha.has_value?(v) }
|
70
|
+
#ha.each { |v| nha << i if !self.include?(v) }
|
71
|
+
nha
|
72
|
+
end
|
73
|
+
|
74
|
+
def <<(e)
|
75
|
+
self.set(self.length,e)
|
76
|
+
self
|
77
|
+
end
|
78
|
+
|
79
|
+
def <=>(ha)
|
80
|
+
(0..self.length-1).each do |i|
|
81
|
+
ieq = (self.fetch(i) <=> ha.fetch(i))
|
82
|
+
return ieq if ieq != 0
|
83
|
+
end
|
84
|
+
self.length <=> ha.length
|
85
|
+
end
|
86
|
+
|
87
|
+
def ===(ha)
|
88
|
+
self.==(ha)
|
89
|
+
end
|
90
|
+
|
91
|
+
alias_method :get, :[]
|
92
|
+
private :get
|
93
|
+
|
94
|
+
def [](i,l=nil)
|
95
|
+
if l
|
96
|
+
i = i...i+l
|
97
|
+
elsif ! i.kind_of?(Range)
|
98
|
+
return self.at(i)
|
99
|
+
end
|
100
|
+
nha = HArray.new
|
101
|
+
i.each { |j| nha.set(nha.length,get(j)) if has_key?(j) }
|
102
|
+
nha
|
103
|
+
end
|
104
|
+
|
105
|
+
alias set []=
|
106
|
+
def []=(i,b,c=nil)
|
107
|
+
if c
|
108
|
+
rng = (Integer(i)..Integer(i+b))
|
109
|
+
b = c
|
110
|
+
elsif i.kind_of? Range
|
111
|
+
rng = i
|
112
|
+
else
|
113
|
+
self.set(Integer(i),b)
|
114
|
+
return b
|
115
|
+
end
|
116
|
+
if b == nil
|
117
|
+
rng.each { |i| qdelete(i) }
|
118
|
+
self.reindex!
|
119
|
+
elsif b.kind_of?(Array) or b.kind_of?(HArray)
|
120
|
+
j = 0
|
121
|
+
rng.each { |i| self[i] = b[j]; j+=1 }
|
122
|
+
else
|
123
|
+
rng.each { |i| qdelete(i) }
|
124
|
+
self[rng.fist] = b
|
125
|
+
self.reindex!
|
126
|
+
end
|
127
|
+
end
|
128
|
+
|
129
|
+
def |(ha)
|
130
|
+
nha = self.dup
|
131
|
+
ha.each { |v| nha << v if !nha.has_value?(v) }
|
132
|
+
nha
|
133
|
+
end
|
134
|
+
|
135
|
+
def assoc(k)
|
136
|
+
(0...self.length).each { |i| return self.fetch(i) if self.fetch(i)[0] == k }
|
137
|
+
return nil
|
138
|
+
end
|
139
|
+
|
140
|
+
def at(i)
|
141
|
+
i = self.length + i if i <= -1
|
142
|
+
get(i)
|
143
|
+
#return nil if i < 0 or i >= self.length
|
144
|
+
#return self.fetch(i)
|
145
|
+
end
|
146
|
+
|
147
|
+
# clear okay
|
148
|
+
|
149
|
+
def collect
|
150
|
+
nha = HArray.new
|
151
|
+
(0...self.length).each { |i| nha << yield(self.fetch(i)) }
|
152
|
+
nha
|
153
|
+
end
|
154
|
+
|
155
|
+
def collect!
|
156
|
+
nha = HArray.new
|
157
|
+
(0...self.length).each { |i| nha << yield(self.fetch(i)) }
|
158
|
+
self.replace(nha)
|
159
|
+
end
|
160
|
+
|
161
|
+
def compact
|
162
|
+
nha, j = HArray.new, 0
|
163
|
+
(0..self.length-1).each do |i|
|
164
|
+
if self.fetch(i) != nil
|
165
|
+
nha.set(j,self.fetch(i))
|
166
|
+
j+=1
|
167
|
+
end
|
168
|
+
end
|
169
|
+
nha
|
170
|
+
end
|
171
|
+
|
172
|
+
def compact!
|
173
|
+
if self.has_value?(nil)
|
174
|
+
nha, j = HArray.new, 0
|
175
|
+
(0..self.length-1).each do |i|
|
176
|
+
if self.fetch(i) != nil
|
177
|
+
nha.set(j,self.fetch(i))
|
178
|
+
j+=1
|
179
|
+
end
|
180
|
+
end
|
181
|
+
return self.replace(nha)
|
182
|
+
else
|
183
|
+
return nil
|
184
|
+
end
|
185
|
+
end
|
186
|
+
|
187
|
+
def concat(ha)
|
188
|
+
(0...ha.length).each { |i| self.set(self.length,ha.fetch(i)) }
|
189
|
+
self
|
190
|
+
end
|
191
|
+
|
192
|
+
def count(e=nil)
|
193
|
+
if block_given?
|
194
|
+
cnt = 0
|
195
|
+
(0...self.length).each { |i| cnt += 1 if yield(self.fetch(i)) }
|
196
|
+
return cnt
|
197
|
+
else
|
198
|
+
cnt = 0
|
199
|
+
(0...self.length).each { |i| cnt += 1 if self.fetch(i) == e }
|
200
|
+
return cnt
|
201
|
+
end
|
202
|
+
end
|
203
|
+
|
204
|
+
alias qdelete delete
|
205
|
+
private :qdelete
|
206
|
+
|
207
|
+
def delete(e)
|
208
|
+
if has_value?(e)
|
209
|
+
qdelete_if { |i,v| v == e }
|
210
|
+
reindex!
|
211
|
+
return e
|
212
|
+
else
|
213
|
+
return yield if block_given?
|
214
|
+
return nil
|
215
|
+
end
|
216
|
+
end
|
217
|
+
|
218
|
+
def delete_at(i)
|
219
|
+
if self.has_key?(i)
|
220
|
+
e = self.fetch(i)
|
221
|
+
qdelete(i)
|
222
|
+
reindex!
|
223
|
+
return e
|
224
|
+
else
|
225
|
+
return nil
|
226
|
+
end
|
227
|
+
end
|
228
|
+
|
229
|
+
alias qdelete_if delete_if
|
230
|
+
private :qdelete_if
|
231
|
+
|
232
|
+
def delete_if
|
233
|
+
qdelete_if { |i,v| yield(v) }
|
234
|
+
reindex!
|
235
|
+
end
|
236
|
+
|
237
|
+
def each
|
238
|
+
(0...self.length).each { |i| yield(self.fetch(i)) }
|
239
|
+
end
|
240
|
+
|
241
|
+
def each_index
|
242
|
+
(0...self.length).each { |i| yield(i) }
|
243
|
+
end
|
244
|
+
|
245
|
+
# empty? okay as is
|
246
|
+
|
247
|
+
def eql?(ha)
|
248
|
+
return false if self.length != ha.length
|
249
|
+
return true if (0...self.length).all? { |i| self.fetch(i).eql?(ha.fetch(i)) }
|
250
|
+
return false
|
251
|
+
end
|
252
|
+
|
253
|
+
def fill(f,s=nil,l=nil)
|
254
|
+
if s.kind_of?(Range)
|
255
|
+
r = s
|
256
|
+
else
|
257
|
+
s = 0 if !s
|
258
|
+
l = self.length - s if !l
|
259
|
+
r = s...(s+l)
|
260
|
+
end
|
261
|
+
r.each{ |i| self.set(i,f) }
|
262
|
+
self
|
263
|
+
end
|
264
|
+
|
265
|
+
def first
|
266
|
+
return nil if self.empty?
|
267
|
+
self.fetch(0)
|
268
|
+
end
|
269
|
+
|
270
|
+
def flatten
|
271
|
+
nha = HArray.new
|
272
|
+
(0...self.length).each do |i|
|
273
|
+
sfi = self.fetch(i)
|
274
|
+
if sfi.kind_of?(HArray) or sfi.kind_of?(Array)
|
275
|
+
nha.concat(sfi.flatten)
|
276
|
+
else
|
277
|
+
nha.set(nha.length,sfi)
|
278
|
+
end
|
279
|
+
end
|
280
|
+
nha
|
281
|
+
end
|
282
|
+
|
283
|
+
def flatten!
|
284
|
+
return nil if !self.any? { |e| e.kind_of?(HArray) or e.kind_of?(Array) }
|
285
|
+
self.replace(self.flatten)
|
286
|
+
end
|
287
|
+
|
288
|
+
def include?(v)
|
289
|
+
self.has_value?(v)
|
290
|
+
end
|
291
|
+
|
292
|
+
# index okay
|
293
|
+
|
294
|
+
def join(sep='')
|
295
|
+
s = ''
|
296
|
+
(0...self.length).each { |i| s << "#{self.fetch(i)}#{sep}" }
|
297
|
+
return s.chomp(sep)
|
298
|
+
end
|
299
|
+
|
300
|
+
def last
|
301
|
+
self[self.length-1]
|
302
|
+
end
|
303
|
+
|
304
|
+
# length okay
|
305
|
+
|
306
|
+
alias map! collect!
|
307
|
+
|
308
|
+
def nitems
|
309
|
+
cnt = 0
|
310
|
+
(0...self.length).each { |i| cnt += 1 if self.fetch(i) != nil }
|
311
|
+
cnt
|
312
|
+
end
|
313
|
+
|
314
|
+
def pack(*args)
|
315
|
+
self.to_a.pack(*args)
|
316
|
+
end
|
317
|
+
|
318
|
+
def pop
|
319
|
+
self.delete_at(self.length-1)
|
320
|
+
end
|
321
|
+
|
322
|
+
def push(*e)
|
323
|
+
self.concat(e)
|
324
|
+
end
|
325
|
+
|
326
|
+
def rassoc(k)
|
327
|
+
(0...self.length).each { |i| return self.fetch(i) if self.fetch(i)[1] == k }
|
328
|
+
return nil
|
329
|
+
end
|
330
|
+
|
331
|
+
def reindex
|
332
|
+
nha, j, k, tl = HArray.new, 0, 0, self.length
|
333
|
+
while k < tl
|
334
|
+
if self.has_key?(j)
|
335
|
+
nha.set(k,self.fetch(j))
|
336
|
+
j+=1; k+=1
|
337
|
+
else
|
338
|
+
j+=1
|
339
|
+
end
|
340
|
+
end
|
341
|
+
nha
|
342
|
+
end
|
343
|
+
|
344
|
+
def reindex!
|
345
|
+
self.replace(self.reindex)
|
346
|
+
end
|
347
|
+
|
348
|
+
def reject!
|
349
|
+
chg=nil
|
350
|
+
qdelete_if { |i,v| r=yield(v); chg=true if r; r }
|
351
|
+
return nil if !chg
|
352
|
+
reindex!
|
353
|
+
end
|
354
|
+
|
355
|
+
#def replace(ha)
|
356
|
+
# if ha.length < self.length
|
357
|
+
# (ha.length..self.length-1).each { |i| self.delete(i) }
|
358
|
+
# (0..ha.length-1).each { |i| self.set(i,ha[i]) }
|
359
|
+
# end
|
360
|
+
#end
|
361
|
+
|
362
|
+
def reverse
|
363
|
+
nha = HArray.new
|
364
|
+
(0...self.length).each { |i| nha.set(self.length-1-i,self.fetch(i)) }
|
365
|
+
nha
|
366
|
+
end
|
367
|
+
|
368
|
+
def reverse!
|
369
|
+
(0...self.length/2).each do |i|
|
370
|
+
ri = self.length-1-i
|
371
|
+
tmp = self.fetch(ri)
|
372
|
+
self.set(ri,self.fetch(i))
|
373
|
+
self.set(i,tmp)
|
374
|
+
end
|
375
|
+
self
|
376
|
+
end
|
377
|
+
|
378
|
+
def reverse_each
|
379
|
+
i = self.length - 1
|
380
|
+
while i >= 0
|
381
|
+
yield(self.fetch(i))
|
382
|
+
i -= 1
|
383
|
+
end
|
384
|
+
end
|
385
|
+
|
386
|
+
def rindex(e)
|
387
|
+
i = self.length - 1
|
388
|
+
while i >= 0
|
389
|
+
return i if self.fetch(i) == e
|
390
|
+
i -= 1
|
391
|
+
end
|
392
|
+
return nil
|
393
|
+
end
|
394
|
+
|
395
|
+
def shift
|
396
|
+
e1 = self[0]
|
397
|
+
tl = self.length - 1
|
398
|
+
(1..tl).each { |i| self.set(i-1,self.fetch(i)) }
|
399
|
+
self.delete_at(tl)
|
400
|
+
e1
|
401
|
+
end
|
402
|
+
|
403
|
+
# size okay
|
404
|
+
|
405
|
+
def slice(*args)
|
406
|
+
self[*args]
|
407
|
+
end
|
408
|
+
|
409
|
+
def slice!(*args)
|
410
|
+
result = self[*args]
|
411
|
+
self[*args] = nil
|
412
|
+
result
|
413
|
+
end
|
414
|
+
|
415
|
+
def sort
|
416
|
+
raise "HArray does not currently support sorting with blocks" if block_given?
|
417
|
+
nha = self.dup
|
418
|
+
qsort(nha,0,nha.length-1)
|
419
|
+
end
|
420
|
+
|
421
|
+
def qsort(ha, l, r)
|
422
|
+
l_hold = l
|
423
|
+
r_hold = r
|
424
|
+
pivot = ha[l]
|
425
|
+
while l < r
|
426
|
+
r -= 1 while (ha[r] <=> pivot) >= 0 and l < r
|
427
|
+
if l != r
|
428
|
+
ha[l] = ha[r]
|
429
|
+
l += 1
|
430
|
+
end
|
431
|
+
l += 1 while (ha[l] <=> pivot) <= 0 and l < r
|
432
|
+
if l != r
|
433
|
+
ha[r] = ha[l]
|
434
|
+
r -= 1
|
435
|
+
end
|
436
|
+
end
|
437
|
+
ha[l] = pivot
|
438
|
+
pivot = l
|
439
|
+
l = l_hold
|
440
|
+
r = r_hold
|
441
|
+
qsort(ha,l,pivot-1) if l < pivot
|
442
|
+
qsort(ha,pivot+1,r) if r > pivot
|
443
|
+
ha
|
444
|
+
end
|
445
|
+
|
446
|
+
def sort!
|
447
|
+
raise "HArray does not currently support sorting with blocks" if block_given?
|
448
|
+
qsort(self,0,self.length-1)
|
449
|
+
end
|
450
|
+
|
451
|
+
def to_a
|
452
|
+
a = []
|
453
|
+
(0..self.length-1).each { |i| a << self.fetch(i) }
|
454
|
+
a
|
455
|
+
end
|
456
|
+
|
457
|
+
def to_ary
|
458
|
+
self
|
459
|
+
end
|
460
|
+
|
461
|
+
def to_h
|
462
|
+
h = Hash.new
|
463
|
+
self.each { |k,v| h[k] = v }
|
464
|
+
h
|
465
|
+
end
|
466
|
+
|
467
|
+
def to_s
|
468
|
+
self.join
|
469
|
+
end
|
470
|
+
|
471
|
+
def uniq
|
472
|
+
nha = HArray.new
|
473
|
+
(0..self.length-1).each do |i|
|
474
|
+
nha[nha.length] = self[i] if !nha.has_value?(self[i])
|
475
|
+
end
|
476
|
+
nha
|
477
|
+
end
|
478
|
+
|
479
|
+
def uniq!
|
480
|
+
j = 0
|
481
|
+
(1..self.length-1).each do |i|
|
482
|
+
if !self[0..j].has_value?(self[i])
|
483
|
+
self[j+1] = self[i]
|
484
|
+
j+=1
|
485
|
+
end
|
486
|
+
end
|
487
|
+
(j+1..self.length-1).each { |i| qdelete(i) }
|
488
|
+
end
|
489
|
+
|
490
|
+
def unshift(e)
|
491
|
+
i = self.length - 1
|
492
|
+
while i >= 0
|
493
|
+
self.set(i+1,self.fetch(i))
|
494
|
+
return i if self.fetch(i) == e
|
495
|
+
i -= 1
|
496
|
+
end
|
497
|
+
self.set(0,e)
|
498
|
+
self
|
499
|
+
end
|
500
|
+
|
501
|
+
def values_at(*ix)
|
502
|
+
nha = HArray.new
|
503
|
+
ix.each {|i| nha[nha.length] = self.at(i)}
|
504
|
+
nha
|
505
|
+
end
|
506
|
+
|
507
|
+
end
|