ruby-iup 0.0.2 → 0.1.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.
Files changed (478) hide show
  1. data/CHANGES +3 -0
  2. data/MANIFEST +8 -0
  3. data/MIT-LICENSE +18 -0
  4. data/README +12 -0
  5. data/Rakefile +68 -80
  6. data/doc/build_install.txt +9 -12
  7. data/examples/ctrl/cbox.rb +14 -15
  8. data/examples/ctrl/checkboard.rb +1 -1
  9. data/examples/ctrl/example1.rb +53 -53
  10. data/examples/ctrl/example2.rb +39 -39
  11. data/examples/ctrl/iupcolorbar.rb +95 -95
  12. data/examples/ctrl/iupcolorbrowser.rb +45 -45
  13. data/examples/ctrl/iupdial.rb +117 -117
  14. data/examples/ctrl/iupgetcolor.rb +7 -7
  15. data/examples/ctrl/iupgetparam.rb +62 -62
  16. data/examples/ctrl/iupglcanvas.rb +172 -172
  17. data/examples/ctrl/iupmask.rb +1 -3
  18. data/examples/ctrl/iupmatrix.rb +39 -39
  19. data/examples/ctrl/iupplot2.rb +2 -1
  20. data/examples/ctrl/iuptabs.rb +22 -22
  21. data/examples/ctrl/iuptree.rb +190 -190
  22. data/examples/ctrl/iupval.rb +71 -71
  23. data/examples/ctrl/numbering.rb +46 -46
  24. data/examples/ctrl/sample.rb +166 -166
  25. data/examples/dlg/iupfiledlg.rb +19 -19
  26. data/examples/dlg/iupgetfile.rb +19 -19
  27. data/examples/dlg/iuplistdialog.rb +26 -26
  28. data/examples/dlg/iupmessage.rb +5 -5
  29. data/examples/dlg/iupscanf.rb +17 -17
  30. data/examples/elem/iupdialog2.rb +25 -25
  31. data/examples/elem/iupfill.rb +51 -51
  32. data/examples/elem/iupframe.rb +25 -25
  33. data/examples/elem/iuphbox.rb +68 -68
  34. data/examples/elem/iupimage.rb +113 -113
  35. data/examples/elem/iupitem.rb +60 -60
  36. data/examples/elem/iuplabel.rb +57 -57
  37. data/examples/elem/iuplist.rb +41 -41
  38. data/examples/elem/iuplist2.rb +125 -125
  39. data/examples/elem/iupmenu.rb +32 -32
  40. data/examples/elem/iupmultiline.rb +24 -24
  41. data/examples/elem/iupmultiline2.rb +156 -156
  42. data/examples/elem/iupradio.rb +32 -32
  43. data/examples/elem/iupseparator.rb +81 -81
  44. data/examples/elem/iupsubmenu.rb +85 -85
  45. data/examples/elem/iuptext.rb +61 -61
  46. data/examples/elem/iuptimer.rb +36 -36
  47. data/examples/elem/iuptoggle.rb +110 -110
  48. data/examples/elem/iupvbox.rb +87 -87
  49. data/examples/elem/iupzbox.rb +60 -60
  50. data/examples/elem/mdisample.rb +377 -376
  51. data/examples/elem/scrollbar.rb +66 -66
  52. data/examples/elem/tray.rb +90 -90
  53. data/examples/func/iupgetattribute.rb +32 -32
  54. data/examples/func/iupidle.rb +48 -48
  55. data/ext/extconf.rb +62 -27
  56. data/ext/iup-linux/include/cd.h +9 -5
  57. data/ext/iup-linux/include/cd_private.h +13 -6
  58. data/ext/iup-linux/include/cdsvg.h +22 -0
  59. data/ext/iup-linux/include/im.h +287 -282
  60. data/ext/iup-linux/include/im_attrib.h +120 -116
  61. data/ext/iup-linux/include/im_attrib_flat.h +39 -39
  62. data/ext/iup-linux/include/im_binfile.h +224 -214
  63. data/ext/iup-linux/include/im_capture.h +365 -365
  64. data/ext/iup-linux/include/im_color.h +465 -465
  65. data/ext/iup-linux/include/im_colorhsi.h +56 -61
  66. data/ext/iup-linux/include/im_complex.h +180 -160
  67. data/ext/iup-linux/include/im_convert.h +142 -127
  68. data/ext/iup-linux/include/im_counter.h +69 -69
  69. data/ext/iup-linux/include/im_dib.h +195 -195
  70. data/ext/iup-linux/include/im_file.h +115 -111
  71. data/ext/iup-linux/include/im_format.h +97 -79
  72. data/ext/iup-linux/include/im_format_all.h +575 -576
  73. data/ext/iup-linux/include/im_format_avi.h +88 -87
  74. data/ext/iup-linux/include/im_format_ecw.h +93 -93
  75. data/ext/iup-linux/include/im_format_jp2.h +79 -78
  76. data/ext/iup-linux/include/im_format_raw.h +74 -64
  77. data/ext/iup-linux/include/im_format_wmv.h +101 -100
  78. data/ext/iup-linux/include/im_image.h +425 -403
  79. data/ext/iup-linux/include/im_kernel.h +315 -315
  80. data/ext/iup-linux/include/im_lib.h +191 -191
  81. data/ext/iup-linux/include/im_math.h +368 -368
  82. data/ext/iup-linux/include/im_math_op.h +214 -219
  83. data/ext/iup-linux/include/im_palette.h +172 -172
  84. data/ext/iup-linux/include/im_plus.h +73 -73
  85. data/ext/iup-linux/include/im_process.h +36 -35
  86. data/ext/iup-linux/include/im_process_ana.h +222 -221
  87. data/ext/iup-linux/include/im_process_glo.h +170 -170
  88. data/ext/iup-linux/include/im_process_loc.h +608 -577
  89. data/ext/iup-linux/include/im_process_pon.h +734 -712
  90. data/ext/iup-linux/include/im_raw.h +34 -34
  91. data/ext/iup-linux/include/im_util.h +277 -277
  92. data/ext/iup-linux/include/imlua.h +75 -83
  93. data/ext/iup-linux/include/iup.h +86 -40
  94. data/ext/iup-linux/include/iupcb.h +1 -25
  95. data/ext/iup-linux/include/iupcbox.h +1 -0
  96. data/ext/iup-linux/include/iupcbs.h +1 -1
  97. data/ext/iup-linux/include/iupcells.h +1 -130
  98. data/ext/iup-linux/include/iupcolorbar.h +1 -126
  99. data/ext/iup-linux/include/iupcontrols.h +26 -16
  100. data/ext/iup-linux/include/iupdef.h +205 -0
  101. data/ext/iup-linux/include/iupdial.h +1 -63
  102. data/ext/iup-linux/include/iupgauge.h +1 -57
  103. data/ext/iup-linux/include/iupgc.h +1 -0
  104. data/ext/iup-linux/include/iupgetparam.h +1 -27
  105. data/ext/iup-linux/include/iupgl.h +2 -7
  106. data/ext/iup-linux/include/iupim.h +7 -1
  107. data/ext/iup-linux/include/iupkey.h +4 -4
  108. data/ext/iup-linux/include/iupmask.h +2 -1
  109. data/ext/iup-linux/include/iupmatrix.h +1 -63
  110. data/ext/iup-linux/include/iupsbox.h +1 -0
  111. data/ext/iup-linux/include/iupspin.h +1 -21
  112. data/ext/iup-linux/include/iuptabs.h +1 -75
  113. data/ext/iup-linux/include/iuptree.h +1 -93
  114. data/ext/iup-linux/include/iupval.h +1 -46
  115. data/ext/iup-linux/include/old_im.h +59 -59
  116. data/ext/iup-linux/include/wd.h +5 -0
  117. data/ext/iup-linux/libcd.a +0 -0
  118. data/ext/iup-linux/libcdcontextplus.a +0 -0
  119. data/ext/iup-linux/libcdgdk.a +0 -0
  120. data/ext/iup-linux/libcdpdf.a +0 -0
  121. data/ext/iup-linux/libfreetype.a +0 -0
  122. data/ext/iup-linux/libim.a +0 -0
  123. data/ext/iup-linux/libim_fftw.a +0 -0
  124. data/ext/iup-linux/libim_jp2.a +0 -0
  125. data/ext/iup-linux/libim_process.a +0 -0
  126. data/ext/iup-linux/libiup.a +0 -0
  127. data/ext/iup-linux/libiup_pplot.a +0 -0
  128. data/ext/iup-linux/libiupcd.a +0 -0
  129. data/ext/iup-linux/libiupcontrols.a +0 -0
  130. data/ext/iup-linux/libiupgl.a +0 -0
  131. data/ext/iup-linux/libiupim.a +0 -0
  132. data/ext/iup-linux/libiupimglib.a +0 -0
  133. data/ext/iup-linux/libiupmot.a +0 -0
  134. data/ext/iup-linux/libpdflib.a +0 -0
  135. data/ext/{iup-win32 → iup-mingw32}/include/cd.h +9 -5
  136. data/ext/{iup-win32 → iup-mingw32}/include/cd_canvas.hpp +0 -0
  137. data/ext/{iup-win32 → iup-mingw32}/include/cd_old.h +0 -0
  138. data/ext/{iup-win32 → iup-mingw32}/include/cd_private.h +13 -6
  139. data/ext/{iup-win32 → iup-mingw32}/include/cdcgm.h +0 -0
  140. data/ext/{iup-win32 → iup-mingw32}/include/cdclipbd.h +0 -0
  141. data/ext/{iup-win32 → iup-mingw32}/include/cddbuf.h +0 -0
  142. data/ext/{iup-win32 → iup-mingw32}/include/cddebug.h +0 -0
  143. data/ext/{iup-win32 → iup-mingw32}/include/cddgn.h +0 -0
  144. data/ext/{iup-win32 → iup-mingw32}/include/cddxf.h +0 -0
  145. data/ext/{iup-win32 → iup-mingw32}/include/cdemf.h +0 -0
  146. data/ext/{iup-win32 → iup-mingw32}/include/cdgdiplus.h +0 -0
  147. data/ext/{iup-win32 → iup-mingw32}/include/cdimage.h +0 -0
  148. data/ext/{iup-win32 → iup-mingw32}/include/cdirgb.h +0 -0
  149. data/ext/{iup-win32 → iup-mingw32}/include/cdiup.h +0 -0
  150. data/ext/{iup-win32 → iup-mingw32}/include/cdlua.h +0 -0
  151. data/ext/{iup-win32 → iup-mingw32}/include/cdlua3_private.h +0 -0
  152. data/ext/{iup-win32 → iup-mingw32}/include/cdlua5_private.h +0 -0
  153. data/ext/{iup-win32 → iup-mingw32}/include/cdluaim.h +0 -0
  154. data/ext/{iup-win32 → iup-mingw32}/include/cdluaiup.h +0 -0
  155. data/ext/{iup-win32 → iup-mingw32}/include/cdluapdf.h +0 -0
  156. data/ext/{iup-win32 → iup-mingw32}/include/cdmf.h +0 -0
  157. data/ext/{iup-win32 → iup-mingw32}/include/cdmf_private.h +0 -0
  158. data/ext/{iup-win32 → iup-mingw32}/include/cdnative.h +0 -0
  159. data/ext/{iup-win32 → iup-mingw32}/include/cdpdf.h +0 -0
  160. data/ext/{iup-win32 → iup-mingw32}/include/cdpicture.h +0 -0
  161. data/ext/{iup-win32 → iup-mingw32}/include/cdprint.h +0 -0
  162. data/ext/{iup-win32 → iup-mingw32}/include/cdps.h +0 -0
  163. data/ext/iup-mingw32/include/cdsvg.h +22 -0
  164. data/ext/{iup-win32 → iup-mingw32}/include/cdwmf.h +0 -0
  165. data/ext/iup-mingw32/include/im.h +287 -0
  166. data/ext/iup-mingw32/include/im_attrib.h +120 -0
  167. data/ext/iup-mingw32/include/im_attrib_flat.h +39 -0
  168. data/ext/iup-mingw32/include/im_binfile.h +224 -0
  169. data/ext/iup-mingw32/include/im_capture.h +365 -0
  170. data/ext/iup-mingw32/include/im_color.h +465 -0
  171. data/ext/iup-mingw32/include/im_colorhsi.h +56 -0
  172. data/ext/iup-mingw32/include/im_complex.h +180 -0
  173. data/ext/iup-mingw32/include/im_convert.h +142 -0
  174. data/ext/iup-mingw32/include/im_counter.h +69 -0
  175. data/ext/iup-mingw32/include/im_dib.h +195 -0
  176. data/ext/iup-mingw32/include/im_file.h +115 -0
  177. data/ext/iup-mingw32/include/im_format.h +97 -0
  178. data/ext/iup-mingw32/include/im_format_all.h +575 -0
  179. data/ext/iup-mingw32/include/im_format_avi.h +88 -0
  180. data/ext/iup-mingw32/include/im_format_ecw.h +93 -0
  181. data/ext/iup-mingw32/include/im_format_jp2.h +79 -0
  182. data/ext/iup-mingw32/include/im_format_raw.h +74 -0
  183. data/ext/iup-mingw32/include/im_format_wmv.h +101 -0
  184. data/ext/iup-mingw32/include/im_image.h +425 -0
  185. data/ext/iup-mingw32/include/im_kernel.h +315 -0
  186. data/ext/iup-mingw32/include/im_lib.h +191 -0
  187. data/ext/iup-mingw32/include/im_math.h +368 -0
  188. data/ext/iup-mingw32/include/im_math_op.h +214 -0
  189. data/ext/iup-mingw32/include/im_palette.h +172 -0
  190. data/ext/iup-mingw32/include/im_plus.h +73 -0
  191. data/ext/iup-mingw32/include/im_process.h +36 -0
  192. data/ext/iup-mingw32/include/im_process_ana.h +222 -0
  193. data/ext/iup-mingw32/include/im_process_glo.h +170 -0
  194. data/ext/iup-mingw32/include/im_process_loc.h +608 -0
  195. data/ext/iup-mingw32/include/im_process_pon.h +734 -0
  196. data/ext/iup-mingw32/include/im_raw.h +34 -0
  197. data/ext/iup-mingw32/include/im_util.h +277 -0
  198. data/ext/iup-mingw32/include/imlua.h +75 -0
  199. data/ext/{iup-win32 → iup-mingw32}/include/iup.h +86 -40
  200. data/ext/{iup-win32 → iup-mingw32}/include/iup_pplot.h +0 -0
  201. data/ext/iup-mingw32/include/iupcb.h +1 -0
  202. data/ext/iup-mingw32/include/iupcbox.h +1 -0
  203. data/ext/{iup-win32 → iup-mingw32}/include/iupcbs.h +1 -1
  204. data/ext/iup-mingw32/include/iupcells.h +1 -0
  205. data/ext/iup-mingw32/include/iupcolorbar.h +1 -0
  206. data/ext/iup-mingw32/include/iupcontrols.h +46 -0
  207. data/ext/{iup-win32 → iup-mingw32}/include/iupdef.h +205 -0
  208. data/ext/iup-mingw32/include/iupdial.h +1 -0
  209. data/ext/iup-mingw32/include/iupgauge.h +1 -0
  210. data/ext/iup-mingw32/include/iupgc.h +1 -0
  211. data/ext/iup-mingw32/include/iupgetparam.h +1 -0
  212. data/ext/{iup-win32 → iup-mingw32}/include/iupgl.h +2 -7
  213. data/ext/{iup-win32 → iup-mingw32}/include/iupim.h +7 -1
  214. data/ext/{iup-win32 → iup-mingw32}/include/iupkey.h +4 -4
  215. data/ext/{iup-win32 → iup-mingw32}/include/iuplua.h +0 -0
  216. data/ext/{iup-win32 → iup-mingw32}/include/iuplua_pplot.h +0 -0
  217. data/ext/{iup-win32 → iup-mingw32}/include/iupluacontrols.h +0 -0
  218. data/ext/{iup-win32 → iup-mingw32}/include/iupluagl.h +0 -0
  219. data/ext/{iup-win32 → iup-mingw32}/include/iupluaim.h +0 -0
  220. data/ext/{iup-win32 → iup-mingw32}/include/iupluaole.h +0 -0
  221. data/ext/{iup-win32 → iup-mingw32}/include/iupmask.h +2 -1
  222. data/ext/iup-mingw32/include/iupmatrix.h +1 -0
  223. data/ext/{iup-win32 → iup-mingw32}/include/iupole.h +0 -0
  224. data/ext/iup-mingw32/include/iupsbox.h +1 -0
  225. data/ext/iup-mingw32/include/iupspin.h +1 -0
  226. data/ext/iup-mingw32/include/iuptabs.h +1 -0
  227. data/ext/iup-mingw32/include/iuptree.h +1 -0
  228. data/ext/iup-mingw32/include/iupval.h +1 -0
  229. data/ext/iup-mingw32/include/old_im.h +59 -0
  230. data/ext/{iup-win32 → iup-mingw32}/include/wd.h +5 -0
  231. data/ext/{iup-win32 → iup-mingw32}/include/wd_old.h +0 -0
  232. data/ext/iup-mingw32/libcd.a +0 -0
  233. data/ext/iup-mingw32/libcdpdf.a +0 -0
  234. data/ext/iup-mingw32/libfreetype6.a +0 -0
  235. data/ext/iup-mingw32/libim.a +0 -0
  236. data/ext/iup-mingw32/libim_avi.a +0 -0
  237. data/ext/iup-mingw32/libim_fftw.a +0 -0
  238. data/ext/iup-mingw32/libim_jp2.a +0 -0
  239. data/ext/iup-mingw32/libim_process.a +0 -0
  240. data/ext/iup-mingw32/libiup.a +0 -0
  241. data/ext/iup-mingw32/libiup_pplot.a +0 -0
  242. data/ext/iup-mingw32/libiupcd.a +0 -0
  243. data/ext/iup-mingw32/libiupcontrols.a +0 -0
  244. data/ext/iup-mingw32/libiupgl.a +0 -0
  245. data/ext/iup-mingw32/libiupim.a +0 -0
  246. data/ext/iup-mingw32/libiupimglib.a +0 -0
  247. data/ext/iup-mingw32/libiupole.a +0 -0
  248. data/ext/iup-mingw32/libpdflib.a +0 -0
  249. data/ext/iup-mswin32/cd.lib +0 -0
  250. data/ext/iup-mswin32/cdcontextplus.lib +0 -0
  251. data/ext/iup-mswin32/cdgdk.lib +0 -0
  252. data/ext/iup-mswin32/cdpdf.lib +0 -0
  253. data/ext/iup-mswin32/freetype6.lib +0 -0
  254. data/ext/iup-mswin32/im.lib +0 -0
  255. data/ext/iup-mswin32/im_avi.lib +0 -0
  256. data/ext/iup-mswin32/im_capture.lib +0 -0
  257. data/ext/iup-mswin32/im_fftw.lib +0 -0
  258. data/ext/iup-mswin32/im_jp2.lib +0 -0
  259. data/ext/iup-mswin32/im_process.lib +0 -0
  260. data/ext/iup-mswin32/im_wmv.lib +0 -0
  261. data/ext/iup-mswin32/include/cd.h +498 -0
  262. data/ext/iup-mswin32/include/cd_canvas.hpp +358 -0
  263. data/ext/iup-mswin32/include/cd_old.h +158 -0
  264. data/ext/iup-mswin32/include/cd_private.h +369 -0
  265. data/ext/iup-mswin32/include/cdcgm.h +34 -0
  266. data/ext/iup-mswin32/include/cdclipbd.h +22 -0
  267. data/ext/iup-mswin32/include/cddbuf.h +23 -0
  268. data/ext/iup-mswin32/include/cddebug.h +24 -0
  269. data/ext/iup-mswin32/include/cddgn.h +23 -0
  270. data/ext/iup-mswin32/include/cddxf.h +22 -0
  271. data/ext/iup-mswin32/include/cdemf.h +22 -0
  272. data/ext/iup-mswin32/include/cdgdiplus.h +29 -0
  273. data/ext/iup-mswin32/include/cdimage.h +23 -0
  274. data/ext/iup-mswin32/include/cdirgb.h +30 -0
  275. data/ext/iup-mswin32/include/cdiup.h +22 -0
  276. data/ext/iup-mswin32/include/cdlua.h +39 -0
  277. data/ext/iup-mswin32/include/cdlua3_private.h +120 -0
  278. data/ext/iup-mswin32/include/cdlua5_private.h +141 -0
  279. data/ext/iup-mswin32/include/cdluaim.h +24 -0
  280. data/ext/iup-mswin32/include/cdluaiup.h +27 -0
  281. data/ext/iup-mswin32/include/cdluapdf.h +27 -0
  282. data/ext/iup-mswin32/include/cdmf.h +24 -0
  283. data/ext/iup-mswin32/include/cdmf_private.h +32 -0
  284. data/ext/iup-mswin32/include/cdnative.h +26 -0
  285. data/ext/iup-mswin32/include/cdpdf.h +38 -0
  286. data/ext/iup-mswin32/include/cdpicture.h +22 -0
  287. data/ext/iup-mswin32/include/cdprint.h +23 -0
  288. data/ext/iup-mswin32/include/cdps.h +37 -0
  289. data/ext/iup-mswin32/include/cdsvg.h +22 -0
  290. data/ext/iup-mswin32/include/cdwmf.h +22 -0
  291. data/ext/iup-mswin32/include/im.h +287 -0
  292. data/ext/iup-mswin32/include/im_attrib.h +120 -0
  293. data/ext/iup-mswin32/include/im_attrib_flat.h +39 -0
  294. data/ext/iup-mswin32/include/im_binfile.h +224 -0
  295. data/ext/iup-mswin32/include/im_capture.h +365 -0
  296. data/ext/iup-mswin32/include/im_color.h +465 -0
  297. data/ext/iup-mswin32/include/im_colorhsi.h +56 -0
  298. data/ext/iup-mswin32/include/im_complex.h +180 -0
  299. data/ext/iup-mswin32/include/im_convert.h +142 -0
  300. data/ext/iup-mswin32/include/im_counter.h +69 -0
  301. data/ext/iup-mswin32/include/im_dib.h +195 -0
  302. data/ext/iup-mswin32/include/im_file.h +115 -0
  303. data/ext/iup-mswin32/include/im_format.h +97 -0
  304. data/ext/iup-mswin32/include/im_format_all.h +575 -0
  305. data/ext/iup-mswin32/include/im_format_avi.h +88 -0
  306. data/ext/iup-mswin32/include/im_format_ecw.h +93 -0
  307. data/ext/iup-mswin32/include/im_format_jp2.h +79 -0
  308. data/ext/iup-mswin32/include/im_format_raw.h +74 -0
  309. data/ext/iup-mswin32/include/im_format_wmv.h +101 -0
  310. data/ext/iup-mswin32/include/im_image.h +425 -0
  311. data/ext/iup-mswin32/include/im_kernel.h +315 -0
  312. data/ext/iup-mswin32/include/im_lib.h +191 -0
  313. data/ext/iup-mswin32/include/im_math.h +368 -0
  314. data/ext/iup-mswin32/include/im_math_op.h +214 -0
  315. data/ext/iup-mswin32/include/im_palette.h +172 -0
  316. data/ext/iup-mswin32/include/im_plus.h +73 -0
  317. data/ext/iup-mswin32/include/im_process.h +36 -0
  318. data/ext/iup-mswin32/include/im_process_ana.h +222 -0
  319. data/ext/iup-mswin32/include/im_process_glo.h +170 -0
  320. data/ext/iup-mswin32/include/im_process_loc.h +608 -0
  321. data/ext/iup-mswin32/include/im_process_pon.h +734 -0
  322. data/ext/iup-mswin32/include/im_raw.h +34 -0
  323. data/ext/iup-mswin32/include/im_util.h +277 -0
  324. data/ext/iup-mswin32/include/imlua.h +75 -0
  325. data/ext/iup-mswin32/include/iup.h +364 -0
  326. data/ext/iup-mswin32/include/iup_pplot.h +40 -0
  327. data/ext/iup-mswin32/include/iupcb.h +1 -0
  328. data/ext/iup-mswin32/include/iupcbox.h +1 -0
  329. data/ext/iup-mswin32/include/iupcbs.h +43 -0
  330. data/ext/iup-mswin32/include/iupcells.h +1 -0
  331. data/ext/iup-mswin32/include/iupcolorbar.h +1 -0
  332. data/ext/iup-mswin32/include/iupcontrols.h +46 -0
  333. data/ext/iup-mswin32/include/iupdef.h +725 -0
  334. data/ext/iup-mswin32/include/iupdial.h +1 -0
  335. data/ext/iup-mswin32/include/iupgauge.h +1 -0
  336. data/ext/iup-mswin32/include/iupgc.h +1 -0
  337. data/ext/iup-mswin32/include/iupgetparam.h +1 -0
  338. data/ext/iup-mswin32/include/iupgl.h +96 -0
  339. data/ext/iup-mswin32/include/iupim.h +27 -0
  340. data/ext/iup-mswin32/include/iupkey.h +457 -0
  341. data/ext/iup-mswin32/include/iuplua.h +41 -0
  342. data/ext/iup-mswin32/include/iuplua_pplot.h +26 -0
  343. data/ext/iup-mswin32/include/iupluacontrols.h +27 -0
  344. data/ext/iup-mswin32/include/iupluagl.h +26 -0
  345. data/ext/iup-mswin32/include/iupluaim.h +26 -0
  346. data/ext/iup-mswin32/include/iupluaole.h +26 -0
  347. data/ext/iup-mswin32/include/iupmask.h +41 -0
  348. data/ext/iup-mswin32/include/iupmatrix.h +1 -0
  349. data/ext/iup-mswin32/include/iupole.h +24 -0
  350. data/ext/iup-mswin32/include/iupsbox.h +1 -0
  351. data/ext/iup-mswin32/include/iupspin.h +1 -0
  352. data/ext/iup-mswin32/include/iuptabs.h +1 -0
  353. data/ext/iup-mswin32/include/iuptree.h +1 -0
  354. data/ext/iup-mswin32/include/iupval.h +1 -0
  355. data/ext/iup-mswin32/include/old_im.h +59 -0
  356. data/ext/iup-mswin32/include/wd.h +83 -0
  357. data/ext/iup-mswin32/include/wd_old.h +85 -0
  358. data/ext/iup-mswin32/iup.lib +0 -0
  359. data/ext/iup-mswin32/iup_pplot.lib +0 -0
  360. data/ext/iup-mswin32/iupcd.lib +0 -0
  361. data/ext/iup-mswin32/iupcontrols.lib +0 -0
  362. data/ext/iup-mswin32/iupgl.lib +0 -0
  363. data/ext/iup-mswin32/iupgtk.lib +0 -0
  364. data/ext/iup-mswin32/iupim.lib +0 -0
  365. data/ext/{iup-win32/iupimglib.dll → iup-mswin32/iupimglib.lib} +0 -0
  366. data/ext/iup-mswin32/iupole.lib +0 -0
  367. data/ext/iup-mswin32/pdflib.lib +0 -0
  368. data/ext/iup.c +6 -37
  369. data/ext/{rb_cd.h → rb_cd.c} +300 -302
  370. data/ext/rb_iup.c +2485 -0
  371. data/ext/rb_iup.h +400 -2475
  372. data/ext/{rb_iup_pplot.h → rb_iup_pplot.c} +21 -22
  373. data/ext/{rb_iupcb.h → rb_iupcb.c} +2 -3
  374. data/ext/{rb_iupcells.h → rb_iupcells.c} +5 -5
  375. data/ext/{rb_iupcolorbar.h → rb_iupcolorbar.c} +2 -3
  376. data/ext/{rb_iupcontrols.h → rb_iupcontrols.c} +1 -1
  377. data/ext/{rb_iupdial.h → rb_iupdial.c} +3 -4
  378. data/ext/{rb_iupgauge.h → rb_iupgauge.c} +2 -3
  379. data/ext/{rb_iupgc.h → rb_iupgc.c} +1 -1
  380. data/ext/{rb_iupgetparam.h → rb_iupgetparam.c} +12 -10
  381. data/ext/{rb_iupgl.h → rb_iupgl.c} +10 -10
  382. data/ext/{rb_iupim.h → rb_iupim.c} +6 -6
  383. data/ext/{rb_iupmatrix.h → rb_iupmatrix.c} +15 -16
  384. data/ext/{rb_iupole.h → rb_iupole.c} +4 -4
  385. data/ext/{rb_iupsbox.h → rb_iupsbox.c} +3 -3
  386. data/ext/{rb_iupspin.h → rb_iupspin.c} +4 -5
  387. data/ext/{rb_iuptabs.h → rb_iuptabs.c} +5 -6
  388. data/ext/{rb_iuptree.h → rb_iuptree.c} +20 -21
  389. data/ext/{rb_iupval.h → rb_iupval.c} +3 -4
  390. data/ruby-iup.gemspec +26 -0
  391. data/test/test_ruby_iup.rb +25 -0
  392. metadata +395 -270
  393. data/ext/iup-linux/include/lauxlib.h +0 -174
  394. data/ext/iup-linux/include/lua.h +0 -388
  395. data/ext/iup-linux/include/lua.hpp +0 -9
  396. data/ext/iup-linux/include/luaconf.h +0 -763
  397. data/ext/iup-linux/include/lualib.h +0 -53
  398. data/ext/iup-linux/libcd.so +0 -0
  399. data/ext/iup-linux/libcdcontextplus.so +0 -0
  400. data/ext/iup-linux/libcdpdf.so +0 -0
  401. data/ext/iup-linux/libfreetype.so +0 -0
  402. data/ext/iup-linux/libim.so +0 -0
  403. data/ext/iup-linux/libim_fftw.so +0 -0
  404. data/ext/iup-linux/libim_jp2.so +0 -0
  405. data/ext/iup-linux/libim_process.so +0 -0
  406. data/ext/iup-linux/libiup.so +0 -0
  407. data/ext/iup-linux/libiup_pplot.so +0 -0
  408. data/ext/iup-linux/libiupcd.so +0 -0
  409. data/ext/iup-linux/libiupcontrols.so +0 -0
  410. data/ext/iup-linux/libiupgl.so +0 -0
  411. data/ext/iup-linux/libiupim.so +0 -0
  412. data/ext/iup-linux/libiupimglib.so +0 -0
  413. data/ext/iup-linux/libiupmot.so +0 -0
  414. data/ext/iup-linux/libpdflib.so +0 -0
  415. data/ext/iup-win32/cd.dll +0 -0
  416. data/ext/iup-win32/cd.lib +0 -0
  417. data/ext/iup-win32/cdcontextplus.dll +0 -0
  418. data/ext/iup-win32/cdcontextplus.lib +0 -0
  419. data/ext/iup-win32/cdpdf.dll +0 -0
  420. data/ext/iup-win32/cdpdf.lib +0 -0
  421. data/ext/iup-win32/freetype6.dll +0 -0
  422. data/ext/iup-win32/freetype6.lib +0 -0
  423. data/ext/iup-win32/im.dll +0 -0
  424. data/ext/iup-win32/im.lib +0 -0
  425. data/ext/iup-win32/im_avi.dll +0 -0
  426. data/ext/iup-win32/im_avi.lib +0 -0
  427. data/ext/iup-win32/im_capture.dll +0 -0
  428. data/ext/iup-win32/im_capture.lib +0 -0
  429. data/ext/iup-win32/im_ecw.dll +0 -0
  430. data/ext/iup-win32/im_fftw.dll +0 -0
  431. data/ext/iup-win32/im_fftw.lib +0 -0
  432. data/ext/iup-win32/im_jp2.dll +0 -0
  433. data/ext/iup-win32/im_jp2.lib +0 -0
  434. data/ext/iup-win32/im_process.dll +0 -0
  435. data/ext/iup-win32/im_process.lib +0 -0
  436. data/ext/iup-win32/im_wmv.dll +0 -0
  437. data/ext/iup-win32/im_wmv.lib +0 -0
  438. data/ext/iup-win32/imlua_capture51.dll +0 -0
  439. data/ext/iup-win32/imlua_capture51.lib +0 -0
  440. data/ext/iup-win32/imlua_wmv51.dll +0 -0
  441. data/ext/iup-win32/imlua_wmv51.lib +0 -0
  442. data/ext/iup-win32/include/iupcb.h +0 -25
  443. data/ext/iup-win32/include/iupcells.h +0 -130
  444. data/ext/iup-win32/include/iupcolorbar.h +0 -126
  445. data/ext/iup-win32/include/iupcontrols.h +0 -36
  446. data/ext/iup-win32/include/iupdial.h +0 -63
  447. data/ext/iup-win32/include/iupgauge.h +0 -57
  448. data/ext/iup-win32/include/iupgetparam.h +0 -27
  449. data/ext/iup-win32/include/iupmatrix.h +0 -63
  450. data/ext/iup-win32/include/iupspin.h +0 -21
  451. data/ext/iup-win32/include/iuptabs.h +0 -75
  452. data/ext/iup-win32/include/iuptree.h +0 -93
  453. data/ext/iup-win32/include/iupval.h +0 -46
  454. data/ext/iup-win32/iup.dll +0 -0
  455. data/ext/iup-win32/iup.lib +0 -0
  456. data/ext/iup-win32/iup_pplot.dll +0 -0
  457. data/ext/iup-win32/iup_pplot.lib +0 -0
  458. data/ext/iup-win32/iupcd.dll +0 -0
  459. data/ext/iup-win32/iupcd.lib +0 -0
  460. data/ext/iup-win32/iupcontrols.dll +0 -0
  461. data/ext/iup-win32/iupcontrols.lib +0 -0
  462. data/ext/iup-win32/iupgl.dll +0 -0
  463. data/ext/iup-win32/iupgl.lib +0 -0
  464. data/ext/iup-win32/iupgtk.dll +0 -0
  465. data/ext/iup-win32/iupgtk.lib +0 -0
  466. data/ext/iup-win32/iupim.dll +0 -0
  467. data/ext/iup-win32/iupim.lib +0 -0
  468. data/ext/iup-win32/iupimglib.lib +0 -0
  469. data/ext/iup-win32/iupole.dll +0 -0
  470. data/ext/iup-win32/iupole.lib +0 -0
  471. data/ext/iup-win32/iupstub.lib +0 -0
  472. data/ext/iup-win32/pdflib.dll +0 -0
  473. data/ext/iup-win32/pdflib.lib +0 -0
  474. data/ext/mkrf_conf.rb +0 -72
  475. data/ext/rb_iupcompat.h +0 -237
  476. data/ext/rb_iupdef.h +0 -3
  477. data/ext/rb_iupmask.h +0 -189
  478. data/lib/README +0 -1
