xamplr 1.3.15 → 1.9.0
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.
- data/.gitignore +1 -0
- data/COPYING +160 -656
- data/LICENSE +1 -1
- data/README.md +33 -0
- data/Rakefile +2 -2
- data/VERSION.yml +2 -2
- data/lib/xamplr.rb +1 -0
- data/lib/xamplr/iterator.rb +123 -0
- data/lib/xamplr/xml-text.rb +5 -5
- data/xamplr.gemspec +9 -204
- metadata +13 -203
- data/README.rdoc +0 -46
- data/README.rdoc.orig +0 -118
- data/bin/xampl-gen +0 -17
- data/docs/intro/.gitignore +0 -1
- data/docs/intro/example1/example1.rb +0 -6
- data/docs/intro/example1/xml/hello.xml +0 -1
- data/docs/intro/example2/example2.rb +0 -38
- data/docs/intro/example2/project-generator.rb +0 -22
- data/docs/intro/example2/xml/hello.xml +0 -2
- data/docs/intro/example3/example3.rb +0 -30
- data/docs/intro/example3/example3a.rb +0 -16
- data/docs/intro/example3/generated.png +0 -0
- data/docs/intro/example3/grab-yuml.rb +0 -10
- data/docs/intro/example3/greeter.rb +0 -15
- data/docs/intro/example3/greeting.rb +0 -9
- data/docs/intro/example3/project-generator.rb +0 -25
- data/docs/intro/example3/xml/greeter.xml +0 -6
- data/docs/intro/example4/example4.rb +0 -27
- data/docs/intro/example4/example4a.rb +0 -19
- data/docs/intro/example4/grab-yuml.rb +0 -10
- data/docs/intro/example4/greeter.rb +0 -15
- data/docs/intro/example4/greeting.rb +0 -9
- data/docs/intro/example4/project-generator.rb +0 -25
- data/docs/intro/example4/xml/greeter.xml +0 -6
- data/docs/intro/grab-yuml.rb +0 -10
- data/docs/intro/project-generator.rb +0 -51
- data/docs/intro/xampl.lyx +0 -1494
- data/docs/intro/xampl.pdf +0 -0
- data/examples/employees/final-xampl/xampl-gen.rb +0 -38
- data/examples/employees/final-xampl/xml/ddd-final-xampl.xml +0 -86
- data/examples/employees/final/xampl-gen.rb +0 -38
- data/examples/employees/final/xml/ddd-final.xml +0 -86
- data/examples/employees/first/xampl-gen.rb +0 -38
- data/examples/employees/first/xml/ddd-first.xml +0 -48
- data/examples/employees/twist/twist.graphml +0 -333
- data/examples/employees/twist/xampl-gen.rb +0 -38
- data/examples/employees/twist/xml/twist.xml +0 -90
- data/examples/employees/xamplr-twist.xml +0 -2
- data/examples/employees/yuml-diagrams/DDD-final-approach.graphml +0 -393
- data/examples/employees/yuml-diagrams/DDD-final-xampl-approach.graphml +0 -265
- data/examples/employees/yuml-diagrams/DDD-ideal-final-approach.graphml +0 -357
- data/examples/employees/yuml-diagrams/ddd-final.png +0 -0
- data/examples/employees/yuml-diagrams/ddd-final.yuml +0 -8
- data/examples/employees/yuml-diagrams/ddd-first.png +0 -0
- data/examples/employees/yuml-diagrams/ddd-first.yuml +0 -7
- data/examples/employees/yuml-diagrams/final-yed.png +0 -0
- data/examples/employees/yuml-diagrams/first-yed.png +0 -0
- data/examples/employees/yuml-diagrams/twist.png +0 -0
- data/examples/employees/yuml-diagrams/twist.yuml +0 -12
- data/examples/employees/yuml-diagrams/xamplr-final-no-mixins.png +0 -0
- data/examples/employees/yuml-diagrams/xamplr-final-simplified.png +0 -0
- data/examples/employees/yuml-diagrams/xamplr-final-with-mixins.png +0 -0
- data/examples/employees/yuml-diagrams/yuml-simplified.txt +0 -19
- data/examples/employees/yuml-diagrams/yuml-with-mixins.txt +0 -53
- data/examples/employees/yuml-diagrams/yuml.txt +0 -27
- data/examples/hobbies/Makefile +0 -5
- data/examples/hobbies/hobbies.rb +0 -193
- data/examples/hobbies/project-generator.rb +0 -25
- data/examples/hobbies/xampl-gen.rb +0 -38
- data/examples/hobbies/xml/hobby.xml +0 -3
- data/examples/hobbies/xml/people.xml +0 -5
- data/examples/random-people-shared-addresses/.gitignore +0 -2
- data/examples/random-people-shared-addresses/Makefile +0 -15
- data/examples/random-people-shared-addresses/batch-load-users-profiled.rb +0 -91
- data/examples/random-people-shared-addresses/batch-load-users-safe.rb +0 -81
- data/examples/random-people-shared-addresses/batch-load-users.rb +0 -79
- data/examples/random-people-shared-addresses/find-mentions.rb +0 -47
- data/examples/random-people-shared-addresses/find-people-by-address.rb +0 -104
- data/examples/random-people-shared-addresses/optimise.rb +0 -16
- data/examples/random-people-shared-addresses/people.rb +0 -35
- data/examples/random-people-shared-addresses/query.rb +0 -75
- data/examples/random-people-shared-addresses/query2.rb +0 -73
- data/examples/random-people-shared-addresses/random-names.csv +0 -10000
- data/examples/random-people-shared-addresses/settings.rb +0 -3
- data/examples/random-people-shared-addresses/what-to-query-on.rb +0 -82
- data/examples/random-people-shared-addresses/xampl-gen.rb +0 -38
- data/examples/random-people-shared-addresses/xml/people.xml +0 -14
- data/examples/random-people/.gitignore +0 -2
- data/examples/random-people/Makefile +0 -20
- data/examples/random-people/batch-load-users.rb +0 -61
- data/examples/random-people/optimise.rb +0 -16
- data/examples/random-people/people.rb +0 -22
- data/examples/random-people/query.rb +0 -73
- data/examples/random-people/query2.rb +0 -73
- data/examples/random-people/random-names.csv +0 -10000
- data/examples/random-people/rawtc.rb +0 -91
- data/examples/random-people/settings.rb +0 -3
- data/examples/random-people/what-to-query-on.rb +0 -80
- data/examples/random-people/xampl-gen.rb +0 -39
- data/examples/random-people/xml/people.xml +0 -11
- data/examples/read-testing/.gitignore +0 -2
- data/examples/read-testing/Makefile +0 -10
- data/examples/read-testing/load.rb +0 -65
- data/examples/read-testing/read.rb +0 -51
- data/examples/read-testing/rrr.rb +0 -88
- data/examples/read-testing/settings.rb +0 -2
- data/examples/read-testing/xampl-gen.rb +0 -38
- data/examples/read-testing/xml/text.xml +0 -8
- data/examples/tokyo-cabinet-experimental/.gitignore +0 -2
- data/examples/tokyo-cabinet-experimental/expt-query.rb +0 -42
- data/examples/tokyo-cabinet-experimental/expt-query2.rb +0 -42
- data/examples/tokyo-cabinet-experimental/expt-query3.rb +0 -41
- data/examples/tokyo-cabinet-experimental/expt-reader.rb +0 -32
- data/examples/tokyo-cabinet-experimental/expt.rb +0 -61
- data/examples/tokyo-cabinet-experimental/xampl-gen.rb +0 -38
- data/examples/tokyo-cabinet-experimental/xml/tcx.xml +0 -6
- data/examples/write-testing/README +0 -4
- data/examples/write-testing/RESULTS.home +0 -33
- data/examples/write-testing/RESULTS.raconteur +0 -33
- data/examples/write-testing/write-speed-test.rb +0 -40
- data/lib/xampl-generator.rb +0 -3
- data/lib/xamplr-generator.rb +0 -9
- data/lib/xamplr/gen-elements.xml +0 -6230
- data/lib/xamplr/gen.elements.xml +0 -108
- data/lib/xamplr/generate-elements.rb +0 -15
- data/lib/xamplr/generator.rb +0 -5
- data/lib/xamplr/graphml-out.rb +0 -451
- data/lib/xamplr/handwritten/example.rb +0 -698
- data/lib/xamplr/handwritten/hand-example.rb +0 -533
- data/lib/xamplr/handwritten/test-handwritten.rb +0 -873
- data/lib/xamplr/my.gen.elements.xml +0 -461
- data/lib/xamplr/obsolete/fsdb.rb +0 -62
- data/lib/xamplr/simpleTemplate/danger.rx +0 -4
- data/lib/xamplr/simpleTemplate/obsolete/input-c.r4 +0 -35
- data/lib/xamplr/simpleTemplate/obsolete/play.r6.txt +0 -12
- data/lib/xamplr/simpleTemplate/obsolete/play_more.r6.txt +0 -20
- data/lib/xamplr/simpleTemplate/obsolete/test001.r5 +0 -8
- data/lib/xamplr/simpleTemplate/obsolete/test002.r5 +0 -13
- data/lib/xamplr/simpleTemplate/obsolete/test003.r5 +0 -37
- data/lib/xamplr/simpleTemplate/old/r6.000.rb +0 -122
- data/lib/xamplr/simpleTemplate/old/r6.001.rb +0 -145
- data/lib/xamplr/simpleTemplate/play.r6 +0 -12
- data/lib/xamplr/simpleTemplate/play_more.r6 +0 -20
- data/lib/xamplr/simpleTemplate/play_noblanks.r6 +0 -21
- data/lib/xamplr/simpleTemplate/playq.r6 +0 -16
- data/lib/xamplr/simpleTemplate/r6.rb +0 -87
- data/lib/xamplr/simpleTemplate/simple-template.rb +0 -75
- data/lib/xamplr/templates/.cvsignore +0 -3
- data/lib/xamplr/templates/child.template +0 -47
- data/lib/xamplr/templates/child_indexed.template +0 -89
- data/lib/xamplr/templates/child_modules.template +0 -5
- data/lib/xamplr/templates/element_classes.template +0 -11
- data/lib/xamplr/templates/element_data.template +0 -283
- data/lib/xamplr/templates/element_empty.template +0 -277
- data/lib/xamplr/templates/element_mixed.template +0 -278
- data/lib/xamplr/templates/element_simple.template +0 -277
- data/lib/xamplr/templates/package.template +0 -38
- data/lib/xamplr/xampl-cl-gen.rb +0 -89
- data/lib/xamplr/xampl-generator.rb +0 -569
- data/lib/xamplr/xampl-hand-generated.rb +0 -1535
- data/lib/xamplr/yEd-sample.graphml +0 -300
- data/lib/xamplr/yuml-out.rb +0 -129
@@ -1,38 +0,0 @@
|
|
1
|
-
#!/usr/bin/env ruby -w -I..
|
2
|
-
|
3
|
-
if $0 == __FILE__ then
|
4
|
-
|
5
|
-
class File
|
6
|
-
def File.sjoin(*args)
|
7
|
-
File.join(args.select{ | o | o })
|
8
|
-
end
|
9
|
-
end
|
10
|
-
|
11
|
-
$LOAD_PATH.unshift('../../lib/')
|
12
|
-
|
13
|
-
require 'xamplr-generator'
|
14
|
-
|
15
|
-
include XamplGenerator
|
16
|
-
include Xampl
|
17
|
-
|
18
|
-
Xampl.transaction("setup", :in_memory) do
|
19
|
-
directory = File.sjoin(".", "xampl_generated_code")
|
20
|
-
|
21
|
-
options = Xampl.make(Options) do |options|
|
22
|
-
options.new_index_attribute("pid").persisted = true
|
23
|
-
options.new_index_attribute("id")
|
24
|
-
|
25
|
-
options.resolve("http://xampl.com/performance", "Perf", "p")
|
26
|
-
end
|
27
|
-
|
28
|
-
filenames = Dir.glob("./xml/**/*.xml")
|
29
|
-
|
30
|
-
generator = Generator.new
|
31
|
-
generator.go(:options => options,
|
32
|
-
:filenames => filenames,
|
33
|
-
:directory => directory)
|
34
|
-
|
35
|
-
#puts generator.print_elements("./generated-elements.xml")
|
36
|
-
exit!
|
37
|
-
end
|
38
|
-
end
|
@@ -1,42 +0,0 @@
|
|
1
|
-
require 'rubygems'
|
2
|
-
|
3
|
-
$LOAD_PATH.unshift("xampl_generated_code")
|
4
|
-
|
5
|
-
require 'TokyoCabinetExperimental'
|
6
|
-
|
7
|
-
Xampl.set_default_persister_kind(:tokyo_cabinet)
|
8
|
-
Xampl.set_default_persister_format(:xml_format)
|
9
|
-
|
10
|
-
module TokyoCabinetExperimental
|
11
|
-
|
12
|
-
start = Time.now
|
13
|
-
found = Xampl.transaction("setup") do
|
14
|
-
Xampl.query do | q |
|
15
|
-
q.add_condition('age', :numle, '50')
|
16
|
-
q.order_by('age', :numasc)
|
17
|
-
end
|
18
|
-
end
|
19
|
-
query_done = Time.now
|
20
|
-
|
21
|
-
total = 0
|
22
|
-
found.each do | person_meta |
|
23
|
-
total += person_meta['age'].to_i
|
24
|
-
end
|
25
|
-
|
26
|
-
meta_done = Time.now
|
27
|
-
|
28
|
-
total1 = 0
|
29
|
-
found.each do | person_meta |
|
30
|
-
total1 += person_meta['xampl'].age.to_i
|
31
|
-
end
|
32
|
-
|
33
|
-
done = Time.now
|
34
|
-
|
35
|
-
found.each do | person_meta |
|
36
|
-
puts "name: #{ person_meta['name']}"
|
37
|
-
end
|
38
|
-
puts "found: #{ found.size }"
|
39
|
-
puts "Total age: #{ total }, #{ total1 }"
|
40
|
-
puts "done: #{ done - start }:: #{ query_done - start } + #{ meta_done - query_done } + #{ done - meta_done }"
|
41
|
-
|
42
|
-
end
|
@@ -1,42 +0,0 @@
|
|
1
|
-
require 'rubygems'
|
2
|
-
|
3
|
-
$LOAD_PATH.unshift("xampl_generated_code")
|
4
|
-
|
5
|
-
require 'TokyoCabinetExperimental'
|
6
|
-
|
7
|
-
Xampl.set_default_persister_kind(:tokyo_cabinet)
|
8
|
-
Xampl.set_default_persister_format(:xml_format)
|
9
|
-
|
10
|
-
module TokyoCabinetExperimental
|
11
|
-
|
12
|
-
start = Time.now
|
13
|
-
found = Xampl.transaction("setup") do
|
14
|
-
@@persister.query do | q |
|
15
|
-
q.add_condition('age', :numle, '50')
|
16
|
-
q.order_by('name', :strasc)
|
17
|
-
end
|
18
|
-
end
|
19
|
-
query_done = Time.now
|
20
|
-
|
21
|
-
total = 0
|
22
|
-
found.each do | person_meta |
|
23
|
-
total += person_meta['age'].to_i
|
24
|
-
end
|
25
|
-
|
26
|
-
meta_done = Time.now
|
27
|
-
|
28
|
-
total1 = 0
|
29
|
-
found.each do | person_meta |
|
30
|
-
total1 += person_meta['xampl'].age.to_i
|
31
|
-
end
|
32
|
-
|
33
|
-
done = Time.now
|
34
|
-
|
35
|
-
found.each do | person_meta |
|
36
|
-
puts "name: #{ person_meta['name']}"
|
37
|
-
end
|
38
|
-
puts "found: #{ found.size }"
|
39
|
-
puts "Total age: #{ total }, #{ total1 }"
|
40
|
-
puts "done: #{ done - start }:: #{ query_done - start } + #{ meta_done - query_done } + #{ done - meta_done }"
|
41
|
-
|
42
|
-
end
|
@@ -1,41 +0,0 @@
|
|
1
|
-
require 'rubygems'
|
2
|
-
|
3
|
-
$LOAD_PATH.unshift("xampl_generated_code")
|
4
|
-
|
5
|
-
require 'TokyoCabinetExperimental'
|
6
|
-
|
7
|
-
Xampl.set_default_persister_kind(:tokyo_cabinet)
|
8
|
-
Xampl.set_default_persister_format(:xml_format)
|
9
|
-
|
10
|
-
module TokyoCabinetExperimental
|
11
|
-
|
12
|
-
start = Time.now
|
13
|
-
found = Xampl.transaction("setup") do
|
14
|
-
@@persister.query do | q |
|
15
|
-
q.add_condition('age', :numle, '50')
|
16
|
-
end
|
17
|
-
end
|
18
|
-
query_done = Time.now
|
19
|
-
|
20
|
-
total = 0
|
21
|
-
found.each do | person_meta |
|
22
|
-
total += person_meta['age'].to_i
|
23
|
-
end
|
24
|
-
|
25
|
-
meta_done = Time.now
|
26
|
-
|
27
|
-
total1 = 0
|
28
|
-
found.each do | person_meta |
|
29
|
-
total1 += person_meta['xampl'].age.to_i
|
30
|
-
end
|
31
|
-
|
32
|
-
done = Time.now
|
33
|
-
|
34
|
-
found.each do | person_meta |
|
35
|
-
puts "name: #{ person_meta['name']}"
|
36
|
-
end
|
37
|
-
puts "found: #{ found.size }"
|
38
|
-
puts "Total age: #{ total }, #{ total1 }"
|
39
|
-
puts "done: #{ done - start }:: #{ query_done - start } + #{ meta_done - query_done } + #{ done - meta_done }"
|
40
|
-
|
41
|
-
end
|
@@ -1,32 +0,0 @@
|
|
1
|
-
require 'rubygems'
|
2
|
-
|
3
|
-
$LOAD_PATH.unshift("xampl_generated_code")
|
4
|
-
|
5
|
-
require 'TokyoCabinetExperimental'
|
6
|
-
|
7
|
-
Xampl.set_default_persister_kind(:tokyo_cabinet)
|
8
|
-
Xampl.set_default_persister_format(:xml_format)
|
9
|
-
|
10
|
-
module TokyoCabinetExperimental
|
11
|
-
|
12
|
-
start = Time.now
|
13
|
-
people = nil
|
14
|
-
|
15
|
-
Xampl.transaction("setup") do
|
16
|
-
people = People['people']
|
17
|
-
end
|
18
|
-
|
19
|
-
loop_start = Time.now
|
20
|
-
|
21
|
-
total = 0
|
22
|
-
people.person.each do | person |
|
23
|
-
age = person.age.to_i
|
24
|
-
total += age
|
25
|
-
end
|
26
|
-
|
27
|
-
done = Time.now
|
28
|
-
|
29
|
-
puts "Total age: #{ total }"
|
30
|
-
puts "done: #{ done - start }:: #{ loop_start - start} + #{ done - loop_start}"
|
31
|
-
|
32
|
-
end
|
@@ -1,61 +0,0 @@
|
|
1
|
-
require 'rubygems'
|
2
|
-
|
3
|
-
$LOAD_PATH.unshift("xampl_generated_code")
|
4
|
-
|
5
|
-
require 'TokyoCabinetExperimental'
|
6
|
-
|
7
|
-
Xampl.set_default_persister_kind(:tokyo_cabinet)
|
8
|
-
Xampl.set_default_persister_format(:xml_format)
|
9
|
-
|
10
|
-
module TokyoCabinetExperimental
|
11
|
-
|
12
|
-
class Person
|
13
|
-
def describe_yourself
|
14
|
-
{
|
15
|
-
'name' => self.name,
|
16
|
-
'age' => self.age
|
17
|
-
}
|
18
|
-
end
|
19
|
-
end
|
20
|
-
|
21
|
-
people = nil
|
22
|
-
n = 1000
|
23
|
-
|
24
|
-
start = Time.now
|
25
|
-
Xampl.transaction("setup") do
|
26
|
-
people = People.new('people')
|
27
|
-
jack = people.ensure_person('jack')
|
28
|
-
jack.age = '0'
|
29
|
-
jack.name = 'jack'
|
30
|
-
jill = people.ensure_person('jill')
|
31
|
-
jill.age = '0'
|
32
|
-
jill.name = 'jill'
|
33
|
-
|
34
|
-
(1..n).each do | i |
|
35
|
-
person = people.ensure_person("person-#{i}")
|
36
|
-
person.age = i.to_s
|
37
|
-
person.name = "person-#{ i }"
|
38
|
-
end
|
39
|
-
end
|
40
|
-
|
41
|
-
start_search = Time.now
|
42
|
-
|
43
|
-
found = Xampl.transaction("setup") do
|
44
|
-
puts ">>>>>> #{@@persister.class.name}"
|
45
|
-
@@persister.query do | q |
|
46
|
-
puts ">>>> #{ q.class.name }"
|
47
|
-
q.add_condition('age', :numle, '50')
|
48
|
-
q.order_by('age', :numasc)
|
49
|
-
end
|
50
|
-
end
|
51
|
-
|
52
|
-
# found.each do | person |
|
53
|
-
# puts "person(#{person[:pk]}):: age: #{person['age']}"
|
54
|
-
# end
|
55
|
-
|
56
|
-
done = Time.now
|
57
|
-
puts "done: #{ done - start }:: construct in: #{ start_search - start}, search in: #{ done - start_search} (#{ found.size } results)"
|
58
|
-
puts "added: #{ n }, found: #{ found.size }"
|
59
|
-
|
60
|
-
# puts people.pp_xml
|
61
|
-
end
|
@@ -1,38 +0,0 @@
|
|
1
|
-
#!/usr/bin/env ruby -w -I..
|
2
|
-
|
3
|
-
if $0 == __FILE__ then
|
4
|
-
|
5
|
-
class File
|
6
|
-
def File.sjoin(*args)
|
7
|
-
File.join(args.select{ | o | o })
|
8
|
-
end
|
9
|
-
end
|
10
|
-
|
11
|
-
$LOAD_PATH.unshift('../../lib/')
|
12
|
-
|
13
|
-
require 'xamplr-generator'
|
14
|
-
|
15
|
-
include XamplGenerator
|
16
|
-
include Xampl
|
17
|
-
|
18
|
-
Xampl.transaction("setup", :in_memory) do
|
19
|
-
directory = File.sjoin(".", "xampl_generated_code")
|
20
|
-
|
21
|
-
options = Xampl.make(Options) do |options|
|
22
|
-
options.new_index_attribute("pid").persisted = true
|
23
|
-
options.new_index_attribute("id")
|
24
|
-
|
25
|
-
options.resolve("http://xampl.com/tcx", "TokyoCabinetExperimental", "tcx")
|
26
|
-
end
|
27
|
-
|
28
|
-
filenames = Dir.glob("./xml/**/*.xml")
|
29
|
-
|
30
|
-
generator = Generator.new
|
31
|
-
generator.go(:options => options,
|
32
|
-
:filenames => filenames,
|
33
|
-
:directory => directory)
|
34
|
-
|
35
|
-
#puts generator.print_elements("./generated-elements.xml")
|
36
|
-
exit!
|
37
|
-
end
|
38
|
-
end
|
@@ -1,33 +0,0 @@
|
|
1
|
-
time puts: 0.004565
|
2
|
-
time puts: 0.001416
|
3
|
-
time puts: 0.001879
|
4
|
-
time puts: 0.000844
|
5
|
-
time puts: 0.000763
|
6
|
-
time puts: 0.000973
|
7
|
-
time puts: 0.000936
|
8
|
-
time puts: 0.000788
|
9
|
-
time puts: 0.000849
|
10
|
-
time puts: 0.000917
|
11
|
-
TOTAL: 0.033575
|
12
|
-
time sync write: 0.045199
|
13
|
-
time sync write: 0.149448
|
14
|
-
time sync write: 0.110496
|
15
|
-
time sync write: 0.121815
|
16
|
-
time sync write: 0.133079
|
17
|
-
time sync write: 0.122049
|
18
|
-
time sync write: 0.122168
|
19
|
-
time sync write: 0.132572
|
20
|
-
time sync write: 0.110322
|
21
|
-
time sync write: 0.133309
|
22
|
-
TOTAL: 1.188656
|
23
|
-
time write: 0.004363
|
24
|
-
time write: 0.000237
|
25
|
-
time write: 0.000394
|
26
|
-
time write: 0.000243
|
27
|
-
time write: 0.000378
|
28
|
-
time write: 0.000506
|
29
|
-
time write: 0.000242
|
30
|
-
time write: 0.000377
|
31
|
-
time write: 0.000743
|
32
|
-
time write: 0.000599
|
33
|
-
TOTAL: 0.009168
|
@@ -1,33 +0,0 @@
|
|
1
|
-
time print: 9.2e-05
|
2
|
-
time print: 6.0e-05
|
3
|
-
time print: 5.3e-05
|
4
|
-
time print: 5.4e-05
|
5
|
-
time print: 5.8e-05
|
6
|
-
time print: 5.4e-05
|
7
|
-
time print: 5.3e-05
|
8
|
-
time print: 6.1e-05
|
9
|
-
time print: 5.4e-05
|
10
|
-
time print: 5.2e-05
|
11
|
-
TOTAL: 0.00077
|
12
|
-
time sync write: 0.002917
|
13
|
-
time sync write: 0.00076
|
14
|
-
time sync write: 0.00077
|
15
|
-
time sync write: 0.001231
|
16
|
-
time sync write: 0.000767
|
17
|
-
time sync write: 0.000771
|
18
|
-
time sync write: 0.000768
|
19
|
-
time sync write: 0.000773
|
20
|
-
time sync write: 0.000782
|
21
|
-
time sync write: 0.000761
|
22
|
-
TOTAL: 0.010476
|
23
|
-
time write: 7.9e-05
|
24
|
-
time write: 6.9e-05
|
25
|
-
time write: 7.5e-05
|
26
|
-
time write: 7.6e-05
|
27
|
-
time write: 5.2e-05
|
28
|
-
time write: 5.2e-05
|
29
|
-
time write: 5.2e-05
|
30
|
-
time write: 5.2e-05
|
31
|
-
time write: 5.5e-05
|
32
|
-
time write: 5.3e-05
|
33
|
-
TOTAL: 0.000767
|
@@ -1,40 +0,0 @@
|
|
1
|
-
|
2
|
-
is_darwin = RUBY_PLATFORM.include? 'darwin'
|
3
|
-
|
4
|
-
#output = (1..1000000).to_a.inspect
|
5
|
-
output = (1..1000).to_a.inspect
|
6
|
-
|
7
|
-
file_name = "./junk.out"
|
8
|
-
|
9
|
-
ss = Time.now
|
10
|
-
10.times do | i |
|
11
|
-
s = Time.now
|
12
|
-
File.open("./junk-a-#{ i }.out", 'w') { | f | f.print output; f.fsync }
|
13
|
-
puts "time puts: #{ Time.now - s }"
|
14
|
-
end
|
15
|
-
|
16
|
-
puts "TOTAL: #{ Time.now - ss}\n"
|
17
|
-
|
18
|
-
ss = Time.now
|
19
|
-
10.times do | i |
|
20
|
-
s = Time.now
|
21
|
-
File.open("./junk-b-#{ i }.out", 'w') do | f |
|
22
|
-
f.write output
|
23
|
-
f.fsync
|
24
|
-
if is_darwin then
|
25
|
-
f.fcntl(51, 0) # Attempt an F_FULLFSYNC fcntl to commit data to disk
|
26
|
-
end
|
27
|
-
end
|
28
|
-
puts "time sync write: #{ Time.now - s }"
|
29
|
-
end
|
30
|
-
|
31
|
-
puts "TOTAL: #{ Time.now - ss}\n"
|
32
|
-
|
33
|
-
ss = Time.now
|
34
|
-
10.times do | i |
|
35
|
-
s = Time.now
|
36
|
-
File.open("./junk-b-#{ i }.out", 'w') { | f | f.write output }
|
37
|
-
puts "time write: #{ Time.now - s }"
|
38
|
-
end
|
39
|
-
|
40
|
-
puts "TOTAL: #{ Time.now - ss}\n"
|
data/lib/xampl-generator.rb
DELETED