libxml-ruby 3.2.2-x64-mingw-ucrt
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/HISTORY +848 -0
- data/LICENSE +21 -0
- data/MANIFEST +166 -0
- data/README.rdoc +217 -0
- data/Rakefile +99 -0
- data/ext/libxml/extconf.rb +61 -0
- data/ext/libxml/libxml.c +80 -0
- data/ext/libxml/libxml_ruby.def +35 -0
- data/ext/libxml/ruby_libxml.h +67 -0
- data/ext/libxml/ruby_xml.c +933 -0
- data/ext/libxml/ruby_xml.h +10 -0
- data/ext/libxml/ruby_xml_attr.c +333 -0
- data/ext/libxml/ruby_xml_attr.h +12 -0
- data/ext/libxml/ruby_xml_attr_decl.c +153 -0
- data/ext/libxml/ruby_xml_attr_decl.h +11 -0
- data/ext/libxml/ruby_xml_attributes.c +275 -0
- data/ext/libxml/ruby_xml_attributes.h +15 -0
- data/ext/libxml/ruby_xml_cbg.c +85 -0
- data/ext/libxml/ruby_xml_document.c +1123 -0
- data/ext/libxml/ruby_xml_document.h +11 -0
- data/ext/libxml/ruby_xml_dtd.c +248 -0
- data/ext/libxml/ruby_xml_dtd.h +9 -0
- data/ext/libxml/ruby_xml_encoding.c +250 -0
- data/ext/libxml/ruby_xml_encoding.h +16 -0
- data/ext/libxml/ruby_xml_error.c +996 -0
- data/ext/libxml/ruby_xml_error.h +12 -0
- data/ext/libxml/ruby_xml_html_parser.c +89 -0
- data/ext/libxml/ruby_xml_html_parser.h +10 -0
- data/ext/libxml/ruby_xml_html_parser_context.c +337 -0
- data/ext/libxml/ruby_xml_html_parser_context.h +10 -0
- data/ext/libxml/ruby_xml_html_parser_options.c +46 -0
- data/ext/libxml/ruby_xml_html_parser_options.h +10 -0
- data/ext/libxml/ruby_xml_input_cbg.c +191 -0
- data/ext/libxml/ruby_xml_input_cbg.h +20 -0
- data/ext/libxml/ruby_xml_io.c +47 -0
- data/ext/libxml/ruby_xml_io.h +10 -0
- data/ext/libxml/ruby_xml_namespace.c +153 -0
- data/ext/libxml/ruby_xml_namespace.h +10 -0
- data/ext/libxml/ruby_xml_namespaces.c +293 -0
- data/ext/libxml/ruby_xml_namespaces.h +9 -0
- data/ext/libxml/ruby_xml_node.c +1402 -0
- data/ext/libxml/ruby_xml_node.h +13 -0
- data/ext/libxml/ruby_xml_parser.c +91 -0
- data/ext/libxml/ruby_xml_parser.h +12 -0
- data/ext/libxml/ruby_xml_parser_context.c +999 -0
- data/ext/libxml/ruby_xml_parser_context.h +10 -0
- data/ext/libxml/ruby_xml_parser_options.c +66 -0
- data/ext/libxml/ruby_xml_parser_options.h +12 -0
- data/ext/libxml/ruby_xml_reader.c +1239 -0
- data/ext/libxml/ruby_xml_reader.h +17 -0
- data/ext/libxml/ruby_xml_relaxng.c +110 -0
- data/ext/libxml/ruby_xml_relaxng.h +10 -0
- data/ext/libxml/ruby_xml_sax2_handler.c +326 -0
- data/ext/libxml/ruby_xml_sax2_handler.h +10 -0
- data/ext/libxml/ruby_xml_sax_parser.c +116 -0
- data/ext/libxml/ruby_xml_sax_parser.h +10 -0
- data/ext/libxml/ruby_xml_schema.c +278 -0
- data/ext/libxml/ruby_xml_schema.h +809 -0
- data/ext/libxml/ruby_xml_schema_attribute.c +109 -0
- data/ext/libxml/ruby_xml_schema_attribute.h +15 -0
- data/ext/libxml/ruby_xml_schema_element.c +95 -0
- data/ext/libxml/ruby_xml_schema_element.h +14 -0
- data/ext/libxml/ruby_xml_schema_facet.c +52 -0
- data/ext/libxml/ruby_xml_schema_facet.h +13 -0
- data/ext/libxml/ruby_xml_schema_type.c +232 -0
- data/ext/libxml/ruby_xml_schema_type.h +9 -0
- data/ext/libxml/ruby_xml_version.h +9 -0
- data/ext/libxml/ruby_xml_writer.c +1133 -0
- data/ext/libxml/ruby_xml_writer.h +10 -0
- data/ext/libxml/ruby_xml_xinclude.c +16 -0
- data/ext/libxml/ruby_xml_xinclude.h +11 -0
- data/ext/libxml/ruby_xml_xpath.c +194 -0
- data/ext/libxml/ruby_xml_xpath.h +13 -0
- data/ext/libxml/ruby_xml_xpath_context.c +360 -0
- data/ext/libxml/ruby_xml_xpath_context.h +9 -0
- data/ext/libxml/ruby_xml_xpath_expression.c +81 -0
- data/ext/libxml/ruby_xml_xpath_expression.h +10 -0
- data/ext/libxml/ruby_xml_xpath_object.c +338 -0
- data/ext/libxml/ruby_xml_xpath_object.h +17 -0
- data/ext/libxml/ruby_xml_xpointer.c +99 -0
- data/ext/libxml/ruby_xml_xpointer.h +11 -0
- data/ext/vc/libxml_ruby.sln +28 -0
- data/lib/3.1/libxml_ruby.so +0 -0
- data/lib/libxml/attr.rb +123 -0
- data/lib/libxml/attr_decl.rb +80 -0
- data/lib/libxml/attributes.rb +14 -0
- data/lib/libxml/document.rb +194 -0
- data/lib/libxml/error.rb +95 -0
- data/lib/libxml/hpricot.rb +78 -0
- data/lib/libxml/html_parser.rb +96 -0
- data/lib/libxml/namespace.rb +62 -0
- data/lib/libxml/namespaces.rb +38 -0
- data/lib/libxml/node.rb +323 -0
- data/lib/libxml/parser.rb +101 -0
- data/lib/libxml/sax_callbacks.rb +180 -0
- data/lib/libxml/sax_parser.rb +41 -0
- data/lib/libxml/schema/attribute.rb +19 -0
- data/lib/libxml/schema/element.rb +19 -0
- data/lib/libxml/schema/type.rb +21 -0
- data/lib/libxml/schema.rb +48 -0
- data/lib/libxml/tree.rb +29 -0
- data/lib/libxml-ruby.rb +30 -0
- data/lib/libxml.rb +5 -0
- data/lib/xml/libxml.rb +10 -0
- data/lib/xml.rb +14 -0
- data/libxml-ruby.gemspec +48 -0
- data/script/benchmark/depixelate +634 -0
- data/script/benchmark/hamlet.xml +9055 -0
- data/script/benchmark/parsecount +170 -0
- data/script/benchmark/sock_entries.xml +507 -0
- data/script/benchmark/throughput +41 -0
- data/script/test +6 -0
- data/setup.rb +1584 -0
- data/test/c14n/given/doc.dtd +1 -0
- data/test/c14n/given/example-1.xml +14 -0
- data/test/c14n/given/example-2.xml +11 -0
- data/test/c14n/given/example-3.xml +18 -0
- data/test/c14n/given/example-4.xml +9 -0
- data/test/c14n/given/example-5.xml +12 -0
- data/test/c14n/given/example-6.xml +2 -0
- data/test/c14n/given/example-7.xml +11 -0
- data/test/c14n/given/example-8.xml +11 -0
- data/test/c14n/given/example-8.xpath +10 -0
- data/test/c14n/given/world.txt +1 -0
- data/test/c14n/result/1-1-without-comments/example-1 +4 -0
- data/test/c14n/result/1-1-without-comments/example-2 +11 -0
- data/test/c14n/result/1-1-without-comments/example-3 +14 -0
- data/test/c14n/result/1-1-without-comments/example-4 +9 -0
- data/test/c14n/result/1-1-without-comments/example-5 +3 -0
- data/test/c14n/result/1-1-without-comments/example-6 +1 -0
- data/test/c14n/result/1-1-without-comments/example-7 +1 -0
- data/test/c14n/result/1-1-without-comments/example-8 +1 -0
- data/test/c14n/result/with-comments/example-1 +6 -0
- data/test/c14n/result/with-comments/example-2 +11 -0
- data/test/c14n/result/with-comments/example-3 +14 -0
- data/test/c14n/result/with-comments/example-4 +9 -0
- data/test/c14n/result/with-comments/example-5 +4 -0
- data/test/c14n/result/with-comments/example-6 +1 -0
- data/test/c14n/result/with-comments/example-7 +1 -0
- data/test/c14n/result/without-comments/example-1 +4 -0
- data/test/c14n/result/without-comments/example-2 +11 -0
- data/test/c14n/result/without-comments/example-3 +14 -0
- data/test/c14n/result/without-comments/example-4 +9 -0
- data/test/c14n/result/without-comments/example-5 +3 -0
- data/test/c14n/result/without-comments/example-6 +1 -0
- data/test/c14n/result/without-comments/example-7 +1 -0
- data/test/model/atom.xml +13 -0
- data/test/model/bands.iso-8859-1.xml +5 -0
- data/test/model/bands.utf-8.xml +5 -0
- data/test/model/bands.xml +5 -0
- data/test/model/books.xml +154 -0
- data/test/model/cwm_1_0.xml +11336 -0
- data/test/model/merge_bug_data.xml +58 -0
- data/test/model/ruby-lang.html +238 -0
- data/test/model/rubynet.xml +79 -0
- data/test/model/rubynet_project +1 -0
- data/test/model/shiporder.rnc +28 -0
- data/test/model/shiporder.rng +86 -0
- data/test/model/shiporder.xml +23 -0
- data/test/model/shiporder.xsd +40 -0
- data/test/model/soap.xml +27 -0
- data/test/model/xinclude.xml +5 -0
- data/test/test_attr.rb +181 -0
- data/test/test_attr_decl.rb +132 -0
- data/test/test_attributes.rb +136 -0
- data/test/test_canonicalize.rb +120 -0
- data/test/test_deprecated_require.rb +12 -0
- data/test/test_document.rb +132 -0
- data/test/test_document_write.rb +146 -0
- data/test/test_dtd.rb +129 -0
- data/test/test_encoding.rb +129 -0
- data/test/test_encoding_sax.rb +115 -0
- data/test/test_error.rb +178 -0
- data/test/test_helper.rb +9 -0
- data/test/test_html_parser.rb +162 -0
- data/test/test_html_parser_context.rb +23 -0
- data/test/test_namespace.rb +60 -0
- data/test/test_namespaces.rb +200 -0
- data/test/test_node.rb +237 -0
- data/test/test_node_cdata.rb +50 -0
- data/test/test_node_comment.rb +32 -0
- data/test/test_node_copy.rb +40 -0
- data/test/test_node_edit.rb +158 -0
- data/test/test_node_pi.rb +37 -0
- data/test/test_node_text.rb +69 -0
- data/test/test_node_write.rb +97 -0
- data/test/test_node_xlink.rb +28 -0
- data/test/test_parser.rb +324 -0
- data/test/test_parser_context.rb +198 -0
- data/test/test_properties.rb +38 -0
- data/test/test_reader.rb +364 -0
- data/test/test_relaxng.rb +53 -0
- data/test/test_sax_parser.rb +326 -0
- data/test/test_schema.rb +168 -0
- data/test/test_suite.rb +48 -0
- data/test/test_traversal.rb +152 -0
- data/test/test_writer.rb +468 -0
- data/test/test_xinclude.rb +20 -0
- data/test/test_xml.rb +263 -0
- data/test/test_xpath.rb +244 -0
- data/test/test_xpath_context.rb +88 -0
- data/test/test_xpath_expression.rb +37 -0
- data/test/test_xpointer.rb +72 -0
- metadata +325 -0
| @@ -0,0 +1,170 @@ | |
| 1 | 
            +
            #!/usr/bin/env ruby
         | 
