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
@@ -1,130 +1,132 @@
1
1
  class KnjDB_mysql::Columns
2
- attr_reader :db, :driver
3
-
4
- def initialize(args)
5
- @args = args
6
- @db = @args[:db]
7
- @driver = @args[:driver]
8
- end
9
-
10
- def data_sql(data)
11
- raise "No type given." if !data["type"]
12
-
13
- data["maxlength"] = 255 if data["type"] == "varchar" and !data.key?("maxlength")
14
-
15
- sql = "`#{data["name"]}` #{data["type"]}"
16
- sql += "(#{data["maxlength"]})" if data["maxlength"]
17
- sql += " PRIMARY KEY" if data["primarykey"]
18
- sql += " AUTO_INCREMENT" if data["autoincr"]
19
- sql += " NOT NULL" if !data["null"]
20
-
21
- if data.key?("default_func")
22
- sql += " DEFAULT #{data["default_func"]}"
23
- elsif data.key?("default") and data["default"] != false
24
- sql += " DEFAULT '#{@db.escape(data["default"])}'"
25
- end
26
-
27
- sql += " COMMENT '#{@db.escape(data["comment"])}'" if data.key?("comment")
28
- sql += " AFTER `#{@db.esc_col(data["after"])}`" if data["after"] and !data["first"]
29
- sql += " FIRST" if data["first"]
30
-
31
- return sql
32
- end
2
+ attr_reader :db, :driver
3
+
4
+ def initialize(args)
5
+ @args = args
6
+ @db = @args[:db]
7
+ @driver = @args[:driver]
8
+ end
9
+
10
+ def data_sql(data)
11
+ raise "No type given." if !data["type"]
12
+
13
+ data["maxlength"] = 255 if data["type"] == "varchar" and !data.key?("maxlength")
14
+
15
+ sql = "`#{data["name"]}` #{data["type"]}"
16
+ sql << "(#{data["maxlength"]})" if data["maxlength"]
17
+ sql << " PRIMARY KEY" if data["primarykey"]
18
+ sql << " AUTO_INCREMENT" if data["autoincr"]
19
+ sql << " NOT NULL" if !data["null"]
20
+
21
+ if data.key?("default_func")
22
+ sql << " DEFAULT #{data["default_func"]}"
23
+ elsif data.key?("default") and data["default"] != false
24
+ sql << " DEFAULT '#{@db.escape(data["default"])}'"
25
+ end
26
+
27
+ sql << " COMMENT '#{@db.escape(data["comment"])}'" if data.key?("comment")
28
+ sql << " AFTER `#{@db.esc_col(data["after"])}`" if data["after"] and !data["first"]
29
+ sql << " FIRST" if data["first"]
30
+
31
+ return sql
32
+ end
33
33
  end
34
34
 
35
35
  class KnjDB_mysql::Columns::Column
