knjrbfw 0.0.8 → 0.0.9

Sign up to get free protection for your applications and to get access to all the features.
Files changed (211) hide show
  1. data/VERSION +1 -1
  2. data/knjrbfw.gemspec +29 -8
  3. data/lib/knj/arrayext.rb +206 -153
  4. data/lib/knj/autoload/backups/ping.rb +2 -2
  5. data/lib/knj/autoload/erubis.rb +3 -3
  6. data/lib/knj/autoload/facets_dictionary.rb +2 -2
  7. data/lib/knj/autoload/gettext.rb +3 -3
  8. data/lib/knj/autoload/gtk2.rb +1 -1
  9. data/lib/knj/autoload/json.rb +14 -0
  10. data/lib/knj/autoload/magick.rb +3 -3
  11. data/lib/knj/autoload/mysql.rb +3 -3
  12. data/lib/knj/autoload/parsedate.rb +1 -1
  13. data/lib/knj/autoload/ping.rb +2 -2
  14. data/lib/knj/autoload/rexml.rb +5 -5
  15. data/lib/knj/autoload/soap.rb +1 -1
  16. data/lib/knj/autoload/sqlite3.rb +3 -3
  17. data/lib/knj/autoload/tmail.rb +3 -3
  18. data/lib/knj/autoload/xmlsimple.rb +3 -3
  19. data/lib/knj/autoload/zip.rb +3 -3
  20. data/lib/knj/autoload.rb +87 -81
  21. data/lib/knj/cmd_gen.rb +19 -19
  22. data/lib/knj/cmd_parser.rb +59 -0
  23. data/lib/knj/compiler.rb +34 -34
  24. data/lib/knj/cpufreq.rb +37 -37
  25. data/lib/knj/csv.rb +20 -0
  26. data/lib/knj/datarow.rb +406 -239
  27. data/lib/knj/datarow_custom.rb +124 -0
  28. data/lib/knj/datestamp.rb +89 -89
  29. data/lib/knj/datet.rb +550 -454
  30. data/lib/knj/db.rb +1 -0
  31. data/lib/knj/degulesider.rb +42 -44
  32. data/lib/knj/erb/erb.rb +5 -5
  33. data/lib/knj/erb/erb_cache_clean.rb +10 -10
  34. data/lib/knj/erb/erb_fcgi.rb +32 -32
  35. data/lib/knj/erb/erb_fcgi_1.9.rb +32 -32
  36. data/lib/knj/erb/erb_fcgi_jruby.rb +2 -2
  37. data/lib/knj/erb/erb_jruby.rb +5 -5
  38. data/lib/knj/erb/include.rb +243 -243
  39. data/lib/knj/errors.rb +19 -18
  40. data/lib/knj/eruby.rb +12 -10
  41. data/lib/knj/event_filemod.rb +31 -31
  42. data/lib/knj/event_handler.rb +73 -67
  43. data/lib/knj/exchangerates.rb +37 -37
  44. data/lib/knj/facebook_connect.rb +95 -18
  45. data/lib/knj/filesystem.rb +6 -6
  46. data/lib/knj/fs/drivers/filesystem.rb +12 -12
  47. data/lib/knj/fs/drivers/ftp.rb +31 -31
  48. data/lib/knj/fs/drivers/ssh.rb +26 -26
  49. data/lib/knj/fs/fs.rb +31 -31
  50. data/lib/knj/gettext_fallback.rb +15 -15
  51. data/lib/knj/gettext_threadded.rb +75 -75
  52. data/lib/knj/google_sitemap.rb +53 -53
  53. data/lib/knj/gtk2.rb +272 -272
  54. data/lib/knj/gtk2_cb.rb +80 -80
  55. data/lib/knj/gtk2_menu.rb +55 -55
  56. data/lib/knj/gtk2_statuswindow.rb +62 -62
  57. data/lib/knj/gtk2_tv.rb +58 -58
  58. data/lib/knj/hash_methods.rb +27 -36
  59. data/lib/knj/http.rb +189 -167
  60. data/lib/knj/http2.rb +259 -53
  61. data/lib/knj/image.rb +2 -2
  62. data/lib/knj/includes/appserver_cli.rb +18 -18
  63. data/lib/knj/includes/require_info.rb +15 -0
  64. data/lib/knj/ip2location.rb +20 -20
  65. data/lib/knj/ironruby-gtk2/button.rb +14 -14
  66. data/lib/knj/ironruby-gtk2/dialog.rb +42 -42
  67. data/lib/knj/ironruby-gtk2/entry.rb +4 -4
  68. data/lib/knj/ironruby-gtk2/gdk_event.rb +1 -1
  69. data/lib/knj/ironruby-gtk2/gdk_eventbutton.rb +11 -11
  70. data/lib/knj/ironruby-gtk2/gdk_pixbuf.rb +9 -9
  71. data/lib/knj/ironruby-gtk2/gladexml.rb +102 -102
  72. data/lib/knj/ironruby-gtk2/glib.rb +13 -13
  73. data/lib/knj/ironruby-gtk2/gtk2.rb +121 -121
  74. data/lib/knj/ironruby-gtk2/gtk_builder.rb +29 -29
  75. data/lib/knj/ironruby-gtk2/gtk_cellrenderertext.rb +3 -3
  76. data/lib/knj/ironruby-gtk2/gtk_combobox.rb +17 -17
  77. data/lib/knj/ironruby-gtk2/gtk_filechooserbutton.rb +3 -3
  78. data/lib/knj/ironruby-gtk2/gtk_liststore.rb +16 -16
  79. data/lib/knj/ironruby-gtk2/gtk_menu.rb +3 -3
  80. data/lib/knj/ironruby-gtk2/gtk_menuitem.rb +2 -2
  81. data/lib/knj/ironruby-gtk2/gtk_statusicon.rb +3 -3
  82. data/lib/knj/ironruby-gtk2/gtk_treeiter.rb +22 -22
  83. data/lib/knj/ironruby-gtk2/gtk_treeselection.rb +11 -11
  84. data/lib/knj/ironruby-gtk2/gtk_treeview.rb +17 -17
  85. data/lib/knj/ironruby-gtk2/gtk_treeviewcolumn.rb +30 -30
  86. data/lib/knj/ironruby-gtk2/iconsize.rb +1 -1
  87. data/lib/knj/ironruby-gtk2/image.rb +13 -13
  88. data/lib/knj/ironruby-gtk2/label.rb +17 -17
  89. data/lib/knj/ironruby-gtk2/stock.rb +2 -2
  90. data/lib/knj/ironruby-gtk2/tests/test_2.rb +14 -14
  91. data/lib/knj/ironruby-gtk2/tests/test_ironruby_window.rb +37 -37
  92. data/lib/knj/ironruby-gtk2/vbox.rb +3 -3
  93. data/lib/knj/ironruby-gtk2/window.rb +18 -18
  94. data/lib/knj/jruby-gtk2/builder/test_builder.rb +11 -11
  95. data/lib/knj/jruby-gtk2/builder.rb +25 -25
  96. data/lib/knj/jruby-gtk2/cellrenderertext.rb +10 -10
  97. data/lib/knj/jruby-gtk2/checkbutton.rb +1 -1
  98. data/lib/knj/jruby-gtk2/combobox.rb +27 -27
  99. data/lib/knj/jruby-gtk2/dialog.rb +40 -40
  100. data/lib/knj/jruby-gtk2/eventbutton.rb +19 -19
  101. data/lib/knj/jruby-gtk2/gladexml.rb +97 -97
  102. data/lib/knj/jruby-gtk2/gtk2.rb +203 -203
  103. data/lib/knj/jruby-gtk2/hbox.rb +8 -8
  104. data/lib/knj/jruby-gtk2/iconsize.rb +3 -3
  105. data/lib/knj/jruby-gtk2/image.rb +8 -8
  106. data/lib/knj/jruby-gtk2/liststore.rb +54 -54
  107. data/lib/knj/jruby-gtk2/menu.rb +35 -35
  108. data/lib/knj/jruby-gtk2/progressbar.rb +10 -10
  109. data/lib/knj/jruby-gtk2/statusicon.rb +3 -3
  110. data/lib/knj/jruby-gtk2/stock.rb +6 -6
  111. data/lib/knj/jruby-gtk2/tests/test_glade_window.rb +36 -36
  112. data/lib/knj/jruby-gtk2/tests/test_normal_window.rb +3 -3
  113. data/lib/knj/jruby-gtk2/tests/test_trayicon.rb +2 -2
  114. data/lib/knj/jruby-gtk2/treeview.rb +88 -88
  115. data/lib/knj/jruby-gtk2/vbox.rb +10 -10
  116. data/lib/knj/jruby-gtk2/window.rb +7 -7
  117. data/lib/knj/jruby_compiler.rb +12 -12
  118. data/lib/knj/knj.rb +12 -11
  119. data/lib/knj/knj_controller.rb +13 -8
  120. data/lib/knj/knjdb/drivers/mysql/knjdb_mysql.rb +499 -316
  121. data/lib/knj/knjdb/drivers/mysql/knjdb_mysql_columns.rb +127 -125
  122. data/lib/knj/knjdb/drivers/mysql/knjdb_mysql_indexes.rb +43 -25
  123. data/lib/knj/knjdb/drivers/mysql/knjdb_mysql_tables.rb +316 -241
  124. data/lib/knj/knjdb/drivers/sqlite3/knjdb_sqlite3.rb +12 -0
  125. data/lib/knj/knjdb/drivers/sqlite3/knjdb_sqlite3_columns.rb +146 -146
  126. data/lib/knj/knjdb/drivers/sqlite3/knjdb_sqlite3_indexes.rb +24 -24
  127. data/lib/knj/knjdb/drivers/sqlite3/knjdb_sqlite3_tables.rb +283 -283
  128. data/lib/knj/knjdb/libknjdb.rb +96 -52
  129. data/lib/knj/knjdb/libknjdb_java_sqlite3.rb +78 -78
  130. data/lib/knj/knjdb/libknjdb_row.rb +147 -147
  131. data/lib/knj/knjdb/libknjdb_sqlite3_ironruby.rb +61 -61
  132. data/lib/knj/knjdb/revision.rb +262 -0
  133. data/lib/knj/libqt.rb +69 -69
  134. data/lib/knj/libqt_window.rb +8 -8
  135. data/lib/knj/locales.rb +62 -52
  136. data/lib/knj/maemo/fremantle-calendar/fremantle-calendar.rb +54 -54
  137. data/lib/knj/mail.rb +73 -73
  138. data/lib/knj/mailobj.rb +82 -80
  139. data/lib/knj/mount.rb +113 -113
  140. data/lib/knj/notify.rb +11 -11
  141. data/lib/knj/nvidia_settings.rb +43 -43
  142. data/lib/knj/objects/objects_sqlhelper.rb +474 -0
  143. data/lib/knj/objects.rb +569 -793
  144. data/lib/knj/opts.rb +38 -38
  145. data/lib/knj/os.rb +176 -158
  146. data/lib/knj/php.rb +853 -683
  147. data/lib/knj/php_parser/arguments.rb +3 -3
  148. data/lib/knj/php_parser/functions.rb +95 -95
  149. data/lib/knj/php_parser/php_parser.rb +16 -16
  150. data/lib/knj/php_parser/tests/test.rb +6 -6
  151. data/lib/knj/php_parser/tests/test_function_run.rb +6 -6
  152. data/lib/knj/power_manager.rb +29 -29
  153. data/lib/knj/process.rb +457 -0
  154. data/lib/knj/process_meta.rb +400 -0
  155. data/lib/knj/rand.rb +8 -8
  156. data/lib/knj/retry.rb +69 -69
  157. data/lib/knj/rhodes/delegate.rb +414 -0
  158. data/lib/knj/rhodes/rhodes.rb +114 -40
  159. data/lib/knj/rhodes/weakref.rb +80 -0
  160. data/lib/knj/rsvgbin.rb +18 -18
  161. data/lib/knj/scripts/degulesider.rb +2 -2
  162. data/lib/knj/scripts/filesearch.rb +35 -35
  163. data/lib/knj/scripts/ip2location.rb +2 -2
  164. data/lib/knj/scripts/keepalive.rb +2 -2
  165. data/lib/knj/scripts/php_to_rb_helper.rb +376 -0
  166. data/lib/knj/scripts/process_meta_exec.rb +104 -0
  167. data/lib/knj/scripts/svn_merge.rb +21 -21
  168. data/lib/knj/scripts/upgrade_knjrbfw_checker.rb +26 -26
  169. data/lib/knj/sms.rb +52 -52
  170. data/lib/knj/sshrobot/sshrobot.rb +90 -88
  171. data/lib/knj/sshrobot.rb +1 -0
  172. data/lib/knj/strings.rb +186 -74
  173. data/lib/knj/sysuser.rb +25 -25
  174. data/lib/knj/table_writer.rb +97 -0
  175. data/lib/knj/tests/compiler/compiler_test.rb +2 -2
  176. data/lib/knj/tests/test_degulesider.rb +1 -1
  177. data/lib/knj/tests/test_http2_proxy.rb +26 -0
  178. data/lib/knj/tests/test_mount.rb +9 -9
  179. data/lib/knj/tests/test_retry.rb +17 -17
  180. data/lib/knj/thread.rb +23 -24
  181. data/lib/knj/thread2.rb +45 -45
  182. data/lib/knj/threadhandler.rb +135 -102
  183. data/lib/knj/threadpool.rb +195 -145
  184. data/lib/knj/translations.rb +128 -119
  185. data/lib/knj/unix_proc.rb +80 -80
  186. data/lib/knj/web.rb +947 -881
  187. data/lib/knj/webscripts/image.rhtml +142 -67
  188. data/lib/knj/win.rb +2 -2
  189. data/lib/knj/win_registry.rb +58 -58
  190. data/lib/knj/win_tightvnc.rb +125 -125
  191. data/lib/knj/wref.rb +104 -0
  192. data/lib/knj/x11vnc.rb +46 -46
  193. data/lib/knj/youtube.rb +33 -36
  194. data/lib/knjrbfw.rb +1 -0
  195. data/spec/cmd_parser_spec.rb +25 -0
  196. data/spec/db_spec.rb +40 -0
  197. data/spec/db_spec_encoding_test_file.txt +1 -0
  198. data/spec/http2_spec.rb +37 -0
  199. data/spec/knjrbfw_spec.rb +17 -15
  200. data/spec/php_spec.rb +69 -0
  201. data/spec/process_meta_spec.rb +150 -0
  202. data/spec/process_spec.rb +107 -0
  203. data/spec/strings_spec.rb +21 -0
  204. data/spec/web_spec.rb +16 -0
  205. metadata +42 -21
  206. data/lib/knj/autoload/json_autoload.rb +0 -7
  207. data/lib/knj/autoload/twitter.rb +0 -2
  208. data/lib/knj/ext/webrick.rb +0 -31
  209. data/lib/knj/jruby-gtk2/gtk-4.0.jar +0 -0
  210. data/lib/knj/knjdb/mysql-connector-java-5.1.13-bin.jar +0 -0
  211. data/lib/knj/knjdb/sqlitejdbc-v056.jar +0 -0