| 2 | 
            +
            #
         | 
| 3 | 
            +
            # Each test has an XML Parser open a 98k XML document and count one type of leaf 
         | 
| 4 | 
            +
            # element (466 entries). This is repeated a total of 100 times, twice for each Parser. 
         | 
| 5 | 
            +
            # Summary measurements are from the second test.
         | 
| 6 | 
            +
            #
         | 
| 7 | 
            +
            # Tests run on a MacBook Pro, Mac OS X 10.5.5, 4GB memory, 2.5 GHz Intel Core 2 Duo.
         | 
| 8 | 
            +
            # 
         | 
| 9 | 
            +
            # Library versions:
         | 
| 10 | 
            +
            #   hpricot 0.6.164
         | 
| 11 | 
            +
            #   libxml: 0.9.2
         | 
| 12 | 
            +
            # 
         | 
| 13 | 
            +
            # All benchmarks were run twice in sequence and the measurements presented here are from 
         | 
| 14 | 
            +
            # the second run. Java automatically optimizes JRuby code which is run many times and the 
         | 
| 15 | 
            +
            # speedup from the first to the second test is from 40 to 75%. There is no essential 
         | 
| 16 | 
            +
            # difference in the speed of the C version of Ruby between the first test and the second.
         | 
| 17 | 
            +
            # 
         | 