36
- attr_reader :args
37
-
38
- def initialize(args)
39
- @args = args
40
- @db = @args[:db]
41
- end
42
-
43
- def name
44
- return @args[:data][:Field]
45
- end
46
-
47
- def data
48
- return {
49
- "type" => self.type,
50
- "name" => self.name,
51
- "null" => self.null?,
52
- "maxlength" => self.maxlength,
53
- "default" => self.default,
54
- "primarykey" => self.primarykey?,
55
- "autoincr" => self.autoincr?
56
- }
57
- end
58
-
59
- def type
60
- if !@type
61
- if match = @args[:data][:Type].match(/^([A-z]+)$/)
62
- @maxlength = false
63
- @type = match[0]
64
- elsif match = @args[:data][:Type].match(/^decimal\((\d+),(\d+)\)$/)
65
- @maxlength = "#{match[1]},#{match[2]}"
66
- @type = "decimal"
67
- elsif match = @args[:data][:Type].match(/^enum\((.+)\)$/)
68
- @maxlength = match[1]
69
- @type = "enum"
70
- elsif match = @args[:data][:Type].match(/^(.+)\((\d+)\)$/)
71
- @maxlength = match[2]
72
- @type = match[1]
73
- end
74
- end
75
-
76
- return @type
77
- end
78
-
79
- def null?
80
- return false if @args[:data][:Null] == "NO"
81
- return true
82
- end
83
-
84
- def maxlength
85
- self.type
86
- return @maxlength if @maxlength
87
- return false
88
- end
89
-
90
- def default
91
- return false if !@args[:data][:Default]
92
- return @args[:data][:Default]
93
- end
94
-
95
- def primarykey?
96
- return false if @args[:data][:pk].to_i == 0
97
- return true
98
- end
99
-
100
- def autoincr?
101
- return true if @args[:data][:Extra].index("auto_increment") != nil
102
- return false
103
- end
104
-
105
- def comment
106
- return @args[:data][:Comment]
107
- end
108
-
109
- def drop
110
- @args[:db].query("ALTER TABLE `#{@args[:table].name}` DROP COLUMN `#{self.name}`")
111
- end
112
-
113
- def change(data)
114
- esc_col = @args[:driver].escape_col
115
- col_escaped = "#{esc_col}#{@db.esc_col(self.name)}#{esc_col}"
116
- table_escape = "#{@args[:driver].escape_table}#{@args[:driver].esc_table(@args[:table].name)}#{@args[:driver].escape_table}"
117
- newdata = data.clone
118
-
119
- newdata["name"] = self.name if !newdata.key?("name")
120
- newdata["type"] = self.type if !newdata.key?("type")
121
- newdata["maxlength"] = self.maxlength if !newdata.key?("maxlength") and self.maxlength
122
- newdata["null"] = self.null? if !newdata.key?("null")
123
- newdata["default"] = self.default if !newdata.key?("default")
124
- newdata.delete("primarykey") if newdata.key?("primarykey")
125
-
126
- type_s = newdata["type"].to_s
127
- @db.query("ALTER TABLE #{table_escape} CHANGE #{col_escaped} #{@db.cols.data_sql(newdata)}")
128
- @args[:table].list = nil if data.key?("name") and data["name"] != self.name
129
- end
36
+ attr_reader :args
37
+
38
+ def initialize(args)
39
+ @args = args
40
+ end
41
+
42
+ def name
43
+ return @args[:data][:Field]
44
+ end
45
+
46
+ def table
47
+ return @args[:db].tables[@args[:table_name]]
48
+ end
49
+
50
+ def data
51
+ return {
52
+ "type" => self.type,
53
+ "name" => self.name,
54
+ "null" => self.null?,
55
+ "maxlength" => self.maxlength,
56
+ "default" => self.default,
57
+ "primarykey" => self.primarykey?,
58
+ "autoincr" => self.autoincr?
59
+ }
60
+ end
61
+
62
+ def type
63
+ if !@type
64
+ if match = @args[:data][:Type].match(/^([A-z]+)$/)
65
+ @maxlength = false
66
+ @type = match[0]
67
+ elsif match = @args[:data][:Type].match(/^decimal\((\d+),(\d+)\)$/)
68
+ @maxlength = "#{match[1]},#{match[2]}"
69
+ @type = "decimal"
70
+ elsif match = @args[:data][:Type].match(/^enum\((.+)\)$/)
71
+ @maxlength = match[1]
72
+ @type = "enum"
73
+ elsif match = @args[:data][:Type].match(/^(.+)\((\d+)\)$/)
74
+ @maxlength = match[2]
75
+ @type = match[1]
76
+ end
77
+ end
78
+
79
+ return @type
80
+ end
81
+
82
+ def null?
83
+ return false if @args[:data][:Null] == "NO"
84
+ return true
85
+ end
86
+
87
+ def maxlength
88
+ self.type
89
+ return @maxlength if @maxlength
90
+ return false
91
+ end
92
+
93
+ def default
94
+ return false if !@args[:data][:Default]
95
+ return @args[:data][:Default]
96
+ end
97
+
98
+ def primarykey?
99
+ return false if @args[:data][:pk].to_i == 0
100
+ return true
101
+ end
102
+
103
+ def autoincr?
104
+ return true if @args[:data][:Extra].index("auto_increment") != nil
105
+ return false
106
+ end
107
+
108
+ def comment
109
+ return @args[:data][:Comment]
110
+ end
111
+
112
+ def drop
113
+ @args[:db].query("ALTER TABLE `#{@args[:table].name}` DROP COLUMN `#{self.name}`")
114
+ end
115
+
116
+ def change(data)
117
+ esc_col = @args[:driver].escape_col
118
+ col_escaped = "#{esc_col}#{@args[:db].esc_col(self.name)}#{esc_col}"
119
+ table_escape = "#{@args[:driver].escape_table}#{@args[:driver].esc_table(self.table.name)}#{@args[:driver].escape_table}"
120
+ newdata = data.clone
121
+
122
+ newdata["name"] = self.name if !newdata.key?("name")
123
+ newdata["type"] = self.type if !newdata.key?("type")
124
+ newdata["maxlength"] = self.maxlength if !newdata.key?("maxlength") and self.maxlength
125
+ newdata["null"] = self.null? if !newdata.key?("null")
126
+ newdata["default"] = self.default if !newdata.key?("default")
127
+ newdata.delete("primarykey") if newdata.key?("primarykey")
128
+
129
+ type_s = newdata["type"].to_s
130
+ @args[:db].query("ALTER TABLE #{table_escape} CHANGE #{col_escaped} #{@args[:db].cols.data_sql(newdata)}")
131
+ end
130
132
  end
@@ -1,30 +1,48 @@
1
1
  class KnjDB_mysql::Indexes
2
- def initialize(args)
3
- @args = args
4
- end
2
+ def initialize(args)
3
+ @args = args
4
+ end
5
5
  end
6
6
 
7
7
  class KnjDB_mysql::Indexes::Index
8
- attr_reader :columns
9
-
10
- def initialize(args)
11
- @args = args
12
- @columns = []
13
- end
14
-
15
- def name
16
- return @args[:data][:Key_name]
17
- end
18
-
19
- def drop
20
- sql = "DROP INDEX `#{self.name}` ON `#{@args[:table].name}`"
21
- @args[:db].query(sql)
22
- end
23
-
24
- def data
25
- return {
26
- "name" => name,
27
- "columns" => @columns
28
- }
29
- end
8
+ attr_reader :columns
9
+
10
+ def initialize(args)
11
+ @args = args
12
+ @columns = []
13
+ end
14
+
15
+ def name
16
+ return @args[:data][:Key_name]
17
+ end
18
+
19
+ def table
20
+ return @args[:db].tables[@args[:table_name]]
21
+ end
22
+
23
+ def drop
24
+ sql = "DROP INDEX `#{self.name}` ON `#{self.table.name}`"
25
+ @args[:db].query(sql)
26
+ end
27
+
28
+ def data
29
+ return {
30
+ "name" => name,
31
+ "columns" => @columns
32
+ }
33
+ end
34
+
35
+ #Returns true if the index is a unique-index.
36
+ def unique?
37
+ if @args[:data][:Index_type] == "UNIQUE"
38
+ return true
39
+ else
40
+ return false
41
+ end
42
+ end
43
+
44
+ #Inspect crashes if this is not present? - knj.
45
+ def to_s
46
+ return "#<#{self.class.name}>"
47
+ end
30
48
  end