@@ -0,0 +1,262 @@
1
+ class Knj::Db::Revision
2
+ def initialize(args = {})
3
+ @args = args
4
+ end
5
+
6
+ #This method checks if certain rows are present in a table based on a hash.
7
+ def rows_init(args)
8
+ table = args["table"]
9
+
10
+ args["rows"].each do |row_data|
11
+ if row_data["find_by"]
12
+ find_by = row_data["find_by"]
13
+ elsif row_data["data"]
14
+ find_by = row_data["data"]
15
+ else
16
+ raise "Could not figure out the find-by."
17
+ end
18
+
19
+ rows_found = 0
20
+ @db.select(table.name, find_by) do |d_rows|
21
+ rows_found += 1
22
+
23
+ if Knj::ArrayExt.hash_diff?(Knj::ArrayExt.hash_sym(row_data["data"]), Knj::ArrayExt.hash_sym(d_rows), {"h2_to_h1" => false})
24
+ print "Data was not right - updating row: #{JSON.generate(row_data["data"])}\n" if args["debug"]
25
+ @db.update(table.name, row_data["data"], d_rows)
26
+ end
27
+ end
28
+
29
+ if rows_found == 0
30
+ print "Inserting row: #{JSON.generate(row_data["data"])}\n" if args["debug"]
31
+ table.insert(row_data["data"])
32
+ end
33
+ end
34
+ end
35
+
36
+ #This initializes a database-structure and content based on a schema-hash.
37
+ def init_db(args)
38
+ schema = args["schema"]
39
+ db = args["db"]
40
+ @db = db
41
+
42
+ #Check for normal bugs and raise apropiate error.
43
+ raise "'schema' argument was not a Hash." if !schema.is_a?(Hash)
44
+ raise "':return_keys' is not 'symbols' - Knjdbrevision will not work without it." if db.opts[:return_keys] != "symbols"
45
+ raise "No tables given." if !schema.has_key?("tables")
46
+
47
+ schema["tables"].each do |table_name, table_data|
48
+ begin
49
+ begin
50
+ table_obj = db.tables[table_name.to_sym]
51
+
52
+ if table_data["columns"]
53
+ first_col = true
54
+ table_data["columns"].each do |col_data|
55
+ begin
56
+ col_obj = table_obj.column(col_data["name"])
57
+ col_str = "#{table_name}.#{col_obj.name}"
58
+ type = col_data["type"].to_s
59
+ dochange = false
60
+
61
+ if !first_col and !col_data["after"]
62
+ #Try to find out the previous column - if so we can set "after" which makes the column being created in the right order as defined.
63
+ if !col_data.has_key?("after")
64
+ prev_no = table_data["columns"].index(col_data)
65
+ if prev_no != nil and prev_no != 0
66
+ prev_no = prev_no - 1
67
+ prev_col_data = table_data["columns"][prev_no]
68
+ col_data["after"] = prev_col_data["name"]
69
+ end
70
+ end
71
+
72
+ actual_after = nil
73
+ set_next = false
74
+ table_obj.columns do |col_iter|
75
+ if col_iter.name == col_obj.name
76
+ break
77
+ else
78
+ actual_after = col_iter.name
79
+ end
80
+ end
81
+
82
+ if actual_after != col_data["after"]
83
+ print "Changing '#{col_str}' after from '#{actual_after}' to '#{col_data["after"]}'.\n" if args["debug"]
84
+ dochange = true
85
+ end
86
+ end
87
+
88
+ #BUGFIX: When using SQLite3 the primary-column or a autoincr-column may never change type from int... This will break it!
89
+ if db.opts[:type] == "sqlite3" and col_obj.type.to_s == "int" and (col_data["primarykey"] or col_data["autoincr"]) and db.int_types.index(col_data["type"].to_s)
90
+ type = "int"
91
+ end
92
+
93
+ if type and col_obj.type.to_s != type
94
+ print "Type mismatch on #{col_str}: #{col_data["type"]}, #{col_obj.type}\n" if args["debug"]
95
+ dochange = true
96
+ end
97
+
98
+ if col_data.has_key?("maxlength") and col_obj.maxlength.to_s != col_data["maxlength"].to_s
99
+ print "Maxlength mismatch on #{col_str}: #{col_data["maxlength"]}, #{col_obj.maxlength}\n" if args["debug"]
100
+ dochange = true
101
+ end
102
+
103
+ if col_data.has_key?("null") and col_obj.null?.to_s != col_data["null"].to_s
104
+ print "Null mismatch on #{col_str}: #{col_data["null"]}, #{col_obj.null?}\n" if args["debug"]
105
+ dochange = true
106
+ end
107
+
108
+ if col_data.has_key?("default") and col_obj.default.to_s != col_data["default"].to_s
109
+ print "Default mismatch on #{col_str}: #{col_data["default"]}, #{col_obj.default}\n" if args["debug"]
110
+ dochange = true
111
+ end
112
+
113
+ if col_data.has_key?("comment") and col_obj.respond_to?(:comment) and col_obj.comment.to_s != col_data["comment"].to_s
114
+ print "Comment mismatch on #{col_str}: #{col_data["comment"]}, #{col_obj.comment}\n" if args["debug"]
115
+ dochange = true
116
+ end
117
+
118
+ if col_data.is_a?(Hash) and col_data["on_before_alter"]
119
+ callback_data = col_data["on_before_alter"].call("db" => db, "table" => table_obj, "col" => col_obj, "col_data" => col_data)
120
+ if callback_data and callback_data["action"]
121
+ if callback_data["action"] == "retry"
122
+ raise Knj::Errors::Retry
123
+ end
124
+ end
125
+ end
126
+
127
+ col_obj.change(col_data) if dochange
128
+ first_col = false
129
+ rescue Knj::Errors::NotFound => e
130
+ print "Column not found: #{table_obj.name}.#{col_data["name"]}.\n" if args["debug"]
131
+
132
+ if col_data.has_key?("renames")
133
+ rename_found = false
134
+ col_data["renames"].each do |col_name|
135
+ begin
136
+ col_rename = table_obj.column(col_name)
137
+ rescue Knj::Errors::NotFound => e
138
+ next
139
+ end
140
+
141
+ print "Rename #{table_obj.name}.#{col_name} to #{table_obj.name}.#{col_data["name"]}\n" if args["debug"]
142
+ if col_data.is_a?(Hash) and col_data["on_before_rename"]
143
+ col_data["on_before_rename"].call("db" => db, "table" => table_obj, "col" => col_rename, "col_data" => col_data)
144
+ end
145
+
146
+ col_rename.change(col_data)
147
+
148
+ if col_data.is_a?(Hash) and col_data["on_after_rename"]
149
+ col_data["on_after_rename"].call("db" => db, "table" => table_obj, "col" => col_rename, "col_data" => col_data)
150
+ end
151
+
152
+ rename_found = true
153
+ break
154
+ end
155
+
156
+ retry if rename_found
157
+ end
158
+
159
+ oncreated = col_data["on_created"]
160
+ col_data.delete("on_created") if col_data["oncreated"]
161
+ col_obj = table_obj.create_columns([col_data])
162
+ oncreated.call("db" => db, "table" => table_obj) if oncreated
163
+ end
164
+ end
165
+ end
166
+
167
+ if table_data["columns_remove"]
168
+ table_data["columns_remove"].each do |column_name, column_data|
169
+ begin
170
+ col_obj = table_obj.column(column_name)
171
+ rescue Knj::Errors::NotFound => e
172
+ next
173
+ end
174
+
175
+ column_data["callback"].call if column_data.is_a?(Hash) and column_data["callback"]
176
+ col_obj.drop
177
+ end
178
+ end
179
+
180
+ if table_data["indexes"]
181
+ table_data["indexes"].each do |index_data|
182
+ if index_data.is_a?(String)
183
+ index_data = {"name" => index_data, "columns" => [index_data]}
184
+ end
185
+
186
+ begin
187
+ index_obj = table_obj.index(index_data["name"])
188
+
189
+ rewrite_index = false
190
+ rewrite_index = true if index_data.key?("unique") and index_data["unique"] != index_obj.unique?
191
+
192
+ if rewrite_index
193
+ index_obj.drop
194
+ table_obj.create_indexes([index_data])
195
+ end
196
+ rescue Knj::Errors::NotFound => e
197
+ table_obj.create_indexes([index_data])
198
+ end
199
+ end
200
+ end
201
+
202
+ if table_data["indexes_remove"]
203
+ table_data["indexes_remove"].each do |index_name, index_data|
204
+ begin
205
+ index_obj = table_obj.index(index_name)
206
+ rescue Knj::Errors::NotFound => e
207
+ next
208
+ end
209
+
210
+ if index_data.is_a?(Hash) and index_data["callback"]
211
+ index_data["callback"].call if index_data["callback"]
212
+ end
213
+
214
+ index_obj.drop
215
+ end
216
+ end
217
+
218
+ self.rows_init("table" => table_obj, "rows" => table_data["rows"]) if table_data["rows"]
219
+ rescue Knj::Errors::NotFound => e
220
+ if table_data["renames"]
221
+ table_data["renames"].each do |table_name_rename|
222
+ begin
223
+ table_rename = db.tables[table_name_rename]
224
+ table_rename.rename(table_name)
225
+ raise Knj::Errors::Retry
226
+ rescue Knj::Errors::NotFound
227
+ next
228
+ end
229
+ end
230
+ end
231
+
232
+ if table_data["on_create"]
233
+ table_data["on_create"].call("db" => db, "table_name" => table_name, "table_data" => table_data)
234
+ end
235
+
236
+ db.tables.create(table_name, table_data)
237
+ table_obj = db.tables[table_name]
238
+
239
+ if table_data["on_create_after"]
240
+ table_data["on_create_after"].call("db" => db, "table_name" => table_name, "table_data" => table_data)
241
+ end
242
+
243
+ self.rows_init("table" => table_obj, "rows" => table_data["rows"]) if table_data["rows"]
244
+ end
245
+ rescue Knj::Errors::Retry
246
+ retry
247
+ end
248
+ end
249
+
250
+ if schema["tables_remove"]
251
+ schema["tables_remove"].each do |table_name, table_data|
252
+ begin
253
+ table_obj = db.tables[table_name.to_sym]
254
+ table_data["callback"].call if table_data.is_a?(Hash) and table_data["callback"]
255
+ table_obj.drop
256
+ rescue Knj::Errors::NotFound => e
257
+ next
258
+ end
259
+ end
260
+ end
261
+ end
262
+ end
data/lib/knj/libqt.rb CHANGED
@@ -3,73 +3,73 @@ require "qtuitools"
3
3
  require "knjrbfw/libqt_window.rb"