| 18 | 
            +
            # Summary:
         | 
| 19 | 
            +
            #
         | 
| 20 | 
            +
            #   100 times: Open 98k XML document and count one type of leaf element (466 entries)
         | 
| 21 | 
            +
            # 
         | 
| 22 | 
            +
            #   JRuby (Java 1.6.0_03-p3-Soylatte using server mode): jdom_document_builder     0.360
         | 
| 23 | 
            +
            #   MRI: libxml v0.9.2                                                             0.383
         | 
| 24 | 
            +
            #   JRuby (Java 1.6.0_07): jdom_document_builder                                   0.401
         | 
| 25 | 
            +
            #   JRuby (Java 1.5.0_16): jdom_document_builder                                   0.428
         | 
| 26 | 
            +
            #   JRuby (Java 1.6.0_03-p3-Soylatte using server mode): hpricot                   1.977
         | 
| 27 | 
            +
            #   JRuby (Java 1.5.0_16): hpricot                                                 2.027
         | 
| 28 | 
            +
            #   JRuby (Java 1.6.0_07): hpricot                                                 2.094
         | 
| 29 | 
            +
            #   MRI: hpricot                                                                   2.140
         | 
| 30 | 
            +
            #   JRuby (Java 1.6.0_03-p3-Soylatte using server mode): rexml                     5.488
         | 
