qtbindings 4.8.6.2 → 4.8.6.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/COPYING.LIB.txt +510 -510
- data/COPYING.txt +286 -286
- data/KNOWN_ISSUES.txt +17 -17
- data/Rakefile +5 -5
- data/bin/rbqtapi +0 -0
- data/bin/rbrcc +0 -0
- data/bin/rbuic4 +0 -0
- data/bin/smokeapi +0 -0
- data/bin/smokedeptool +0 -0
- data/examples/designer/calculatorbuilder/calculatorbuilder.qrc +5 -5
- data/examples/designer/calculatorbuilder/calculatorform.rb +60 -60
- data/examples/designer/calculatorbuilder/calculatorform.ui +299 -299
- data/examples/designer/calculatorbuilder/main.rb +34 -34
- data/examples/designer/calculatorbuilder/makefile +2 -2
- data/examples/designer/calculatorform/calculatorform.rb +46 -46
- data/examples/designer/calculatorform/calculatorform.ui +277 -277
- data/examples/designer/calculatorform/main.rb +32 -32
- data/examples/designer/calculatorform/makefile +3 -3
- data/examples/desktop/screenshot/main.rb +32 -32
- data/examples/desktop/screenshot/screenshot.rb +157 -157
- data/examples/desktop/systray/images/bad.svg +64 -64
- data/examples/desktop/systray/images/heart.svg +55 -55
- data/examples/desktop/systray/images/trash.svg +58 -58
- data/examples/desktop/systray/main.rb +41 -41
- data/examples/desktop/systray/makefile +2 -2
- data/examples/desktop/systray/systray.qrc +7 -7
- data/examples/desktop/systray/window.rb +219 -219
- data/examples/dialogs/complexwizard/complexwizard.rb +140 -140
- data/examples/dialogs/complexwizard/licensewizard.rb +294 -294
- data/examples/dialogs/complexwizard/main.rb +31 -31
- data/examples/dialogs/configdialog/configdialog.rb +109 -109
- data/examples/dialogs/configdialog/main.rb +31 -31
- data/examples/dialogs/configdialog/pages.rb +140 -140
- data/examples/dialogs/extension/finddialog.rb +89 -89
- data/examples/dialogs/extension/main.rb +31 -31
- data/examples/dialogs/findfiles/main.rb +32 -32
- data/examples/dialogs/findfiles/window.rb +177 -177
- data/examples/dialogs/simplewizard/classwizard.rb +374 -374
- data/examples/dialogs/simplewizard/main.rb +31 -31
- data/examples/dialogs/simplewizard/simplewizard.rb +110 -110
- data/examples/dialogs/standarddialogs/dialog.rb +340 -340
- data/examples/dialogs/standarddialogs/main.rb +31 -31
- data/examples/dialogs/tabdialog/main.rb +38 -38
- data/examples/dialogs/tabdialog/tabdialog.rb +178 -178
- data/examples/draganddrop/draggableicons/dragwidget.rb +125 -125
- data/examples/draganddrop/draggableicons/main.rb +41 -41
- data/examples/draganddrop/draggabletext/draglabel.rb +51 -51
- data/examples/draganddrop/draggabletext/dragwidget.rb +94 -94
- data/examples/draganddrop/draggabletext/main.rb +33 -33
- data/examples/draganddrop/draggabletext/words.txt +41 -41
- data/examples/draganddrop/dropsite/dropsitewidget.rb +99 -99
- data/examples/draganddrop/dropsite/dropsitewindow.rb +114 -114
- data/examples/draganddrop/dropsite/main.rb +33 -33
- data/examples/draganddrop/fridgemagnets/draglabel.rb +78 -78
- data/examples/draganddrop/fridgemagnets/dragwidget.rb +130 -130
- data/examples/draganddrop/fridgemagnets/main.rb +33 -33
- data/examples/draganddrop/fridgemagnets/words.txt +48 -48
- data/examples/draganddrop/puzzle/main.rb +33 -33
- data/examples/draganddrop/puzzle/mainwindow.rb +136 -136
- data/examples/draganddrop/puzzle/pieceslist.rb +95 -95
- data/examples/draganddrop/puzzle/puzzlewidget.rb +190 -190
- data/examples/graphicsview/collidingmice/main.rb +53 -53
- data/examples/graphicsview/collidingmice/makefile +2 -2
- data/examples/graphicsview/collidingmice/mice.qrc +5 -5
- data/examples/graphicsview/collidingmice/mouse.rb +176 -176
- data/examples/graphicsview/dragdroprobot/coloritem.rb +86 -86
- data/examples/graphicsview/dragdroprobot/main.rb +57 -57
- data/examples/graphicsview/dragdroprobot/makefile +2 -2
- data/examples/graphicsview/dragdroprobot/robot.qrc +5 -5
- data/examples/graphicsview/dragdroprobot/robot.rb +246 -246
- data/examples/itemviews/chart/chart.qrc +5 -5
- data/examples/itemviews/chart/main.rb +33 -33
- data/examples/itemviews/chart/mainwindow.rb +151 -151
- data/examples/itemviews/chart/makefile +2 -2
- data/examples/itemviews/chart/mydata.cht +8 -8
- data/examples/itemviews/chart/pieview.rb +516 -516
- data/examples/itemviews/chart/qtdata.cht +14 -14
- data/examples/itemviews/dirview/main.rb +39 -39
- data/examples/itemviews/pixelator/imagemodel.rb +51 -51
- data/examples/itemviews/pixelator/images.qrc +5 -5
- data/examples/itemviews/pixelator/main.rb +34 -34
- data/examples/itemviews/pixelator/mainwindow.rb +218 -218
- data/examples/itemviews/pixelator/makefile +3 -3
- data/examples/itemviews/pixelator/pixeldelegate.rb +67 -67
- data/examples/itemviews/puzzle/main.rb +36 -36
- data/examples/itemviews/puzzle/mainwindow.rb +143 -143
- data/examples/itemviews/puzzle/piecesmodel.rb +174 -174
- data/examples/itemviews/puzzle/puzzlewidget.rb +192 -192
- data/examples/itemviews/simpledommodel/domitem.rb +62 -62
- data/examples/itemviews/simpledommodel/dommodel.rb +139 -139
- data/examples/itemviews/simpledommodel/main.rb +33 -33
- data/examples/itemviews/simpledommodel/mainwindow.rb +66 -66
- data/examples/itemviews/simpletreemodel/default.txt +40 -40
- data/examples/itemviews/simpletreemodel/main.rb +41 -41
- data/examples/itemviews/simpletreemodel/makefile +2 -2
- data/examples/itemviews/simpletreemodel/simpletreemodel.qrc +5 -5
- data/examples/itemviews/simpletreemodel/treeitem.rb +67 -67
- data/examples/itemviews/simpletreemodel/treemodel.rb +164 -164
- data/examples/itemviews/sortingmodel/default.txt +40 -40
- data/examples/itemviews/sortingmodel/main.rb +53 -53
- data/examples/itemviews/sortingmodel/treeitem.rb +73 -73
- data/examples/itemviews/sortingmodel/treemodel.rb +166 -166
- data/examples/itemviews/spinboxdelegate/main.rb +47 -47
- data/examples/itemviews/spinboxdelegate/spinboxdelegate.rb +62 -62
- data/examples/killerfilter/killerfilter.rb +55 -55
- data/examples/layouts/basiclayouts/dialog.rb +110 -110
- data/examples/layouts/basiclayouts/main.rb +31 -31
- data/examples/layouts/borderlayout/borderlayout.rb +190 -190
- data/examples/layouts/borderlayout/main.rb +32 -32
- data/examples/layouts/borderlayout/window.rb +52 -52
- data/examples/layouts/flowlayouts/flowlayout.rb +108 -108
- data/examples/layouts/flowlayouts/main.rb +32 -32
- data/examples/layouts/flowlayouts/window.rb +43 -43
- data/examples/mainwindows/application/main.rb +32 -32
- data/examples/mainwindows/application/mainwindow.rb +285 -285
- data/examples/mainwindows/dockwidgets/main.rb +32 -32
- data/examples/mainwindows/dockwidgets/mainwindow.rb +302 -302
- data/examples/mainwindows/mdi/main.rb +32 -32
- data/examples/mainwindows/mdi/mainwindow.rb +363 -363
- data/examples/mainwindows/mdi/mdichild.rb +152 -152
- data/examples/mainwindows/menus/main.rb +32 -32
- data/examples/mainwindows/menus/mainwindow.rb +327 -327
- data/examples/mainwindows/recentfiles/main.rb +32 -32
- data/examples/mainwindows/recentfiles/mainwindow.rb +258 -258
- data/examples/mainwindows/sdi/main.rb +32 -32
- data/examples/mainwindows/sdi/mainwindow.rb +335 -335
- data/examples/network/broadcastreceiver/main.rb +32 -32
- data/examples/network/broadcastreceiver/receiver.rb +64 -64
- data/examples/network/broadcastsender/main.rb +32 -32
- data/examples/network/broadcastsender/sender.rb +72 -72
- data/examples/network/fortuneclient/client.rb +149 -149
- data/examples/network/fortuneclient/main.rb +32 -32
- data/examples/network/fortuneserver/main.rb +32 -32
- data/examples/network/fortuneserver/server.rb +88 -88
- data/examples/network/ftp/ftpwindow.rb +259 -259
- data/examples/network/ftp/main.rb +32 -32
- data/examples/network/http/httpwindow.rb +187 -187
- data/examples/network/http/main.rb +32 -32
- data/examples/network/loopback/dialog.rb +163 -163
- data/examples/network/loopback/main.rb +32 -32
- data/examples/opengl/grabber/glwidget.rb +265 -265
- data/examples/opengl/grabber/main.rb +32 -32
- data/examples/opengl/grabber/mainwindow.rb +189 -189
- data/examples/opengl/hellogl/glwidget.rb +226 -226
- data/examples/opengl/hellogl/main.rb +32 -32
- data/examples/opengl/hellogl/window.rb +66 -66
- data/examples/opengl/textures/glwidget.rb +151 -151
- data/examples/opengl/textures/main.rb +32 -32
- data/examples/opengl/textures/window.rb +77 -77
- data/examples/painting/basicdrawing/main.rb +32 -32
- data/examples/painting/basicdrawing/renderarea.rb +166 -166
- data/examples/painting/basicdrawing/window.rb +215 -215
- data/examples/painting/concentriccircles/circlewidget.rb +88 -88
- data/examples/painting/concentriccircles/main.rb +32 -32
- data/examples/painting/concentriccircles/window.rb +72 -72
- data/examples/painting/fontsampler/main.rb +32 -32
- data/examples/painting/fontsampler/mainwindow.rb +369 -369
- data/examples/painting/fontsampler/mainwindowbase.ui +136 -136
- data/examples/painting/fontsampler/makefile +8 -8
- data/examples/painting/fontsampler/previewdialog.rb +257 -257
- data/examples/painting/fontsampler/previewdialogbase.ui +224 -224
- data/examples/painting/fontsampler/previewlabel.rb +43 -43
- data/examples/painting/imagecomposition/imagecomposer.rb +152 -152
- data/examples/painting/imagecomposition/imagecomposition.qrc +6 -6
- data/examples/painting/imagecomposition/main.rb +33 -33
- data/examples/painting/imagecomposition/makefile +2 -2
- data/examples/painting/painterpaths/main.rb +32 -32
- data/examples/painting/painterpaths/renderarea.rb +97 -97
- data/examples/painting/painterpaths/window.rb +247 -247
- data/examples/painting/svgviewer/files/bubbles.svg +212 -212
- data/examples/painting/svgviewer/files/cubic.svg +77 -77
- data/examples/painting/svgviewer/files/spheres.svg +79 -79
- data/examples/painting/svgviewer/main.rb +38 -38
- data/examples/painting/svgviewer/mainwindow.rb +99 -99
- data/examples/painting/svgviewer/makefile +2 -2
- data/examples/painting/svgviewer/svgview.rb +156 -156
- data/examples/painting/svgviewer/svgviewer.qrc +6 -6
- data/examples/painting/svgviewer/svgwindow.rb +87 -87
- data/examples/painting/transformations/main.rb +32 -32
- data/examples/painting/transformations/renderarea.rb +127 -127
- data/examples/painting/transformations/window.rb +153 -153
- data/examples/passivepopup/passivepopup.rb +38 -38
- data/examples/qdbus/chat/chat.rb +146 -146
- data/examples/qdbus/chat/chat_adaptor.rb +12 -12
- data/examples/qdbus/chat/chat_interface.rb +13 -13
- data/examples/qdbus/chat/chatmainwindow.ui +184 -184
- data/examples/qdbus/chat/chatsetnickname.ui +145 -145
- data/examples/qdbus/chat/makefile +8 -8
- data/examples/qdbus/complexpingpong/complexping.rb +92 -92
- data/examples/qdbus/complexpingpong/complexpong.rb +83 -83
- data/examples/qdbus/complexpingpong/ping-common.rb +1 -1
- data/examples/qdbus/listnames/listnames.rb +69 -69
- data/examples/qdbus/pingpong/ping-common.rb +1 -1
- data/examples/qdbus/pingpong/ping.rb +52 -52
- data/examples/qdbus/pingpong/pong.rb +55 -55
- data/examples/qdbus/remotecontrolledcar/car/car.rb +151 -151
- data/examples/qdbus/remotecontrolledcar/car/main.rb +50 -50
- data/examples/qdbus/remotecontrolledcar/controller/controller.rb +66 -66
- data/examples/qdbus/remotecontrolledcar/controller/controller.ui +61 -61
- data/examples/qdbus/remotecontrolledcar/controller/main.rb +32 -32
- data/examples/qdbus/remotecontrolledcar/controller/makefile +2 -2
- data/examples/qtscribble/scribble.rb +270 -270
- data/examples/richtext/calendar/main.rb +33 -33
- data/examples/richtext/calendar/mainwindow.rb +173 -173
- data/examples/richtext/orderform/detailsdialog.rb +130 -130
- data/examples/richtext/orderform/main.rb +34 -34
- data/examples/richtext/orderform/mainwindow.rb +194 -194
- data/examples/richtext/syntaxhighlighter/examples/example +79 -79
- data/examples/richtext/syntaxhighlighter/highlighter.rb +90 -90
- data/examples/richtext/syntaxhighlighter/main.rb +34 -34
- data/examples/richtext/syntaxhighlighter/mainwindow.rb +105 -105
- data/examples/ruboids/LICENSE.txt +58 -58
- data/examples/ruboids/Manifest +26 -26
- data/examples/ruboids/README +53 -53
- data/examples/ruboids/TODO +29 -29
- data/examples/ruboids/boids.properties +33 -33
- data/examples/ruboids/generateManifest.rb +42 -42
- data/examples/ruboids/release.rb +152 -152
- data/examples/ruboids/ruboids/Boid.rb +141 -141
- data/examples/ruboids/ruboids/BoidView.rb +159 -159
- data/examples/ruboids/ruboids/Camera.rb +24 -24
- data/examples/ruboids/ruboids/CameraDialog.rb +218 -218
- data/examples/ruboids/ruboids/Canvas.rb +143 -143
- data/examples/ruboids/ruboids/Cloud.rb +61 -61
- data/examples/ruboids/ruboids/CloudView.rb +54 -54
- data/examples/ruboids/ruboids/Flock.rb +47 -47
- data/examples/ruboids/ruboids/Graphics.rb +278 -278
- data/examples/ruboids/ruboids/Params.rb +87 -87
- data/examples/ruboids/ruboids/Point.rb +153 -153
- data/examples/ruboids/ruboids/Thing.rb +34 -34
- data/examples/ruboids/ruboids/Triangle.rb +21 -21
- data/examples/ruboids/ruboids/View.rb +88 -88
- data/examples/ruboids/ruboids/World.rb +82 -82
- data/examples/ruboids/ruboids/WorldWindow.rb +52 -52
- data/examples/ruboids/ruboids/info.rb +12 -12
- data/examples/ruboids/ruboids/ruboids.rb +29 -29
- data/examples/threading/main_thread.rb +19 -19
- data/examples/tutorial/t1/t1.rb +10 -10
- data/examples/tutorial/t10/cannon.rb +72 -72
- data/examples/tutorial/t10/lcdrange.rb +45 -45
- data/examples/tutorial/t10/t10.rb +55 -55
- data/examples/tutorial/t11/cannon.rb +124 -124
- data/examples/tutorial/t11/lcdrange.rb +45 -45
- data/examples/tutorial/t11/t11.rb +65 -65
- data/examples/tutorial/t12/cannon.rb +158 -158
- data/examples/tutorial/t12/lcdrange.rb +59 -59
- data/examples/tutorial/t12/t12.rb +66 -66
- data/examples/tutorial/t13/cannon.rb +208 -208
- data/examples/tutorial/t13/gamebrd.rb +113 -113
- data/examples/tutorial/t13/lcdrange.rb +60 -60
- data/examples/tutorial/t13/t13.rb +11 -11
- data/examples/tutorial/t14/cannon.rb +263 -263
- data/examples/tutorial/t14/gamebrd.rb +123 -123
- data/examples/tutorial/t14/lcdrange.rb +63 -63
- data/examples/tutorial/t14/t14.rb +11 -11
- data/examples/tutorial/t2/t2.rb +16 -16
- data/examples/tutorial/t3/t3.rb +18 -18
- data/examples/tutorial/t4/t4.rb +25 -25
- data/examples/tutorial/t5/t5.rb +37 -37
- data/examples/tutorial/t6/t6.rb +52 -52
- data/examples/tutorial/t7/lcdrange.rb +32 -32
- data/examples/tutorial/t7/t7.rb +42 -42
- data/examples/tutorial/t8/cannon.rb +38 -38
- data/examples/tutorial/t8/lcdrange.rb +45 -45
- data/examples/tutorial/t8/t8.rb +43 -43
- data/examples/tutorial/t9/cannon.rb +45 -45
- data/examples/tutorial/t9/lcdrange.rb +46 -46
- data/examples/tutorial/t9/t9.rb +43 -43
- data/examples/widgets/analogclock/analogclock.rb +94 -94
- data/examples/widgets/analogclock/main.rb +9 -9
- data/examples/widgets/calculator/button.rb +45 -45
- data/examples/widgets/calculator/calculator.rb +382 -382
- data/examples/widgets/calculator/main.rb +32 -32
- data/examples/widgets/charactermap/characterwidget.rb +109 -109
- data/examples/widgets/charactermap/main.rb +32 -32
- data/examples/widgets/charactermap/mainwindow.rb +118 -118
- data/examples/widgets/digitalclock/digitalclock.rb +30 -30
- data/examples/widgets/digitalclock/main.rb +9 -9
- data/examples/widgets/groupbox/main.rb +32 -32
- data/examples/widgets/groupbox/window.rb +134 -134
- data/examples/widgets/icons/iconpreviewarea.rb +110 -110
- data/examples/widgets/icons/iconsizespinbox.rb +39 -39
- data/examples/widgets/icons/imagedelegate.rb +73 -73
- data/examples/widgets/icons/main.rb +32 -32
- data/examples/widgets/icons/mainwindow.rb +351 -351
- data/examples/widgets/imageviewer/imageviewer.rb +219 -219
- data/examples/widgets/imageviewer/main.rb +32 -32
- data/examples/widgets/lineedits/main.rb +32 -32
- data/examples/widgets/lineedits/window.rb +199 -199
- data/examples/widgets/movie/main.rb +32 -32
- data/examples/widgets/movie/movieplayer.rb +201 -201
- data/examples/widgets/screenshot/main.rb +32 -32
- data/examples/widgets/screenshot/screenshot.rb +154 -154
- data/examples/widgets/scribble/main.rb +32 -32
- data/examples/widgets/scribble/mainwindow.rb +202 -202
- data/examples/widgets/scribble/scribblearea.rb +154 -154
- data/examples/widgets/sliders/main.rb +32 -32
- data/examples/widgets/sliders/slidersgroup.rb +97 -97
- data/examples/widgets/sliders/window.rb +124 -124
- data/examples/widgets/spinboxes/main.rb +32 -32
- data/examples/widgets/spinboxes/window.rb +213 -213
- data/examples/widgets/tetrix/main.rb +33 -33
- data/examples/widgets/tetrix/tetrixboard.rb +346 -346
- data/examples/widgets/tetrix/tetrixpiece.rb +135 -135
- data/examples/widgets/tetrix/tetrixwindow.rb +88 -88
- data/examples/widgets/tooltips/main.rb +32 -32
- data/examples/widgets/tooltips/shapeitem.rb +31 -31
- data/examples/widgets/tooltips/sortingbox.rb +222 -222
- data/examples/widgets/wiggly/dialog.rb +48 -48
- data/examples/widgets/wiggly/main.rb +9 -9
- data/examples/widgets/wiggly/wigglywidget.rb +75 -75
- data/examples/widgets/windowflags/controllerwindow.rb +195 -195
- data/examples/widgets/windowflags/main.rb +32 -32
- data/examples/widgets/windowflags/previewwindow.rb +103 -103
- data/examples/xml/dombookmarks/frank.xbel +230 -230
- data/examples/xml/dombookmarks/jennifer.xbel +93 -93
- data/examples/xml/dombookmarks/main.rb +34 -34
- data/examples/xml/dombookmarks/mainwindow.rb +129 -129
- data/examples/xml/dombookmarks/xbeltree.rb +172 -172
- data/examples/xml/saxbookmarks/frank.xbel +230 -230
- data/examples/xml/saxbookmarks/jennifer.xbel +93 -93
- data/examples/xml/saxbookmarks/main.rb +34 -34
- data/examples/xml/saxbookmarks/mainwindow.rb +144 -144
- data/examples/xml/saxbookmarks/xbelgenerator.rb +95 -95
- data/examples/xml/saxbookmarks/xbelhandler.rb +122 -122
- data/ext/CMakeLists.txt +3 -0
- data/ext/cmake/modules/BasicFindPackageVersion.cmake.in +30 -30
- data/ext/cmake/modules/CMakeCSharpCompiler.cmake.in +7 -7
- data/ext/cmake/modules/CMakeCSharpInformation.cmake +366 -366
- data/ext/cmake/modules/CMakeDetermineCSharpCompiler.cmake +85 -85
- data/ext/cmake/modules/CMakeTestCSharpCompiler.cmake +1 -1
- data/ext/cmake/modules/FindLibraryWithDebug.cmake +113 -113
- data/ext/cmake/modules/FindMono.cmake +36 -36
- data/ext/cmake/modules/FindPHP5.cmake +179 -179
- data/ext/cmake/modules/FindPerlMore.cmake +78 -78
- data/ext/cmake/modules/FindPhonon.cmake +71 -71
- data/ext/cmake/modules/FindQImageBlitz.cmake +51 -51
- data/ext/cmake/modules/FindQScintilla.cmake +57 -57
- data/ext/cmake/modules/FindQwt5.cmake +104 -104
- data/ext/cmake/modules/FindRuby.cmake +279 -279
- data/ext/cmake/modules/FindSmoke.cmake +78 -78
- data/ext/cmake/modules/MacroLogFeature.cmake +146 -146
- data/ext/cmake/modules/MacroOptionalAddBindings.cmake +47 -47
- data/ext/cmake/modules/MacroOptionalFindPackage.cmake +28 -28
- data/ext/cmake/modules/MacroPushRequiredVars.cmake +47 -47
- data/ext/cmake/modules/MacroWriteBasicCMakeVersionFile.cmake +22 -22
- data/ext/cmake/modules/SmokeConfig.cmake.in +109 -109
- data/ext/generator/CMakeLists.txt +38 -38
- data/ext/generator/cmake/BasicFindPackageVersion.cmake.in +30 -30
- data/ext/generator/cmake/CMakeLists.txt +24 -24
- data/ext/generator/cmake/FindLibraryWithDebug.cmake +113 -113
- data/ext/generator/cmake/FindPhonon.cmake +71 -71
- data/ext/generator/cmake/FindQImageBlitz.cmake +51 -51
- data/ext/generator/cmake/FindQScintilla.cmake +57 -57
- data/ext/generator/cmake/FindQwt5.cmake +104 -104
- data/ext/generator/cmake/HandleImportedTargetsInCMakeRequiredLibraries.cmake +85 -85
- data/ext/generator/cmake/MacroLogFeature.cmake +146 -146
- data/ext/generator/cmake/MacroOptionalAddBindings.cmake +47 -47
- data/ext/generator/cmake/MacroOptionalFindPackage.cmake +28 -28
- data/ext/generator/cmake/MacroWriteBasicCMakeVersionFile.cmake +22 -22
- data/ext/generator/cmake/SmokeConfig.cmake.in +109 -109
- data/ext/generator/config.h +25 -25
- data/ext/generator/generator_export.h +31 -31
- data/ext/generator/generatorenvironment.cpp +52 -52
- data/ext/generator/generatorenvironment.h +35 -35
- data/ext/generator/generatorpreprocessor.cpp +303 -303
- data/ext/generator/generatorpreprocessor.h +83 -83
- data/ext/generator/generators/CMakeLists.txt +4 -4
- data/ext/generator/generators/dump/CMakeLists.txt +15 -15
- data/ext/generator/generators/dump/generator_dump.cpp +36 -36
- data/ext/generator/generators/smoke/CMakeLists.txt +18 -18
- data/ext/generator/generators/smoke/generator_smoke.cpp +240 -240
- data/ext/generator/generators/smoke/globals.h +140 -140
- data/ext/generator/generators/smoke/helpers.cpp +793 -793
- data/ext/generator/generators/smoke/writeClasses.cpp +502 -502
- data/ext/generator/generators/smoke/writeSmokeDataFile.cpp +754 -754
- data/ext/generator/generatorvisitor.cpp +922 -922
- data/ext/generator/generatorvisitor.h +119 -119
- data/ext/generator/name_compiler.cpp +205 -205
- data/ext/generator/name_compiler.h +76 -76
- data/ext/generator/options.cpp +33 -33
- data/ext/generator/options.h +46 -46
- data/ext/generator/parser/CMakeLists.txt +50 -50
- data/ext/generator/parser/ast.cpp +21 -21
- data/ext/generator/parser/ast.h +923 -923
- data/ext/generator/parser/astutilities.h +65 -65
- data/ext/generator/parser/codegenerator.cpp +867 -867
- data/ext/generator/parser/codegenerator.h +180 -180
- data/ext/generator/parser/codemodel_fwd.h +76 -76
- data/ext/generator/parser/commentformatter.cpp +54 -54
- data/ext/generator/parser/commentformatter.h +45 -45
- data/ext/generator/parser/commentparser.cpp +109 -109
- data/ext/generator/parser/commentparser.h +84 -84
- data/ext/generator/parser/control.cpp +40 -40
- data/ext/generator/parser/control.h +51 -51
- data/ext/generator/parser/cppparser_export.h +33 -33
- data/ext/generator/parser/default_visitor.cpp +470 -470
- data/ext/generator/parser/default_visitor.h +116 -116
- data/ext/generator/parser/dumptree.cpp +146 -146
- data/ext/generator/parser/dumptree.h +50 -50
- data/ext/generator/parser/indexedstring.cpp +213 -213
- data/ext/generator/parser/indexedstring.h +147 -147
- data/ext/generator/parser/kdevelop-parser-rev +1 -1
- data/ext/generator/parser/kdevvarlengtharray.h +346 -346
- data/ext/generator/parser/lexer.cpp +964 -964
- data/ext/generator/parser/lexer.h +308 -308
- data/ext/generator/parser/listnode.cpp +20 -20
- data/ext/generator/parser/listnode.h +97 -97
- data/ext/generator/parser/memorypool.cpp +20 -20
- data/ext/generator/parser/memorypool.h +41 -41
- data/ext/generator/parser/name_compiler.cpp +190 -190
- data/ext/generator/parser/name_compiler.h +77 -77
- data/ext/generator/parser/parser.cpp +4708 -4708
- data/ext/generator/parser/parser.h +290 -290
- data/ext/generator/parser/parsesession.cpp +106 -106
- data/ext/generator/parser/parsesession.h +87 -87
- data/ext/generator/parser/problem.h +21 -21
- data/ext/generator/parser/rpp/CMakeLists.txt +45 -45
- data/ext/generator/parser/rpp/Makefile.am +13 -13
- data/ext/generator/parser/rpp/anchor.h +51 -51
- data/ext/generator/parser/rpp/appendedlist.h +363 -363
- data/ext/generator/parser/rpp/chartools.cpp +146 -146
- data/ext/generator/parser/rpp/chartools.h +99 -99
- data/ext/generator/parser/rpp/macrorepository.cpp +44 -44
- data/ext/generator/parser/rpp/macrorepository.h +59 -59
- data/ext/generator/parser/rpp/pp-configuration +86 -86
- data/ext/generator/parser/rpp/pp-engine.h +267 -267
- data/ext/generator/parser/rpp/pp-environment.cpp +271 -271
- data/ext/generator/parser/rpp/pp-environment.h +119 -119
- data/ext/generator/parser/rpp/pp-internal.cpp +38 -38
- data/ext/generator/parser/rpp/pp-internal.h +37 -37
- data/ext/generator/parser/rpp/pp-location.cpp +191 -191
- data/ext/generator/parser/rpp/pp-location.h +89 -89
- data/ext/generator/parser/rpp/pp-macro-expander.cpp +568 -568
- data/ext/generator/parser/rpp/pp-macro-expander.cpp.orig +558 -558
- data/ext/generator/parser/rpp/pp-macro-expander.h +130 -130
- data/ext/generator/parser/rpp/pp-macro.cpp +153 -153
- data/ext/generator/parser/rpp/pp-macro.h +176 -176
- data/ext/generator/parser/rpp/pp-scanner.cpp +311 -311
- data/ext/generator/parser/rpp/pp-scanner.h +97 -97
- data/ext/generator/parser/rpp/pp-stream.cpp +425 -425
- data/ext/generator/parser/rpp/pp-stream.h +183 -183
- data/ext/generator/parser/rpp/preprocessor.cpp +65 -65
- data/ext/generator/parser/rpp/preprocessor.h +80 -80
- data/ext/generator/parser/rpp/rpp.pri +2 -2
- data/ext/generator/parser/rpp/test/t001.cpp +23 -23
- data/ext/generator/parser/rpp/test/t002.cpp +15 -15
- data/ext/generator/parser/rpp/test/t003.cpp +10 -10
- data/ext/generator/parser/rpp/test/t004.cpp +9 -9
- data/ext/generator/parser/rpp/test/t005.cpp +10 -10
- data/ext/generator/parser/rpp/test/t006.cpp +10 -10
- data/ext/generator/parser/rpp/test/t007.cpp +6 -6
- data/ext/generator/parser/rpp/test/t008.cpp +6 -6
- data/ext/generator/parser/rpp/test/t009.cpp +5 -5
- data/ext/generator/parser/rpp/test/t010.cpp +15 -15
- data/ext/generator/parser/rpp/test/t011.cpp +9 -9
- data/ext/generator/parser/rpp/tests/CMakeLists.txt +17 -17
- data/ext/generator/parser/rpp/tests/main.cpp +69 -69
- data/ext/generator/parser/rxx.pri +50 -50
- data/ext/generator/parser/rxx_allocator.h +128 -128
- data/ext/generator/parser/safetycounter.h +57 -57
- data/ext/generator/parser/simplecursor.h +74 -74
- data/ext/generator/parser/stringhelpers.cpp +577 -577
- data/ext/generator/parser/stringhelpers.h +118 -118
- data/ext/generator/parser/symbol.h +140 -140
- data/ext/generator/parser/tests/CMakeLists.txt +46 -46
- data/ext/generator/parser/tests/test_generator.cpp +259 -259
- data/ext/generator/parser/tests/test_parser.cpp +474 -474
- data/ext/generator/parser/tests/test_pool.cpp +109 -109
- data/ext/generator/parser/tests/test_pool.h +35 -35
- data/ext/generator/parser/tests/testconfig.h.cmake +4 -4
- data/ext/generator/parser/tokens.cpp +367 -367
- data/ext/generator/parser/tokens.h +148 -148
- data/ext/generator/parser/type_compiler.cpp +135 -135
- data/ext/generator/parser/type_compiler.h +68 -68
- data/ext/generator/parser/visitor.cpp +115 -115
- data/ext/generator/parser/visitor.h +138 -138
- data/ext/generator/smoke.h +557 -557
- data/ext/generator/smokegen_string.h +43 -43
- data/ext/generator/type.cpp +204 -204
- data/ext/generator/type.h +497 -497
- data/ext/generator/type_compiler.cpp +277 -277
- data/ext/generator/type_compiler.h +80 -80
- data/ext/ruby/CMakeLists.txt +64 -64
- data/ext/ruby/qtdeclarative/CMakeLists.txt +17 -17
- data/ext/ruby/qtdeclarative/qtdeclarative.cpp +67 -67
- data/ext/ruby/qtdeclarative/qtdeclarative.rb +17 -17
- data/ext/ruby/qtdeclarative/qtdeclarativehandlers.cpp +36 -36
- data/ext/ruby/qtruby/AUTHORS +54 -54
- data/ext/ruby/qtruby/COPYING +355 -355
- data/ext/ruby/qtruby/COPYING.LIB +510 -510
- data/ext/ruby/qtruby/ChangeLog +3732 -3732
- data/ext/ruby/qtruby/INSTALL +79 -79
- data/ext/ruby/qtruby/README +264 -264
- data/ext/ruby/qtruby/TODO +8 -8
- data/ext/ruby/qtruby/bin/rbqtapi +152 -152
- data/ext/ruby/qtruby/rails_support/CMakeLists.txt +1 -1
- data/ext/ruby/qtruby/rails_support/active_item_model.rb +234 -234
- data/ext/ruby/qtruby/rails_support/active_table_model.rb +122 -122
- data/ext/ruby/qtruby/src/Qt.cpp +8 -8
- data/ext/ruby/qtruby/src/marshall_basetypes.h +208 -208
- data/ext/ruby/qtruby/src/marshall_complex.h +175 -175
- data/ext/ruby/qtruby/src/marshall_macros.h +647 -647
- data/ext/ruby/qtruby/src/marshall_types.cpp +815 -815
- data/ext/ruby/qtruby/src/marshall_types.h +240 -240
- data/ext/ruby/qtruby/src/qtruby.cpp +69 -12
- data/ext/ruby/qtruby/src/qtruby.h +1 -1
- data/ext/ruby/qtruby/test/opoverloading.rb +46 -46
- data/ext/ruby/qtruby/test/unittests.rb +151 -151
- data/ext/ruby/qtruby/tools/rbrcc/main.cpp +173 -173
- data/ext/ruby/qtruby/tools/rbrcc/rbrcc.pro +14 -14
- data/ext/ruby/qtruby/tools/rbrcc/rcc.cpp +648 -648
- data/ext/ruby/qtruby/tools/rbrcc/rcc.h +165 -165
- data/ext/ruby/qtruby/tools/rbuic/LICENSE.GPL +280 -280
- data/ext/ruby/qtruby/tools/rbuic/TODO +4 -4
- data/ext/ruby/qtruby/tools/rbuic/customwidgetsinfo.cpp +106 -106
- data/ext/ruby/qtruby/tools/rbuic/customwidgetsinfo.h +95 -95
- data/ext/ruby/qtruby/tools/rbuic/databaseinfo.cpp +102 -102
- data/ext/ruby/qtruby/tools/rbuic/databaseinfo.h +85 -85
- data/ext/ruby/qtruby/tools/rbuic/driver.cpp +384 -384
- data/ext/ruby/qtruby/tools/rbuic/driver.h +141 -141
- data/ext/ruby/qtruby/tools/rbuic/option.h +3 -0
- data/ext/ruby/qtruby/tools/rbuic/rbuic.pri +23 -23
- data/ext/ruby/qtruby/tools/rbuic/rbuic4.pro +43 -43
- data/ext/ruby/qtruby/tools/rbuic/ruby/rbextractimages.cpp +150 -150
- data/ext/ruby/qtruby/tools/rbuic/ruby/rbextractimages.h +83 -83
- data/ext/ruby/qtruby/tools/rbuic/ruby/rbwritedeclaration.cpp +217 -217
- data/ext/ruby/qtruby/tools/rbuic/ruby/rbwritedeclaration.h +85 -85
- data/ext/ruby/qtruby/tools/rbuic/ruby/rbwriteicondata.cpp +185 -185
- data/ext/ruby/qtruby/tools/rbuic/ruby/rbwriteicondata.h +86 -86
- data/ext/ruby/qtruby/tools/rbuic/ruby/rbwriteicondeclaration.cpp +88 -88
- data/ext/ruby/qtruby/tools/rbuic/ruby/rbwriteicondeclaration.h +83 -83
- data/ext/ruby/qtruby/tools/rbuic/ruby/rbwriteiconinitialization.cpp +126 -126
- data/ext/ruby/qtruby/tools/rbuic/ruby/rbwriteiconinitialization.h +87 -87
- data/ext/ruby/qtruby/tools/rbuic/ruby/rbwriteinitialization.cpp +2478 -2478
- data/ext/ruby/qtruby/tools/rbuic/ruby/rbwriteinitialization.h +314 -314
- data/ext/ruby/qtruby/tools/rbuic/ruby/ruby.pri +18 -18
- data/ext/ruby/qtruby/tools/rbuic/treewalker.cpp +318 -318
- data/ext/ruby/qtruby/tools/rbuic/treewalker.h +139 -139
- data/ext/ruby/qtruby/tools/rbuic/ui4.cpp +7623 -7623
- data/ext/ruby/qtruby/tools/rbuic/ui4.h +3180 -3180
- data/ext/ruby/qtruby/tools/rbuic/utils.h +125 -125
- data/ext/ruby/qtruby/tools/rbuic/validator.cpp +100 -100
- data/ext/ruby/qtruby/tools/rbuic/validator.h +80 -80
- data/ext/ruby/qtscript/CMakeLists.txt +19 -19
- data/ext/ruby/qtscript/qtscript.cpp +83 -83
- data/ext/ruby/qtscript/qtscript.rb +40 -40
- data/ext/ruby/qtscript/qtscripthandlers.cpp +37 -37
- data/ext/ruby/qtscript/smokedata.cpp +1403 -1403
- data/ext/ruby/qttest/CMakeLists.txt +18 -18
- data/ext/ruby/qttest/ChangeLog +9 -9
- data/ext/ruby/qttest/examples/myfirsttest.rb +30 -30
- data/ext/ruby/qttest/qttest.cpp +83 -83
- data/ext/ruby/qttest/qttest.rb +166 -166
- data/ext/ruby/qttest/qttesthandlers.cpp +37 -37
- data/ext/ruby/qtuitools/CMakeLists.txt +16 -16
- data/ext/ruby/qtuitools/qtuitools.cpp +83 -83
- data/ext/ruby/qtuitools/qtuitools.rb +17 -17
- data/ext/ruby/qtuitools/qtuitoolshandlers.cpp +32 -32
- data/ext/ruby/qtwebkit/CMakeLists.txt +17 -17
- data/ext/ruby/qtwebkit/qtwebkit.cpp +67 -67
- data/ext/ruby/qtwebkit/qtwebkit.rb +17 -17
- data/ext/ruby/qtwebkit/qtwebkithandlers.cpp +40 -40
- data/ext/smoke/deptool/CMakeLists.txt +7 -7
- data/ext/smoke/deptool/main.cpp +128 -128
- data/ext/smoke/qtcore/CMakeLists.txt +88 -88
- data/ext/smoke/qtcore/QtGuess.txt +180 -180
- data/ext/smoke/qtcore/config.xml.cmake +10 -10
- data/ext/smoke/qtcore/qt-config.xml.cmake +21 -21
- data/ext/smoke/qtcore/qtcore_includes.h +1 -1
- data/ext/smoke/qtcore/smokeconfig.xml +193 -193
- data/ext/smoke/qtcore/tests/CMakeLists.txt +13 -13
- data/ext/smoke/qtcore/tests/test.cpp +846 -846
- data/ext/smoke/qtcore_smoke.h +16 -16
- data/ext/smoke/qtdbus/CMakeLists.txt +38 -38
- data/ext/smoke/qtdbus/config.xml.cmake +11 -11
- data/ext/smoke/qtdbus/qtdbus_includes.h +2 -2
- data/ext/smoke/qtdbus/smokeconfig.xml +65 -65
- data/ext/smoke/qtdbus_smoke.h +16 -16
- data/ext/smoke/qtdeclarative/CMakeLists.txt +45 -45
- data/ext/smoke/qtdeclarative/config.xml.cmake +12 -12
- data/ext/smoke/qtdeclarative/qtdeclarative_includes.h +3 -3
- data/ext/smoke/qtdeclarative/smokeconfig.xml +59 -59
- data/ext/smoke/qtdeclarative_smoke.h +16 -16
- data/ext/smoke/qtgui/CMakeLists.txt +76 -76
- data/ext/smoke/qtgui/config.xml.cmake +11 -11
- data/ext/smoke/qtgui/qtgui_includes.h +7 -7
- data/ext/smoke/qtgui/smokeconfig.xml +500 -500
- data/ext/smoke/qtgui_smoke.h +16 -16
- data/ext/smoke/qthelp/CMakeLists.txt +45 -45
- data/ext/smoke/qthelp/config.xml.cmake +13 -13
- data/ext/smoke/qthelp/qthelp_includes.h +3 -3
- data/ext/smoke/qthelp/smokeconfig.xml +54 -54
- data/ext/smoke/qthelp_smoke.h +16 -16
- data/ext/smoke/qtmultimedia/CMakeLists.txt +42 -42
- data/ext/smoke/qtmultimedia/config.xml.cmake +12 -12
- data/ext/smoke/qtmultimedia/qtmultimedia_includes.h +3 -3
- data/ext/smoke/qtmultimedia/smokeconfig.xml +51 -51
- data/ext/smoke/qtmultimedia_smoke.h +16 -16
- data/ext/smoke/qtnetwork/CMakeLists.txt +38 -38
- data/ext/smoke/qtnetwork/config.xml.cmake +11 -11
- data/ext/smoke/qtnetwork/qtnetwork_includes.h +2 -2
- data/ext/smoke/qtnetwork/smokeconfig.xml +81 -81
- data/ext/smoke/qtnetwork_smoke.h +16 -16
- data/ext/smoke/qtopengl/CMakeLists.txt +43 -43
- data/ext/smoke/qtopengl/config.xml.cmake +13 -13
- data/ext/smoke/qtopengl/qtopengl_includes.h +3 -3
- data/ext/smoke/qtopengl/smokeconfig.xml +58 -58
- data/ext/smoke/qtopengl_smoke.h +16 -16
- data/ext/smoke/qtscript/CMakeLists.txt +31 -31
- data/ext/smoke/qtscript/config.xml.cmake +11 -11
- data/ext/smoke/qtscript/qtscript_includes.h +14 -14
- data/ext/smoke/qtscript/smokeconfig.xml +39 -39
- data/ext/smoke/qtscript_smoke.h +16 -16
- data/ext/smoke/qtsql/CMakeLists.txt +45 -45
- data/ext/smoke/qtsql/config.xml.cmake +11 -11
- data/ext/smoke/qtsql/qtsql_includes.h +3 -3
- data/ext/smoke/qtsql/smokeconfig.xml +60 -60
- data/ext/smoke/qtsql_smoke.h +16 -16
- data/ext/smoke/qtsvg/CMakeLists.txt +43 -43
- data/ext/smoke/qtsvg/config.xml.cmake +12 -12
- data/ext/smoke/qtsvg/qtsvg_includes.h +3 -3
- data/ext/smoke/qtsvg/smokeconfig.xml +46 -46
- data/ext/smoke/qtsvg_smoke.h +16 -16
- data/ext/smoke/qttest/CMakeLists.txt +35 -35
- data/ext/smoke/qttest/config.xml.cmake +12 -12
- data/ext/smoke/qttest/qttest_includes.h +14 -14
- data/ext/smoke/qttest/smokeconfig.xml +36 -36
- data/ext/smoke/qttest_smoke.h +16 -16
- data/ext/smoke/qtuitools/CMakeLists.txt +30 -30
- data/ext/smoke/qtuitools/config.xml.cmake +12 -12
- data/ext/smoke/qtuitools/qtuitools_includes.h +1 -1
- data/ext/smoke/qtuitools/smokeconfig.xml +20 -20
- data/ext/smoke/qtuitools_smoke.h +16 -16
- data/ext/smoke/qtwebkit/CMakeLists.txt +36 -36
- data/ext/smoke/qtwebkit/config.xml.cmake +11 -11
- data/ext/smoke/qtwebkit/qtwebkit_includes.h +1 -1
- data/ext/smoke/qtwebkit/smokeconfig.xml +48 -48
- data/ext/smoke/qtwebkit_smoke.h +16 -16
- data/ext/smoke/qtxml/CMakeLists.txt +41 -41
- data/ext/smoke/qtxml/config.xml.cmake +11 -11
- data/ext/smoke/qtxml/qtxml_includes.h +2 -2
- data/ext/smoke/qtxml/smokeconfig.xml +70 -70
- data/ext/smoke/qtxml_smoke.h +16 -16
- data/ext/smoke/qtxmlpatterns/CMakeLists.txt +42 -42
- data/ext/smoke/qtxmlpatterns/config.xml.cmake +12 -12
- data/ext/smoke/qtxmlpatterns/qtxmlpatterns_includes.h +3 -3
- data/ext/smoke/qtxmlpatterns/smokeconfig.xml +80 -80
- data/ext/smoke/qtxmlpatterns_smoke.h +16 -16
- data/ext/smoke/smokeapi/CMakeLists.txt +9 -9
- data/ext/smoke/smokeapi/main.cpp +309 -309
- data/ext/smoke/smokebase/CMakeLists.txt +11 -11
- data/ext/smoke/smokebase/smokebase.cpp +6 -6
- data/ext/smoke/solid_smoke.h +16 -16
- data/extconf.rb +2 -2
- data/lib/Qt.rb +1 -1
- data/lib/Qt4.rb +111 -111
- data/lib/qtbindings_version.rb +2 -2
- data/lib/qtdeclarative/qtdeclarative.rb +17 -17
- data/lib/qtscript/qtscript.rb +40 -40
- data/lib/qttest/qttest.rb +166 -166
- data/lib/qtuitools/qtuitools.rb +17 -17
- data/lib/qtwebkit/qtwebkit.rb +17 -17
- data/qtbindings.gemspec +18 -18
- metadata +48 -48
@@ -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
|