qtbindings 4.8.6.3 → 4.8.6.4

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 (659) hide show
  1. checksums.yaml +5 -5
  2. data/COPYING.LIB.txt +510 -510
  3. data/COPYING.txt +286 -286
  4. data/KNOWN_ISSUES.txt +17 -17
  5. data/bin/rbqtapi +0 -0
  6. data/bin/rbrcc +0 -0
  7. data/bin/rbuic4 +0 -0
  8. data/bin/smokeapi +0 -0
  9. data/bin/smokedeptool +0 -0
  10. data/examples/designer/calculatorbuilder/calculatorbuilder.qrc +5 -5
  11. data/examples/designer/calculatorbuilder/calculatorform.rb +60 -60
  12. data/examples/designer/calculatorbuilder/calculatorform.ui +299 -299
  13. data/examples/designer/calculatorbuilder/main.rb +34 -34
  14. data/examples/designer/calculatorbuilder/makefile +2 -2
  15. data/examples/designer/calculatorform/calculatorform.rb +46 -46
  16. data/examples/designer/calculatorform/calculatorform.ui +277 -277
  17. data/examples/designer/calculatorform/main.rb +32 -32
  18. data/examples/designer/calculatorform/makefile +3 -3
  19. data/examples/desktop/screenshot/main.rb +32 -32
  20. data/examples/desktop/screenshot/screenshot.rb +157 -157
  21. data/examples/desktop/systray/images/bad.svg +64 -64
  22. data/examples/desktop/systray/images/heart.svg +55 -55
  23. data/examples/desktop/systray/images/trash.svg +58 -58
  24. data/examples/desktop/systray/main.rb +41 -41
  25. data/examples/desktop/systray/makefile +2 -2
  26. data/examples/desktop/systray/systray.qrc +7 -7
  27. data/examples/desktop/systray/window.rb +219 -219
  28. data/examples/dialogs/complexwizard/complexwizard.rb +140 -140
  29. data/examples/dialogs/complexwizard/licensewizard.rb +294 -294
  30. data/examples/dialogs/complexwizard/main.rb +31 -31
  31. data/examples/dialogs/configdialog/configdialog.rb +109 -109
  32. data/examples/dialogs/configdialog/main.rb +31 -31
  33. data/examples/dialogs/configdialog/pages.rb +140 -140
  34. data/examples/dialogs/extension/finddialog.rb +89 -89
  35. data/examples/dialogs/extension/main.rb +31 -31
  36. data/examples/dialogs/findfiles/main.rb +32 -32
  37. data/examples/dialogs/findfiles/window.rb +177 -177
  38. data/examples/dialogs/simplewizard/classwizard.rb +374 -374
  39. data/examples/dialogs/simplewizard/main.rb +31 -31
  40. data/examples/dialogs/simplewizard/simplewizard.rb +110 -110
  41. data/examples/dialogs/standarddialogs/dialog.rb +340 -340
  42. data/examples/dialogs/standarddialogs/main.rb +31 -31
  43. data/examples/dialogs/tabdialog/main.rb +38 -38
  44. data/examples/dialogs/tabdialog/tabdialog.rb +178 -178
  45. data/examples/draganddrop/draggableicons/dragwidget.rb +125 -125
  46. data/examples/draganddrop/draggableicons/main.rb +41 -41
  47. data/examples/draganddrop/draggabletext/draglabel.rb +51 -51
  48. data/examples/draganddrop/draggabletext/dragwidget.rb +94 -94
  49. data/examples/draganddrop/draggabletext/main.rb +33 -33
  50. data/examples/draganddrop/draggabletext/words.txt +41 -41
  51. data/examples/draganddrop/dropsite/dropsitewidget.rb +99 -99
  52. data/examples/draganddrop/dropsite/dropsitewindow.rb +114 -114
  53. data/examples/draganddrop/dropsite/main.rb +33 -33
  54. data/examples/draganddrop/fridgemagnets/draglabel.rb +78 -78
  55. data/examples/draganddrop/fridgemagnets/dragwidget.rb +130 -130
  56. data/examples/draganddrop/fridgemagnets/main.rb +33 -33
  57. data/examples/draganddrop/fridgemagnets/words.txt +48 -48
  58. data/examples/draganddrop/puzzle/main.rb +33 -33
  59. data/examples/draganddrop/puzzle/mainwindow.rb +136 -136
  60. data/examples/draganddrop/puzzle/pieceslist.rb +95 -95
  61. data/examples/draganddrop/puzzle/puzzlewidget.rb +190 -190
  62. data/examples/graphicsview/collidingmice/main.rb +53 -53
  63. data/examples/graphicsview/collidingmice/makefile +2 -2
  64. data/examples/graphicsview/collidingmice/mice.qrc +5 -5
  65. data/examples/graphicsview/collidingmice/mouse.rb +176 -176
  66. data/examples/graphicsview/dragdroprobot/coloritem.rb +86 -86
  67. data/examples/graphicsview/dragdroprobot/main.rb +57 -57
  68. data/examples/graphicsview/dragdroprobot/makefile +2 -2
  69. data/examples/graphicsview/dragdroprobot/robot.qrc +5 -5
  70. data/examples/graphicsview/dragdroprobot/robot.rb +246 -246
  71. data/examples/itemviews/chart/chart.qrc +5 -5
  72. data/examples/itemviews/chart/main.rb +33 -33
  73. data/examples/itemviews/chart/mainwindow.rb +151 -151
  74. data/examples/itemviews/chart/makefile +2 -2
  75. data/examples/itemviews/chart/mydata.cht +8 -8
  76. data/examples/itemviews/chart/pieview.rb +516 -516
  77. data/examples/itemviews/chart/qtdata.cht +14 -14
  78. data/examples/itemviews/dirview/main.rb +39 -39
  79. data/examples/itemviews/pixelator/imagemodel.rb +51 -51
  80. data/examples/itemviews/pixelator/images.qrc +5 -5
  81. data/examples/itemviews/pixelator/main.rb +34 -34
  82. data/examples/itemviews/pixelator/mainwindow.rb +218 -218
  83. data/examples/itemviews/pixelator/makefile +3 -3
  84. data/examples/itemviews/pixelator/pixeldelegate.rb +67 -67
  85. data/examples/itemviews/puzzle/main.rb +36 -36
  86. data/examples/itemviews/puzzle/mainwindow.rb +143 -143
  87. data/examples/itemviews/puzzle/piecesmodel.rb +174 -174
  88. data/examples/itemviews/puzzle/puzzlewidget.rb +192 -192
  89. data/examples/itemviews/simpledommodel/domitem.rb +62 -62
  90. data/examples/itemviews/simpledommodel/dommodel.rb +139 -139
  91. data/examples/itemviews/simpledommodel/main.rb +33 -33
  92. data/examples/itemviews/simpledommodel/mainwindow.rb +66 -66
  93. data/examples/itemviews/simpletreemodel/default.txt +40 -40
  94. data/examples/itemviews/simpletreemodel/main.rb +41 -41
  95. data/examples/itemviews/simpletreemodel/makefile +2 -2
  96. data/examples/itemviews/simpletreemodel/simpletreemodel.qrc +5 -5
  97. data/examples/itemviews/simpletreemodel/treeitem.rb +67 -67
  98. data/examples/itemviews/simpletreemodel/treemodel.rb +164 -164
  99. data/examples/itemviews/sortingmodel/default.txt +40 -40
  100. data/examples/itemviews/sortingmodel/main.rb +53 -53
  101. data/examples/itemviews/sortingmodel/treeitem.rb +73 -73
  102. data/examples/itemviews/sortingmodel/treemodel.rb +166 -166
  103. data/examples/itemviews/spinboxdelegate/main.rb +47 -47
  104. data/examples/itemviews/spinboxdelegate/spinboxdelegate.rb +62 -62
  105. data/examples/killerfilter/killerfilter.rb +55 -55
  106. data/examples/layouts/basiclayouts/dialog.rb +110 -110
  107. data/examples/layouts/basiclayouts/main.rb +31 -31
  108. data/examples/layouts/borderlayout/borderlayout.rb +190 -190
  109. data/examples/layouts/borderlayout/main.rb +32 -32
  110. data/examples/layouts/borderlayout/window.rb +52 -52
  111. data/examples/layouts/flowlayouts/flowlayout.rb +108 -108
  112. data/examples/layouts/flowlayouts/main.rb +32 -32
  113. data/examples/layouts/flowlayouts/window.rb +43 -43
  114. data/examples/mainwindows/application/main.rb +32 -32
  115. data/examples/mainwindows/application/mainwindow.rb +285 -285
  116. data/examples/mainwindows/dockwidgets/main.rb +32 -32
  117. data/examples/mainwindows/dockwidgets/mainwindow.rb +302 -302
  118. data/examples/mainwindows/mdi/main.rb +32 -32
  119. data/examples/mainwindows/mdi/mainwindow.rb +363 -363
  120. data/examples/mainwindows/mdi/mdichild.rb +152 -152
  121. data/examples/mainwindows/menus/main.rb +32 -32
  122. data/examples/mainwindows/menus/mainwindow.rb +327 -327
  123. data/examples/mainwindows/recentfiles/main.rb +32 -32
  124. data/examples/mainwindows/recentfiles/mainwindow.rb +258 -258
  125. data/examples/mainwindows/sdi/main.rb +32 -32
  126. data/examples/mainwindows/sdi/mainwindow.rb +335 -335
  127. data/examples/network/broadcastreceiver/main.rb +32 -32
  128. data/examples/network/broadcastreceiver/receiver.rb +64 -64
  129. data/examples/network/broadcastsender/main.rb +32 -32
  130. data/examples/network/broadcastsender/sender.rb +72 -72
  131. data/examples/network/fortuneclient/client.rb +149 -149
  132. data/examples/network/fortuneclient/main.rb +32 -32
  133. data/examples/network/fortuneserver/main.rb +32 -32
  134. data/examples/network/fortuneserver/server.rb +88 -88
  135. data/examples/network/ftp/ftpwindow.rb +259 -259
  136. data/examples/network/ftp/main.rb +32 -32
  137. data/examples/network/http/httpwindow.rb +187 -187
  138. data/examples/network/http/main.rb +32 -32
  139. data/examples/network/loopback/dialog.rb +163 -163
  140. data/examples/network/loopback/main.rb +32 -32
  141. data/examples/opengl/grabber/glwidget.rb +265 -265
  142. data/examples/opengl/grabber/main.rb +32 -32
  143. data/examples/opengl/grabber/mainwindow.rb +189 -189
  144. data/examples/opengl/hellogl/glwidget.rb +226 -226
  145. data/examples/opengl/hellogl/main.rb +32 -32
  146. data/examples/opengl/hellogl/window.rb +66 -66
  147. data/examples/opengl/textures/glwidget.rb +151 -151
  148. data/examples/opengl/textures/main.rb +32 -32
  149. data/examples/opengl/textures/window.rb +77 -77
  150. data/examples/painting/basicdrawing/main.rb +32 -32
  151. data/examples/painting/basicdrawing/renderarea.rb +166 -166
  152. data/examples/painting/basicdrawing/window.rb +215 -215
  153. data/examples/painting/concentriccircles/circlewidget.rb +88 -88
  154. data/examples/painting/concentriccircles/main.rb +32 -32
  155. data/examples/painting/concentriccircles/window.rb +72 -72
  156. data/examples/painting/fontsampler/main.rb +32 -32
  157. data/examples/painting/fontsampler/mainwindow.rb +369 -369
  158. data/examples/painting/fontsampler/mainwindowbase.ui +136 -136
  159. data/examples/painting/fontsampler/makefile +8 -8
  160. data/examples/painting/fontsampler/previewdialog.rb +257 -257
  161. data/examples/painting/fontsampler/previewdialogbase.ui +224 -224
  162. data/examples/painting/fontsampler/previewlabel.rb +43 -43
  163. data/examples/painting/imagecomposition/imagecomposer.rb +152 -152
  164. data/examples/painting/imagecomposition/imagecomposition.qrc +6 -6
  165. data/examples/painting/imagecomposition/main.rb +33 -33
  166. data/examples/painting/imagecomposition/makefile +2 -2
  167. data/examples/painting/painterpaths/main.rb +32 -32
  168. data/examples/painting/painterpaths/renderarea.rb +97 -97
  169. data/examples/painting/painterpaths/window.rb +247 -247
  170. data/examples/painting/svgviewer/files/bubbles.svg +212 -212
  171. data/examples/painting/svgviewer/files/cubic.svg +77 -77
  172. data/examples/painting/svgviewer/files/spheres.svg +79 -79
  173. data/examples/painting/svgviewer/main.rb +38 -38
  174. data/examples/painting/svgviewer/mainwindow.rb +99 -99
  175. data/examples/painting/svgviewer/makefile +2 -2
  176. data/examples/painting/svgviewer/svgview.rb +156 -156
  177. data/examples/painting/svgviewer/svgviewer.qrc +6 -6
  178. data/examples/painting/svgviewer/svgwindow.rb +87 -87
  179. data/examples/painting/transformations/main.rb +32 -32
  180. data/examples/painting/transformations/renderarea.rb +127 -127
  181. data/examples/painting/transformations/window.rb +153 -153
  182. data/examples/passivepopup/passivepopup.rb +38 -38
  183. data/examples/qdbus/chat/chat.rb +146 -146
  184. data/examples/qdbus/chat/chat_adaptor.rb +12 -12
  185. data/examples/qdbus/chat/chat_interface.rb +13 -13
  186. data/examples/qdbus/chat/chatmainwindow.ui +184 -184
  187. data/examples/qdbus/chat/chatsetnickname.ui +145 -145
  188. data/examples/qdbus/chat/makefile +8 -8
  189. data/examples/qdbus/complexpingpong/complexping.rb +92 -92
  190. data/examples/qdbus/complexpingpong/complexpong.rb +83 -83
  191. data/examples/qdbus/complexpingpong/ping-common.rb +1 -1
  192. data/examples/qdbus/listnames/listnames.rb +69 -69
  193. data/examples/qdbus/pingpong/ping-common.rb +1 -1
  194. data/examples/qdbus/pingpong/ping.rb +52 -52
  195. data/examples/qdbus/pingpong/pong.rb +55 -55
  196. data/examples/qdbus/remotecontrolledcar/car/car.rb +151 -151
  197. data/examples/qdbus/remotecontrolledcar/car/main.rb +50 -50
  198. data/examples/qdbus/remotecontrolledcar/controller/controller.rb +66 -66
  199. data/examples/qdbus/remotecontrolledcar/controller/controller.ui +61 -61
  200. data/examples/qdbus/remotecontrolledcar/controller/main.rb +32 -32
  201. data/examples/qdbus/remotecontrolledcar/controller/makefile +2 -2
  202. data/examples/qtscribble/scribble.rb +270 -270
  203. data/examples/richtext/calendar/main.rb +33 -33
  204. data/examples/richtext/calendar/mainwindow.rb +173 -173
  205. data/examples/richtext/orderform/detailsdialog.rb +130 -130
  206. data/examples/richtext/orderform/main.rb +34 -34
  207. data/examples/richtext/orderform/mainwindow.rb +194 -194
  208. data/examples/richtext/syntaxhighlighter/examples/example +79 -79
  209. data/examples/richtext/syntaxhighlighter/highlighter.rb +90 -90
  210. data/examples/richtext/syntaxhighlighter/main.rb +34 -34
  211. data/examples/richtext/syntaxhighlighter/mainwindow.rb +105 -105
  212. data/examples/ruboids/LICENSE.txt +58 -58
  213. data/examples/ruboids/Manifest +26 -26
  214. data/examples/ruboids/README +53 -53
  215. data/examples/ruboids/TODO +29 -29
  216. data/examples/ruboids/boids.properties +33 -33
  217. data/examples/ruboids/generateManifest.rb +42 -42
  218. data/examples/ruboids/release.rb +152 -152
  219. data/examples/ruboids/ruboids/Boid.rb +141 -141
  220. data/examples/ruboids/ruboids/BoidView.rb +159 -159
  221. data/examples/ruboids/ruboids/Camera.rb +24 -24
  222. data/examples/ruboids/ruboids/CameraDialog.rb +218 -218
  223. data/examples/ruboids/ruboids/Canvas.rb +143 -143
  224. data/examples/ruboids/ruboids/Cloud.rb +61 -61
  225. data/examples/ruboids/ruboids/CloudView.rb +54 -54
  226. data/examples/ruboids/ruboids/Flock.rb +47 -47
  227. data/examples/ruboids/ruboids/Graphics.rb +278 -278
  228. data/examples/ruboids/ruboids/Params.rb +87 -87
  229. data/examples/ruboids/ruboids/Point.rb +153 -153
  230. data/examples/ruboids/ruboids/Thing.rb +34 -34
  231. data/examples/ruboids/ruboids/Triangle.rb +21 -21
  232. data/examples/ruboids/ruboids/View.rb +88 -88
  233. data/examples/ruboids/ruboids/World.rb +82 -82
  234. data/examples/ruboids/ruboids/WorldWindow.rb +52 -52
  235. data/examples/ruboids/ruboids/info.rb +12 -12
  236. data/examples/ruboids/ruboids/ruboids.rb +29 -29
  237. data/examples/threading/main_thread.rb +19 -19
  238. data/examples/tutorial/t1/t1.rb +10 -10
  239. data/examples/tutorial/t10/cannon.rb +72 -72
  240. data/examples/tutorial/t10/lcdrange.rb +45 -45
  241. data/examples/tutorial/t10/t10.rb +55 -55
  242. data/examples/tutorial/t11/cannon.rb +123 -124
  243. data/examples/tutorial/t11/lcdrange.rb +45 -45
  244. data/examples/tutorial/t11/t11.rb +65 -65
  245. data/examples/tutorial/t12/cannon.rb +157 -158
  246. data/examples/tutorial/t12/lcdrange.rb +58 -59
  247. data/examples/tutorial/t12/t12.rb +65 -66
  248. data/examples/tutorial/t13/cannon.rb +206 -208
  249. data/examples/tutorial/t13/gamebrd.rb +112 -113
  250. data/examples/tutorial/t13/lcdrange.rb +59 -60
  251. data/examples/tutorial/t13/t13.rb +11 -11
  252. data/examples/tutorial/t14/cannon.rb +262 -263
  253. data/examples/tutorial/t14/gamebrd.rb +122 -123
  254. data/examples/tutorial/t14/lcdrange.rb +61 -63
  255. data/examples/tutorial/t14/t14.rb +11 -11
  256. data/examples/tutorial/t2/t2.rb +16 -16
  257. data/examples/tutorial/t3/t3.rb +17 -18
  258. data/examples/tutorial/t4/t4.rb +23 -25
  259. data/examples/tutorial/t5/t5.rb +35 -37
  260. data/examples/tutorial/t6/t6.rb +48 -52
  261. data/examples/tutorial/t7/lcdrange.rb +32 -32
  262. data/examples/tutorial/t7/t7.rb +40 -42
  263. data/examples/tutorial/t8/cannon.rb +37 -38
  264. data/examples/tutorial/t8/lcdrange.rb +45 -45
  265. data/examples/tutorial/t8/t8.rb +43 -43
  266. data/examples/tutorial/t9/cannon.rb +44 -45
  267. data/examples/tutorial/t9/lcdrange.rb +46 -46
  268. data/examples/tutorial/t9/t9.rb +43 -43
  269. data/examples/widgets/analogclock/analogclock.rb +94 -94
  270. data/examples/widgets/analogclock/main.rb +9 -9
  271. data/examples/widgets/calculator/button.rb +45 -45
  272. data/examples/widgets/calculator/calculator.rb +382 -382
  273. data/examples/widgets/calculator/main.rb +32 -32
  274. data/examples/widgets/charactermap/characterwidget.rb +109 -109
  275. data/examples/widgets/charactermap/main.rb +32 -32
  276. data/examples/widgets/charactermap/mainwindow.rb +118 -118
  277. data/examples/widgets/digitalclock/digitalclock.rb +30 -30
  278. data/examples/widgets/digitalclock/main.rb +9 -9
  279. data/examples/widgets/groupbox/main.rb +32 -32
  280. data/examples/widgets/groupbox/window.rb +134 -134
  281. data/examples/widgets/icons/iconpreviewarea.rb +110 -110
  282. data/examples/widgets/icons/iconsizespinbox.rb +39 -39
  283. data/examples/widgets/icons/imagedelegate.rb +73 -73
  284. data/examples/widgets/icons/main.rb +32 -32
  285. data/examples/widgets/icons/mainwindow.rb +351 -351
  286. data/examples/widgets/imageviewer/imageviewer.rb +219 -219
  287. data/examples/widgets/imageviewer/main.rb +32 -32
  288. data/examples/widgets/lineedits/main.rb +32 -32
  289. data/examples/widgets/lineedits/window.rb +199 -199
  290. data/examples/widgets/movie/main.rb +32 -32
  291. data/examples/widgets/movie/movieplayer.rb +201 -201
  292. data/examples/widgets/screenshot/main.rb +32 -32
  293. data/examples/widgets/screenshot/screenshot.rb +154 -154
  294. data/examples/widgets/scribble/main.rb +32 -32
  295. data/examples/widgets/scribble/mainwindow.rb +202 -202
  296. data/examples/widgets/scribble/scribblearea.rb +154 -154
  297. data/examples/widgets/sliders/main.rb +32 -32
  298. data/examples/widgets/sliders/slidersgroup.rb +97 -97
  299. data/examples/widgets/sliders/window.rb +124 -124
  300. data/examples/widgets/spinboxes/main.rb +32 -32
  301. data/examples/widgets/spinboxes/window.rb +213 -213
  302. data/examples/widgets/tetrix/main.rb +33 -33
  303. data/examples/widgets/tetrix/tetrixboard.rb +346 -346
  304. data/examples/widgets/tetrix/tetrixpiece.rb +135 -135
  305. data/examples/widgets/tetrix/tetrixwindow.rb +88 -88
  306. data/examples/widgets/tooltips/main.rb +32 -32
  307. data/examples/widgets/tooltips/shapeitem.rb +31 -31
  308. data/examples/widgets/tooltips/sortingbox.rb +222 -222
  309. data/examples/widgets/wiggly/dialog.rb +48 -48
  310. data/examples/widgets/wiggly/main.rb +9 -9
  311. data/examples/widgets/wiggly/wigglywidget.rb +75 -75
  312. data/examples/widgets/windowflags/controllerwindow.rb +195 -195
  313. data/examples/widgets/windowflags/main.rb +32 -32
  314. data/examples/widgets/windowflags/previewwindow.rb +103 -103
  315. data/examples/xml/dombookmarks/frank.xbel +230 -230
  316. data/examples/xml/dombookmarks/jennifer.xbel +93 -93
  317. data/examples/xml/dombookmarks/main.rb +34 -34
  318. data/examples/xml/dombookmarks/mainwindow.rb +129 -129
  319. data/examples/xml/dombookmarks/xbeltree.rb +172 -172
  320. data/examples/xml/saxbookmarks/frank.xbel +230 -230
  321. data/examples/xml/saxbookmarks/jennifer.xbel +93 -93
  322. data/examples/xml/saxbookmarks/main.rb +34 -34
  323. data/examples/xml/saxbookmarks/mainwindow.rb +144 -144
  324. data/examples/xml/saxbookmarks/xbelgenerator.rb +95 -95
  325. data/examples/xml/saxbookmarks/xbelhandler.rb +122 -122
  326. data/ext/cmake/modules/BasicFindPackageVersion.cmake.in +30 -30
  327. data/ext/cmake/modules/CMakeCSharpCompiler.cmake.in +7 -7
  328. data/ext/cmake/modules/CMakeCSharpInformation.cmake +366 -366
  329. data/ext/cmake/modules/CMakeDetermineCSharpCompiler.cmake +85 -85
  330. data/ext/cmake/modules/CMakeTestCSharpCompiler.cmake +1 -1
  331. data/ext/cmake/modules/FindLibraryWithDebug.cmake +113 -113
  332. data/ext/cmake/modules/FindMono.cmake +36 -36
  333. data/ext/cmake/modules/FindPHP5.cmake +179 -179
  334. data/ext/cmake/modules/FindPerlMore.cmake +78 -78
  335. data/ext/cmake/modules/FindPhonon.cmake +71 -71
  336. data/ext/cmake/modules/FindQImageBlitz.cmake +51 -51
  337. data/ext/cmake/modules/FindQScintilla.cmake +57 -57
  338. data/ext/cmake/modules/FindQwt5.cmake +104 -104
  339. data/ext/cmake/modules/FindRuby.cmake +279 -279
  340. data/ext/cmake/modules/FindSmoke.cmake +78 -78
  341. data/ext/cmake/modules/MacroLogFeature.cmake +146 -146
  342. data/ext/cmake/modules/MacroOptionalAddBindings.cmake +47 -47
  343. data/ext/cmake/modules/MacroOptionalFindPackage.cmake +28 -28
  344. data/ext/cmake/modules/MacroPushRequiredVars.cmake +47 -47
  345. data/ext/cmake/modules/MacroWriteBasicCMakeVersionFile.cmake +22 -22
  346. data/ext/cmake/modules/SmokeConfig.cmake.in +109 -109
  347. data/ext/generator/CMakeLists.txt +38 -38
  348. data/ext/generator/cmake/BasicFindPackageVersion.cmake.in +30 -30
  349. data/ext/generator/cmake/CMakeLists.txt +24 -24
  350. data/ext/generator/cmake/FindLibraryWithDebug.cmake +113 -113
  351. data/ext/generator/cmake/FindPhonon.cmake +71 -71
  352. data/ext/generator/cmake/FindQImageBlitz.cmake +51 -51
  353. data/ext/generator/cmake/FindQScintilla.cmake +57 -57
  354. data/ext/generator/cmake/FindQwt5.cmake +104 -104
  355. data/ext/generator/cmake/HandleImportedTargetsInCMakeRequiredLibraries.cmake +85 -85
  356. data/ext/generator/cmake/MacroLogFeature.cmake +146 -146
  357. data/ext/generator/cmake/MacroOptionalAddBindings.cmake +47 -47
  358. data/ext/generator/cmake/MacroOptionalFindPackage.cmake +28 -28
  359. data/ext/generator/cmake/MacroWriteBasicCMakeVersionFile.cmake +22 -22
  360. data/ext/generator/cmake/SmokeConfig.cmake.in +109 -109
  361. data/ext/generator/config.h +25 -25
  362. data/ext/generator/generator_export.h +31 -31
  363. data/ext/generator/generatorenvironment.cpp +52 -52
  364. data/ext/generator/generatorenvironment.h +35 -35
  365. data/ext/generator/generatorpreprocessor.cpp +303 -303
  366. data/ext/generator/generatorpreprocessor.h +83 -83
  367. data/ext/generator/generators/CMakeLists.txt +4 -4
  368. data/ext/generator/generators/dump/CMakeLists.txt +15 -15
  369. data/ext/generator/generators/dump/generator_dump.cpp +36 -36
  370. data/ext/generator/generators/smoke/CMakeLists.txt +18 -18
  371. data/ext/generator/generators/smoke/generator_smoke.cpp +240 -240
  372. data/ext/generator/generators/smoke/globals.h +140 -140
  373. data/ext/generator/generators/smoke/helpers.cpp +793 -793
  374. data/ext/generator/generators/smoke/writeClasses.cpp +502 -502
  375. data/ext/generator/generators/smoke/writeSmokeDataFile.cpp +754 -754
  376. data/ext/generator/generatorvisitor.cpp +922 -922
  377. data/ext/generator/generatorvisitor.h +119 -119
  378. data/ext/generator/name_compiler.cpp +205 -205
  379. data/ext/generator/name_compiler.h +76 -76
  380. data/ext/generator/options.cpp +33 -33
  381. data/ext/generator/options.h +46 -46
  382. data/ext/generator/parser/CMakeLists.txt +50 -50
  383. data/ext/generator/parser/ast.cpp +21 -21
  384. data/ext/generator/parser/ast.h +923 -923
  385. data/ext/generator/parser/astutilities.h +65 -65
  386. data/ext/generator/parser/codegenerator.cpp +867 -867
  387. data/ext/generator/parser/codegenerator.h +180 -180
  388. data/ext/generator/parser/codemodel_fwd.h +76 -76
  389. data/ext/generator/parser/commentformatter.cpp +54 -54
  390. data/ext/generator/parser/commentformatter.h +45 -45
  391. data/ext/generator/parser/commentparser.cpp +109 -109
  392. data/ext/generator/parser/commentparser.h +84 -84
  393. data/ext/generator/parser/control.cpp +40 -40
  394. data/ext/generator/parser/control.h +51 -51
  395. data/ext/generator/parser/cppparser_export.h +33 -33
  396. data/ext/generator/parser/default_visitor.cpp +470 -470
  397. data/ext/generator/parser/default_visitor.h +116 -116
  398. data/ext/generator/parser/dumptree.cpp +146 -146
  399. data/ext/generator/parser/dumptree.h +50 -50
  400. data/ext/generator/parser/indexedstring.cpp +213 -213
  401. data/ext/generator/parser/indexedstring.h +147 -147
  402. data/ext/generator/parser/kdevelop-parser-rev +1 -1
  403. data/ext/generator/parser/kdevvarlengtharray.h +346 -346
  404. data/ext/generator/parser/lexer.cpp +964 -964
  405. data/ext/generator/parser/lexer.h +308 -308
  406. data/ext/generator/parser/listnode.cpp +20 -20
  407. data/ext/generator/parser/listnode.h +97 -97
  408. data/ext/generator/parser/memorypool.cpp +20 -20
  409. data/ext/generator/parser/memorypool.h +41 -41
  410. data/ext/generator/parser/name_compiler.cpp +190 -190
  411. data/ext/generator/parser/name_compiler.h +77 -77
  412. data/ext/generator/parser/parser.cpp +4708 -4708
  413. data/ext/generator/parser/parser.h +290 -290
  414. data/ext/generator/parser/parsesession.cpp +106 -106
  415. data/ext/generator/parser/parsesession.h +87 -87
  416. data/ext/generator/parser/problem.h +21 -21
  417. data/ext/generator/parser/rpp/CMakeLists.txt +45 -45
  418. data/ext/generator/parser/rpp/Makefile.am +13 -13
  419. data/ext/generator/parser/rpp/anchor.h +51 -51
  420. data/ext/generator/parser/rpp/appendedlist.h +363 -363
  421. data/ext/generator/parser/rpp/chartools.cpp +146 -146
  422. data/ext/generator/parser/rpp/chartools.h +99 -99
  423. data/ext/generator/parser/rpp/macrorepository.cpp +44 -44
  424. data/ext/generator/parser/rpp/macrorepository.h +59 -59
  425. data/ext/generator/parser/rpp/pp-configuration +86 -86
  426. data/ext/generator/parser/rpp/pp-engine.h +267 -267
  427. data/ext/generator/parser/rpp/pp-environment.cpp +271 -271
  428. data/ext/generator/parser/rpp/pp-environment.h +119 -119
  429. data/ext/generator/parser/rpp/pp-internal.cpp +38 -38
  430. data/ext/generator/parser/rpp/pp-internal.h +37 -37
  431. data/ext/generator/parser/rpp/pp-location.cpp +191 -191
  432. data/ext/generator/parser/rpp/pp-location.h +89 -89
  433. data/ext/generator/parser/rpp/pp-macro-expander.cpp +568 -568
  434. data/ext/generator/parser/rpp/pp-macro-expander.cpp.orig +558 -558
  435. data/ext/generator/parser/rpp/pp-macro-expander.h +130 -130
  436. data/ext/generator/parser/rpp/pp-macro.cpp +153 -153
  437. data/ext/generator/parser/rpp/pp-macro.h +176 -176
  438. data/ext/generator/parser/rpp/pp-scanner.cpp +311 -311
  439. data/ext/generator/parser/rpp/pp-scanner.h +97 -97
  440. data/ext/generator/parser/rpp/pp-stream.cpp +425 -425
  441. data/ext/generator/parser/rpp/pp-stream.h +183 -183
  442. data/ext/generator/parser/rpp/preprocessor.cpp +65 -65
  443. data/ext/generator/parser/rpp/preprocessor.h +80 -80
  444. data/ext/generator/parser/rpp/rpp.pri +2 -2
  445. data/ext/generator/parser/rpp/test/t001.cpp +23 -23
  446. data/ext/generator/parser/rpp/test/t002.cpp +15 -15
  447. data/ext/generator/parser/rpp/test/t003.cpp +10 -10
  448. data/ext/generator/parser/rpp/test/t004.cpp +9 -9
  449. data/ext/generator/parser/rpp/test/t005.cpp +10 -10
  450. data/ext/generator/parser/rpp/test/t006.cpp +10 -10
  451. data/ext/generator/parser/rpp/test/t007.cpp +6 -6
  452. data/ext/generator/parser/rpp/test/t008.cpp +6 -6
  453. data/ext/generator/parser/rpp/test/t009.cpp +5 -5
  454. data/ext/generator/parser/rpp/test/t010.cpp +15 -15
  455. data/ext/generator/parser/rpp/test/t011.cpp +9 -9
  456. data/ext/generator/parser/rpp/tests/CMakeLists.txt +17 -17
  457. data/ext/generator/parser/rpp/tests/main.cpp +69 -69
  458. data/ext/generator/parser/rxx.pri +50 -50
  459. data/ext/generator/parser/rxx_allocator.h +128 -128
  460. data/ext/generator/parser/safetycounter.h +57 -57
  461. data/ext/generator/parser/simplecursor.h +74 -74
  462. data/ext/generator/parser/stringhelpers.cpp +577 -577
  463. data/ext/generator/parser/stringhelpers.h +118 -118
  464. data/ext/generator/parser/symbol.h +140 -140
  465. data/ext/generator/parser/tests/CMakeLists.txt +46 -46
  466. data/ext/generator/parser/tests/test_generator.cpp +259 -259
  467. data/ext/generator/parser/tests/test_parser.cpp +474 -474
  468. data/ext/generator/parser/tests/test_pool.cpp +109 -109
  469. data/ext/generator/parser/tests/test_pool.h +35 -35
  470. data/ext/generator/parser/tests/testconfig.h.cmake +4 -4
  471. data/ext/generator/parser/tokens.cpp +367 -367
  472. data/ext/generator/parser/tokens.h +148 -148
  473. data/ext/generator/parser/type_compiler.cpp +135 -135
  474. data/ext/generator/parser/type_compiler.h +68 -68
  475. data/ext/generator/parser/visitor.cpp +115 -115
  476. data/ext/generator/parser/visitor.h +138 -138
  477. data/ext/generator/smoke.h +557 -557
  478. data/ext/generator/smokegen_string.h +43 -43
  479. data/ext/generator/type.cpp +204 -204
  480. data/ext/generator/type.h +497 -497
  481. data/ext/generator/type_compiler.cpp +277 -277
  482. data/ext/generator/type_compiler.h +80 -80
  483. data/ext/ruby/CMakeLists.txt +64 -64
  484. data/ext/ruby/qtdeclarative/CMakeLists.txt +17 -17
  485. data/ext/ruby/qtdeclarative/qtdeclarative.cpp +67 -67
  486. data/ext/ruby/qtdeclarative/qtdeclarative.rb +17 -17
  487. data/ext/ruby/qtdeclarative/qtdeclarativehandlers.cpp +36 -36
  488. data/ext/ruby/qtruby/AUTHORS +54 -54
  489. data/ext/ruby/qtruby/COPYING +355 -355
  490. data/ext/ruby/qtruby/COPYING.LIB +510 -510
  491. data/ext/ruby/qtruby/ChangeLog +3732 -3732
  492. data/ext/ruby/qtruby/INSTALL +79 -79
  493. data/ext/ruby/qtruby/README +264 -264
  494. data/ext/ruby/qtruby/TODO +8 -8
  495. data/ext/ruby/qtruby/bin/rbqtapi +152 -152
  496. data/ext/ruby/qtruby/rails_support/CMakeLists.txt +1 -1
  497. data/ext/ruby/qtruby/rails_support/active_item_model.rb +234 -234
  498. data/ext/ruby/qtruby/rails_support/active_table_model.rb +122 -122
  499. data/ext/ruby/qtruby/src/marshall_basetypes.h +208 -208
  500. data/ext/ruby/qtruby/src/marshall_complex.h +175 -175
  501. data/ext/ruby/qtruby/src/marshall_macros.h +647 -647
  502. data/ext/ruby/qtruby/src/marshall_types.cpp +815 -815
  503. data/ext/ruby/qtruby/src/marshall_types.h +240 -240
  504. data/ext/ruby/qtruby/src/qtruby.cpp +1 -1
  505. data/ext/ruby/qtruby/test/opoverloading.rb +46 -46
  506. data/ext/ruby/qtruby/test/unittests.rb +151 -151
  507. data/ext/ruby/qtruby/tools/rbrcc/main.cpp +173 -173
  508. data/ext/ruby/qtruby/tools/rbrcc/rbrcc.pro +14 -14
  509. data/ext/ruby/qtruby/tools/rbrcc/rcc.cpp +648 -648
  510. data/ext/ruby/qtruby/tools/rbrcc/rcc.h +165 -165
  511. data/ext/ruby/qtruby/tools/rbuic/LICENSE.GPL +280 -280
  512. data/ext/ruby/qtruby/tools/rbuic/TODO +4 -4
  513. data/ext/ruby/qtruby/tools/rbuic/customwidgetsinfo.cpp +106 -106
  514. data/ext/ruby/qtruby/tools/rbuic/customwidgetsinfo.h +95 -95
  515. data/ext/ruby/qtruby/tools/rbuic/databaseinfo.cpp +102 -102
  516. data/ext/ruby/qtruby/tools/rbuic/databaseinfo.h +85 -85
  517. data/ext/ruby/qtruby/tools/rbuic/driver.cpp +384 -384
  518. data/ext/ruby/qtruby/tools/rbuic/driver.h +141 -141
  519. data/ext/ruby/qtruby/tools/rbuic/rbuic.pri +23 -23
  520. data/ext/ruby/qtruby/tools/rbuic/rbuic4.pro +43 -43
  521. data/ext/ruby/qtruby/tools/rbuic/ruby/rbextractimages.cpp +150 -150
  522. data/ext/ruby/qtruby/tools/rbuic/ruby/rbextractimages.h +83 -83
  523. data/ext/ruby/qtruby/tools/rbuic/ruby/rbwritedeclaration.cpp +217 -217
  524. data/ext/ruby/qtruby/tools/rbuic/ruby/rbwritedeclaration.h +85 -85
  525. data/ext/ruby/qtruby/tools/rbuic/ruby/rbwriteicondata.cpp +185 -185
  526. data/ext/ruby/qtruby/tools/rbuic/ruby/rbwriteicondata.h +86 -86
  527. data/ext/ruby/qtruby/tools/rbuic/ruby/rbwriteicondeclaration.cpp +88 -88
  528. data/ext/ruby/qtruby/tools/rbuic/ruby/rbwriteicondeclaration.h +83 -83
  529. data/ext/ruby/qtruby/tools/rbuic/ruby/rbwriteiconinitialization.cpp +126 -126
  530. data/ext/ruby/qtruby/tools/rbuic/ruby/rbwriteiconinitialization.h +87 -87
  531. data/ext/ruby/qtruby/tools/rbuic/ruby/rbwriteinitialization.cpp +2478 -2478
  532. data/ext/ruby/qtruby/tools/rbuic/ruby/rbwriteinitialization.h +314 -314
  533. data/ext/ruby/qtruby/tools/rbuic/ruby/ruby.pri +18 -18
  534. data/ext/ruby/qtruby/tools/rbuic/treewalker.cpp +318 -318
  535. data/ext/ruby/qtruby/tools/rbuic/treewalker.h +139 -139
  536. data/ext/ruby/qtruby/tools/rbuic/ui4.cpp +7623 -7623
  537. data/ext/ruby/qtruby/tools/rbuic/ui4.h +3180 -3180
  538. data/ext/ruby/qtruby/tools/rbuic/utils.h +125 -125
  539. data/ext/ruby/qtruby/tools/rbuic/validator.cpp +100 -100
  540. data/ext/ruby/qtruby/tools/rbuic/validator.h +80 -80
  541. data/ext/ruby/qtscript/CMakeLists.txt +19 -19
  542. data/ext/ruby/qtscript/qtscript.cpp +83 -83
  543. data/ext/ruby/qtscript/qtscript.rb +40 -40
  544. data/ext/ruby/qtscript/qtscripthandlers.cpp +37 -37
  545. data/ext/ruby/qtscript/smokedata.cpp +1403 -1403
  546. data/ext/ruby/qttest/CMakeLists.txt +18 -18
  547. data/ext/ruby/qttest/ChangeLog +9 -9
  548. data/ext/ruby/qttest/examples/myfirsttest.rb +30 -30
  549. data/ext/ruby/qttest/qttest.cpp +83 -83
  550. data/ext/ruby/qttest/qttest.rb +166 -166
  551. data/ext/ruby/qttest/qttesthandlers.cpp +37 -37
  552. data/ext/ruby/qtuitools/CMakeLists.txt +16 -16
  553. data/ext/ruby/qtuitools/qtuitools.cpp +83 -83
  554. data/ext/ruby/qtuitools/qtuitools.rb +17 -17
  555. data/ext/ruby/qtuitools/qtuitoolshandlers.cpp +32 -32
  556. data/ext/ruby/qtwebkit/CMakeLists.txt +17 -17
  557. data/ext/ruby/qtwebkit/qtwebkit.cpp +67 -67
  558. data/ext/ruby/qtwebkit/qtwebkit.rb +17 -17
  559. data/ext/ruby/qtwebkit/qtwebkithandlers.cpp +40 -40
  560. data/ext/smoke/deptool/CMakeLists.txt +7 -7
  561. data/ext/smoke/deptool/main.cpp +128 -128
  562. data/ext/smoke/qtcore/CMakeLists.txt +88 -88
  563. data/ext/smoke/qtcore/QtGuess.txt +180 -180
  564. data/ext/smoke/qtcore/config.xml.cmake +10 -10
  565. data/ext/smoke/qtcore/qt-config.xml.cmake +21 -21
  566. data/ext/smoke/qtcore/qtcore_includes.h +1 -1
  567. data/ext/smoke/qtcore/smokeconfig.xml +193 -193
  568. data/ext/smoke/qtcore/tests/CMakeLists.txt +13 -13
  569. data/ext/smoke/qtcore/tests/test.cpp +846 -846
  570. data/ext/smoke/qtcore_smoke.h +16 -16
  571. data/ext/smoke/qtdbus/CMakeLists.txt +38 -38
  572. data/ext/smoke/qtdbus/config.xml.cmake +11 -11
  573. data/ext/smoke/qtdbus/qtdbus_includes.h +2 -2
  574. data/ext/smoke/qtdbus/smokeconfig.xml +65 -65
  575. data/ext/smoke/qtdbus_smoke.h +16 -16
  576. data/ext/smoke/qtdeclarative/CMakeLists.txt +45 -45
  577. data/ext/smoke/qtdeclarative/config.xml.cmake +12 -12
  578. data/ext/smoke/qtdeclarative/qtdeclarative_includes.h +3 -3
  579. data/ext/smoke/qtdeclarative/smokeconfig.xml +59 -59
  580. data/ext/smoke/qtdeclarative_smoke.h +16 -16
  581. data/ext/smoke/qtgui/CMakeLists.txt +76 -76
  582. data/ext/smoke/qtgui/config.xml.cmake +11 -11
  583. data/ext/smoke/qtgui/qtgui_includes.h +7 -7
  584. data/ext/smoke/qtgui/smokeconfig.xml +500 -500
  585. data/ext/smoke/qtgui_smoke.h +16 -16
  586. data/ext/smoke/qthelp/CMakeLists.txt +45 -45
  587. data/ext/smoke/qthelp/config.xml.cmake +13 -13
  588. data/ext/smoke/qthelp/qthelp_includes.h +3 -3
  589. data/ext/smoke/qthelp/smokeconfig.xml +54 -54
  590. data/ext/smoke/qthelp_smoke.h +16 -16
  591. data/ext/smoke/qtmultimedia/CMakeLists.txt +42 -42
  592. data/ext/smoke/qtmultimedia/config.xml.cmake +12 -12
  593. data/ext/smoke/qtmultimedia/qtmultimedia_includes.h +3 -3
  594. data/ext/smoke/qtmultimedia/smokeconfig.xml +51 -51
  595. data/ext/smoke/qtmultimedia_smoke.h +16 -16
  596. data/ext/smoke/qtnetwork/CMakeLists.txt +38 -38
  597. data/ext/smoke/qtnetwork/config.xml.cmake +11 -11
  598. data/ext/smoke/qtnetwork/qtnetwork_includes.h +2 -2
  599. data/ext/smoke/qtnetwork/smokeconfig.xml +81 -81
  600. data/ext/smoke/qtnetwork_smoke.h +16 -16
  601. data/ext/smoke/qtopengl/CMakeLists.txt +43 -43
  602. data/ext/smoke/qtopengl/config.xml.cmake +13 -13
  603. data/ext/smoke/qtopengl/qtopengl_includes.h +3 -3
  604. data/ext/smoke/qtopengl/smokeconfig.xml +58 -58
  605. data/ext/smoke/qtopengl_smoke.h +16 -16
  606. data/ext/smoke/qtscript/CMakeLists.txt +31 -31
  607. data/ext/smoke/qtscript/config.xml.cmake +11 -11
  608. data/ext/smoke/qtscript/qtscript_includes.h +14 -14
  609. data/ext/smoke/qtscript/smokeconfig.xml +39 -39
  610. data/ext/smoke/qtscript_smoke.h +16 -16
  611. data/ext/smoke/qtsql/CMakeLists.txt +45 -45
  612. data/ext/smoke/qtsql/config.xml.cmake +11 -11
  613. data/ext/smoke/qtsql/qtsql_includes.h +3 -3
  614. data/ext/smoke/qtsql/smokeconfig.xml +60 -60
  615. data/ext/smoke/qtsql_smoke.h +16 -16
  616. data/ext/smoke/qtsvg/CMakeLists.txt +43 -43
  617. data/ext/smoke/qtsvg/config.xml.cmake +12 -12
  618. data/ext/smoke/qtsvg/qtsvg_includes.h +3 -3
  619. data/ext/smoke/qtsvg/smokeconfig.xml +46 -46
  620. data/ext/smoke/qtsvg_smoke.h +16 -16
  621. data/ext/smoke/qttest/CMakeLists.txt +35 -35
  622. data/ext/smoke/qttest/config.xml.cmake +12 -12
  623. data/ext/smoke/qttest/qttest_includes.h +14 -14
  624. data/ext/smoke/qttest/smokeconfig.xml +36 -36
  625. data/ext/smoke/qttest_smoke.h +16 -16
  626. data/ext/smoke/qtuitools/CMakeLists.txt +30 -30
  627. data/ext/smoke/qtuitools/config.xml.cmake +12 -12
  628. data/ext/smoke/qtuitools/qtuitools_includes.h +1 -1
  629. data/ext/smoke/qtuitools/smokeconfig.xml +20 -20
  630. data/ext/smoke/qtuitools_smoke.h +16 -16
  631. data/ext/smoke/qtwebkit/CMakeLists.txt +36 -36
  632. data/ext/smoke/qtwebkit/config.xml.cmake +11 -11
  633. data/ext/smoke/qtwebkit/qtwebkit_includes.h +1 -1
  634. data/ext/smoke/qtwebkit/smokeconfig.xml +48 -48
  635. data/ext/smoke/qtwebkit_smoke.h +16 -16
  636. data/ext/smoke/qtxml/CMakeLists.txt +41 -41
  637. data/ext/smoke/qtxml/config.xml.cmake +11 -11
  638. data/ext/smoke/qtxml/qtxml_includes.h +2 -2
  639. data/ext/smoke/qtxml/smokeconfig.xml +70 -70
  640. data/ext/smoke/qtxml_smoke.h +16 -16
  641. data/ext/smoke/qtxmlpatterns/CMakeLists.txt +42 -42
  642. data/ext/smoke/qtxmlpatterns/config.xml.cmake +12 -12
  643. data/ext/smoke/qtxmlpatterns/qtxmlpatterns_includes.h +3 -3
  644. data/ext/smoke/qtxmlpatterns/smokeconfig.xml +80 -80
  645. data/ext/smoke/qtxmlpatterns_smoke.h +16 -16
  646. data/ext/smoke/smokeapi/CMakeLists.txt +9 -9
  647. data/ext/smoke/smokeapi/main.cpp +309 -309
  648. data/ext/smoke/smokebase/CMakeLists.txt +11 -11
  649. data/ext/smoke/smokebase/smokebase.cpp +6 -6
  650. data/ext/smoke/solid_smoke.h +16 -16
  651. data/lib/Qt.rb +1 -1
  652. data/lib/Qt4.rb +119 -111
  653. data/lib/qtbindings_version.rb +2 -2
  654. data/lib/qtdeclarative/qtdeclarative.rb +17 -17
  655. data/lib/qtscript/qtscript.rb +40 -40
  656. data/lib/qttest/qttest.rb +166 -166
  657. data/lib/qtuitools/qtuitools.rb +17 -17
  658. data/lib/qtwebkit/qtwebkit.rb +17 -17
  659. metadata +6 -7