@@ -1,116 +1,120 @@
1
- /** \file
2
- * \brief Attributes Table.
3
- *
4
- * See Copyright Notice in im_lib.h
5
- */
6
-
7
- #ifndef __IM_ATTRIB_H_
8
- #define __IM_ATTRIB_H_
9
-
10
- #include "im_attrib_flat.h"
11
-
12
- /** \brief Attributes Table.
13
- *
14
- * \par
15
- * All the attributes have a name, a type, a count and the data.\n
16
- * Names are usually strings with less that 30 chars.
17
- * \par
18
- * Attributes are stored in a hash table for fast access. \n
19
- * We use the hash function described in "The Pratice of Programming" of Kernighan & Pike.
20
- * \ingroup util */
21
- class imAttribTable
22
- {
23
- imAttribTablePrivate* ptable;
24
- public:
25
-
26
- /** Creates an empty table.
27
- * If size is zero the default size of 101 is used. Size must be a prime number.
28
- * Other common values are 67, 599 and 1499.*/
29
- imAttribTable(int hash_size)
30
- { ptable = imAttribTableCreate(hash_size); }
31
-
32
- /** Destroys the table and all the attributes. */
33
- ~imAttribTable()
34
- { imAttribTableDestroy(ptable); ptable = 0; }
35
-
36
- /** Returns the number of elements in the table. */
37
- int Count() const
38
- { return imAttribTableCount(ptable); }
39
-
40
- /** Removes all the attributes in the table */
41
- void RemoveAll()
42
- { imAttribTableRemoveAll(ptable); }
43
-
44
- /** Copies the contents of the given table into this table. */
45
- void CopyFrom(const imAttribTable& table)
46
- { imAttribTableCopyFrom(ptable, table.ptable); }
47
-
48
- /** Inserts an attribute into the table. \n
49
- * Data is duplicated if not NULL, else data is initialized with zeros.
50
- * See also \ref imDataType. */
51
- void Set(const char* name, int data_type, int count, const void* data)
52
- { imAttribTableSet(ptable, name, data_type, count, data); }
53
-
54
- /** Removes an attribute from the table given its name. */
55
- void UnSet(const char *name)
56
- { imAttribTableUnSet(ptable, name); }
57
-
58
- /** Finds an attribute in the table.
59
- * Returns the attribute if found, NULL otherwise.
60
- * See also \ref imDataType. */
61
- const void* Get(const char *name, int *data_type = 0, int *count = 0) const
62
- { return imAttribTableGet(ptable, name, data_type, count); }
63
-
64
- /** For each attribute calls the user callback. If the callback returns 0 the function returns. */
65
- void ForEach(void* user_data, imAttribTableCallback attrib_func) const
66
- { imAttribTableForEach(ptable, user_data, attrib_func); }
67
- };
68
-
69
- /** \brief Attributes Table.
70
- *
71
- * \par
72
- * Same as \ref imAttribTable, but uses an array of fixed size.
73
- * \ingroup util */
74
- class imAttribArray
75
- {
76
- imAttribTablePrivate* ptable;
77
- public:
78
-
79
- /** Creates an empty array. */
80
- imAttribArray(int count)
81
- { ptable = imAttribArrayCreate(count); }
82
-
83
- /** Destroys the array and all the attributes. */
84
- ~imAttribArray()
85
- { imAttribTableDestroy(ptable); ptable = 0; }
86
-
87
- /** Returns the number of elements in the array. */
88
- int Count() const
89
- { return imAttribTableCount(ptable); }
90
-
91
- /** Removes all the attributes in the array */
92
- void RemoveAll()
93
- { imAttribTableRemoveAll(ptable); }
94
-
95
- /** Copies the contents of the given table into this table. */
96
- void CopyFrom(const imAttribArray& table)
97
- { imAttribArrayCopyFrom(ptable, table.ptable); }
98
-
99
- /** Inserts an attribute into the array. \n
100
- * Data is duplicated if not NULL, else data is initialized with zeros.
101
- * See also \ref imDataType. */
102
- void Set(int index, const char* name, int data_type, int count, const void* data)
103
- { imAttribArraySet(ptable, index, name, data_type, count, data); }
104
-
105
- /** Finds an attribute in the array.
106
- * Returns the attribute if found, NULL otherwise.
107
- * See also \ref imDataType. */
108
- const void* Get(int index, char *name = 0, int *data_type = 0, int *count = 0) const
109
- { return imAttribArrayGet(ptable, index, name, data_type, count); }
110
-
111
- /** For each attribute calls the user callback. If the callback returns 0 the function returns. */
112
- void ForEach(void* user_data, imAttribTableCallback attrib_func) const
113
- { imAttribTableForEach(ptable, user_data, attrib_func); }
114
- };
115
-
116
- #endif
1
+ /** \file
2
+ * \brief Attributes Table.
3
+ *
4
+ * See Copyright Notice in im_lib.h
5
+ */
6
+
7
+ #ifndef __IM_ATTRIB_H_
8
+ #define __IM_ATTRIB_H_
9
+
10
+ #include "im_attrib_flat.h"
11
+
12
+ /** \brief Attributes Table.
13
+ *
14
+ * \par
15
+ * All the attributes have a name, a type, a count and the data.\n
16
+ * Names are usually strings with less that 30 chars.
17
+ * \par
18
+ * Attributes are stored in a hash table for fast access. \n
19
+ * We use the hash function described in "The Pratice of Programming" of Kernighan & Pike.
20
+ * \ingroup util */
21
+ class imAttribTable
22
+ {
23
+ imAttribTablePrivate* ptable;
24
+ public:
25
+
26
+ /** Creates an empty table.
27
+ * If size is zero the default size of 101 is used. Size must be a prime number.
28
+ * Other common values are 67, 599 and 1499.*/
29
+ imAttribTable(int hash_size)
30
+ { ptable = imAttribTableCreate(hash_size); }
31
+
32
+ /** Destroys the table and all the attributes. */
33
+ ~imAttribTable()
34
+ { imAttribTableDestroy(ptable); ptable = 0; }
35
+
36
+ /** Returns the number of elements in the table. */
37
+ int Count() const
38
+ { return imAttribTableCount(ptable); }
39
+
40
+ /** Removes all the attributes in the table */
41
+ void RemoveAll()
42
+ { imAttribTableRemoveAll(ptable); }
43
+
44
+ /** Copies the contents of the given table into this table. */
45
+ void CopyFrom(const imAttribTable& table)
46
+ { imAttribTableCopyFrom(ptable, table.ptable); }
47
+
48
+ /** Inserts an attribute into the table. \n
49
+ * If data_type is BYTE then count can be -1 to indicate a NULL terminated string.
50
+ * Data is duplicated if not NULL, else data is initialized with zeros.
51
+ * See also \ref imDataType. */
52
+ void Set(const char* name, int data_type, int count, const void* data)
53
+ { imAttribTableSet(ptable, name, data_type, count, data); }
54
+
55
+ /** Removes an attribute from the table given its name. */
56
+ void UnSet(const char *name)
57
+ { imAttribTableUnSet(ptable, name); }
58
+
59
+ /** Finds an attribute in the table.
60
+ * Returns the attribute if found, NULL otherwise.
61
+ * See also \ref imDataType. */
62
+ const void* Get(const char *name, int *data_type = 0, int *count = 0) const
63
+ { return imAttribTableGet(ptable, name, data_type, count); }
64
+
65
+ /** For each attribute calls the user callback. If the callback returns 0 the function returns. */
66
+ void ForEach(void* user_data, imAttribTableCallback attrib_func) const
67
+ { imAttribTableForEach(ptable, user_data, attrib_func); }
68
+ };
69
+
70
+ /** \brief Attributes Table.
71
+ *
72
+ * \par
73
+ * Same as \ref imAttribTable, but uses an array of fixed size.
74
+ * \ingroup util */
75
+ class imAttribArray
76
+ {
77
+ imAttribTablePrivate* ptable;
78
+ public:
79
+
80
+ /** Creates an empty array. */
81
+ imAttribArray(int count)
82
+ { ptable = imAttribArrayCreate(count); }
83
+
84
+ /** Destroys the array and all the attributes. */
85
+ ~imAttribArray()
86
+ { imAttribTableDestroy(ptable); ptable = 0; }
87
+
88
+ /** Returns the number of elements in the array. */
89
+ int Count() const
90
+ { return imAttribTableCount(ptable); }
91
+
92
+ /** Removes all the attributes in the array */
93
+ void RemoveAll()
94
+ { imAttribTableRemoveAll(ptable); }
95
+
96
+ /** Copies the contents of the given table into this table. */
97
+ void CopyFrom(const imAttribArray& table)
98
+ { imAttribArrayCopyFrom(ptable, table.ptable); }
99
+
100
+ /** Inserts one attribute into the array.
101
+ * The attribute data is a simple array of data_type elements of count length. \n
102
+ * Data is duplicated if not NULL, else data is initialized with zeros.
103
+ * When NULL is specified use the Get method to retrieve a pointer to the data
104
+ * so you can initialize it with other values.
105
+ * See also \ref imDataType. */
106
+ void Set(int index, const char* name, int data_type, int count, const void* data)
107
+ { imAttribArraySet(ptable, index, name, data_type, count, data); }
108
+
109
+ /** Finds one attribute in the array.
110
+ * Returns the attribute if found, NULL otherwise.
111
+ * See also \ref imDataType. */
112
+ const void* Get(int index, char *name = 0, int *data_type = 0, int *count = 0) const
113
+ { return imAttribArrayGet(ptable, index, name, data_type, count); }
114
+
115
+ /** For each attribute calls the user callback. If the callback returns 0 the function returns. */
116
+ void ForEach(void* user_data, imAttribTableCallback attrib_func) const
117
+ { imAttribTableForEach(ptable, user_data, attrib_func); }
118
+ };
119
+
120
+ #endif
@@ -1,39 +1,39 @@
1
- /** \file
2
- * \brief Attributes Table Flat API.
3
- * This will simplify the DLL export, and can be used for C aplications.
4
- *
5
- * See Copyright Notice in im_lib.h
6
- */
7
-
8
- #ifndef __IM_ATTRIB_FLAT_H_
9
- #define __IM_ATTRIB_FLAT_H_
10
-
11
- #if defined(__cplusplus)
12
- extern "C" {
13
- #endif
14
-
15
- struct imAttribTablePrivate;
16
-
17
- /** Definition of the callback used in ForEach function. */
18
- typedef int (*imAttribTableCallback)(void* user_data, int index, const char* name, int data_type, int count, const void* data);
19
-
20
- imAttribTablePrivate* imAttribTableCreate(int hash_size);
21
- void imAttribTableDestroy(imAttribTablePrivate* ptable);
22
- int imAttribTableCount(imAttribTablePrivate* ptable);
23
- void imAttribTableRemoveAll(imAttribTablePrivate* ptable);
24
- const void* imAttribTableGet(const imAttribTablePrivate* ptable, const char *name, int *data_type, int *count);
25
- void imAttribTableSet(imAttribTablePrivate* ptable, const char* name, int data_type, int count, const void* data);
26
- void imAttribTableUnSet(imAttribTablePrivate* ptable, const char *name);
27
- void imAttribTableCopyFrom(imAttribTablePrivate* ptable_dst, const imAttribTablePrivate* ptable_src);
28
- void imAttribTableForEach(const imAttribTablePrivate* ptable, void* user_data, imAttribTableCallback attrib_func);
29
-
30
- imAttribTablePrivate* imAttribArrayCreate(int hash_size);
31
- const void* imAttribArrayGet(const imAttribTablePrivate* ptable, int index, char *name, int *data_type, int *count);
32
- void imAttribArraySet(imAttribTablePrivate* ptable, int index, const char* name, int data_type, int count, const void* data);
33
- void imAttribArrayCopyFrom(imAttribTablePrivate* ptable_dst, const imAttribTablePrivate* ptable_src);
34
-
35
- #if defined(__cplusplus)
36
- }
37
- #endif
38
-
39
- #endif
1
+ /** \file
2
+ * \brief Attributes Table Flat API.
3
+ * This will simplify the DLL export, and can be used for C aplications.
4
+ *
5
+ * See Copyright Notice in im_lib.h
6
+ */
7
+
8
+ #ifndef __IM_ATTRIB_FLAT_H_
9
+ #define __IM_ATTRIB_FLAT_H_
10
+
11
+ #if defined(__cplusplus)
12
+ extern "C" {
13
+ #endif
14
+
15
+ struct imAttribTablePrivate;
16
+
17
+ /** Definition of the callback used in ForEach function. */
18
+ typedef int (*imAttribTableCallback)(void* user_data, int index, const char* name, int data_type, int count, const void* data);
19
+
20
+ imAttribTablePrivate* imAttribTableCreate(int hash_size);
21
+ void imAttribTableDestroy(imAttribTablePrivate* ptable);
22
+ int imAttribTableCount(imAttribTablePrivate* ptable);
23
+ void imAttribTableRemoveAll(imAttribTablePrivate* ptable);
24
+ const void* imAttribTableGet(const imAttribTablePrivate* ptable, const char *name, int *data_type, int *count);
25
+ void imAttribTableSet(imAttribTablePrivate* ptable, const char* name, int data_type, int count, const void* data);
26
+ void imAttribTableUnSet(imAttribTablePrivate* ptable, const char *name);
27
+ void imAttribTableCopyFrom(imAttribTablePrivate* ptable_dst, const imAttribTablePrivate* ptable_src);
28
+ void imAttribTableForEach(const imAttribTablePrivate* ptable, void* user_data, imAttribTableCallback attrib_func);
29
+
30
+ imAttribTablePrivate* imAttribArrayCreate(int hash_size);
31
+ const void* imAttribArrayGet(const imAttribTablePrivate* ptable, int index, char *name, int *data_type, int *count);
32
+ void imAttribArraySet(imAttribTablePrivate* ptable, int index, const char* name, int data_type, int count, const void* data);
33
+ void imAttribArrayCopyFrom(imAttribTablePrivate* ptable_dst, const imAttribTablePrivate* ptable_src);
34
+
35
+ #if defined(__cplusplus)
36
+ }
37
+ #endif
38
+
39
+ #endif
@@ -1,214 +1,224 @@
1
- /** \file
2
- * \brief Binary File Access.
3
- *
4
- * See Copyright Notice in im_lib.h
5
- */
6
-
7
- #include "im_util.h"
8
-
9
- #ifndef __IM_BINFILE_H
10
- #define __IM_BINFILE_H
11
-
12
- #if defined(__cplusplus)
13
- extern "C" {
14
- #endif
15
-
16
-
17
- /** \defgroup binfile Binary File Access
18
- *
19
- * \par
20
- * These functions are very usefull for reading/writing binary files
21
- * that have headers or data that have to be converted depending on
22
- * the current CPU byte order. It can invert 2, 4 or 8 bytes numbers to/from little/big-endian orders.
23
- * \par
24
- * It will process the data only if the file format is diferent from the current CPU.
25
- * \par
26
- * Can read from disk or memory. In case of a memory buffer, the file name must be the \ref imBinMemoryFileName structure.
27
- * \par
28
- * See \ref im_binfile.h
29
- * \ingroup util */
30
-
31
- typedef struct _imBinFile imBinFile;
32
-
33
- /** Opens an existant binary file for reading.
34
- * The default file byte order is the CPU byte order.
35
- * Returns NULL if failed.
36
- * \ingroup binfile */
37
- imBinFile* imBinFileOpen(const char* pFileName);
38
-
39
- /** Creates a new binary file for writing.
40
- * The default file byte order is the CPU byte order.
41
- * Returns NULL if failed.
42
- * \ingroup binfile */
43
- imBinFile* imBinFileNew(const char* pFileName);
44
-
45
- /** Closes the file.
46
- * \ingroup binfile */
47
- void imBinFileClose(imBinFile* bfile);
48
-
49
- /** Indicates that was an error on the last operation.
50
- * \ingroup binfile */
51
- int imBinFileError(imBinFile* bfile);
52
-
53
- /** Returns the file size in bytes.
54
- * \ingroup binfile */
55
- unsigned long imBinFileSize(imBinFile* bfile);
56
-
57
- /** Changes the file byte order. Returns the old one.
58
- * \ingroup binfile */
59
- int imBinFileByteOrder(imBinFile* bfile, int pByteOrder);
60
-
61
- /** Reads an array of count values with byte sizes: 1, 2, 4, or 8. And invert the byte order if necessary after read.
62
- * \ingroup binfile */
63
- unsigned long imBinFileRead(imBinFile* bfile, void* pValues, unsigned long pCount, int pSizeOf);
64
-
65
- /** Writes an array of values with sizes: 1, 2, 4, or 8. And invert the byte order if necessary before write.\n
66
- * <b>ATENTION</b>: The function will not make a temporary copy of the values to invert the byte order.\n
67
- * So after the call the values will be invalid, if the file byte order is diferent from the CPU byte order.
68
- * \ingroup binfile */
69
- unsigned long imBinFileWrite(imBinFile* bfile, void* pValues, unsigned long pCount, int pSizeOf);
70
-
71
- /** Writes a string without the NULL terminator. The function uses sprintf to compose the string. \n
72
- * The internal buffer is fixed at 4096 bytes.
73
- * \ingroup binfile */
74
- unsigned long imBinFilePrintf(imBinFile* bfile, char *format, ...);
75
-
76
- /** Moves the file pointer from the begining of the file.\n
77
- * When writing to a file seeking can go beyond the end of the file.
78
- * \ingroup binfile */
79
- void imBinFileSeekTo(imBinFile* bfile, unsigned long pOffset);
80
-
81
- /** Moves the file pointer from current position.\n
82
- * If the offset is a negative value the pointer moves backwards.
83
- * \ingroup binfile */
84
- void imBinFileSeekOffset(imBinFile* bfile, long pOffset);
85
-
86
- /** Moves the file pointer from the end of the file.\n
87
- * The offset is usually a negative value.
88
- * \ingroup binfile */
89
- void imBinFileSeekFrom(imBinFile* bfile, long pOffset);
90
-
91
- /** Returns the current offset position.
92
- * \ingroup binfile */
93
- unsigned long imBinFileTell(imBinFile* bfile);
94
-
95
- /** Indicates that the file pointer is at the end of the file.
96
- * \ingroup binfile */
97
- int imBinFileEndOfFile(imBinFile* bfile);
98
-
99
- /** Predefined I/O Modules.
100
- * \ingroup binfile */
101
- enum imBinFileModule
102
- {
103
- IM_RAWFILE, /**< System dependent file I/O Rotines. */
104
- IM_STREAM, /**< Standard Ansi C Stream I/O Rotines. */
105
- IM_MEMFILE, /**< Uses a memory buffer (see \ref imBinMemoryFileName). */
106
- IM_SUBFILE, /**< It is a sub file. FileName is a imBinFile* pointer from any other module. */
107
- IM_FILEHANDLE,/**< System dependent file I/O Rotines, but FileName is a system file handle ("int" in UNIX and "HANDLE" in Windows). */
108
- IM_IOCUSTOM0 /**< Other registered modules starts from here. */
109
- };
110
-
111
- /** Sets the current I/O module.
112
- * \returns the previous function set, or -1 if failed.
113
- * See also \ref imBinFileModule.
114
- * \ingroup binfile */
115
- int imBinFileSetCurrentModule(int pModule);
116
-
117
- /** \brief Memory File I/O Filename
118
- *
119
- * \par
120
- * Fake file name for the memory I/O module.
121
- * \ingroup binfile */
122
- typedef struct _imBinMemoryFileName
123
- {
124
- unsigned char *buffer; /**< The memory buffer. If you are reading the buffer must exists.
125
- * If you are writing the buffer can be internally allocated to the given size. The buffer is never free.
126
- * The buffer is allocated using "malloc", and reallocated using "realloc". Use "free" to release it.
127
- * To avoid RTL conflicts use the function imBinMemoryRelease. */
128
- int size; /**< Size of the buffer. */
129
- float reallocate; /**< Reallocate factor for the memory buffer when writing (size += reallocate*size).
130
- * Set reallocate to 0 to disable reallocation, in this case buffer must not be NULL. */
131
- }imBinMemoryFileName;
132
-
133
- /** Release the internal memory allocated when writing a Memory File (see \ref imBinMemoryFileName).
134
- * \ingroup binfile */
135
- void imBinMemoryRelease(unsigned char *buffer);
136
-
137
-
138
- #if defined(__cplusplus)
139
- }
140
- #endif
141
-
142
-
143
- #if defined(__cplusplus)
144
-
145
- /** Base class to help the creation of new modules.\n
146
- * It handles the read/write operations with byte order correction if necessary.
147
- * \ingroup binfile */
148
- class imBinFileBase
149
- {
150
- friend class imBinSubFile;
151
-
152
- protected:
153
- int IsNew,
154
- FileByteOrder,
155
- DoByteOrder; // to speed up byte order checking
156
-
157
- // These will actually read/write the data
158
- virtual unsigned long ReadBuf(void* pValues, unsigned long pSize) = 0;
159
- virtual unsigned long WriteBuf(void* pValues, unsigned long pSize) = 0;
160
-
161
- public:
162
-
163
- int InitByteOrder(int ByteOrder)
164
- {
165
- int old_byte_order = this->FileByteOrder;
166
- this->FileByteOrder = ByteOrder;
167
-
168
- if (ByteOrder != imBinCPUByteOrder())
169
- this->DoByteOrder = 1;
170
- else
171
- this->DoByteOrder = 0;
172
- return old_byte_order;
173
- }
174
-
175
- // These will take care of byte swap if needed.
176
-
177
- unsigned long Read(void* pValues, unsigned long pCount, int pSizeOf)
178
- {
179
- unsigned long rSize = ReadBuf(pValues, pCount * pSizeOf);
180
- if (pSizeOf != 1 && DoByteOrder) imBinSwapBytes(pValues, pCount, pSizeOf);
181
- return rSize/pSizeOf;
182
- }
183
-
184
- unsigned long Write(void* pValues, unsigned long pCount, int pSizeOf)
185
- {
186
- if (pSizeOf != 1 && DoByteOrder) imBinSwapBytes(pValues, pCount, pSizeOf);
187
- return WriteBuf(pValues, pCount * pSizeOf)/pSizeOf;
188
- }
189
-
190
- virtual void Open(const char* pFileName) = 0;
191
- virtual void New(const char* pFileName) = 0;
192
- virtual void Close() = 0;
193
- virtual unsigned long FileSize() = 0;
194
- virtual int HasError() const = 0;
195
- virtual void SeekTo(unsigned long pOffset) = 0;
196
- virtual void SeekOffset(long pOffset) = 0;
197
- virtual void SeekFrom(long pOffset) = 0;
198
- virtual unsigned long Tell() const = 0;
199
- virtual int EndOfFile() const = 0;
200
- };
201
-
202
- /** File I/O module creation callback.
203
- * \ingroup binfile */
204
- typedef imBinFileBase* (*imBinFileNewFunc)();
205
-
206
- /** Register a user I/O module.\n
207
- * Returns the new function set id.\n
208
- * Accepts up to 10 modules.
209
- * \ingroup binfile */
210
- int imBinFileRegisterModule(imBinFileNewFunc pNewFunc);
211
-
212
- #endif
213
-
214
- #endif
1
+ /** \file
2
+ * \brief Binary File Access.
3
+ *
4
+ * See Copyright Notice in im_lib.h
5
+ */
6
+
7
+ #include "im_util.h"
8
+
9
+ #ifndef __IM_BINFILE_H
10
+ #define __IM_BINFILE_H
11
+
12
+ #if defined(__cplusplus)
13
+ extern "C" {
14
+ #endif
15
+
16
+
17
+ /** \defgroup binfile Binary File Access
18
+ *
19
+ * \par
20
+ * These functions are very usefull for reading/writing binary files
21
+ * that have headers or data that have to be converted depending on
22
+ * the current CPU byte order. It can invert 2, 4 or 8 bytes numbers to/from little/big-endian orders.
23
+ * \par
24
+ * It will process the data only if the file format is diferent from the current CPU.
25
+ * \par
26
+ * Can read from disk or memory. In case of a memory buffer, the file name must be the \ref imBinMemoryFileName structure.
27
+ * \par
28
+ * See \ref im_binfile.h
29
+ * \ingroup util */
30
+
31
+ typedef struct _imBinFile imBinFile;
32
+
33
+ /** Opens an existant binary file for reading.
34
+ * The default file byte order is the CPU byte order.
35
+ * Returns NULL if failed.
36
+ * \ingroup binfile */
37
+ imBinFile* imBinFileOpen(const char* pFileName);
38
+
39
+ /** Creates a new binary file for writing.
40
+ * The default file byte order is the CPU byte order.
41
+ * Returns NULL if failed.
42
+ * \ingroup binfile */
43
+ imBinFile* imBinFileNew(const char* pFileName);
44
+
45
+ /** Closes the file.
46
+ * \ingroup binfile */
47
+ void imBinFileClose(imBinFile* bfile);
48
+
49
+ /** Indicates that was an error on the last operation.
50
+ * \ingroup binfile */
51
+ int imBinFileError(imBinFile* bfile);
52
+
53
+ /** Returns the file size in bytes.
54
+ * \ingroup binfile */
55
+ unsigned long imBinFileSize(imBinFile* bfile);
56
+
57
+ /** Changes the file byte order. Returns the old one.
58
+ * \ingroup binfile */
59
+ int imBinFileByteOrder(imBinFile* bfile, int pByteOrder);
60
+
61
+ /** Reads an array of count values with byte sizes: 1, 2, 4, or 8. And invert the byte order if necessary after read.
62
+ * \ingroup binfile */
63
+ unsigned long imBinFileRead(imBinFile* bfile, void* pValues, unsigned long pCount, int pSizeOf);
64
+
65
+ /** Writes an array of values with sizes: 1, 2, 4, or 8. And invert the byte order if necessary before write.\n
66
+ * <b>ATENTION</b>: The function will not make a temporary copy of the values to invert the byte order.\n
67
+ * So after the call the values will be invalid, if the file byte order is diferent from the CPU byte order.
68
+ * \ingroup binfile */
69
+ unsigned long imBinFileWrite(imBinFile* bfile, void* pValues, unsigned long pCount, int pSizeOf);
70
+
71
+ /** Writes a string without the NULL terminator. The function uses sprintf to compose the string. \n
72
+ * The internal buffer is fixed at 4096 bytes.
73
+ * \ingroup binfile */
74
+ unsigned long imBinFilePrintf(imBinFile* bfile, char *format, ...);
75
+
76
+ /** Reads an integer number from the current position until found a non integer character.
77
+ * Returns a non zero value if sucessfull.
78
+ * \ingroup binfile */
79
+ int imBinFileReadInteger(imBinFile* handle, int *value);
80
+
81
+ /** Reads an floating point number from the current position until found a non number character.
82
+ * Returns a non zero value if sucessfull.
83
+ * \ingroup binfile */
84
+ int imBinFileReadFloat(imBinFile* handle, float *value);
85
+
86
+ /** Moves the file pointer from the begining of the file.\n
87
+ * When writing to a file seeking can go beyond the end of the file.
88
+ * \ingroup binfile */
89
+ void imBinFileSeekTo(imBinFile* bfile, unsigned long pOffset);
90
+
91
+ /** Moves the file pointer from current position.\n
92
+ * If the offset is a negative value the pointer moves backwards.
93
+ * \ingroup binfile */
94
+ void imBinFileSeekOffset(imBinFile* bfile, long pOffset);
95
+
96
+ /** Moves the file pointer from the end of the file.\n
97
+ * The offset is usually a negative value.
98
+ * \ingroup binfile */
99
+ void imBinFileSeekFrom(imBinFile* bfile, long pOffset);
100
+
101
+ /** Returns the current offset position.
102
+ * \ingroup binfile */
103
+ unsigned long imBinFileTell(imBinFile* bfile);
104
+
105
+ /** Indicates that the file pointer is at the end of the file.
106
+ * \ingroup binfile */
107
+ int imBinFileEndOfFile(imBinFile* bfile);
108
+
109
+ /** Predefined I/O Modules.
110
+ * \ingroup binfile */
111
+ enum imBinFileModule
112
+ {
113
+ IM_RAWFILE, /**< System dependent file I/O Rotines. */
114
+ IM_STREAM, /**< Standard Ansi C Stream I/O Rotines. */
115
+ IM_MEMFILE, /**< Uses a memory buffer (see \ref imBinMemoryFileName). */
116
+ IM_SUBFILE, /**< It is a sub file. FileName is a imBinFile* pointer from any other module. */
117
+ IM_FILEHANDLE,/**< System dependent file I/O Rotines, but FileName is a system file handle ("int" in UNIX and "HANDLE" in Windows). */
118
+ IM_IOCUSTOM0 /**< Other registered modules starts from here. */
119
+ };
120
+
121
+ /** Sets the current I/O module.
122
+ * \returns the previous function set, or -1 if failed.
123
+ * See also \ref imBinFileModule.
124
+ * \ingroup binfile */
125
+ int imBinFileSetCurrentModule(int pModule);
126
+
127
+ /** \brief Memory File I/O Filename
128
+ *
129
+ * \par
130
+ * Fake file name for the memory I/O module.
131
+ * \ingroup binfile */
132
+ typedef struct _imBinMemoryFileName
133
+ {
134
+ unsigned char *buffer; /**< The memory buffer. If you are reading the buffer must exists.
135
+ * If you are writing the buffer can be internally allocated to the given size. The buffer is never free.
136
+ * The buffer is allocated using "malloc", and reallocated using "realloc". Use "free" to release it.
137
+ * To avoid RTL conflicts use the function imBinMemoryRelease. */
138
+ int size; /**< Size of the buffer. */
139
+ float reallocate; /**< Reallocate factor for the memory buffer when writing (size += reallocate*size).
140
+ * Set reallocate to 0 to disable reallocation, in this case buffer must not be NULL. */
141
+ }imBinMemoryFileName;
142
+
143
+ /** Release the internal memory allocated when writing a Memory File (see \ref imBinMemoryFileName).
144
+ * \ingroup binfile */
145
+ void imBinMemoryRelease(unsigned char *buffer);
146
+
147
+
148
+ #if defined(__cplusplus)
149
+ }
150
+ #endif
151
+
152
+
153
+ #if defined(__cplusplus)
154
+
155
+ /** Base class to help the creation of new modules.\n
156
+ * It handles the read/write operations with byte order correction if necessary.
157
+ * \ingroup binfile */
158
+ class imBinFileBase
159
+ {
160
+ friend class imBinSubFile;
161
+
162
+ protected:
163
+ int IsNew,
164
+ FileByteOrder,
165
+ DoByteOrder; // to speed up byte order checking
166
+
167
+ // These will actually read/write the data
168
+ virtual unsigned long ReadBuf(void* pValues, unsigned long pSize) = 0;
169
+ virtual unsigned long WriteBuf(void* pValues, unsigned long pSize) = 0;
170
+
171
+ public:
172
+
173
+ int InitByteOrder(int ByteOrder)
174
+ {
175
+ int old_byte_order = this->FileByteOrder;
176
+ this->FileByteOrder = ByteOrder;
177
+
178
+ if (ByteOrder != imBinCPUByteOrder())
179
+ this->DoByteOrder = 1;
180
+ else
181
+ this->DoByteOrder = 0;
182
+ return old_byte_order;
183
+ }
184
+
185
+ // These will take care of byte swap if needed.
186
+
187
+ unsigned long Read(void* pValues, unsigned long pCount, int pSizeOf)
188
+ {
189
+ unsigned long rSize = ReadBuf(pValues, pCount * pSizeOf);
190
+ if (pSizeOf != 1 && DoByteOrder) imBinSwapBytes(pValues, pCount, pSizeOf);
191
+ return rSize/pSizeOf;
192
+ }
193
+
194
+ unsigned long Write(void* pValues, unsigned long pCount, int pSizeOf)
195
+ {
196
+ if (pSizeOf != 1 && DoByteOrder) imBinSwapBytes(pValues, pCount, pSizeOf);
197
+ return WriteBuf(pValues, pCount * pSizeOf)/pSizeOf;
198
+ }
199
+
200
+ virtual void Open(const char* pFileName) = 0;
201
+ virtual void New(const char* pFileName) = 0;
202
+ virtual void Close() = 0;
203
+ virtual unsigned long FileSize() = 0;
204
+ virtual int HasError() const = 0;
205
+ virtual void SeekTo(unsigned long pOffset) = 0;
206
+ virtual void SeekOffset(long pOffset) = 0;
207
+ virtual void SeekFrom(long pOffset) = 0;
208
+ virtual unsigned long Tell() const = 0;
209
+ virtual int EndOfFile() const = 0;
210
+ };
211
+
212
+ /** File I/O module creation callback.
213
+ * \ingroup binfile */
214
+ typedef imBinFileBase* (*imBinFileNewFunc)();
215
+
216
+ /** Register a user I/O module.\n
217
+ * Returns the new function set id.\n
218
+ * Accepts up to 10 modules.
219
+ * \ingroup binfile */
220
+ extern "C" int imBinFileRegisterModule(imBinFileNewFunc pNewFunc);
221
+
222
+ #endif
223
+
224
+ #endif