4
4
 
5
5
  class QtLoader
6
- def window
7
- return @window
8
- end
9
-
10
- def loader
11
- return @loader
12
- end
13
-
14
- def object_connect
15
- return @object_connect
16
- end
17
-
18
- def widget(name)
19
- return @widgets[name]
20
- end
21
-
22
- def initialize(paras)
23
- @widgets = {}
24
-
25
- if (paras.class.to_s == "Hash")
26
- file_path = paras["file"]
27
- @object_connect = paras["object_connect"]
28
- elsif(paras.class.to_s == "String")
29
- file_path = paras
30
- elsif(paras.class.to_s == "Array")
31
- file_path = paras[0]
32
- @object_connect = paras[1]
33
- else
34
- raise "Unknown parameter"
35
- end
36
-
37
- file = Qt::File.new(file_path)
38
- file.open(Qt::File::ReadOnly)
39
- @loader = Qt::UiLoader.new
40
- @window = @loader.load(file, nil)
41
- file.close
42
-
43
-
44
- @window.findChildren(Qt::Object).each do |widget|
45
- object_name = widget.object_name.to_s
46
-
47
- if (object_name.length > 0)
48
- @widgets[object_name] = widget
49
-
50
- if (@object_connect)
51
- meta = widget.meta_object
52
- signals = {}
53
- 0.upto(meta.methodCount - 1) do |count|
54
- method_info = meta.method(count)
55
-
56
- if (method_info.method_type == 1)
57
- method_name = method_info.signature.match(/^(.+)\(/)
58
- signals[method_name[1]] = method_info.signature
59
- end
60
- end
61
- end
62
-
63
- signals.each do |item|
64
- func_name = "on_" + object_name + "_" + item[0]
65
- if (@object_connect.respond_to?(func_name))
66
- params = item[1].sub(/[a-z]+(\(.*$)/, '\1')
67
- widget.connect(SIGNAL item[1]) do
68
- @object_connect.send(func_name)
69
- end
70
- end
71
- end
72
- end
73
- end
74
- end
6
+ def window
7
+ return @window
8
+ end
9
+
10
+ def loader
11
+ return @loader
12
+ end
13
+
14
+ def object_connect
15
+ return @object_connect
16
+ end
17
+
18
+ def widget(name)
19
+ return @widgets[name]
20
+ end
21
+
22
+ def initialize(paras)
23
+ @widgets = {}
24
+
25
+ if (paras.class.to_s == "Hash")
26
+ file_path = paras["file"]
27
+ @object_connect = paras["object_connect"]
28
+ elsif(paras.class.to_s == "String")
29
+ file_path = paras
30
+ elsif(paras.class.to_s == "Array")
31
+ file_path = paras[0]
32
+ @object_connect = paras[1]
33
+ else
34
+ raise "Unknown parameter"
35
+ end
36
+
37
+ file = Qt::File.new(file_path)
38
+ file.open(Qt::File::ReadOnly)
39
+ @loader = Qt::UiLoader.new
40
+ @window = @loader.load(file, nil)
41
+ file.close
42
+
43
+
44
+ @window.findChildren(Qt::Object).each do |widget|
45
+ object_name = widget.object_name.to_s
46
+
47
+ if (object_name.length > 0)
48
+ @widgets[object_name] = widget
49
+
50
+ if (@object_connect)
51
+ meta = widget.meta_object
52
+ signals = {}
53
+ 0.upto(meta.methodCount - 1) do |count|
54
+ method_info = meta.method(count)
55
+
56
+ if (method_info.method_type == 1)
57
+ method_name = method_info.signature.match(/^(.+)\(/)
58
+ signals[method_name[1]] = method_info.signature
59
+ end
60
+ end
61
+ end
62
+
63
+ signals.each do |item|
64
+ func_name = "on_" + object_name + "_" + item[0]
65
+ if (@object_connect.respond_to?(func_name))
66
+ params = item[1].sub(/[a-z]+(\(.*$)/, '\1')
67
+ widget.connect(SIGNAL item[1]) do
68
+ @object_connect.send(func_name)
69
+ end
70
+ end
71
+ end
72
+ end
73
+ end
74
+ end
75
75
  end
@@ -1,10 +1,10 @@
1
1
  class QtWindow
2
- def self.doCenter(tha_window)
3
- qdw = Qt::DesktopWidget.new
4
-
5
- move_left = (qdw.width / 2) - (tha_window.width / 2)
6
- move_top = (qdw.height / 2) - (tha_window.height / 2)
7
-
8
- tha_window.move(move_left, move_top)
9
- end
2
+ def self.doCenter(tha_window)
3
+ qdw = Qt::DesktopWidget.new
4
+
5
+ move_left = (qdw.width / 2) - (tha_window.width / 2)
6
+ move_top = (qdw.height / 2) - (tha_window.height / 2)
7
+
8
+ tha_window.move(move_left, move_top)
9
+ end
10
10
  end
data/lib/knj/locales.rb CHANGED
@@ -1,54 +1,64 @@
1
1
  module Knj::Locales
2
- def self.lang
3
- begin
4
- locale = _session[:locale]
5
- rescue NameError
6
- #_session method does not exist - continue.
7
- end
8
-
9
- locale = ENV["LANGUAGE"] if !locale and ENV["LANGUAGE"]
10
- locale = $locale if !locale and $locale
11
-
12
- raise "Could not figure out locale." if !locale
13
- raise "Could not understand language: #{locale}." if !match = locale.to_s.match(/^([a-z]{2})_([A-Z]{2})/)
14
-
15
- return {
16
- "first" => match[1],
17
- "second" => match[2],
18
- "full" => match[1] + "_" + match[2]
19
- }
20
- end
21
-
22
- def self.localeconv
23
- f = Knj::Locales.lang["first"]
24
-
25
- dec = "."
26
- thousand = ","
27
-
28
- case f
29
- when "da", "es", "de", "sv"
30
- dec = ","
31
- thousand = "."
32
- when "en"
33
- #do nothing.
34
- else
35
- raise "Cant figure out numbers for language: #{f}."
36
- end
37
-
38
- return {
39
- "decimal_point" => dec,
40
- "thousands_sep" => thousand
41
- }
42
- end
43
-
44
- def self.number_in(num_str)
45
- lc = Knj::Locales.localeconv
46
- num_str = num_str.to_s.gsub(lc["thousands_sep"], "").gsub(lc["decimal_point"], ".").to_f
47
- return num_str
48
- end
49
-
50
- def self.number_out(num_str, dec = 2)
51
- lc = Knj::Locales.localeconv
52
- return Knj::Php.number_format(num_str, dec, lc["decimal_point"], lc["thousands_sep"])
53
- end
2
+ def self.lang
3
+ match = self.locale.to_s.match(/^([a-z]{2})_([A-Z]{2})/)
4
+ raise "Could not understand language: #{self.locale}." if !match
5
+
6
+ return {
7
+ "first" => match[1],
8
+ "second" => match[2],
9
+ "full" => match[1] + "_" + match[2]
10
+ }
11
+ end
12
+
13
+ def self.localeconv
14
+ f = Knj::Locales.lang["first"]
15
+
16
+ dec = "."
17
+ thousand = ","
18
+ csv_delimiter = ","
19
+
20
+ case f
21
+ when "da", "es", "de", "sv"
22
+ dec = ","
23
+ thousand = "."
24
+ csv_delimiter = ";"
25
+ when "en"
26
+ #do nothing.
27
+ else
28
+ raise "Cant figure out numbers for language: #{f}."
29
+ end
30
+
31
+ return {
32
+ "decimal_point" => dec,
33
+ "thousands_sep" => thousand,
34
+ "csv_delimiter" => csv_delimiter
35
+ }
36
+ end
37
+
38
+ def self.number_in(num_str)
39
+ lc = Knj::Locales.localeconv
40
+ num_str = num_str.to_s.gsub(lc["thousands_sep"], "").gsub(lc["decimal_point"], ".").to_f
41
+ return num_str
42
+ end
43
+
44
+ def self.number_out(num_str, dec = 2)
45
+ lc = Knj::Locales.localeconv
46
+ return Knj::Php.number_format(num_str, dec, lc["decimal_point"], lc["thousands_sep"])
47
+ end
48
+
49
+ def self.locale
50
+ begin
51
+ return _session[:locale]
52
+ rescue NameError
53
+ if Thread.current[:locale]
54
+ return Thread.current[:locale]
55
+ elsif $locale
56
+ return $locale
57
+ elsif ENV["LANGUAGE"]
58
+ return ENV["LANGUAGE"]
59
+ end
60
+ end
61
+
62
+ raise "Could not figure out locale."
63
+ end
54
64
  end
@@ -1,56 +1,56 @@
1
1
  class Knj
2
- class Maemo
3
- class FremantleCalendar
4
- def initialize
5
- require "knjrbfw/libknjphpfuncs.rb"
6
-
7
- require "knjrbfw/knjdb/libknjdb.rb"
8
- @db = KnjDB.new({
9
- "type" => "sqlite3",
10
- "path" => "/home/user/.calendar/calendardb"
11
- })
12
- end
13
-
14
- def events
15
- ret = []
16
- f_gevents = @db.query("SELECT * FROM Components ORDER BY DateStart")
17
- while(d_gevents = f_gevents.fetch)
18
- ret << Event.new({
19
- "cal" => self,
20
- "data" => d_gevents,
21
- "db" => @db
22
- })
23
- end
24
-
25
- return ret
26
- end
27
-
28
- class Event
29
- def data; return @data; end
30
- def db; return @db; end
31
- def cal; return @cal; end
32
-
33
- def initialize(paras)
34
- @db = paras["db"]
35
- @data = paras["data"]
36
- @cal = paras["cal"]
37
- end
38
-
39
- def [](key)
40
- if (!@data.key?(key))
41
- raise "No such key: '" + key + "'"
42
- end
43
-
44
- return @data[key]
45
- end
46
-
47
- def []=(key, value)
48
- self[key] #raises error if key is invalid.
49
-
50
- @db.update("Components", {key => value}, {"Id" => @data["Id"]})
51
- @data[key] = value
52
- end
53
- end
54
- end
55
- end
2
+ class Maemo
3
+ class FremantleCalendar
4
+ def initialize
5
+ require "knjrbfw/libknjphpfuncs.rb"
6
+
7
+ require "knjrbfw/knjdb/libknjdb.rb"
8
+ @db = KnjDB.new({
9
+ "type" => "sqlite3",
10
+ "path" => "/home/user/.calendar/calendardb"
11
+ })
12
+ end
13
+
14
+ def events
15
+ ret = []
16
+ f_gevents = @db.query("SELECT * FROM Components ORDER BY DateStart")
17
+ while(d_gevents = f_gevents.fetch)
18
+ ret << Event.new({
19
+ "cal" => self,
20
+ "data" => d_gevents,
21
+ "db" => @db
22
+ })
23
+ end
24
+
25
+ return ret
26
+ end
27
+
28
+ class Event
29
+ def data; return @data; end
30
+ def db; return @db; end
31
+ def cal; return @cal; end
32
+
33
+ def initialize(paras)
34
+ @db = paras["db"]
35
+ @data = paras["data"]
36
+ @cal = paras["cal"]
37
+ end
38
+
39
+ def [](key)
40
+ if (!@data.key?(key))
41
+ raise "No such key: '" + key + "'"
42
+ end
43
+
44
+ return @data[key]
45
+ end
46
+
47
+ def []=(key, value)
48
+ self[key] #raises error if key is invalid.
49
+
50
+ @db.update("Components", {key => value}, {"Id" => @data["Id"]})
51
+ @data[key] = value
52
+ end
53
+ end
54
+ end
55
+ end
56
56
  end