| 31 | 
            +
            #   JRuby (Java 1.5.0_16): rexml                                                   5.569
         | 
| 32 | 
            +
            #   JRuby (Java 1.5.0_16): rexml                                                   5.578
         | 
| 33 | 
            +
            #   MRI: rexml                                                                     8.606
         | 
| 34 | 
            +
            # 
         | 
| 35 | 
            +
            # Ruby version: MRI 1.8.6 (2008-03-03 rev 114), platform: universal-darwin9.0
         | 
| 36 | 
            +
            # --------------------------------------------------------------------------------
         | 
| 37 | 
            +
            #                             user     system      total        real
         | 
| 38 | 
            +
            # rexml                   8.170000   0.100000   8.270000 (  8.606676)
         | 
| 39 | 
            +
            # hpricot                 1.990000   0.040000   2.030000 (  2.140865)
         | 
| 40 | 
            +
            # libxml                  0.350000   0.020000   0.370000 (  0.383475)
         | 
| 41 | 
            +
            # 
         | 
| 42 | 
            +
            # JRuby 1.1.5 (svn r8078) on Java 1.5.0_16
         | 
| 43 | 
            +
            # --------------------------------------------------------------------------------
         | 
| 44 | 
            +
            #                             user     system      total        real
         | 
| 45 | 
            +
            # rexml                   5.578000   0.000000   5.578000 (  5.578371)
         | 
| 46 | 
            +
            # hpricot                 2.028000   0.000000   2.028000 (  2.027348)
         | 
| 47 | 
            +
            # jdom_document_builder   0.429000   0.000000   0.429000 (  0.428713)
         | 
| 48 | 
            +
            # 
         | 
| 49 | 
            +
            # JRuby 1.1.5 (svn r8078) on Java 1.6.0_07
         | 
| 50 | 
            +
            # --------------------------------------------------------------------------------
         | 
| 51 | 
            +
            #                             user     system      total        real
         | 
| 52 | 
            +
            # rexml                   5.569000   0.000000   5.569000 (  5.569135)
         | 
| 53 | 
            +
            # hpricot                 2.094000   0.000000   2.094000 (  2.093635)
         | 
| 54 | 
            +
            # jdom_document_builder   0.401000   0.000000   0.401000 (  0.401115)
         | 
| 55 | 
            +
            # 
         | 
| 56 | 
            +
            # JRuby 1.1.5 (svn r8078) on Java 1.6.0_07 using server mode (-J-server)
         | 
