knjrbfw 0.0.90 → 0.0.91
Sign up to get free protection for your applications and to get access to all the features.
- data/VERSION +1 -1
- data/knjrbfw.gemspec +2 -4
- data/lib/knj/gtk2_tv.rb +0 -3
- data/lib/knj/knj.rb +28 -0
- data/lib/knj/knjdb/drivers/mysql/knjdb_mysql.rb +1 -1
- data/lib/knj/knjdb/libknjdb.rb +3 -2
- metadata +3 -5
- data/lib/knj/retry.rb +0 -71
- data/lib/knj/tests/test_retry.rb +0 -30
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
0.0.
|
1
|
+
0.0.91
|
data/knjrbfw.gemspec
CHANGED
@@ -5,11 +5,11 @@
|
|
5
5
|
|
6
6
|
Gem::Specification.new do |s|
|
7
7
|
s.name = %q{knjrbfw}
|
8
|
-
s.version = "0.0.
|
8
|
+
s.version = "0.0.91"
|
9
9
|
|
10
10
|
s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
|
11
11
|
s.authors = ["Kasper Johansen"]
|
12
|
-
s.date = %q{2012-08-
|
12
|
+
s.date = %q{2012-08-30}
|
13
13
|
s.description = %q{Including stuff for HTTP, SSH and much more.}
|
14
14
|
s.email = %q{k@spernj.org}
|
15
15
|
s.extra_rdoc_files = [
|
@@ -208,7 +208,6 @@ Gem::Specification.new do |s|
|
|
208
208
|
"lib/knj/process.rb",
|
209
209
|
"lib/knj/process_meta.rb",
|
210
210
|
"lib/knj/rand.rb",
|
211
|
-
"lib/knj/retry.rb",
|
212
211
|
"lib/knj/rhodes/mutex.rb",
|
213
212
|
"lib/knj/rhodes/rhodes.js",
|
214
213
|
"lib/knj/rhodes/rhodes.rb",
|
@@ -236,7 +235,6 @@ Gem::Specification.new do |s|
|
|
236
235
|
"lib/knj/tests/test_http2.rb",
|
237
236
|
"lib/knj/tests/test_http2_proxy.rb",
|
238
237
|
"lib/knj/tests/test_mount.rb",
|
239
|
-
"lib/knj/tests/test_retry.rb",
|
240
238
|
"lib/knj/thread.rb",
|
241
239
|
"lib/knj/thread2.rb",
|
242
240
|
"lib/knj/threadhandler.rb",
|
data/lib/knj/gtk2_tv.rb
CHANGED
@@ -39,7 +39,6 @@ module Knj::Gtk2::Tv
|
|
39
39
|
end
|
40
40
|
|
41
41
|
tv.model = list_store
|
42
|
-
tv.reorderable = true
|
43
42
|
|
44
43
|
count = 0
|
45
44
|
columns.each do |args|
|
@@ -296,8 +295,6 @@ module Knj::Gtk2::Tv
|
|
296
295
|
value_i = 1
|
297
296
|
end
|
298
297
|
else
|
299
|
-
puts "Test: #{iter[col_no]}"
|
300
|
-
|
301
298
|
if iter[col_no] == 0
|
302
299
|
value = true
|
303
300
|
value_i = 1
|
data/lib/knj/knj.rb
CHANGED
@@ -44,4 +44,32 @@ module Knj
|
|
44
44
|
return Array_enumerator.new(args[:enum])
|
45
45
|
end
|
46
46
|
end
|
47
|
+
|
48
|
+
#Loads a gem by a given name. First tries to load the gem from a custom parent directory to enable loading of development-gems.
|
49
|
+
def self.gem_require(gem_const, gem_name)
|
50
|
+
#Return false if the constant is already loaded.
|
51
|
+
return false if ::Kernel.const_defined?(gem_const)
|
52
|
+
|
53
|
+
#Try to load gem from custom development-path.
|
54
|
+
found_custom = false
|
55
|
+
|
56
|
+
paths = [
|
57
|
+
"#{File.dirname(__FILE__)}/../../../#{gem_name}/lib/#{gem_name}.rb"
|
58
|
+
]
|
59
|
+
paths.each do |path|
|
60
|
+
if File.exists?(path)
|
61
|
+
require path
|
62
|
+
found_custom = true
|
63
|
+
break
|
64
|
+
end
|
65
|
+
end
|
66
|
+
|
67
|
+
#Custom-path could not be loaded - load gem normally.
|
68
|
+
if !found_custom
|
69
|
+
require gem_name
|
70
|
+
end
|
71
|
+
|
72
|
+
#Return true to enable detection of that something was loaded.
|
73
|
+
return true
|
74
|
+
end
|
47
75
|
end
|
@@ -144,7 +144,7 @@ class KnjDB_mysql
|
|
144
144
|
|
145
145
|
#Save reference to result and statement, so we can close them when they are garbage collected.
|
146
146
|
@java_rs_data[id] = {:res => res, :stmt => stmt}
|
147
|
-
ObjectSpace.define_finalizer(ret, self.method(
|
147
|
+
ObjectSpace.define_finalizer(ret, self.method(:java_mysql_resultset_killer))
|
148
148
|
|
149
149
|
return ret
|
150
150
|
rescue => e
|
data/lib/knj/knjdb/libknjdb.rb
CHANGED
@@ -16,9 +16,10 @@ require "datet" if !Kernel.const_defined?(:Datet)
|
|
16
16
|
# print data[:name]
|
17
17
|
# end
|
18
18
|
class Knj::Db
|
19
|
-
#Autoloader
|
19
|
+
#Autoloader for subclasses..
|
20
20
|
def self.const_missing(name)
|
21
|
-
require "#{$knjpath}knjdb/#{name.to_s.downcase}"
|
21
|
+
require "#{$knjpath}knjdb/#{name.to_s.downcase}.rb"
|
22
|
+
raise "Still not defined: '#{name}'." if !Knj::Db.const_defined?(name)
|
22
23
|
return Knj::Db.const_get(name)
|
23
24
|
end
|
24
25
|
|
metadata
CHANGED
@@ -2,7 +2,7 @@
|
|
2
2
|
name: knjrbfw
|
3
3
|
version: !ruby/object:Gem::Version
|
4
4
|
prerelease:
|
5
|
-
version: 0.0.
|
5
|
+
version: 0.0.91
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
8
8
|
- Kasper Johansen
|
@@ -10,7 +10,7 @@ autorequire:
|
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
12
|
|
13
|
-
date: 2012-08-
|
13
|
+
date: 2012-08-30 00:00:00 +02:00
|
14
14
|
default_executable:
|
15
15
|
dependencies:
|
16
16
|
- !ruby/object:Gem::Dependency
|
@@ -324,7 +324,6 @@ files:
|
|
324
324
|
- lib/knj/process.rb
|
325
325
|
- lib/knj/process_meta.rb
|
326
326
|
- lib/knj/rand.rb
|
327
|
-
- lib/knj/retry.rb
|
328
327
|
- lib/knj/rhodes/mutex.rb
|
329
328
|
- lib/knj/rhodes/rhodes.js
|
330
329
|
- lib/knj/rhodes/rhodes.rb
|
@@ -352,7 +351,6 @@ files:
|
|
352
351
|
- lib/knj/tests/test_http2.rb
|
353
352
|
- lib/knj/tests/test_http2_proxy.rb
|
354
353
|
- lib/knj/tests/test_mount.rb
|
355
|
-
- lib/knj/tests/test_retry.rb
|
356
354
|
- lib/knj/thread.rb
|
357
355
|
- lib/knj/thread2.rb
|
358
356
|
- lib/knj/threadhandler.rb
|
@@ -394,7 +392,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
394
392
|
requirements:
|
395
393
|
- - ">="
|
396
394
|
- !ruby/object:Gem::Version
|
397
|
-
hash:
|
395
|
+
hash: -1209507472905610326
|
398
396
|
segments:
|
399
397
|
- 0
|
400
398
|
version: "0"
|
data/lib/knj/retry.rb
DELETED
@@ -1,71 +0,0 @@
|
|
1
|
-
class Knj::Retry
|
2
|
-
def self.try(args = {}, &block)
|
3
|
-
raise "No block was given." if !block_given?
|
4
|
-
|
5
|
-
args[:tries] = 3 if !args[:tries]
|
6
|
-
tries = []
|
7
|
-
error = nil
|
8
|
-
|
9
|
-
args[:tries].to_i.downto(1) do |count|
|
10
|
-
error = nil
|
11
|
-
dobreak = false
|
12
|
-
|
13
|
-
begin
|
14
|
-
if args[:timeout]
|
15
|
-
begin
|
16
|
-
Timeout.timeout(args[:timeout]) do
|
17
|
-
block.call
|
18
|
-
dobreak = true
|
19
|
-
break
|
20
|
-
end
|
21
|
-
rescue Timeout::Error => e
|
22
|
-
doraise = e if count <= 1
|
23
|
-
error = e
|
24
|
-
sleep(args[:wait]) if args[:wait] and !doraise
|
25
|
-
end
|
26
|
-
else
|
27
|
-
block.call
|
28
|
-
dobreak = true
|
29
|
-
break
|
30
|
-
end
|
31
|
-
rescue Exception => e
|
32
|
-
if e.class == Interrupt
|
33
|
-
raise e if !args.key?(:interrupt) or args[:interrupt]
|
34
|
-
elsif e.class == SystemExit
|
35
|
-
raise e if !args.key?(:exit) or args[:exit]
|
36
|
-
elsif count <= 1 or (args.key?(:errors) and args[:errors].index(e.class) == nil)
|
37
|
-
doraise = e
|
38
|
-
elsif args.key?(:errors) and args[:errors].index(e.class) != nil
|
39
|
-
#given error was in the :errors-array - do nothing. Maybe later it should be logged and returned in a stats-hash or something? - knj
|
40
|
-
end
|
41
|
-
|
42
|
-
error = e
|
43
|
-
sleep(args[:wait]) if args[:wait] and !doraise
|
44
|
-
end
|
45
|
-
|
46
|
-
if doraise
|
47
|
-
if args[:return_error]
|
48
|
-
tries << {:error => error}
|
49
|
-
return {
|
50
|
-
:tries => tries,
|
51
|
-
:result => false
|
52
|
-
}
|
53
|
-
else
|
54
|
-
raise e
|
55
|
-
end
|
56
|
-
elsif error
|
57
|
-
tries << {:error => error}
|
58
|
-
end
|
59
|
-
|
60
|
-
break if dobreak
|
61
|
-
end
|
62
|
-
|
63
|
-
res = true
|
64
|
-
res = false if error
|
65
|
-
|
66
|
-
return {
|
67
|
-
:tries => tries,
|
68
|
-
:result => res
|
69
|
-
}
|
70
|
-
end
|
71
|
-
end
|
data/lib/knj/tests/test_retry.rb
DELETED
@@ -1,30 +0,0 @@
|
|
1
|
-
#!/usr/bin/env ruby
|
2
|
-
|
3
|
-
Dir.chdir(File.dirname(__FILE__))
|
4
|
-
require "../autoload"
|
5
|
-
|
6
|
-
count = 0
|
7
|
-
result = Knj::Retry.try(
|
8
|
-
:exit => false,
|
9
|
-
:interrupt => true,
|
10
|
-
:errors => [Errno::ENOENT, RuntimeError],
|
11
|
-
:timeout => 1,
|
12
|
-
:tries => 3,
|
13
|
-
:return_error => true
|
14
|
-
) do
|
15
|
-
count += 1
|
16
|
-
print "Count: #{count.to_s}\n"
|
17
|
-
|
18
|
-
if count <= 2
|
19
|
-
exit
|
20
|
-
end
|
21
|
-
|
22
|
-
if count <= 3
|
23
|
-
|
24
|
-
#raise "Test"
|
25
|
-
end
|
26
|
-
end
|
27
|
-
|
28
|
-
#print "Error 1 was a #{result[0][:error].class.to_s} with the message: #{result[0][:error].message.to_s}\n"
|
29
|
-
|
30
|
-
Php4r.print_r(result)
|