ttk 0.1.576
Sign up to get free protection for your applications and to get access to all the features.
- data/AUTHORS +32 -0
- data/COPYING +18 -0
- data/ChangeLog +4629 -0
- data/DATE +1 -0
- data/DESCRIPTION +8 -0
- data/GUIDELINES +84 -0
- data/LGPL +504 -0
- data/NEWS +69 -0
- data/NORM +85 -0
- data/README +206 -0
- data/REVISION +1 -0
- data/Rakefile +120 -0
- data/TODO +23 -0
- data/TODO.old +115 -0
- data/VERSION +5 -0
- data/bin/getopts/ttk.rb +394 -0
- data/bin/getopts/ttkd.rb +150 -0
- data/bin/getopts/ttkm.rb +71 -0
- data/bin/ttk +170 -0
- data/bin/ttkd +73 -0
- data/bin/ttkm +54 -0
- data/doc/html/classes/IO/CutInput.html +159 -0
- data/doc/html/classes/IO/Delegator.html +291 -0
- data/doc/html/classes/IO/Dispatch.html +204 -0
- data/doc/html/classes/IO/Ext.html +118 -0
- data/doc/html/classes/IO/ImplExt.html +149 -0
- data/doc/html/classes/IO/ImplIndent.html +175 -0
- data/doc/html/classes/IO/ImplPrintFile.html +142 -0
- data/doc/html/classes/IO/ImplPrintIO.html +143 -0
- data/doc/html/classes/IO/InputFilter.html +347 -0
- data/doc/html/classes/IO/OutputFilter.html +298 -0
- data/doc/html/classes/NilClass.html +198 -0
- data/doc/html/classes/SafeEval.html +277 -0
- data/doc/html/classes/String.html +245 -0
- data/doc/html/classes/SymTbl.html +146 -0
- data/doc/html/classes/TTK.html +658 -0
- data/doc/html/classes/TTK/AbortStatus.html +211 -0
- data/doc/html/classes/TTK/Daemons.html +142 -0
- data/doc/html/classes/TTK/Daemons/Daemon.html +170 -0
- data/doc/html/classes/TTK/Daemons/Daemon/Logger.html +192 -0
- data/doc/html/classes/TTK/Daemons/Master.html +163 -0
- data/doc/html/classes/TTK/Daemons/Slave.html +158 -0
- data/doc/html/classes/TTK/Dumpers.html +150 -0
- data/doc/html/classes/TTK/Dumpers/Dumper.html +461 -0
- data/doc/html/classes/TTK/Dumpers/Notif.html +208 -0
- data/doc/html/classes/TTK/Dumpers/Xml.html +260 -0
- data/doc/html/classes/TTK/Dumpers/Yaml.html +307 -0
- data/doc/html/classes/TTK/ErrorStatus.html +133 -0
- data/doc/html/classes/TTK/FailStatus.html +195 -0
- data/doc/html/classes/TTK/Fetchers.html +135 -0
- data/doc/html/classes/TTK/Fetchers/Client.html +229 -0
- data/doc/html/classes/TTK/Fetchers/Client/Receiver.html +254 -0
- data/doc/html/classes/TTK/Fetchers/Server.html +256 -0
- data/doc/html/classes/TTK/Fetchers/Server/Sender.html +241 -0
- data/doc/html/classes/TTK/Filters.html +142 -0
- data/doc/html/classes/TTK/Filters/BasicLogger.html +187 -0
- data/doc/html/classes/TTK/Filters/Filter.html +188 -0
- data/doc/html/classes/TTK/Filters/Saver.html +279 -0
- data/doc/html/classes/TTK/Loaders.html +115 -0
- data/doc/html/classes/TTK/Loaders/BaseNode.html +224 -0
- data/doc/html/classes/TTK/Loaders/Loader.html +242 -0
- data/doc/html/classes/TTK/Loaders/OYaml.html +161 -0
- data/doc/html/classes/TTK/Loaders/Yaml.html +157 -0
- data/doc/html/classes/TTK/Loaders/YamlOld.html +155 -0
- data/doc/html/classes/TTK/Logger.html +836 -0
- data/doc/html/classes/TTK/Logger/Path.html +161 -0
- data/doc/html/classes/TTK/Logger/SectionNode.html +925 -0
- data/doc/html/classes/TTK/Logger/Severity.html +306 -0
- data/doc/html/classes/TTK/Logger/ToTTKLog.html +119 -0
- data/doc/html/classes/TTK/Logger/Verbosity.html +278 -0
- data/doc/html/classes/TTK/LoggerFactory.html +204 -0
- data/doc/html/classes/TTK/Monitors.html +132 -0
- data/doc/html/classes/TTK/Monitors/Client.html +261 -0
- data/doc/html/classes/TTK/Monitors/Monitor.html +209 -0
- data/doc/html/classes/TTK/Monitors/Server.html +288 -0
- data/doc/html/classes/TTK/Monitors/Server/Notification.html +118 -0
- data/doc/html/classes/TTK/Monitors/Server/Notifier.html +118 -0
- data/doc/html/classes/TTK/PassStatus.html +168 -0
- data/doc/html/classes/TTK/RunningStatus.html +133 -0
- data/doc/html/classes/TTK/Services.html +161 -0
- data/doc/html/classes/TTK/Services/DRbService.html +217 -0
- data/doc/html/classes/TTK/Services/DRbService/Notification.html +123 -0
- data/doc/html/classes/TTK/Services/DRbService/SubTestable.html +197 -0
- data/doc/html/classes/TTK/Services/FetcherClient.html +190 -0
- data/doc/html/classes/TTK/Services/FetcherServer.html +149 -0
- data/doc/html/classes/TTK/Services/MonitorClient.html +190 -0
- data/doc/html/classes/TTK/Services/MonitorServer.html +149 -0
- data/doc/html/classes/TTK/Services/TesterClient.html +207 -0
- data/doc/html/classes/TTK/Services/TesterMaster.html +193 -0
- data/doc/html/classes/TTK/Services/TesterMaster/Notification.html +123 -0
- data/doc/html/classes/TTK/Services/TesterSlave.html +157 -0
- data/doc/html/classes/TTK/Services/TesterSlave/Notification.html +118 -0
- data/doc/html/classes/TTK/SkipStatus.html +169 -0
- data/doc/html/classes/TTK/StartStatus.html +133 -0
- data/doc/html/classes/TTK/Status.html +373 -0
- data/doc/html/classes/TTK/StatusException.html +161 -0
- data/doc/html/classes/TTK/StatusWithMessage.html +220 -0
- data/doc/html/classes/TTK/Strategies.html +356 -0
- data/doc/html/classes/TTK/Strategies/Abort.html +161 -0
- data/doc/html/classes/TTK/Strategies/Authors.html +170 -0
- data/doc/html/classes/TTK/Strategies/Ball.html +200 -0
- data/doc/html/classes/TTK/Strategies/Block.html +230 -0
- data/doc/html/classes/TTK/Strategies/Bootstrap.html +238 -0
- data/doc/html/classes/TTK/Strategies/Checkout.html +201 -0
- data/doc/html/classes/TTK/Strategies/Clean.html +160 -0
- data/doc/html/classes/TTK/Strategies/Cmd.html +218 -0
- data/doc/html/classes/TTK/Strategies/CmdBase.html +312 -0
- data/doc/html/classes/TTK/Strategies/Collection.html +282 -0
- data/doc/html/classes/TTK/Strategies/Compile.html +199 -0
- data/doc/html/classes/TTK/Strategies/Composite.html +541 -0
- data/doc/html/classes/TTK/Strategies/Composite/Ordered.html +183 -0
- data/doc/html/classes/TTK/Strategies/Configure.html +270 -0
- data/doc/html/classes/TTK/Strategies/DistDelegate.html +192 -0
- data/doc/html/classes/TTK/Strategies/DistDuplicate.html +221 -0
- data/doc/html/classes/TTK/Strategies/DistStrategy.html +224 -0
- data/doc/html/classes/TTK/Strategies/Distribute.html +163 -0
- data/doc/html/classes/TTK/Strategies/Error.html +161 -0
- data/doc/html/classes/TTK/Strategies/Extract.html +179 -0
- data/doc/html/classes/TTK/Strategies/Fail.html +161 -0
- data/doc/html/classes/TTK/Strategies/Fetch.html +400 -0
- data/doc/html/classes/TTK/Strategies/Fetcher.html +276 -0
- data/doc/html/classes/TTK/Strategies/Glob.html +201 -0
- data/doc/html/classes/TTK/Strategies/IOBased.html +400 -0
- data/doc/html/classes/TTK/Strategies/Import.html +215 -0
- data/doc/html/classes/TTK/Strategies/JUnit.html +623 -0
- data/doc/html/classes/TTK/Strategies/KillAll.html +249 -0
- data/doc/html/classes/TTK/Strategies/Make.html +235 -0
- data/doc/html/classes/TTK/Strategies/Make/All.html +120 -0
- data/doc/html/classes/TTK/Strategies/Make/Check.html +120 -0
- data/doc/html/classes/TTK/Strategies/Make/Default.html +155 -0
- data/doc/html/classes/TTK/Strategies/Make/DistCheck.html +120 -0
- data/doc/html/classes/TTK/Strategies/Make/Install.html +120 -0
- data/doc/html/classes/TTK/Strategies/Make/Target.html +179 -0
- data/doc/html/classes/TTK/Strategies/Package.html +271 -0
- data/doc/html/classes/TTK/Strategies/PackageCollection.html +168 -0
- data/doc/html/classes/TTK/Strategies/Pass.html +161 -0
- data/doc/html/classes/TTK/Strategies/Pool.html +306 -0
- data/doc/html/classes/TTK/Strategies/Pool/PoolComponent.html +139 -0
- data/doc/html/classes/TTK/Strategies/ProbabilityThreshold.html +187 -0
- data/doc/html/classes/TTK/Strategies/Proxy.html +211 -0
- data/doc/html/classes/TTK/Strategies/RUnit.html +355 -0
- data/doc/html/classes/TTK/Strategies/RemoteCmd.html +213 -0
- data/doc/html/classes/TTK/Strategies/SignalCmd.html +269 -0
- data/doc/html/classes/TTK/Strategies/Sleep.html +193 -0
- data/doc/html/classes/TTK/Strategies/SqlQuery.html +248 -0
- data/doc/html/classes/TTK/Strategies/Strategy.html +2847 -0
- data/doc/html/classes/TTK/Strategies/Strategy/AssertEval.html +233 -0
- data/doc/html/classes/TTK/Strategies/Strategy/AttributedClass.html +107 -0
- data/doc/html/classes/TTK/Strategies/Strategy/AttributedClass/Attribute.html +246 -0
- data/doc/html/classes/TTK/Strategies/Strategy/Failure.html +121 -0
- data/doc/html/classes/TTK/Strategies/Stub.html +179 -0
- data/doc/html/classes/TTK/Strategies/SubCmd.html +243 -0
- data/doc/html/classes/TTK/Strategies/Suite.html +182 -0
- data/doc/html/classes/TTK/Strategies/Test.html +310 -0
- data/doc/html/classes/TTK/Strategies/Tester.html +218 -0
- data/doc/html/classes/TTK/Streams.html +116 -0
- data/doc/html/classes/TTK/Streams/Diff.html +148 -0
- data/doc/html/classes/TTK/Streams/Stream.html +295 -0
- data/doc/html/classes/TTK/SymTbl.html +266 -0
- data/doc/html/classes/TTK/TTKException.html +118 -0
- data/doc/html/classes/TTK/TTKModule.html +145 -0
- data/doc/html/classes/TTK/Testers.html +156 -0
- data/doc/html/classes/TTK/Testers/Master.html +304 -0
- data/doc/html/classes/TTK/Testers/Slave.html +120 -0
- data/doc/html/classes/TTK/Testers/Tester.html +547 -0
- data/doc/html/classes/TTK/Testers/Tester/Config.html +310 -0
- data/doc/html/classes/TTK/Testers/Tester/Notification.html +123 -0
- data/doc/html/classes/TTK/Testers/Tester/Notifier.html +118 -0
- data/doc/html/classes/TTK/Testers/Tester/QueryNode.html +341 -0
- data/doc/html/classes/TTK/Testers/Tester/RemoteStatus.html +165 -0
- data/doc/html/classes/TTK/Testers/Tester/RunningTask.html +262 -0
- data/doc/html/classes/TTK/Testers/Tester/Score.html +198 -0
- data/doc/html/classes/TTK/TimeoutAbortStatus.html +161 -0
- data/doc/html/classes/TTK/Tools.html +111 -0
- data/doc/html/classes/TTK/Tools/HostDispatcher.html +246 -0
- data/doc/html/classes/TTK/Weights.html +160 -0
- data/doc/html/classes/TTK/Weights/WExpr.html +326 -0
- data/doc/html/classes/TTK/Weights/WFloat.html +149 -0
- data/doc/html/classes/TTK/Weights/WMin.html +148 -0
- data/doc/html/classes/TTK/Weights/Weight.html +624 -0
- data/doc/html/created.rid +1 -0
- data/doc/html/files/AUTHORS.html +198 -0
- data/doc/html/files/NEWS.html +236 -0
- data/doc/html/files/README.html +435 -0
- data/doc/html/files/TODO.html +128 -0
- data/doc/html/files/lib/ttk/Tools/HostDispatcher_rb.html +126 -0
- data/doc/html/files/lib/ttk/Tools/SafeEval_rb.html +119 -0
- data/doc/html/files/lib/ttk/Tools/cut_output_rb.html +126 -0
- data/doc/html/files/lib/ttk/Tools/io/delegator_rb.html +127 -0
- data/doc/html/files/lib/ttk/Tools/io/dispatch_rb.html +127 -0
- data/doc/html/files/lib/ttk/Tools/io/ext_rb.html +126 -0
- data/doc/html/files/lib/ttk/Tools/io/filters_rb.html +127 -0
- data/doc/html/files/lib/ttk/daemons/Daemon_rb.html +126 -0
- data/doc/html/files/lib/ttk/daemons/Master_rb.html +119 -0
- data/doc/html/files/lib/ttk/daemons/Slave_rb.html +119 -0
- data/doc/html/files/lib/ttk/daemons/daemon/logger_rb.html +126 -0
- data/doc/html/files/lib/ttk/dumpers/Dumper_rb.html +119 -0
- data/doc/html/files/lib/ttk/dumpers/Notif_rb.html +119 -0
- data/doc/html/files/lib/ttk/dumpers/Xml_rb.html +126 -0
- data/doc/html/files/lib/ttk/dumpers/Yaml_rb.html +119 -0
- data/doc/html/files/lib/ttk/fetchers/Client_rb.html +126 -0
- data/doc/html/files/lib/ttk/fetchers/Server_rb.html +126 -0
- data/doc/html/files/lib/ttk/fetchers/client/receiver_rb.html +127 -0
- data/doc/html/files/lib/ttk/fetchers/server/sender_rb.html +127 -0
- data/doc/html/files/lib/ttk/filters/BasicLogger_rb.html +126 -0
- data/doc/html/files/lib/ttk/filters/Filter_rb.html +119 -0
- data/doc/html/files/lib/ttk/filters/Saver_rb.html +119 -0
- data/doc/html/files/lib/ttk/loaders/Loader_rb.html +119 -0
- data/doc/html/files/lib/ttk/loaders/OYaml_rb.html +126 -0
- data/doc/html/files/lib/ttk/loaders/YamlOld_rb.html +126 -0
- data/doc/html/files/lib/ttk/loaders/Yaml_rb.html +126 -0
- data/doc/html/files/lib/ttk/logger/path_rb.html +119 -0
- data/doc/html/files/lib/ttk/logger/section_node_rb.html +119 -0
- data/doc/html/files/lib/ttk/logger/severity_rb.html +119 -0
- data/doc/html/files/lib/ttk/logger/to_ttk_log_rb.html +119 -0
- data/doc/html/files/lib/ttk/logger/verbosity_rb.html +119 -0
- data/doc/html/files/lib/ttk/logger_factory_rb.html +119 -0
- data/doc/html/files/lib/ttk/logger_rb.html +131 -0
- data/doc/html/files/lib/ttk/monitors/Client_rb.html +119 -0
- data/doc/html/files/lib/ttk/monitors/Monitor_rb.html +127 -0
- data/doc/html/files/lib/ttk/monitors/Server_rb.html +126 -0
- data/doc/html/files/lib/ttk/services/DRbService/sub_testable_rb.html +119 -0
- data/doc/html/files/lib/ttk/services/DRbService_rb.html +126 -0
- data/doc/html/files/lib/ttk/services/FetcherClient_rb.html +119 -0
- data/doc/html/files/lib/ttk/services/FetcherServer_rb.html +119 -0
- data/doc/html/files/lib/ttk/services/MonitorClient_rb.html +119 -0
- data/doc/html/files/lib/ttk/services/MonitorServer_rb.html +119 -0
- data/doc/html/files/lib/ttk/services/TesterClient_rb.html +119 -0
- data/doc/html/files/lib/ttk/services/TesterMaster_rb.html +119 -0
- data/doc/html/files/lib/ttk/services/TesterSlave_rb.html +119 -0
- data/doc/html/files/lib/ttk/status_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Abort_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Authors_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Ball_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Block_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Bootstrap_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Checkout_rb.html +127 -0
- data/doc/html/files/lib/ttk/strategies/Clean_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/CmdBase_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Cmd_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Collection_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Compile_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Composite_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Configure_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/DistDelegate_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/DistDuplicate_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/DistStrategy_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Distribute_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Error_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Extract_rb.html +126 -0
- data/doc/html/files/lib/ttk/strategies/Fail_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Fetch_rb.html +127 -0
- data/doc/html/files/lib/ttk/strategies/Fetcher_rb.html +126 -0
- data/doc/html/files/lib/ttk/strategies/Glob_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/IOBased_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Import_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/JUnit_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/KillAll_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Make_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/PackageCollection_rb.html +126 -0
- data/doc/html/files/lib/ttk/strategies/Package_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Pass_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Pool_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/ProbabilityThreshold_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Proxy_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/RUnit_rb.html +127 -0
- data/doc/html/files/lib/ttk/strategies/RemoteCmd_rb.html +126 -0
- data/doc/html/files/lib/ttk/strategies/SignalCmd_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Sleep_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/SqlQuery_rb.html +126 -0
- data/doc/html/files/lib/ttk/strategies/Strategy/assert_eval_rb.html +127 -0
- data/doc/html/files/lib/ttk/strategies/Strategy_rb.html +131 -0
- data/doc/html/files/lib/ttk/strategies/Streams/Diff_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Streams/Stream_rb.html +126 -0
- data/doc/html/files/lib/ttk/strategies/Stub_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/SubCmd_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Suite_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Test_rb.html +127 -0
- data/doc/html/files/lib/ttk/strategies/Tester_rb.html +126 -0
- data/doc/html/files/lib/ttk/symtbl_rb.html +126 -0
- data/doc/html/files/lib/ttk/testers/Master_rb.html +119 -0
- data/doc/html/files/lib/ttk/testers/Slave_rb.html +119 -0
- data/doc/html/files/lib/ttk/testers/Tester_rb.html +131 -0
- data/doc/html/files/lib/ttk/testers/tester/config_rb.html +126 -0
- data/doc/html/files/lib/ttk/testers/tester/notifier_rb.html +119 -0
- data/doc/html/files/lib/ttk/testers/tester/query_node_rb.html +126 -0
- data/doc/html/files/lib/ttk/testers/tester/remote_status_rb.html +119 -0
- data/doc/html/files/lib/ttk/testers/tester/running_task_rb.html +119 -0
- data/doc/html/files/lib/ttk/testers/tester/score_rb.html +119 -0
- data/doc/html/files/lib/ttk/weights/WExpr_rb.html +119 -0
- data/doc/html/files/lib/ttk/weights/WFloat_rb.html +119 -0
- data/doc/html/files/lib/ttk/weights/WMin_rb.html +119 -0
- data/doc/html/files/lib/ttk/weights/Weight_rb.html +126 -0
- data/doc/html/files/lib/ttk_rb.html +146 -0
- data/doc/html/files/lib/ttkd_rb.html +131 -0
- data/doc/html/files/template/README.html +160 -0
- data/doc/html/files/test/examples/README.html +190 -0
- data/doc/html/fr_class_index.html +186 -0
- data/doc/html/fr_file_index.html +147 -0
- data/doc/html/fr_method_index.html +581 -0
- data/doc/html/index.html +24 -0
- data/doc/html/rdoc-style.css +208 -0
- data/lib/ttk.rb +111 -0
- data/lib/ttk/Tools/HostDispatcher.rb +44 -0
- data/lib/ttk/Tools/SafeEval.rb +64 -0
- data/lib/ttk/Tools/cut_output.rb +35 -0
- data/lib/ttk/Tools/io/delegator.rb +88 -0
- data/lib/ttk/Tools/io/dispatch.rb +31 -0
- data/lib/ttk/Tools/io/ext.rb +70 -0
- data/lib/ttk/Tools/io/filters.rb +71 -0
- data/lib/ttk/daemons/Daemon.rb +34 -0
- data/lib/ttk/daemons/Master.rb +34 -0
- data/lib/ttk/daemons/Slave.rb +29 -0
- data/lib/ttk/daemons/daemon/logger.rb +57 -0
- data/lib/ttk/dumpers/Dumper.rb +81 -0
- data/lib/ttk/dumpers/Notif.rb +33 -0
- data/lib/ttk/dumpers/Xml.rb +112 -0
- data/lib/ttk/dumpers/Yaml.rb +159 -0
- data/lib/ttk/fetchers/Client.rb +41 -0
- data/lib/ttk/fetchers/Server.rb +49 -0
- data/lib/ttk/fetchers/client/receiver.rb +62 -0
- data/lib/ttk/fetchers/server/sender.rb +69 -0
- data/lib/ttk/filters/BasicLogger.rb +30 -0
- data/lib/ttk/filters/Filter.rb +24 -0
- data/lib/ttk/filters/Saver.rb +60 -0
- data/lib/ttk/loaders/Loader.rb +123 -0
- data/lib/ttk/loaders/OYaml.rb +60 -0
- data/lib/ttk/loaders/Yaml.rb +74 -0
- data/lib/ttk/loaders/YamlOld.rb +65 -0
- data/lib/ttk/logger.rb +237 -0
- data/lib/ttk/logger/path.rb +23 -0
- data/lib/ttk/logger/section_node.rb +214 -0
- data/lib/ttk/logger/severity.rb +62 -0
- data/lib/ttk/logger/to_ttk_log.rb +83 -0
- data/lib/ttk/logger/verbosity.rb +61 -0
- data/lib/ttk/logger_factory.rb +50 -0
- data/lib/ttk/monitors/Client.rb +61 -0
- data/lib/ttk/monitors/Monitor.rb +50 -0
- data/lib/ttk/monitors/Server.rb +73 -0
- data/lib/ttk/services/DRbService.rb +45 -0
- data/lib/ttk/services/DRbService/sub_testable.rb +41 -0
- data/lib/ttk/services/FetcherClient.rb +31 -0
- data/lib/ttk/services/FetcherServer.rb +23 -0
- data/lib/ttk/services/MonitorClient.rb +31 -0
- data/lib/ttk/services/MonitorServer.rb +23 -0
- data/lib/ttk/services/TesterClient.rb +38 -0
- data/lib/ttk/services/TesterMaster.rb +40 -0
- data/lib/ttk/services/TesterSlave.rb +31 -0
- data/lib/ttk/status.rb +190 -0
- data/lib/ttk/strategies/Abort.rb +24 -0
- data/lib/ttk/strategies/Authors.rb +43 -0
- data/lib/ttk/strategies/Ball.rb +68 -0
- data/lib/ttk/strategies/Block.rb +95 -0
- data/lib/ttk/strategies/Bootstrap.rb +52 -0
- data/lib/ttk/strategies/Checkout.rb +53 -0
- data/lib/ttk/strategies/Clean.rb +29 -0
- data/lib/ttk/strategies/Cmd.rb +55 -0
- data/lib/ttk/strategies/CmdBase.rb +103 -0
- data/lib/ttk/strategies/Collection.rb +131 -0
- data/lib/ttk/strategies/Compile.rb +56 -0
- data/lib/ttk/strategies/Composite.rb +173 -0
- data/lib/ttk/strategies/Configure.rb +64 -0
- data/lib/ttk/strategies/DistDelegate.rb +45 -0
- data/lib/ttk/strategies/DistDuplicate.rb +64 -0
- data/lib/ttk/strategies/DistStrategy.rb +42 -0
- data/lib/ttk/strategies/Distribute.rb +39 -0
- data/lib/ttk/strategies/Error.rb +23 -0
- data/lib/ttk/strategies/Extract.rb +45 -0
- data/lib/ttk/strategies/Fail.rb +26 -0
- data/lib/ttk/strategies/Fetch.rb +124 -0
- data/lib/ttk/strategies/Fetcher.rb +74 -0
- data/lib/ttk/strategies/Glob.rb +48 -0
- data/lib/ttk/strategies/IOBased.rb +156 -0
- data/lib/ttk/strategies/Import.rb +45 -0
- data/lib/ttk/strategies/JUnit.rb +205 -0
- data/lib/ttk/strategies/KillAll.rb +59 -0
- data/lib/ttk/strategies/Make.rb +94 -0
- data/lib/ttk/strategies/Package.rb +128 -0
- data/lib/ttk/strategies/PackageCollection.rb +72 -0
- data/lib/ttk/strategies/Pass.rb +24 -0
- data/lib/ttk/strategies/Pool.rb +99 -0
- data/lib/ttk/strategies/ProbabilityThreshold.rb +42 -0
- data/lib/ttk/strategies/Proxy.rb +42 -0
- data/lib/ttk/strategies/RUnit.rb +170 -0
- data/lib/ttk/strategies/RemoteCmd.rb +48 -0
- data/lib/ttk/strategies/SignalCmd.rb +85 -0
- data/lib/ttk/strategies/Sleep.rb +36 -0
- data/lib/ttk/strategies/SqlQuery.rb +120 -0
- data/lib/ttk/strategies/Strategy.rb +606 -0
- data/lib/ttk/strategies/Strategy/assert_eval.rb +53 -0
- data/lib/ttk/strategies/Streams/Diff.rb +60 -0
- data/lib/ttk/strategies/Streams/Stream.rb +133 -0
- data/lib/ttk/strategies/Stub.rb +35 -0
- data/lib/ttk/strategies/SubCmd.rb +58 -0
- data/lib/ttk/strategies/Suite.rb +118 -0
- data/lib/ttk/strategies/Test.rb +88 -0
- data/lib/ttk/strategies/Tester.rb +59 -0
- data/lib/ttk/symtbl.rb +115 -0
- data/lib/ttk/testers/Master.rb +69 -0
- data/lib/ttk/testers/Slave.rb +19 -0
- data/lib/ttk/testers/Tester.rb +134 -0
- data/lib/ttk/testers/tester/config.rb +65 -0
- data/lib/ttk/testers/tester/notifier.rb +24 -0
- data/lib/ttk/testers/tester/query_node.rb +91 -0
- data/lib/ttk/testers/tester/remote_status.rb +29 -0
- data/lib/ttk/testers/tester/running_task.rb +47 -0
- data/lib/ttk/testers/tester/score.rb +34 -0
- data/lib/ttk/weights/WExpr.rb +68 -0
- data/lib/ttk/weights/WFloat.rb +23 -0
- data/lib/ttk/weights/WMin.rb +22 -0
- data/lib/ttk/weights/Weight.rb +85 -0
- data/lib/ttkd.rb +51 -0
- data/ruby_ex/abstract.rb +246 -0
- data/ruby_ex/abstract_node.rb +85 -0
- data/ruby_ex/array_each_pair.rb +18 -0
- data/ruby_ex/ask.rb +101 -0
- data/ruby_ex/attributed_class.rb +304 -0
- data/ruby_ex/cache.rb +373 -0
- data/ruby_ex/checkout.rb +12 -0
- data/ruby_ex/config_file.rb +96 -0
- data/ruby_ex/const_regexp.rb +59 -0
- data/ruby_ex/daemon.rb +134 -0
- data/ruby_ex/diff.rb +667 -0
- data/ruby_ex/dlogger.rb +62 -0
- data/ruby_ex/drb/dispatcher.rb +252 -0
- data/ruby_ex/drb/dispatcher_server_test.rb +29 -0
- data/ruby_ex/drb/drb_observable.rb +97 -0
- data/ruby_ex/drb/drb_observable_pool.rb +27 -0
- data/ruby_ex/drb/drb_service.rb +43 -0
- data/ruby_ex/drb/drb_undumped_attributes.rb +55 -0
- data/ruby_ex/drb/drb_undumped_indexed_object.rb +54 -0
- data/ruby_ex/drb/insecure_protected_methods.rb +103 -0
- data/ruby_ex/drb/session_client_test.rb +40 -0
- data/ruby_ex/drb/session_manager.rb +246 -0
- data/ruby_ex/drb/session_server.rb +53 -0
- data/ruby_ex/dtime.rb +143 -0
- data/ruby_ex/dumpable_proc.rb +63 -0
- data/ruby_ex/exception.rb +32 -0
- data/ruby_ex/filetype.rb +229 -0
- data/ruby_ex/fileutils_ex.rb +44 -0
- data/ruby_ex/fold.rb +58 -0
- data/ruby_ex/generate_id.rb +31 -0
- data/ruby_ex/inactive_timeout.rb +137 -0
- data/ruby_ex/indexed_node.rb +66 -0
- data/ruby_ex/io_marshal.rb +100 -0
- data/ruby_ex/ioo.rb +194 -0
- data/ruby_ex/labeled_node.rb +63 -0
- data/ruby_ex/logger_observer.rb +23 -0
- data/ruby_ex/md5sum.rb +66 -0
- data/ruby_ex/mktemp.rb +208 -0
- data/ruby_ex/module/attr_once.rb +36 -0
- data/ruby_ex/module/autoload_tree.rb +68 -0
- data/ruby_ex/module/hierarchy.rb +335 -0
- data/ruby_ex/module/instance_method_visibility.rb +73 -0
- data/ruby_ex/module_ex.rb +11 -0
- data/ruby_ex/node.rb +80 -0
- data/ruby_ex/object_monitor.rb +145 -0
- data/ruby_ex/object_monitor_activity.rb +33 -0
- data/ruby_ex/observable.rb +140 -0
- data/ruby_ex/observable_pool.rb +293 -0
- data/ruby_ex/orderedhash.rb +252 -0
- data/ruby_ex/pathname_ex.rb +113 -0
- data/ruby_ex/pp_hierarchy.rb +29 -0
- data/ruby_ex/pseudo_cache.rb +190 -0
- data/ruby_ex/queue.rb +56 -0
- data/ruby_ex/safe_eval.rb +348 -0
- data/ruby_ex/service_manager.rb +121 -0
- data/ruby_ex/session/administrable.rb +120 -0
- data/ruby_ex/session/client.rb +153 -0
- data/ruby_ex/session/const.rb +18 -0
- data/ruby_ex/session/dispatcher.rb +184 -0
- data/ruby_ex/session/error.rb +21 -0
- data/ruby_ex/session/fetchable.rb +57 -0
- data/ruby_ex/session/fetcher.rb +62 -0
- data/ruby_ex/session/hookable.rb +26 -0
- data/ruby_ex/session/profile.rb +110 -0
- data/ruby_ex/session/server.rb +582 -0
- data/ruby_ex/session/test/administrable_test.rb +337 -0
- data/ruby_ex/session/test/basic_test.rb +523 -0
- data/ruby_ex/session/test/dispatcher_test.rb +409 -0
- data/ruby_ex/session/test/fetchable_test.rb +119 -0
- data/ruby_ex/session/test/sub_server_test.rb +188 -0
- data/ruby_ex/spring.rb +136 -0
- data/ruby_ex/spring_set.rb +137 -0
- data/ruby_ex/symtbl.rb +106 -0
- data/ruby_ex/synflow.rb +474 -0
- data/ruby_ex/test/unit/ui/yaml/testrunner.rb +164 -0
- data/ruby_ex/thread_mutex.rb +10 -0
- data/ruby_ex/timeout_ex.rb +81 -0
- data/ruby_ex/top_down.rb +73 -0
- data/ruby_ex/trace.rb +26 -0
- data/ruby_ex/uri/druby.rb +81 -0
- data/ruby_ex/uri/file.rb +39 -0
- data/ruby_ex/uri/ftp_ex.rb +37 -0
- data/ruby_ex/uri/http_ex.rb +43 -0
- data/ruby_ex/uri/svn.rb +101 -0
- data/ruby_ex/uri_ex.rb +35 -0
- data/ruby_ex/version.rb +66 -0
- data/ruby_ex/yaml/basenode_ext.rb +63 -0
- data/ruby_ex/yaml/transform.rb +447 -0
- data/ruby_ex/yaml/yregexpath.rb +76 -0
- data/test/all/TestTAssert/first.yml +65 -0
- data/test/all/TestTAssert/segfault.yml +31 -0
- data/test/all/dist-suite-indirect-nested.yml +15 -0
- data/test/all/dist-suite-nested-3.yml +16 -0
- data/test/all/dist-suite-nested-in-pool.yml +51 -0
- data/test/all/dist-suite-nested.yml +28 -0
- data/test/all/no_suite.yml +18 -0
- data/test/all/pipeline-timeout.yml +21 -0
- data/test/all/remote_cmd.yml +23 -0
- data/test/all/remote_dispatcher.yml +26 -0
- data/test/all/suite_timeout.yml +32 -0
- data/test/all/weight.yml +113 -0
- data/test/all/xunit/junit/MultiRight/Foo/Foo.java +11 -0
- data/test/all/xunit/junit/MultiRight/Foo/FooTest.java +15 -0
- data/test/all/xunit/junit/MultiRight/MultiRight.java +13 -0
- data/test/all/xunit/junit/MultiRight/MultiRightTest.java +12 -0
- data/test/all/xunit/junit/MultiRight/bar/Bar.java +11 -0
- data/test/all/xunit/junit/MultiRight/bar/BarTest.java +21 -0
- data/test/all/xunit/junit/MultiRight/build.sh +7 -0
- data/test/all/xunit/junit/SimpleException/SimpleExceptionTest.java +11 -0
- data/test/all/xunit/junit/SimpleException/build.sh +4 -0
- data/test/all/xunit/junit/build.sh +9 -0
- data/test/all/xunit/junit/multibar.yml +6 -0
- data/test/all/xunit/junit/multifoo.yml +6 -0
- data/test/all/xunit/junit/multiright.yml +8 -0
- data/test/all/xunit/junit/simple_exception.yml +6 -0
- data/test/examples-suite.yml +10 -0
- data/test/examples/README +68 -0
- data/test/examples/cache/simple.yml +33 -0
- data/test/examples/sql/basic.yml +26 -0
- data/test/examples/students-suite.yml +11 -0
- data/test/examples/students/ball.yml +13 -0
- data/test/examples/students/glob_stud.yml +23 -0
- data/test/examples/students/mini-lib.yml +73 -0
- data/test/examples/students/pool_stud.yml +35 -0
- data/test/examples/students/stud.yml +25 -0
- data/test/ressources/ball/20040804-exam_a1-zapngo-tessar_m.tar.gz +0 -0
- data/test/ressources/ball/Makefile +24 -0
- data/test/ressources/ball/bar_p-mini-lib.tar.bz2 +0 -0
- data/test/ressources/ball/bar_p-mini-lib/Makefile +20 -0
- data/test/ressources/ball/bar_p-mini-lib/my_strlen.c +13 -0
- data/test/ressources/ball/foo_s-mini-lib.tar.bz2 +0 -0
- data/test/ressources/ball/foo_s-mini-lib/Makefile +20 -0
- data/test/ressources/ball/foo_s-mini-lib/configure +2 -0
- data/test/ressources/ball/foo_s-mini-lib/my_strlen.c +10 -0
- data/test/ressources/ball/hello.tar.bz2 +0 -0
- data/test/ressources/ball/hello.tar.gz +0 -0
- data/test/ressources/ball/hello/Makefile +14 -0
- data/test/ressources/ball/hello/hello.c +7 -0
- data/test/ressources/ball/jack-exit.tar.bz2 +0 -0
- data/test/ressources/ball/jack-exit/Makefile +14 -0
- data/test/ressources/ball/jack-exit/exit.c +16 -0
- data/test/ressources/ball/joe-exit.tar.bz2 +0 -0
- data/test/ressources/ball/joe-exit/Makefile +14 -0
- data/test/ressources/ball/joe-exit/exit.c +8 -0
- data/test/ressources/ball/joe_i-mini-lib.tar.bz2 +0 -0
- data/test/ressources/ball/joe_i-mini-lib/Makefile +20 -0
- data/test/ressources/ball/joe_i-mini-lib/configure +2 -0
- data/test/ressources/ball/joe_i-mini-lib/my_strlen.c +10 -0
- data/test/ressources/ball/john-exit.tar.bz2 +0 -0
- data/test/ressources/ball/john-exit/Makefile +14 -0
- data/test/ressources/ball/john-exit/exit.c +6 -0
- data/test/ressources/ball/qux_j-mini-lib.tar.bz2 +0 -0
- data/test/ressources/ball/qux_j-mini-lib/Makefile +20 -0
- data/test/ressources/ball/qux_j-mini-lib/my_strlen.c +12 -0
- data/test/ressources/mini-lib/Makefile +9 -0
- data/test/ressources/mini-lib/strlen.c +15 -0
- data/test/ressources/package/pkg_foo.tar.gz +0 -0
- data/test/ressources/package/pkg_foo/Makefile +20 -0
- data/test/ressources/package/pkg_foo/bootstrap +3 -0
- data/test/ressources/package/pkg_foo/configure +3 -0
- data/test/ressources/package/pkg_foo/foo.sh +2 -0
- data/test/ressources/runit/bad.rb +30 -0
- data/test/ressources/runit/error.rb +6 -0
- data/test/ressources/runit/good.rb +30 -0
- data/test/ressources/text/1.txt +4 -0
- data/test/runit/dumpers/xml_test.rb +75 -0
- data/test/runit/dumpers/yaml_test.rb +68 -0
- data/test/runit/fetchers/fetchers_test.rb +48 -0
- data/test/runit/loaders/OYaml_test.rb +35 -0
- data/test/runit/logger/section_node_test.rb +125 -0
- data/test/runit/logger/severity_test.rb +41 -0
- data/test/runit/logger/verbosity_test.rb +49 -0
- data/test/runit/logger_test.rb +295 -0
- data/test/runit/strategies/Strategy/assert_eval_test.rb +196 -0
- data/test/ttk-check +26 -0
- data/test/ttk-dist-suite.yml +44 -0
- data/test/ttk-dist/cat/file.in +3 -0
- data/test/ttk-dist/cat/file.out +3 -0
- data/test/ttk-dist/dist-abort.yml +51 -0
- data/test/ttk-dist/dist-cat.yml +38 -0
- data/test/ttk-dist/dist-delegate.yml +56 -0
- data/test/ttk-dist/dist-dispatch.yml +28 -0
- data/test/ttk-dist/dist-error.yml +10 -0
- data/test/ttk-dist/dist-fail.yml +9 -0
- data/test/ttk-dist/dist-nested-pass.yml +11 -0
- data/test/ttk-dist/dist-pass.yml +8 -0
- data/test/ttk-dist/dist-ribute.yml +31 -0
- data/test/ttk-dist/dist-suite.yml +18 -0
- data/test/ttk-dist/local-fetch.yml +17 -0
- data/test/ttk-dist/tester.yml +36 -0
- data/test/ttk-minimal-suite.yml +12 -0
- data/test/ttk-minimal/author.yml +14 -0
- data/test/ttk-minimal/base.yml +137 -0
- data/test/ttk-minimal/block.yml +15 -0
- data/test/ttk-minimal/cat.yml +19 -0
- data/test/ttk-minimal/diff.yml +29 -0
- data/test/ttk-minimal/env_cmd.yml +54 -0
- data/test/ttk-minimal/exit.yml +17 -0
- data/test/ttk-minimal/fatal.yml +32 -0
- data/test/ttk-minimal/glob.yml +13 -0
- data/test/ttk-minimal/import.yml +33 -0
- data/test/ttk-minimal/killall.yml +36 -0
- data/test/ttk-minimal/pkg.yml +18 -0
- data/test/ttk-minimal/pool.yml +44 -0
- data/test/ttk-minimal/probability_threshold.yml +39 -0
- data/test/ttk-minimal/runit.yml +25 -0
- data/test/ttk-minimal/signal_cmd.yml +24 -0
- data/test/ttk-minimal/sub.yml +9 -0
- data/test/ttk-minimal/test.yml +26 -0
- data/test/ttk-minimal/timeout.yml +24 -0
- data/test/ttk-minimal/unit_test.yml +13 -0
- data/test/ttk-minimal/wc.yml +28 -0
- metadata +801 -0
@@ -0,0 +1,65 @@
|
|
1
|
+
# Author:: Nicolas Pouillard <ertai@lrde.epita.fr>.
|
2
|
+
# Copyright:: Copyright (c) 2004, 2005 TTK team. All rights reserved.
|
3
|
+
# License:: LGPL
|
4
|
+
# $Id: YamlOld.rb 567 2005-04-13 08:00:06Z polrop $
|
5
|
+
|
6
|
+
|
7
|
+
require 'yaml'
|
8
|
+
|
9
|
+
class Object # :nodoc:
|
10
|
+
def yaml_load_map
|
11
|
+
self
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
class Array # :nodoc:
|
16
|
+
def yaml_load_map
|
17
|
+
map { |x| x.yaml_load_map }
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
class Hash # :nodoc:
|
22
|
+
def yaml_load_map
|
23
|
+
res = {}
|
24
|
+
each do |k,v|
|
25
|
+
k = k.to_s.to_sym unless k.is_a? Symbol or k.is_a? Integer
|
26
|
+
if k == :class or k == :strategy
|
27
|
+
if k == :class
|
28
|
+
k = :strategy
|
29
|
+
end
|
30
|
+
unless v.is_a? Strategies::Strategy
|
31
|
+
v = v.to_s
|
32
|
+
if v =~ /TestT/
|
33
|
+
v.gsub!(/TestTBase/, 'Strategy')
|
34
|
+
v.gsub!(/TTK::Test::TestT/, 'TTK::Strategies::')
|
35
|
+
v.gsub!(/Test::TestT/, 'Strategies::')
|
36
|
+
v.gsub!(/TestT/, '')
|
37
|
+
end
|
38
|
+
end
|
39
|
+
res[k] = Loaders.get_class(v)
|
40
|
+
elsif k == :content
|
41
|
+
res[:contents] = v.yaml_load_map
|
42
|
+
else
|
43
|
+
res[k] = v.yaml_load_map
|
44
|
+
end
|
45
|
+
end
|
46
|
+
res
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
module TTK
|
51
|
+
|
52
|
+
module Loaders
|
53
|
+
|
54
|
+
class YamlOld < Loader
|
55
|
+
include Concrete
|
56
|
+
|
57
|
+
def load_doc(io)
|
58
|
+
YAML::load(io).yaml_load_map
|
59
|
+
end
|
60
|
+
|
61
|
+
end # class Yaml
|
62
|
+
|
63
|
+
end # module Loaders
|
64
|
+
|
65
|
+
end # module TTK
|
data/lib/ttk/logger.rb
ADDED
@@ -0,0 +1,237 @@
|
|
1
|
+
# Author:: Nicolas Pouillard <ertai@lrde.epita.fr>.
|
2
|
+
# Copyright:: Copyright (c) 2004, 2005 TTK team. All rights reserved.
|
3
|
+
# License:: LGPL
|
4
|
+
# $Id: logger.rb 571 2005-04-13 14:41:22Z polrop $
|
5
|
+
|
6
|
+
|
7
|
+
require 'observer'
|
8
|
+
|
9
|
+
require 'ttk/logger/severity'
|
10
|
+
require 'ttk/logger/to_ttk_log'
|
11
|
+
require 'ttk/logger/section_node'
|
12
|
+
require 'ttk/logger/path'
|
13
|
+
require 'ttk/logger/verbosity'
|
14
|
+
|
15
|
+
|
16
|
+
module TTK
|
17
|
+
|
18
|
+
class Logger
|
19
|
+
|
20
|
+
include Observable
|
21
|
+
|
22
|
+
TYPES = [ :map, :seq ]
|
23
|
+
|
24
|
+
MESSAGES = [ :new_node, :new_leaf, :up, :close ]
|
25
|
+
|
26
|
+
def initialize ( *observers )
|
27
|
+
@path = []
|
28
|
+
observers.flatten.each { |obs| add_observer(obs) }
|
29
|
+
@closed = false
|
30
|
+
@sections = []
|
31
|
+
@section_tree = SectionNode.new('all')
|
32
|
+
@severity_level = Severity::DEBUG
|
33
|
+
@nb_log_msg = 0
|
34
|
+
@verbosity = Verbosity.new
|
35
|
+
@verbosity_level = 0
|
36
|
+
end
|
37
|
+
|
38
|
+
attr_reader :severity_level
|
39
|
+
|
40
|
+
def severity_level=(severity_level)
|
41
|
+
if severity_level.is_a?(String)
|
42
|
+
severity_level = Severity.const_get(severity_level.to_s.upcase)
|
43
|
+
end
|
44
|
+
if Severity.lower <= severity_level and severity_level <= Severity.higher
|
45
|
+
@severity_level = severity_level
|
46
|
+
else
|
47
|
+
raise(ArgumentError, "`#{severity_level}' - invalid severity level")
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
attr_accessor :section_tree
|
52
|
+
|
53
|
+
def active_section(active, *section_names)
|
54
|
+
@sections = @section_tree.set_active_section(active, *section_names)
|
55
|
+
nil
|
56
|
+
end
|
57
|
+
|
58
|
+
def active_section?(section_name)
|
59
|
+
@sections.include?(section_name)
|
60
|
+
end
|
61
|
+
|
62
|
+
attr_reader :verbosity
|
63
|
+
|
64
|
+
def verbosity=(verbosity)
|
65
|
+
unless verbosity.is_a?(Verbosity)
|
66
|
+
raise(ArgumentError,
|
67
|
+
"`#{verbosity}' - must inherit from Verbosity")
|
68
|
+
end
|
69
|
+
@verbosity = verbosity
|
70
|
+
end
|
71
|
+
|
72
|
+
attr_reader :verbosity_level
|
73
|
+
|
74
|
+
def verbosity_level=(verbosity_level)
|
75
|
+
if verbosity_level < 0
|
76
|
+
raise(ArgumentError,
|
77
|
+
"`#{verbosity_level}' - " +
|
78
|
+
'verbosity level must be positive or null')
|
79
|
+
end
|
80
|
+
@verbosity_level = verbosity_level
|
81
|
+
end
|
82
|
+
|
83
|
+
def log(severity_level=nil, *section_names, &block)
|
84
|
+
severity_level ||= Severity.higher
|
85
|
+
return true if severity_level < @severity_level
|
86
|
+
if section_names.empty?
|
87
|
+
format_log_message(severity_level, section_names, &block)
|
88
|
+
else
|
89
|
+
section_names.each do |s|
|
90
|
+
if @sections.include?(s)
|
91
|
+
format_log_message(severity_level, section_names, &block)
|
92
|
+
break
|
93
|
+
end
|
94
|
+
end
|
95
|
+
end
|
96
|
+
end
|
97
|
+
|
98
|
+
def format_log_message(severity_level, section_names, &block)
|
99
|
+
new_node("log_#@nb_log_msg") do
|
100
|
+
if @verbosity_level == 0
|
101
|
+
block[].to_ttk_log(self)
|
102
|
+
else
|
103
|
+
for i in 1..@verbosity_level do
|
104
|
+
@verbosity.class.level_fields(i).each do |field|
|
105
|
+
self[field] = @verbosity.send(field,
|
106
|
+
severity_level,
|
107
|
+
section_names)
|
108
|
+
end
|
109
|
+
end
|
110
|
+
self['message'] = block[]
|
111
|
+
end
|
112
|
+
end
|
113
|
+
@nb_log_msg += 1
|
114
|
+
end
|
115
|
+
protected :format_log_message
|
116
|
+
|
117
|
+
def new_node ( node, type=:map, &block )
|
118
|
+
raise ArgumentError, "bad node type: #{type}" unless TYPES.include? type
|
119
|
+
node = node.to_s.to_sym unless node.is_a? Symbol or node.is_a? Integer
|
120
|
+
|
121
|
+
begin
|
122
|
+
@path << [node, type]
|
123
|
+
notif :new_node, @path.dup
|
124
|
+
rescue Exception => ex
|
125
|
+
up if block_given?
|
126
|
+
raise ex
|
127
|
+
end
|
128
|
+
|
129
|
+
if block_given?
|
130
|
+
begin
|
131
|
+
block[]
|
132
|
+
ensure
|
133
|
+
up
|
134
|
+
end
|
135
|
+
end
|
136
|
+
end
|
137
|
+
|
138
|
+
def up
|
139
|
+
@path.pop
|
140
|
+
notif :up, @path.dup
|
141
|
+
end
|
142
|
+
|
143
|
+
def new_leaf ( x )
|
144
|
+
notif :new_leaf, @path.dup, x
|
145
|
+
end
|
146
|
+
|
147
|
+
def []= ( k, v )
|
148
|
+
new_node(k) do
|
149
|
+
v.to_ttk_log(self)
|
150
|
+
end
|
151
|
+
end
|
152
|
+
|
153
|
+
def << ( v )
|
154
|
+
v.to_ttk_log(self)
|
155
|
+
end
|
156
|
+
|
157
|
+
def method_missing ( key, *a, &b )
|
158
|
+
str = key.to_s
|
159
|
+
case str
|
160
|
+
when /^(.*)=$/
|
161
|
+
self[$1.to_sym] = a[0]
|
162
|
+
when /^log_/
|
163
|
+
begin
|
164
|
+
args = make_log_arguments(str)
|
165
|
+
args.concat([ *a ])
|
166
|
+
self.log(*args, &b)
|
167
|
+
rescue ArgumentError
|
168
|
+
super
|
169
|
+
end
|
170
|
+
else
|
171
|
+
super
|
172
|
+
end
|
173
|
+
end
|
174
|
+
|
175
|
+
def make_log_arguments(str)
|
176
|
+
if str =~ /^log_([A-Za-z0-9]+)(.*)$/
|
177
|
+
args = []
|
178
|
+
begin
|
179
|
+
args << Severity.const_get($1.upcase)
|
180
|
+
rescue NameError
|
181
|
+
raise(NameError, "`#{$1}' - unknown severity level")
|
182
|
+
end
|
183
|
+
while $2 =~ /^_([A-Za-z0-9]+)(.*)$/
|
184
|
+
args << $1
|
185
|
+
end
|
186
|
+
args
|
187
|
+
else
|
188
|
+
raise(ArgumentError, "`#{str}' - bad format")
|
189
|
+
end
|
190
|
+
end
|
191
|
+
|
192
|
+
def path
|
193
|
+
Path.new(@path)
|
194
|
+
end
|
195
|
+
|
196
|
+
def path_size
|
197
|
+
@path.size
|
198
|
+
end
|
199
|
+
|
200
|
+
def to_s
|
201
|
+
"#<#{self.class} path=#{path}>"
|
202
|
+
end
|
203
|
+
|
204
|
+
alias :inspect :to_s
|
205
|
+
|
206
|
+
# FIXME : WARNING
|
207
|
+
#
|
208
|
+
# r = Logger.new
|
209
|
+
# r.new_node(:root)
|
210
|
+
# r.update(:new_node, [:another_path], :foo) # it's incorrect
|
211
|
+
def update ( msg, *args )
|
212
|
+
notif(msg, *args) if MESSAGES.include? msg
|
213
|
+
end
|
214
|
+
|
215
|
+
def notif ( *args )
|
216
|
+
changed
|
217
|
+
notify_observers(*args)
|
218
|
+
end
|
219
|
+
|
220
|
+
private :notif, :notify_observers, :changed
|
221
|
+
|
222
|
+
def close
|
223
|
+
unless @closed
|
224
|
+
@closed = true
|
225
|
+
notif(:close)
|
226
|
+
end
|
227
|
+
end
|
228
|
+
|
229
|
+
def closed?
|
230
|
+
@closed
|
231
|
+
end
|
232
|
+
|
233
|
+
end # class Logger
|
234
|
+
|
235
|
+
end # module TTK
|
236
|
+
|
237
|
+
|
@@ -0,0 +1,23 @@
|
|
1
|
+
# Author:: Nicolas Pouillard <ertai@lrde.epita.fr>.
|
2
|
+
# Copyright:: Copyright (c) 2004, 2005 TTK team. All rights reserved.
|
3
|
+
# License:: LGPL
|
4
|
+
# $Id: path.rb 567 2005-04-13 08:00:06Z polrop $
|
5
|
+
|
6
|
+
|
7
|
+
module TTK
|
8
|
+
|
9
|
+
class Logger
|
10
|
+
|
11
|
+
class Path < Array
|
12
|
+
|
13
|
+
def to_s
|
14
|
+
'/' + map{ |x| x[0] }.join('/')
|
15
|
+
end
|
16
|
+
|
17
|
+
alias :inspect :to_s
|
18
|
+
|
19
|
+
end # class Path
|
20
|
+
|
21
|
+
end # class Logger
|
22
|
+
|
23
|
+
end # module TTK
|
@@ -0,0 +1,214 @@
|
|
1
|
+
# Author:: Nicolas Despres <nicolas.despres@gmail.com>.
|
2
|
+
# Copyright:: Copyright (c) 2004, 2005 TTK team. All rights reserved.
|
3
|
+
# License:: LGPL
|
4
|
+
# $Id: section_node.rb 567 2005-04-13 08:00:06Z polrop $
|
5
|
+
|
6
|
+
|
7
|
+
module TTK
|
8
|
+
|
9
|
+
class Logger
|
10
|
+
|
11
|
+
# Implement a tree of section. A section node has a name and a `active'
|
12
|
+
# flag that say if the section node is on/off. A section tree verifies the
|
13
|
+
# following property:
|
14
|
+
#
|
15
|
+
# a node is active iff at least one of its sub nodes is active
|
16
|
+
#
|
17
|
+
# Obviously, when activating a node, all its sub nodes are also activated.
|
18
|
+
class SectionNode
|
19
|
+
|
20
|
+
def initialize(name, *sub_sections)
|
21
|
+
self.name = name
|
22
|
+
@sub_sections = {}
|
23
|
+
sub_sections.each { |s| self << s }
|
24
|
+
@active = false
|
25
|
+
end
|
26
|
+
|
27
|
+
attr_reader :name
|
28
|
+
|
29
|
+
def name=(new_name)
|
30
|
+
@name = new_name.to_s
|
31
|
+
end
|
32
|
+
|
33
|
+
def sub_sections
|
34
|
+
@sub_sections.values
|
35
|
+
end
|
36
|
+
|
37
|
+
def [](name)
|
38
|
+
@sub_sections[name]
|
39
|
+
end
|
40
|
+
|
41
|
+
def []=(name, sub_section)
|
42
|
+
check_sub_section_type(sub_section)
|
43
|
+
sub_section.name = name
|
44
|
+
@sub_sections[sub_section.name] = sub_section
|
45
|
+
end
|
46
|
+
|
47
|
+
def <<(sub_section)
|
48
|
+
check_sub_section_type(sub_section)
|
49
|
+
@sub_sections[sub_section.name] = sub_section
|
50
|
+
end
|
51
|
+
|
52
|
+
def push(*sub_sections)
|
53
|
+
sub_sections.each { |ss| self << ss }
|
54
|
+
end
|
55
|
+
|
56
|
+
def active=(new_active)
|
57
|
+
active_tree(new_active)
|
58
|
+
@active
|
59
|
+
end
|
60
|
+
|
61
|
+
def active?
|
62
|
+
@active
|
63
|
+
end
|
64
|
+
|
65
|
+
def active_tree(new_active)
|
66
|
+
accu = []
|
67
|
+
active_tree_rec(new_active, accu) unless new_active == @active
|
68
|
+
accu
|
69
|
+
end
|
70
|
+
|
71
|
+
def active_tree_rec(new_active, accu)
|
72
|
+
@active = new_active
|
73
|
+
accu << @name
|
74
|
+
@sub_sections.each_value { |s| s.active_tree_rec(new_active, accu) }
|
75
|
+
end
|
76
|
+
protected :active_tree_rec
|
77
|
+
|
78
|
+
# Active the given section name in the tree. Return an array of all the
|
79
|
+
# section name that have been activated. The returned array is empty if
|
80
|
+
# the section name doesn't exists in the tree.
|
81
|
+
def active_section(section_name)
|
82
|
+
accu = []
|
83
|
+
active_section_rec(section_name, accu)
|
84
|
+
accu
|
85
|
+
end
|
86
|
+
|
87
|
+
def active_section_rec(section_name, accu)
|
88
|
+
if @name == section_name
|
89
|
+
accu.concat(active_tree(true))
|
90
|
+
true
|
91
|
+
else
|
92
|
+
ret = false
|
93
|
+
@sub_sections.each_value do |s|
|
94
|
+
if s.active_section_rec(section_name, accu)
|
95
|
+
@active = true
|
96
|
+
accu << @name
|
97
|
+
ret = true
|
98
|
+
break
|
99
|
+
end
|
100
|
+
end
|
101
|
+
ret
|
102
|
+
end
|
103
|
+
end
|
104
|
+
protected :active_section_rec
|
105
|
+
|
106
|
+
# Unactive the given section name in the tree. Return an array of all the
|
107
|
+
# section name that have been unactivated. The returned array is empty if
|
108
|
+
# the section name doesn't exists in the tree or if none section have
|
109
|
+
# been unactivated.
|
110
|
+
def unactive_section(section_name)
|
111
|
+
accu = []
|
112
|
+
unactive_section_rec(section_name, accu)
|
113
|
+
accu
|
114
|
+
end
|
115
|
+
|
116
|
+
def unactive_section_rec(section_name, accu)
|
117
|
+
if @name == section_name
|
118
|
+
accu.concat(active_tree(false))
|
119
|
+
true
|
120
|
+
else
|
121
|
+
not_unactivable = ret = false
|
122
|
+
@sub_sections.each_value do |s|
|
123
|
+
ret ||= s.unactive_section_rec(section_name, accu)
|
124
|
+
not_unactivable ||= s.active?
|
125
|
+
end
|
126
|
+
if ret and (not not_unactivable)
|
127
|
+
@active = false
|
128
|
+
accu << @name
|
129
|
+
true
|
130
|
+
else
|
131
|
+
false
|
132
|
+
end
|
133
|
+
end
|
134
|
+
end
|
135
|
+
protected :unactive_section_rec
|
136
|
+
|
137
|
+
def set_active_section(active, *section_names)
|
138
|
+
section = []
|
139
|
+
section_names.each do |s|
|
140
|
+
section.concat(active ? active_section(s) : unactive_section(s))
|
141
|
+
end
|
142
|
+
section.uniq!
|
143
|
+
section
|
144
|
+
end
|
145
|
+
|
146
|
+
def each(&block)
|
147
|
+
@sub_sections.each(&block)
|
148
|
+
end
|
149
|
+
|
150
|
+
alias :each_pair :each
|
151
|
+
|
152
|
+
def each_section(&block)
|
153
|
+
@sub_sections.each_value(&block)
|
154
|
+
end
|
155
|
+
|
156
|
+
alias :each_value :each_section
|
157
|
+
|
158
|
+
def each_label(&block)
|
159
|
+
@sub_sections.each_key(&block)
|
160
|
+
end
|
161
|
+
|
162
|
+
alias :each_key :each_label
|
163
|
+
|
164
|
+
def delete(name)
|
165
|
+
@sub_sections.delete(name)
|
166
|
+
end
|
167
|
+
|
168
|
+
def clear(name)
|
169
|
+
@sub_sections.clear
|
170
|
+
end
|
171
|
+
|
172
|
+
def nb_sub_sections
|
173
|
+
@sub_sections.size
|
174
|
+
end
|
175
|
+
|
176
|
+
alias :size :nb_sub_sections
|
177
|
+
alias :length :nb_sub_sections
|
178
|
+
|
179
|
+
def leaf?
|
180
|
+
@sub_sections.empty?
|
181
|
+
end
|
182
|
+
|
183
|
+
def pre_depth_first(&block)
|
184
|
+
block[self]
|
185
|
+
@sub_sections.each_value { |s| s.pre_depth_first(&block) }
|
186
|
+
nil
|
187
|
+
end
|
188
|
+
|
189
|
+
def find(name)
|
190
|
+
if @name == name
|
191
|
+
self
|
192
|
+
else
|
193
|
+
@sub_sections.each_value do |s|
|
194
|
+
ret = s.find(name)
|
195
|
+
return ret unless ret.nil?
|
196
|
+
end
|
197
|
+
nil
|
198
|
+
end
|
199
|
+
end
|
200
|
+
|
201
|
+
protected
|
202
|
+
def check_sub_section_type(sub_section)
|
203
|
+
unless sub_section.is_a?(self.class)
|
204
|
+
raise(TypeError, "`#{sub_section}' - must be a #{self.class}")
|
205
|
+
end
|
206
|
+
end
|
207
|
+
|
208
|
+
end # class SectionNode
|
209
|
+
|
210
|
+
end # class Logger
|
211
|
+
|
212
|
+
end # module TTK
|
213
|
+
|
214
|
+
|