| 57 | 
            +
            # --------------------------------------------------------------------------------
         | 
| 58 | 
            +
            #                             user     system      total        real
         | 
| 59 | 
            +
            # rexml                   5.489000   0.000000   5.489000 (  5.488560)
         | 
| 60 | 
            +
            # hpricot                 1.977000   0.000000   1.977000 (  1.976845)
         | 
| 61 | 
            +
            # jdom_document_builder   0.377000   0.000000   0.377000 (  0.377808)
         | 
| 62 | 
            +
            # 
         | 
| 63 | 
            +
            # JRuby 1.1.5 (svn r8078) on Java 1.6.0_03-p3 (Soylatte) using server mode (-J-server)
         | 
| 64 | 
            +
            # --------------------------------------------------------------------------------
         | 
| 65 | 
            +
            #                             user     system      total        real
         | 
| 66 | 
            +
            # rexml                   5.596000   0.000000   5.596000 (  5.596212)
         | 
| 67 | 
            +
            # hpricot                 1.937000   0.000000   1.937000 (  1.937312)
         | 
| 68 | 
            +
            # jdom_document_builder   0.360000   0.000000   0.360000 (  0.360068)
         | 
| 69 | 
            +
             | 
| 70 | 
            +
            require 'rubygems'
         | 
| 71 | 
            +
            require 'benchmark'
         | 
| 72 | 
            +
            require "rexml/document"
         | 
| 73 | 
            +
            require 'hpricot'
         | 
| 74 | 
            +
             | 
| 75 | 
            +
            if RUBY_PLATFORM =~ /java/ 
         | 
| 76 | 
            +
                include Java 
         | 
| 77 | 
            +
                import javax.xml.parsers.DocumentBuilder
         | 
| 78 | 
            +
                import javax.xml.parsers.DocumentBuilderFactory
         | 
| 79 | 
            +
                @dbf = DocumentBuilderFactory.new_instance
         | 
| 80 | 
            +
                @ruby_info = "Ruby version: JRuby #{RUBY_VERSION} (#{RUBY_RELEASE_DATE} rev #{RUBY_PATCHLEVEL}) [i386-jruby#{JRUBY_VERSION}]"
         | 
| 81 | 
            +
                @ruby_info << ", platform: Java, version #{java.lang.System.getProperty('java.version')}"
         | 
| 82 | 
            +
              else
         | 
| 83 | 
            +
                @ruby_info = "Ruby version: MRI #{RUBY_VERSION} (#{RUBY_RELEASE_DATE} rev #{RUBY_PATCHLEVEL})"
         | 
| 84 | 
            +
                @ruby_info << ", platform: #{RUBY_PLATFORM}"
         | 
| 85 | 
            +
             | 
| 86 | 
            +
                gem 'nokogiri', '>= 1.0.6'
         | 
| 87 | 
            +
                require 'nokogiri'
         | 
| 88 | 
            +
             | 
| 89 | 
            +
                gem 'libxml-ruby', '>= 0.9.2'
         | 
| 90 | 
            +
                require 'libxml'
         | 
| 91 | 
            +
                @xml_parser = LibXML::XML::Parser.new
         | 
| 92 | 
            +
            end
         | 
| 93 | 
            +
             | 
| 94 | 
            +
            file = File.expand_path(File.join(File.dirname(__FILE__), "sock_entries.xml"))
         | 
| 95 | 
            +
            @bundle_with_466_sock_entries = File.read(file)
         | 
| 96 | 
            +
             | 
| 97 | 
            +
            def rexml_count_socks
         | 
| 98 | 
            +
              doc = REXML::Document.new(@bundle_with_466_sock_entries).root
         | 
| 99 | 
            +
              socks = doc.elements.to_a('./sockEntries').length
         | 
| 100 | 
            +
            end
         | 
| 101 | 
            +
             | 
| 102 | 
            +
            unless RUBY_PLATFORM =~ /java/ 
         | 
| 103 | 
            +
              def nokogiri_count_socks
         | 
| 104 | 
            +
                #doc = Nokogiri(@bundle_with_466_sock_entries)
         | 
| 105 | 
            +
                #socks = doc.search('//sockEntries').length
         | 
| 106 | 
            +
              end
         | 
| 107 | 
            +
             | 
| 108 | 
            +
              def libxml_count_socks
         | 
| 109 | 
            +
                @xml_parser = LibXML::XML::Parser.new
         | 