@@ -1,13 +1,13 @@
1
- INCLUDES = $(all_includes)
2
-
3
- METASOURCES = AUTO
4
-
5
- noinst_LTLIBRARIES = libkdevcpprpp.la
6
-
7
- libkdevcpprppla_SOURCES = preprocessor.cpp
8
-
9
- noinst_HEADERS = \
10
-
11
-
12
-
13
- libkdevcpprpp_la_SOURCES = preprocessor.cpp
1
+ INCLUDES = $(all_includes)
2
+
3
+ METASOURCES = AUTO
4
+
5
+ noinst_LTLIBRARIES = libkdevcpprpp.la
6
+
7
+ libkdevcpprppla_SOURCES = preprocessor.cpp
8
+
9
+ noinst_HEADERS = \
10
+
11
+
12
+
13
+ libkdevcpprpp_la_SOURCES = preprocessor.cpp
@@ -1,51 +1,51 @@
1
- /*
2
- Copyright 2008 David Nolden <david.nolden.kdevelop@art-master.de>
3
-
4
- Permission to use, copy, modify, distribute, and sell this software and its
5
- documentation for any purpose is hereby granted without fee, provided that
6
- the above copyright notice appear in all copies and that both that
7
- copyright notice and this permission notice appear in supporting
8
- documentation.
9
-
10
- The above copyright notice and this permission notice shall be included in
11
- all copies or substantial portions of the Software.
12
-
13
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16
- KDEVELOP TEAM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
17
- AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
18
- CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
19
- */
20
-
21
- #ifndef ANCHOR_H
22
- #define ANCHOR_H
23
-
24
- #include <QtCore/Qt>
25
-
26
- #include "../cppparser_export.h"
27
- #include "../simplecursor.h"
28
-
29
- namespace rpp {
30
- /**
31
- * A SimpleCursor with additional boolean value whether the range opened by this anchor is collapsed.
32
- * If that value is true, it means that Everything behind the anchor until the next one is collapsed to the exact position of this anchor.
33
- * */
34
- class CPPPARSER_EXPORT Anchor : public SimpleCursor {
35
- public:
36
- Anchor() : collapsed(false) {
37
- }
38
-
39
- explicit Anchor(const SimpleCursor& cursor, bool _collapsed=false, SimpleCursor _macroExpansion=SimpleCursor::invalid()) : SimpleCursor(cursor), collapsed(_collapsed), macroExpansion(_macroExpansion) {
40
- }
41
- explicit Anchor(int line, int column, bool _collapsed=false, SimpleCursor _macroExpansion=SimpleCursor::invalid()) : SimpleCursor(line, column), collapsed(_collapsed), macroExpansion(_macroExpansion) {
42
- }
43
-
44
- bool collapsed;
45
-
46
- ///@todo create a sub-class that contains macroExpansion. It is only needed in the location-table and everything using not, not actually in the anchors.
47
- SimpleCursor macroExpansion; //Zero if this position was not transformed through a macro-expansion, else a number that identifies the expansion
48
- };
49
- }
50
-
51
- #endif
1
+ /*
2
+ Copyright 2008 David Nolden <david.nolden.kdevelop@art-master.de>
3
+
4
+ Permission to use, copy, modify, distribute, and sell this software and its
5
+ documentation for any purpose is hereby granted without fee, provided that
6
+ the above copyright notice appear in all copies and that both that
7
+ copyright notice and this permission notice appear in supporting
8
+ documentation.
9
+
10
+ The above copyright notice and this permission notice shall be included in
11
+ all copies or substantial portions of the Software.
12
+
13
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16
+ KDEVELOP TEAM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
17
+ AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
18
+ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
19
+ */
20
+
21
+ #ifndef ANCHOR_H
22
+ #define ANCHOR_H
23
+
24
+ #include <QtCore/Qt>
25
+
26
+ #include "../cppparser_export.h"
27
+ #include "../simplecursor.h"
28
+
29
+ namespace rpp {
30
+ /**
31
+ * A SimpleCursor with additional boolean value whether the range opened by this anchor is collapsed.
32
+ * If that value is true, it means that Everything behind the anchor until the next one is collapsed to the exact position of this anchor.
33
+ * */
34
+ class CPPPARSER_EXPORT Anchor : public SimpleCursor {
35
+ public:
36
+ Anchor() : collapsed(false) {
37
+ }
38
+
39
+ explicit Anchor(const SimpleCursor& cursor, bool _collapsed=false, SimpleCursor _macroExpansion=SimpleCursor::invalid()) : SimpleCursor(cursor), collapsed(_collapsed), macroExpansion(_macroExpansion) {
40
+ }
41
+ explicit Anchor(int line, int column, bool _collapsed=false, SimpleCursor _macroExpansion=SimpleCursor::invalid()) : SimpleCursor(line, column), collapsed(_collapsed), macroExpansion(_macroExpansion) {
42
+ }
43
+
44
+ bool collapsed;
45
+
46
+ ///@todo create a sub-class that contains macroExpansion. It is only needed in the location-table and everything using not, not actually in the anchors.
47
+ SimpleCursor macroExpansion; //Zero if this position was not transformed through a macro-expansion, else a number that identifies the expansion
48
+ };
49
+ }
50
+
51
+ #endif
@@ -1,363 +1,363 @@
1
- /*
2
- Copyright 2008 David Nolden <david.nolden.kdevelop@art-master.de>
3
-
4
- This library is free software; you can redistribute it and/or
5
- modify it under the terms of the GNU Library General Public
6
- License version 2 as published by the Free Software Foundation.
7
-
8
- This library is distributed in the hope that it will be useful,
9
- but WITHOUT ANY WARRANTY; without even the implied warranty of
10
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11
- Library General Public License for more details.
12
-
13
- You should have received a copy of the GNU Library General Public License
14
- along with this library; see the file COPYING.LIB. If not, write to
15
- the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
16
- Boston, MA 02110-1301, USA.
17
- */
18
-
19
- #ifndef APPENDEDLIST_H
20
- #define APPENDEDLIST_H
21
-
22
- #include <QtCore/QMutex>
23
- #include <QtCore/QVector>
24
- #include <QtCore/QStack>
25
- #include <QtCore/QPair>
26
- // #include <kglobal.h>
27
- // #include <kdebug.h>
28
- #include "../kdevvarlengtharray.h"
29
- #include <iostream>
30
- #include <time.h>
31
-
32
- namespace KDevelop {
33
- class AbstractItemRepository;
34
- /**
35
- * This file contains macros and classes that can be used to conveniently implement classes that store the data of an arbitrary count
36
- * of additional lists within the same memory block directly behind the class data, in a way that one the whole data can be stored by one copy-operation
37
- * to another place, like needed in ItemRepository. These macros simplify having two versions of a class: One that has its lists attached in memory,
38
- * and one version that has them contained as a directly accessible KDevVarLengthArray. Both versions have their lists accessible through access-functions,
39
- * have a completeSize() function that computes the size of the one-block version, and a copyListsFrom(..) function which can copy the lists from one
40
- * version to the other.
41
- *
42
- * @warning Always follow these rules:
43
- * You must call initalizeAppendedLists(bool) on construction, also in any copy-constructor, but before calling copyFrom(..).
44
- * The parameter to that function should be whether the lists in the items should be dynamic, and thus most times "true".
45
- * You must call freeAppendedLists() on destruction, our you will be leaking memory(only when dynamic)
46
- *
47
- * For each embedded list, you must use macros to define a global hash that will be used to allocate the temporary lists, example fir identifier.cpp:
48
- * DEFINE_LIST_MEMBER_HASH(IdentifierPrivate, templateIdentifiers, uint);
49
- *
50
- * See identifier.cpp for an example how to use these classes. @todo Document this a bit more
51
- * */
52
-
53
-
54
- enum {
55
- DynamicAppendedListMask = 1 << 31
56
- };
57
- enum {
58
- DynamicAppendedListRevertMask = 0xffffffff - DynamicAppendedListMask
59
- };
60
- /**
61
- * Manages a repository of items for temporary usage. The items will be allocated with an index on alloc(),
62
- * and freed on free(index). When freed, the same index will be re-used for a later allocation, thus no real allocations
63
- * will be happening in most cases.
64
- * The returned indices will always be ored with DynamicAppendedListMask.
65
- *
66
- */
67
- template<class T, bool threadSafe = true>
68
- class TemporaryDataManager {
69
- public:
70
- TemporaryDataManager(QString id = QString()) : m_itemsUsed(0), m_itemsSize(0), m_items(0), m_id(id) {
71
- uint first = alloc(); //Allocate the zero item, just to reserve that index
72
- Q_ASSERT(first == (uint)DynamicAppendedListMask);
73
- }
74
- ~TemporaryDataManager() {
75
- free(DynamicAppendedListMask); //Free the zero index, so we don't get wrong warnings
76
- uint cnt = usedItemCount();
77
- if(cnt) //Don't use kDebug, because that may not work during destruction
78
- std::cout << m_id.toLocal8Bit().data() << " There were items left on destruction: " << usedItemCount() << "\n";
79
-
80
- for(uint a = 0; a < m_itemsUsed; ++a)
81
- delete m_items[a];
82
- }
83
-
84
- inline T& getItem(uint index) {
85
- //For performance reasons this function does not lock the mutex, it's called too often and must be
86
- //extremely fast. There is special measures in alloc() to make this safe.
87
- Q_ASSERT(index & DynamicAppendedListMask);
88
-
89
- return *m_items[index & KDevelop::DynamicAppendedListRevertMask];
90
- }
91
-
92
- ///Allocates an item index, which from now on you can get using getItem, until you call free(..) on the index.
93
- ///The returned item is not initialized and may contain random older content, so you should clear it after getting it for the first time
94
- uint alloc() {
95
-
96
- if(threadSafe)
97
- m_mutex.lock();
98
-
99
- uint ret;
100
- if(!m_freeIndicesWithData.isEmpty()) {
101
- ret = m_freeIndicesWithData.pop();
102
- }else if(!m_freeIndices.isEmpty()) {
103
- ret = m_freeIndices.pop();
104
- Q_ASSERT(!m_items[ret]);
105
- m_items[ret] = new T;
106
- }else{
107
-
108
- if(m_itemsUsed >= m_itemsSize) {
109
- //We need to re-allocate
110
- uint newItemsSize = m_itemsSize + 20 + (m_itemsSize/3);
111
- T** newItems = new T*[newItemsSize];
112
- memcpy(newItems, m_items, sizeof(T*) * m_itemsSize);
113
-
114
- T** oldItems = m_items;
115
- m_items = newItems;
116
- m_itemsSize = newItemsSize;
117
- //The only function that does not lock the mutex is getItem(..), because that function must be very efficient.
118
- //Since it's only a few instructions from the moment m_items is read to the moment it's used,
119
- //deleting the old data after a few seconds should be safe.
120
- m_deleteLater.append(qMakePair(time(0), oldItems));
121
-
122
- //We do this in this place so it isn't called too often. The result is that we will always have some additional data around.
123
- //However the index itself should anyway not consume too much data.
124
- if(!m_deleteLater.isEmpty()) {
125
- while(!m_deleteLater.isEmpty()) {
126
- //We delete after 5 seconds
127
- if(time(0) - m_deleteLater.first().first > 5) {
128
- delete[] m_deleteLater.first().second;
129
- m_deleteLater.removeFirst();
130
- }else{
131
- break;
132
- }
133
- }
134
- }
135
- }
136
-
137
- ret = m_itemsUsed;
138
- m_items[m_itemsUsed] = new T;
139
- ++m_itemsUsed;
140
- Q_ASSERT(m_itemsUsed <= m_itemsSize);
141
- }
142
-
143
- if(threadSafe)
144
- m_mutex.unlock();
145
-
146
- Q_ASSERT(!(ret & DynamicAppendedListMask));
147
-
148
- return ret | DynamicAppendedListMask;
149
- }
150
-
151
- void free(uint index) {
152
- Q_ASSERT(index & DynamicAppendedListMask);
153
- index &= KDevelop::DynamicAppendedListRevertMask;
154
-
155
- if(threadSafe)
156
- m_mutex.lock();
157
-
158
- freeItem(m_items[index]);
159
-
160
- m_freeIndicesWithData.push(index);
161
-
162
- //Hold the amount of free indices with data between 100 and 200
163
- if(m_freeIndicesWithData.size() > 200) {
164
- for(int a = 0; a < 100; ++a) {
165
- uint deleteIndexData = m_freeIndicesWithData.pop();
166
- delete m_items[deleteIndexData];
167
- m_items[deleteIndexData] = 0;
168
- m_freeIndices.push(deleteIndexData);
169
- }
170
- }
171
-
172
- if(threadSafe)
173
- m_mutex.unlock();
174
- }
175
-
176
- uint usedItemCount() const {
177
- uint ret = 0;
178
- for(uint a = 0; a < m_itemsUsed; ++a)
179
- if(m_items[a])
180
- ++ret;
181
- return ret - m_freeIndicesWithData.size();
182
- }
183
-
184
- private:
185
- //To save some memory, clear the lists
186
- void freeItem(T* item) {
187
- item->clear(); ///@todo make this a template specialization that only does this for containers
188
- }
189
-
190
- uint m_itemsUsed, m_itemsSize;
191
- T** m_items;
192
- QStack<uint> m_freeIndicesWithData;
193
- QStack<uint> m_freeIndices;
194
- QMutex m_mutex;
195
- QString m_id;
196
- QList<QPair<time_t, T**> > m_deleteLater;
197
- };
198
-
199
- ///Foreach macro that takes a container and a function-name, and will iterate through the vector returned by that function, using the length returned by the function-name with "Size" appended.
200
- //This might be a little slow
201
- #define FOREACH_FUNCTION(item, container) for(uint a = 0, mustDo = 1, containerSize = container ## Size(); a < containerSize; ++a) if((mustDo == 0 || mustDo == 1) && (mustDo = 2)) for(item(container()[a]); mustDo; mustDo = 0)
202
- //More efficient version that does not repeatedly call functions on the container, but the syntax is a bit less nice
203
- // #define FOREACH_FUNCTION_EFFICIENT(itemType, itemName, container) for(itemType* start = container(), end = start + container ## Size(), fake = start; start != end; ++start) for( itemType itemName(*start); fake != end; fake = end)
204
-
205
- #define DEFINE_LIST_MEMBER_HASH(container, member, type) \
206
- typedef TemporaryDataManager<KDevVarLengthArray<type, 10> > temporaryHash ## container ## member ## Type; \
207
- Q_GLOBAL_STATIC_WITH_ARGS(temporaryHash ## container ## member ## Type, temporaryHash ## container ## member ## Static, ( #container "::" #member )) \
208
- temporaryHash ## container ## member ## Type& temporaryHash ## container ## member() { \
209
- return *temporaryHash ## container ## member ## Static; \
210
- }
211
-
212
- #define DECLARE_LIST_MEMBER_HASH(container, member, type) KDevelop::TemporaryDataManager<KDevVarLengthArray<type, 10> >& temporaryHash ## container ## member();
213
-
214
- ///This implements the interfaces so this container can be used as a predecessor for classes with appended lists.
215
- ///You should do this within the abstract base class that opens a tree of classes that can have appended lists,
216
- ///so each class that uses them, can also give its predecessor to START_APPENDE_LISTS, to increase flexibility.
217
- ///This creates a boolean entry that is initialized when initializeAppendedLists is called.
218
- ///You can call appendedListsDynamic() to find out whether the item is marked as dynamic.
219
- ///When this item is used, the same rules have to be followed as for a class with appended lists: You have to call
220
- ///initializeAppendedLists(...) and freeAppendedLists(..)
221
- ///Also, when you use this, you have to implement a size_t classSize() function, that returns the size of the class including derived classes,
222
- ///but not including the dynamic data. Optionally you can implement a static bool appendedListDynamicDefault() function, that returns the default-value for the "dynamic" parameter.
223
- ///to initializeAppendedLists.
224
- #define APPENDED_LISTS_STUB(container) \
225
- bool m_dynamic : 1; \
226
- unsigned int offsetBehindLastList() const { return 0; } \
227
- size_t dynamicSize() const { return classSize(); } \
228
- template<class T> bool listsEqual(const T& /*rhs*/) const { return true; } \
229
- template<class T> void copyAllFrom(const T& /*rhs*/) const { } \
230
- void initializeAppendedLists(bool dynamic = appendedListDynamicDefault()) { m_dynamic = dynamic; } \
231
- void freeAppendedLists() { } \
232
- bool appendedListsDynamic() const { return m_dynamic; }
233
-
234
-
235
- ///use this if the class does not have a base class that also uses appended lists
236
- #define START_APPENDED_LISTS(container) \
237
- unsigned int offsetBehindBase() const { return 0; } \
238
- void freeDynamicData() { freeAppendedLists(); }
239
-
240
- ///Use this if one of the base-classes of the container also has the appended lists interfaces implemented.
241
- ///To reduce the probability of future problems, you should give the direct base class this one inherits from.
242
- ///@note: Multiple inheritance is not supported, however it will work ok if only one of the base-classes uses appended lists.
243
- #define START_APPENDED_LISTS_BASE(container, base) \
244
- unsigned int offsetBehindBase() const { return base :: offsetBehindLastList(); } \
245
- void freeDynamicData() { freeAppendedLists(); base::freeDynamicData(); }
246
-
247
-
248
- #define APPENDED_LIST_COMMON(container, type, name) \
249
- uint name ## Data; \
250
- unsigned int name ## Size() const { if((name ## Data & KDevelop::DynamicAppendedListRevertMask) == 0) return 0; if(!appendedListsDynamic()) return name ## Data; else return temporaryHash ## container ## name().getItem(name ## Data).size(); } \
251
- KDevVarLengthArray<type, 10>& name ## List() { name ## NeedDynamicList(); return temporaryHash ## container ## name().getItem(name ## Data); }\
252
- template<class T> bool name ## Equals(const T& rhs) const { unsigned int size = name ## Size(); if(size != rhs.name ## Size()) return false; for(uint a = 0; a < size; ++a) {if(!(name()[a] == rhs.name()[a])) return false;} return true; } \
253
- template<class T> void name ## CopyFrom( const T& rhs ) { \
254
- if(rhs.name ## Size() == 0 && (name ## Data & KDevelop::DynamicAppendedListRevertMask) == 0) return; \
255
- if(appendedListsDynamic()) { \
256
- name ## NeedDynamicList(); \
257
- KDevVarLengthArray<type, 10>& item( temporaryHash ## container ## name().getItem(name ## Data) ); \
258
- item.clear(); \
259
- const type* otherCurr = rhs.name(); \
260
- const type* otherEnd = otherCurr + rhs.name ## Size(); \
261
- for(; otherCurr < otherEnd; ++otherCurr) \
262
- item.append(*otherCurr); \
263
- }else{ \
264
- Q_ASSERT(name ## Data == 0); /* It is dangerous to overwrite the contents of non-dynamic lists(Most probably a mistake) */ \
265
- name ## Data = rhs.name ## Size(); \
266
- type* curr = const_cast<type*>(name()); type* end = curr + name ## Size(); \
267
- const type* otherCurr = rhs.name(); \
268
- for(; curr < end; ++curr, ++otherCurr) \
269
- new (curr) type(*otherCurr); /* Call the copy constructors */ \
270
- }\
271
- } \
272
- void name ## NeedDynamicList() { Q_ASSERT(appendedListsDynamic()); if((name ## Data & KDevelop::DynamicAppendedListRevertMask) == 0) { name ## Data = temporaryHash ## container ## name().alloc(); Q_ASSERT(temporaryHash ## container ## name().getItem(name ## Data).isEmpty()); } } \
273
- void name ## Initialize(bool dynamic) { name ## Data = (dynamic ? KDevelop::DynamicAppendedListMask : 0); } \
274
- void name ## Free() { if(appendedListsDynamic()) { if(name ## Data & KDevelop::DynamicAppendedListRevertMask) temporaryHash ## container ## name().free(name ## Data); } else { type* curr = const_cast<type*>(name()); type* end = curr + name ## Size(); for(; curr < end; ++curr) curr->~type(); /*call destructors*/ } } \
275
-
276
-
277
- ///@todo Make these things a bit faster(less recursion)
278
-
279
- #define APPENDED_LIST_FIRST(container, type, name) APPENDED_LIST_COMMON(container, type, name) \
280
- const type* name() const { if((name ## Data & KDevelop::DynamicAppendedListRevertMask) == 0) return 0; if(!appendedListsDynamic()) return (type*)(((char*)this) + classSize() + offsetBehindBase()); else return temporaryHash ## container ## name().getItem(name ## Data).data(); } \
281
- unsigned int name ## OffsetBehind() const { return name ## Size() * sizeof(type) + offsetBehindBase(); } \
282
- template<class T> bool name ## ListChainEquals( const T& rhs ) const { return name ## Equals(rhs); } \
283
- template<class T> void name ## CopyAllFrom( const T& rhs ) { name ## CopyFrom(rhs); } \
284
- void name ## InitializeChain(bool dynamic) { name ## Initialize(dynamic); } \
285
- void name ## FreeChain() { name ## Free(); }
286
-
287
- #define APPENDED_LIST(container, type, name, predecessor) APPENDED_LIST_COMMON(container, type, name) \
288
- const type* name() const {if((name ## Data & KDevelop::DynamicAppendedListRevertMask) == 0) return 0; if(!appendedListsDynamic()) return (type*)(((char*)this) + classSize() + predecessor ## OffsetBehind()); else return temporaryHash ## container ## name().getItem(name ## Data).data(); } \
289
- unsigned int name ## OffsetBehind() const { return name ## Size() * sizeof(type) + predecessor ## OffsetBehind(); } \
290
- template<class T> bool name ## ListChainEquals( const T& rhs ) const { return name ## Equals(rhs) && predecessor ## ListChainEquals(rhs); } \
291
- template<class T> void name ## CopyAllFrom( const T& rhs ) { predecessor ## CopyAllFrom(rhs); name ## CopyFrom(rhs); } \
292
- void name ## InitializeChain(bool dynamic) { name ## Initialize(dynamic); predecessor ## InitializeChain(dynamic); } \
293
- void name ## FreeChain() { name ## Free(); predecessor ## FreeChain(); }
294
-
295
- #define END_APPENDED_LISTS(container, predecessor) /* Returns the size of the object containing the appended lists, including them */ \
296
- unsigned int completeSize() const { return classSize() + predecessor ## OffsetBehind(); } \
297
- /* Compares all local appended lists(not from base classes) and returns true if they are equal */ \
298
- template<class T> bool listsEqual(const T& rhs) const { return predecessor ## ListChainEquals(rhs); } \
299
- /* Copies all the local appended lists(not from base classes) from the given item.*/ \
300
- template<class T> void copyListsFrom(const T& rhs) { return predecessor ## CopyAllFrom(rhs); } \
301
- void initializeAppendedLists(bool dynamic = appendedListDynamicDefault()) { predecessor ## Data = (dynamic ? KDevelop::DynamicAppendedListMask : 0); predecessor ## InitializeChain(dynamic); } \
302
- void freeAppendedLists() { predecessor ## FreeChain(); } \
303
- bool appendedListsDynamic() const { return predecessor ## Data & KDevelop::DynamicAppendedListMask; } \
304
- unsigned int offsetBehindLastList() const { return predecessor ## OffsetBehind(); } \
305
- size_t dynamicSize() const { return offsetBehindLastList() + classSize(); }
306
- /**
307
- * This is a class that allows you easily putting instances of your class into an ItemRepository as seen in itemrepository.h.
308
- * All your class needs to do is:
309
- * - Be implemented using the APPENDED_LIST macros.
310
- * - Have a real copy-constructor that additionally takes a "bool dynamic = true" parameter, which should be given to initializeAppendedLists
311
- * - Except for these appended lists, only contain directly copyable data like indices(no pointers, no virtual functions)
312
- * - Implement operator==(..) which should compare everything, including the lists. @warning The default operator will not work!
313
- * - Implement a hash() function. The hash should equal for two instances when operator==(..) returns true.
314
- * - Should be completely functional without a constructor called, only the data copied
315
- * - Implement a "bool persistent() const" function, that should check the reference-count or other information to decide whether the item should stay in the repository
316
- * If those conditions are fulfilled, the data can easily be put into a repository using this request class.
317
- * */
318
-
319
- template<class Type, uint averageAppendedBytes = 8>
320
- class AppendedListItemRequest {
321
- public:
322
- AppendedListItemRequest(const Type& item) : m_item(item) {
323
- }
324
-
325
- enum {
326
- AverageSize = sizeof(Type) + averageAppendedBytes
327
- };
328
-
329
- unsigned int hash() const {
330
- return m_item.hash();
331
- }
332
-
333
- size_t itemSize() const {
334
- return m_item.dynamicSize();
335
- }
336
-
337
- void createItem(Type* item) const {
338
- new (item) Type(m_item, false);
339
- }
340
-
341
- static void destroy(Type* item, KDevelop::AbstractItemRepository&) {
342
- item->~Type();
343
- }
344
-
345
- static bool persistent(const Type* item) {
346
- return item->persistent();
347
- }
348
-
349
- bool equals(const Type* item) const {
350
- return m_item == *item;
351
- }
352
-
353
- const Type& m_item;
354
- };
355
- }
356
-
357
- ///This function is outside of the namespace, so it can always be found. It's used as default-parameter to initializeAppendedLists(..),
358
- ///and you can for example implement a function called like this in your local class hierarchy to override this default.
359
- inline bool appendedListDynamicDefault() {
360
- return true;
361
- }
362
-
363
- #endif
1
+ /*
2
+ Copyright 2008 David Nolden <david.nolden.kdevelop@art-master.de>
3
+
4
+ This library is free software; you can redistribute it and/or
5
+ modify it under the terms of the GNU Library General Public
6
+ License version 2 as published by the Free Software Foundation.
7
+
8
+ This library is distributed in the hope that it will be useful,
9
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
10
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11
+ Library General Public License for more details.
12
+
13
+ You should have received a copy of the GNU Library General Public License
14
+ along with this library; see the file COPYING.LIB. If not, write to
15
+ the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
16
+ Boston, MA 02110-1301, USA.
17
+ */
18
+
19
+ #ifndef APPENDEDLIST_H
20
+ #define APPENDEDLIST_H
21
+
22
+ #include <QtCore/QMutex>
23
+ #include <QtCore/QVector>
24
+ #include <QtCore/QStack>
25
+ #include <QtCore/QPair>
26
+ // #include <kglobal.h>
27
+ // #include <kdebug.h>
28
+ #include "../kdevvarlengtharray.h"
29
+ #include <iostream>
30
+ #include <time.h>
31
+
32
+ namespace KDevelop {
33
+ class AbstractItemRepository;
34
+ /**
35
+ * This file contains macros and classes that can be used to conveniently implement classes that store the data of an arbitrary count
36
+ * of additional lists within the same memory block directly behind the class data, in a way that one the whole data can be stored by one copy-operation
37
+ * to another place, like needed in ItemRepository. These macros simplify having two versions of a class: One that has its lists attached in memory,
38
+ * and one version that has them contained as a directly accessible KDevVarLengthArray. Both versions have their lists accessible through access-functions,
39
+ * have a completeSize() function that computes the size of the one-block version, and a copyListsFrom(..) function which can copy the lists from one
40
+ * version to the other.
41
+ *
42
+ * @warning Always follow these rules:
43
+ * You must call initalizeAppendedLists(bool) on construction, also in any copy-constructor, but before calling copyFrom(..).
44
+ * The parameter to that function should be whether the lists in the items should be dynamic, and thus most times "true".
45
+ * You must call freeAppendedLists() on destruction, our you will be leaking memory(only when dynamic)
46
+ *
47
+ * For each embedded list, you must use macros to define a global hash that will be used to allocate the temporary lists, example fir identifier.cpp:
48
+ * DEFINE_LIST_MEMBER_HASH(IdentifierPrivate, templateIdentifiers, uint);
49
+ *
50
+ * See identifier.cpp for an example how to use these classes. @todo Document this a bit more
51
+ * */
52
+
53
+
54
+ enum {
55
+ DynamicAppendedListMask = 1 << 31
56
+ };
57
+ enum {
58
+ DynamicAppendedListRevertMask = 0xffffffff - DynamicAppendedListMask
59
+ };
60
+ /**
61
+ * Manages a repository of items for temporary usage. The items will be allocated with an index on alloc(),
62
+ * and freed on free(index). When freed, the same index will be re-used for a later allocation, thus no real allocations
63
+ * will be happening in most cases.
64
+ * The returned indices will always be ored with DynamicAppendedListMask.
65
+ *
66
+ */
67
+ template<class T, bool threadSafe = true>
68
+ class TemporaryDataManager {
69
+ public:
70
+ TemporaryDataManager(QString id = QString()) : m_itemsUsed(0), m_itemsSize(0), m_items(0), m_id(id) {
71
+ uint first = alloc(); //Allocate the zero item, just to reserve that index
72
+ Q_ASSERT(first == (uint)DynamicAppendedListMask);
73
+ }
74
+ ~TemporaryDataManager() {
75
+ free(DynamicAppendedListMask); //Free the zero index, so we don't get wrong warnings
76
+ uint cnt = usedItemCount();
77
+ if(cnt) //Don't use kDebug, because that may not work during destruction
78
+ std::cout << m_id.toLocal8Bit().data() << " There were items left on destruction: " << usedItemCount() << "\n";
79
+
80
+ for(uint a = 0; a < m_itemsUsed; ++a)
81
+ delete m_items[a];
82
+ }
83
+
84
+ inline T& getItem(uint index) {
85
+ //For performance reasons this function does not lock the mutex, it's called too often and must be
86
+ //extremely fast. There is special measures in alloc() to make this safe.
87
+ Q_ASSERT(index & DynamicAppendedListMask);
88
+
89
+ return *m_items[index & KDevelop::DynamicAppendedListRevertMask];
90
+ }
91
+
92
+ ///Allocates an item index, which from now on you can get using getItem, until you call free(..) on the index.
93
+ ///The returned item is not initialized and may contain random older content, so you should clear it after getting it for the first time
94
+ uint alloc() {
95
+
96
+ if(threadSafe)
97
+ m_mutex.lock();
98
+
99
+ uint ret;
100
+ if(!m_freeIndicesWithData.isEmpty()) {
101
+ ret = m_freeIndicesWithData.pop();
102
+ }else if(!m_freeIndices.isEmpty()) {
103
+ ret = m_freeIndices.pop();
104
+ Q_ASSERT(!m_items[ret]);
105
+ m_items[ret] = new T;
106
+ }else{
107
+
108
+ if(m_itemsUsed >= m_itemsSize) {
109
+ //We need to re-allocate
110
+ uint newItemsSize = m_itemsSize + 20 + (m_itemsSize/3);
111
+ T** newItems = new T*[newItemsSize];
112
+ memcpy(newItems, m_items, sizeof(T*) * m_itemsSize);
113
+
114
+ T** oldItems = m_items;
115
+ m_items = newItems;
116
+ m_itemsSize = newItemsSize;
117
+ //The only function that does not lock the mutex is getItem(..), because that function must be very efficient.
118
+ //Since it's only a few instructions from the moment m_items is read to the moment it's used,
119
+ //deleting the old data after a few seconds should be safe.
120
+ m_deleteLater.append(qMakePair(time(0), oldItems));
121
+
122
+ //We do this in this place so it isn't called too often. The result is that we will always have some additional data around.
123
+ //However the index itself should anyway not consume too much data.
124
+ if(!m_deleteLater.isEmpty()) {
125
+ while(!m_deleteLater.isEmpty()) {
126
+ //We delete after 5 seconds
127
+ if(time(0) - m_deleteLater.first().first > 5) {
128
+ delete[] m_deleteLater.first().second;
129
+ m_deleteLater.removeFirst();
130
+ }else{
131
+ break;
132
+ }
133
+ }
134
+ }
135
+ }
136
+
137
+ ret = m_itemsUsed;
138
+ m_items[m_itemsUsed] = new T;
139
+ ++m_itemsUsed;
140
+ Q_ASSERT(m_itemsUsed <= m_itemsSize);
141
+ }
142
+
143
+ if(threadSafe)
144
+ m_mutex.unlock();
145
+
146
+ Q_ASSERT(!(ret & DynamicAppendedListMask));
147
+
148
+ return ret | DynamicAppendedListMask;
149
+ }
150
+
151
+ void free(uint index) {
152
+ Q_ASSERT(index & DynamicAppendedListMask);
153
+ index &= KDevelop::DynamicAppendedListRevertMask;
154
+
155
+ if(threadSafe)
156
+ m_mutex.lock();
157
+
158
+ freeItem(m_items[index]);
159
+
160
+ m_freeIndicesWithData.push(index);
161
+
162
+ //Hold the amount of free indices with data between 100 and 200
163
+ if(m_freeIndicesWithData.size() > 200) {
164
+ for(int a = 0; a < 100; ++a) {
165
+ uint deleteIndexData = m_freeIndicesWithData.pop();
166
+ delete m_items[deleteIndexData];
167
+ m_items[deleteIndexData] = 0;
168
+ m_freeIndices.push(deleteIndexData);
169
+ }
170
+ }
171
+
172
+ if(threadSafe)
173
+ m_mutex.unlock();
174
+ }
175
+
176
+ uint usedItemCount() const {
177
+ uint ret = 0;
178
+ for(uint a = 0; a < m_itemsUsed; ++a)
179
+ if(m_items[a])
180
+ ++ret;
181
+ return ret - m_freeIndicesWithData.size();
182
+ }
183
+
184
+ private:
185
+ //To save some memory, clear the lists
186
+ void freeItem(T* item) {
187
+ item->clear(); ///@todo make this a template specialization that only does this for containers
188
+ }
189
+
190
+ uint m_itemsUsed, m_itemsSize;
191
+ T** m_items;
192
+ QStack<uint> m_freeIndicesWithData;
193
+ QStack<uint> m_freeIndices;
194
+ QMutex m_mutex;
195
+ QString m_id;
196
+ QList<QPair<time_t, T**> > m_deleteLater;
197
+ };
198
+
199
+ ///Foreach macro that takes a container and a function-name, and will iterate through the vector returned by that function, using the length returned by the function-name with "Size" appended.
200
+ //This might be a little slow
201
+ #define FOREACH_FUNCTION(item, container) for(uint a = 0, mustDo = 1, containerSize = container ## Size(); a < containerSize; ++a) if((mustDo == 0 || mustDo == 1) && (mustDo = 2)) for(item(container()[a]); mustDo; mustDo = 0)
202
+ //More efficient version that does not repeatedly call functions on the container, but the syntax is a bit less nice
203
+ // #define FOREACH_FUNCTION_EFFICIENT(itemType, itemName, container) for(itemType* start = container(), end = start + container ## Size(), fake = start; start != end; ++start) for( itemType itemName(*start); fake != end; fake = end)
204
+
205
+ #define DEFINE_LIST_MEMBER_HASH(container, member, type) \
206
+ typedef TemporaryDataManager<KDevVarLengthArray<type, 10> > temporaryHash ## container ## member ## Type; \
207
+ Q_GLOBAL_STATIC_WITH_ARGS(temporaryHash ## container ## member ## Type, temporaryHash ## container ## member ## Static, ( #container "::" #member )) \
208
+ temporaryHash ## container ## member ## Type& temporaryHash ## container ## member() { \
209
+ return *temporaryHash ## container ## member ## Static; \
210
+ }
211
+
212
+ #define DECLARE_LIST_MEMBER_HASH(container, member, type) KDevelop::TemporaryDataManager<KDevVarLengthArray<type, 10> >& temporaryHash ## container ## member();
213
+
214
+ ///This implements the interfaces so this container can be used as a predecessor for classes with appended lists.
215
+ ///You should do this within the abstract base class that opens a tree of classes that can have appended lists,
216
+ ///so each class that uses them, can also give its predecessor to START_APPENDE_LISTS, to increase flexibility.
217
+ ///This creates a boolean entry that is initialized when initializeAppendedLists is called.
218
+ ///You can call appendedListsDynamic() to find out whether the item is marked as dynamic.
219
+ ///When this item is used, the same rules have to be followed as for a class with appended lists: You have to call
220
+ ///initializeAppendedLists(...) and freeAppendedLists(..)
221
+ ///Also, when you use this, you have to implement a size_t classSize() function, that returns the size of the class including derived classes,
222
+ ///but not including the dynamic data. Optionally you can implement a static bool appendedListDynamicDefault() function, that returns the default-value for the "dynamic" parameter.
223
+ ///to initializeAppendedLists.
224
+ #define APPENDED_LISTS_STUB(container) \
225
+ bool m_dynamic : 1; \
226
+ unsigned int offsetBehindLastList() const { return 0; } \
227
+ size_t dynamicSize() const { return classSize(); } \
228
+ template<class T> bool listsEqual(const T& /*rhs*/) const { return true; } \
229
+ template<class T> void copyAllFrom(const T& /*rhs*/) const { } \
230
+ void initializeAppendedLists(bool dynamic = appendedListDynamicDefault()) { m_dynamic = dynamic; } \
231
+ void freeAppendedLists() { } \
232
+ bool appendedListsDynamic() const { return m_dynamic; }
233
+
234
+
235
+ ///use this if the class does not have a base class that also uses appended lists
236
+ #define START_APPENDED_LISTS(container) \
237
+ unsigned int offsetBehindBase() const { return 0; } \
238
+ void freeDynamicData() { freeAppendedLists(); }
239
+
240
+ ///Use this if one of the base-classes of the container also has the appended lists interfaces implemented.
241
+ ///To reduce the probability of future problems, you should give the direct base class this one inherits from.
242
+ ///@note: Multiple inheritance is not supported, however it will work ok if only one of the base-classes uses appended lists.
243
+ #define START_APPENDED_LISTS_BASE(container, base) \
244
+ unsigned int offsetBehindBase() const { return base :: offsetBehindLastList(); } \
245
+ void freeDynamicData() { freeAppendedLists(); base::freeDynamicData(); }
246
+
247
+
248
+ #define APPENDED_LIST_COMMON(container, type, name) \
249
+ uint name ## Data; \
250
+ unsigned int name ## Size() const { if((name ## Data & KDevelop::DynamicAppendedListRevertMask) == 0) return 0; if(!appendedListsDynamic()) return name ## Data; else return temporaryHash ## container ## name().getItem(name ## Data).size(); } \
251
+ KDevVarLengthArray<type, 10>& name ## List() { name ## NeedDynamicList(); return temporaryHash ## container ## name().getItem(name ## Data); }\
252
+ template<class T> bool name ## Equals(const T& rhs) const { unsigned int size = name ## Size(); if(size != rhs.name ## Size()) return false; for(uint a = 0; a < size; ++a) {if(!(name()[a] == rhs.name()[a])) return false;} return true; } \
253
+ template<class T> void name ## CopyFrom( const T& rhs ) { \
254
+ if(rhs.name ## Size() == 0 && (name ## Data & KDevelop::DynamicAppendedListRevertMask) == 0) return; \
255
+ if(appendedListsDynamic()) { \
256
+ name ## NeedDynamicList(); \
257
+ KDevVarLengthArray<type, 10>& item( temporaryHash ## container ## name().getItem(name ## Data) ); \
258
+ item.clear(); \
259
+ const type* otherCurr = rhs.name(); \
260
+ const type* otherEnd = otherCurr + rhs.name ## Size(); \
261
+ for(; otherCurr < otherEnd; ++otherCurr) \
262
+ item.append(*otherCurr); \
263
+ }else{ \
264
+ Q_ASSERT(name ## Data == 0); /* It is dangerous to overwrite the contents of non-dynamic lists(Most probably a mistake) */ \
265
+ name ## Data = rhs.name ## Size(); \
266
+ type* curr = const_cast<type*>(name()); type* end = curr + name ## Size(); \
267
+ const type* otherCurr = rhs.name(); \
268
+ for(; curr < end; ++curr, ++otherCurr) \
269
+ new (curr) type(*otherCurr); /* Call the copy constructors */ \
270
+ }\
271
+ } \
272
+ void name ## NeedDynamicList() { Q_ASSERT(appendedListsDynamic()); if((name ## Data & KDevelop::DynamicAppendedListRevertMask) == 0) { name ## Data = temporaryHash ## container ## name().alloc(); Q_ASSERT(temporaryHash ## container ## name().getItem(name ## Data).isEmpty()); } } \
273
+ void name ## Initialize(bool dynamic) { name ## Data = (dynamic ? KDevelop::DynamicAppendedListMask : 0); } \
274
+ void name ## Free() { if(appendedListsDynamic()) { if(name ## Data & KDevelop::DynamicAppendedListRevertMask) temporaryHash ## container ## name().free(name ## Data); } else { type* curr = const_cast<type*>(name()); type* end = curr + name ## Size(); for(; curr < end; ++curr) curr->~type(); /*call destructors*/ } } \
275
+
276
+
277
+ ///@todo Make these things a bit faster(less recursion)
278
+
279
+ #define APPENDED_LIST_FIRST(container, type, name) APPENDED_LIST_COMMON(container, type, name) \
280
+ const type* name() const { if((name ## Data & KDevelop::DynamicAppendedListRevertMask) == 0) return 0; if(!appendedListsDynamic()) return (type*)(((char*)this) + classSize() + offsetBehindBase()); else return temporaryHash ## container ## name().getItem(name ## Data).data(); } \
281
+ unsigned int name ## OffsetBehind() const { return name ## Size() * sizeof(type) + offsetBehindBase(); } \
282
+ template<class T> bool name ## ListChainEquals( const T& rhs ) const { return name ## Equals(rhs); } \
283
+ template<class T> void name ## CopyAllFrom( const T& rhs ) { name ## CopyFrom(rhs); } \
284
+ void name ## InitializeChain(bool dynamic) { name ## Initialize(dynamic); } \
285
+ void name ## FreeChain() { name ## Free(); }
286
+
287
+ #define APPENDED_LIST(container, type, name, predecessor) APPENDED_LIST_COMMON(container, type, name) \
288
+ const type* name() const {if((name ## Data & KDevelop::DynamicAppendedListRevertMask) == 0) return 0; if(!appendedListsDynamic()) return (type*)(((char*)this) + classSize() + predecessor ## OffsetBehind()); else return temporaryHash ## container ## name().getItem(name ## Data).data(); } \
289
+ unsigned int name ## OffsetBehind() const { return name ## Size() * sizeof(type) + predecessor ## OffsetBehind(); } \
290
+ template<class T> bool name ## ListChainEquals( const T& rhs ) const { return name ## Equals(rhs) && predecessor ## ListChainEquals(rhs); } \
291
+ template<class T> void name ## CopyAllFrom( const T& rhs ) { predecessor ## CopyAllFrom(rhs); name ## CopyFrom(rhs); } \
292
+ void name ## InitializeChain(bool dynamic) { name ## Initialize(dynamic); predecessor ## InitializeChain(dynamic); } \
293
+ void name ## FreeChain() { name ## Free(); predecessor ## FreeChain(); }
294
+
295
+ #define END_APPENDED_LISTS(container, predecessor) /* Returns the size of the object containing the appended lists, including them */ \
296
+ unsigned int completeSize() const { return classSize() + predecessor ## OffsetBehind(); } \
297
+ /* Compares all local appended lists(not from base classes) and returns true if they are equal */ \
298
+ template<class T> bool listsEqual(const T& rhs) const { return predecessor ## ListChainEquals(rhs); } \
299
+ /* Copies all the local appended lists(not from base classes) from the given item.*/ \
300
+ template<class T> void copyListsFrom(const T& rhs) { return predecessor ## CopyAllFrom(rhs); } \
301
+ void initializeAppendedLists(bool dynamic = appendedListDynamicDefault()) { predecessor ## Data = (dynamic ? KDevelop::DynamicAppendedListMask : 0); predecessor ## InitializeChain(dynamic); } \
302
+ void freeAppendedLists() { predecessor ## FreeChain(); } \
303
+ bool appendedListsDynamic() const { return predecessor ## Data & KDevelop::DynamicAppendedListMask; } \
304
+ unsigned int offsetBehindLastList() const { return predecessor ## OffsetBehind(); } \
305
+ size_t dynamicSize() const { return offsetBehindLastList() + classSize(); }
306
+ /**
307
+ * This is a class that allows you easily putting instances of your class into an ItemRepository as seen in itemrepository.h.
308
+ * All your class needs to do is:
309
+ * - Be implemented using the APPENDED_LIST macros.
310
+ * - Have a real copy-constructor that additionally takes a "bool dynamic = true" parameter, which should be given to initializeAppendedLists
311
+ * - Except for these appended lists, only contain directly copyable data like indices(no pointers, no virtual functions)
312
+ * - Implement operator==(..) which should compare everything, including the lists. @warning The default operator will not work!
313
+ * - Implement a hash() function. The hash should equal for two instances when operator==(..) returns true.
314
+ * - Should be completely functional without a constructor called, only the data copied
315
+ * - Implement a "bool persistent() const" function, that should check the reference-count or other information to decide whether the item should stay in the repository
316
+ * If those conditions are fulfilled, the data can easily be put into a repository using this request class.
317
+ * */
318
+
319
+ template<class Type, uint averageAppendedBytes = 8>
320
+ class AppendedListItemRequest {
321
+ public:
322
+ AppendedListItemRequest(const Type& item) : m_item(item) {
323
+ }
324
+
325
+ enum {
326
+ AverageSize = sizeof(Type) + averageAppendedBytes
327
+ };
328
+
329
+ unsigned int hash() const {
330
+ return m_item.hash();
331
+ }
332
+
333
+ size_t itemSize() const {
334
+ return m_item.dynamicSize();
335
+ }
336
+
337
+ void createItem(Type* item) const {
338
+ new (item) Type(m_item, false);
339
+ }
340
+
341
+ static void destroy(Type* item, KDevelop::AbstractItemRepository&) {
342
+ item->~Type();
343
+ }
344
+
345
+ static bool persistent(const Type* item) {
346
+ return item->persistent();
347
+ }
348
+
349
+ bool equals(const Type* item) const {
350
+ return m_item == *item;
351
+ }
352
+
353
+ const Type& m_item;
354
+ };
355
+ }
356
+
357
+ ///This function is outside of the namespace, so it can always be found. It's used as default-parameter to initializeAppendedLists(..),
358
+ ///and you can for example implement a function called like this in your local class hierarchy to override this default.
359
+ inline bool appendedListDynamicDefault() {
360
+ return true;
361
+ }
362
+
363
+ #endif