| 110 | 
            +
                @xml_parser.string = @bundle_with_466_sock_entries
         | 
| 111 | 
            +
                doc = @xml_parser.parse
         | 
| 112 | 
            +
                socks = doc.find('//sockEntries').length
         | 
| 113 | 
            +
              end
         | 
| 114 | 
            +
            end
         | 
| 115 | 
            +
             | 
| 116 | 
            +
            def hpricot_count_socks
         | 
| 117 | 
            +
              doc = Hpricot.XML(@bundle_with_466_sock_entries)
         | 
| 118 | 
            +
              socks = doc.search("//sockEntries").length
         | 
| 119 | 
            +
            end
         | 
| 120 | 
            +
             | 
| 121 | 
            +
            if RUBY_PLATFORM =~ /java/ 
         | 
| 122 | 
            +
              def jdom_document_builder_count_socks
         | 
| 123 | 
            +
                file = File.expand_path(File.join(File.dirname(__FILE__), "sock_entries.xml"))
         | 
| 124 | 
            +
                doc = @dbf.new_document_builder.parse(file).get_document_element
         | 
| 125 | 
            +
                socks = doc.getElementsByTagName("sockEntries")
         | 
| 126 | 
            +
                socks.get_length
         | 
| 127 | 
            +
              end
         | 
| 128 | 
            +
            end
         | 
| 129 | 
            +
             | 
| 130 | 
            +
            n = 100
         | 
| 131 | 
            +
            test_iterations = ARGV.first.to_i 
         | 
| 132 | 
            +
            test_iterations = 1 unless test_iterations > 1
         | 
| 133 | 
            +
            puts 
         | 
| 134 | 
            +
            puts @ruby_info
         | 
| 135 | 
            +
            puts
         | 
| 136 | 
            +
            puts "#{n} times: Open 98k XML document and count one type of leaf element (466 entries)"
         | 
| 137 | 
            +
            puts
         | 
| 138 | 
            +
            print "running benchmark "
         | 
| 139 | 
            +
            if test_iterations == 1 
         | 
| 140 | 
            +
              puts "once.\n\n"
         | 
| 141 | 
            +
            else
         | 
| 142 | 
            +
              puts "#{test_iterations} times.\n\n"
         | 
| 143 | 
            +
            end
         | 
| 144 | 
            +
            test_iterations.times do
         | 
| 145 | 
            +
              Benchmark.bmbm do |x|
         | 
| 146 | 
            +
                x.report("rexml") { n.times {rexml_count_socks} }
         | 
| 147 | 
            +
                x.report("hpricot")  { n.times {hpricot_count_socks} }
         | 
| 148 | 
            +
                x.report("jdom_document_builder")  { n.times {jdom_document_builder_count_socks} } if RUBY_PLATFORM =~ /java/
         | 
| 149 | 
            +
                #x.report("nokogiri") { n.times {nokogiri_count_socks} }  unless RUBY_PLATFORM =~ /java/
         | 
| 150 | 
            +
                x.report("libxml") { n.times {libxml_count_socks} }  unless RUBY_PLATFORM =~ /java/ 
         | 
| 151 | 
            +
              end
         | 
| 152 | 
            +
              puts
         | 
| 153 | 
            +
            end
         | 
| 154 | 
            +
             | 
| 155 | 
            +
            #
         | 
| 156 | 
            +
            # jrexml doesn't appear to have any speedup in this test
         | 
| 157 | 
            +
            #
         | 
| 158 | 
            +
            # if RUBY_PLATFORM =~ /java/ 
         | 
| 159 | 
            +
            #   require 'jrexml'
         | 
| 160 | 
            +
            #   def rexml_with_jrexml_count_socks
         | 
| 161 | 
            +
            #     doc = REXML::Document.new(@bundle_with_466_sock_entries).root
         | 
| 162 | 
            +
            #     socks = doc.elements.to_a('./sockEntries').length
         | 
| 163 | 
            +
            #   end
         | 
| 164 | 
            +
            # 
         | 
| 165 | 
            +
            #   puts "\nNow add in JREXML to see if it speeds up rexml\n"
         | 
| 166 | 
            +
            #   Benchmark.bmbm do |x|
         | 
| 167 | 
            +
            #     x.report("rexml+jrexml") { n.times {rexml_with_jrexml_count_socks} }
         | 
| 168 | 
            +
            #   end
         | 
| 169 | 
            +
            #   puts
         | 
| 170 | 
            +
            # end
         |