summaryrefslogtreecommitdiff
path: root/unoidl
AgeCommit message (Collapse)Author
2013-10-24fdo#67725 unoidl::AggregatingCursor must wrap modules for aggregation, tooStephan Bergmann
Otherwise cppuhelper::TypeManager::createTypeDescriptionEnumeration, sitting on top such an AggregatingCursor, will miss any entities from provider P' in module M if any previous provider P contains the same module M. That happened when climaker generates cli_oootypes.dll, where the enumeration missed everything from offapi in top-level module "com" because it had already seen udkapi's "com", and only reported the handful of entities under offapi's other top-level module "org" (which does not appear in udkapi). Change-Id: If538391bde22bcc346417b5988cf12023f0d4172
2013-10-15Allow starts-/endsWith* to also return the rest of the matched stringStephan Bergmann
...as there are many cases where the code later wants to obtain this part, and esp. for the string literal variants it is awkward to calculate the length of the literal again if this is coded with a following copy() call. Adapt some code to use this new feature. (Strictly speaking, the @since tags for the---backwards-compatibly---modified functions are no longer accurate of course. Also, clean up some sal_Bool and SAL_THROWS(()) that are unnecesssary cargo-cult here, and where the clean-up should have no practical compatibility consequences.) Change-Id: I43e5c578c8c4b44cb47fd08f170b5c69322ad641
2013-10-10Silence some false Covertiy scan warnings about uninitialized membersStephan Bergmann
Change-Id: I5e1d870a60f4c0d4b805c615d0e3c958e856bf8c
2013-10-10Make changes of interface method parameter names a hard failureStephan Bergmann
...instead of a warning, now that all the deliberate changes have been addressed. Change-Id: I6075a36a560bd68826c6840992eefb8f51b939ba
2013-09-20keep C++03 compilers happyStephan Bergmann
Change-Id: I62af395105f51e802b874424b993dcf7e687a78b
2013-09-20Reject "too similar" service constructorsStephan Bergmann
Change-Id: Ie81e9994084b5a2f44a436c764318ea6e5049faf
2013-09-20Certain UNOIDL typedefs are forbidden for historic reasonsStephan Bergmann
Change-Id: I0fb4ca4e529f5f35e3619bab5e89348dd9c67faf
2013-09-19Directly build UNOIDL .rdb files from .idl filesStephan Bergmann
...via unoidl-write and the new source-format registry provicers, instead of using idlc to produce .urd files, regmerge to merge them into legacy .rdb files, and unoidl-write to translate those to new UNOIDL .rdb files. gb_UnoApi and gb_InternalUnoApi ctors take an additional argument now that is the path (below $(SRCDIR)) of the source-format registry from which to obtain UNOIDL entity definitions. It can either be an .idl file (in which case no *_add_idlfiles calls should be used and the resulting .rdb will contain all the entities from that one .idl file; used in some tests to conveniently define all test-specific entities in a single file) or a directory denoting the root of an .idl file tree (in which case *_add_idlfiles calls specify the entites to include in the resulting .idl file). (In the first case, the generated .rdb file needs to depend on that single .idl file, so the gb_UnoApiTarget ctor contains a dependency on that additional argument, which happens, as a side effect, to trigger rebuilds in the second, tree-based case when addition/removal of .idl files in the tree causes updates of directory time-stamps.) UnoApiPartTarget and all the dependency-tracking logic based on .urd files in solenv/gbuild/UnoApiTarget.mk is gone. Generation of an .rdb file now depends on its source registry (see previous paragraph) and all the .idl files specified with *_add_idlfiles (in the second, tree-based case above). A consequence of that is that gb_UnoApi_add_idlfile, -_nohdl, and -_noheader all do the same now. I left them in for now anyway, maybe they become relevant again when the use of cppumaker is changed to read directly from a source-format registry instead of going via a .rdb registry. The legacy tools idlc, regcompare, regmerge, and regview are still contained in the URE or SDK for now. cb344cd59e1ddb7c6db66dbd9263b4755969d4ba "Revert 'Looks like idlc resolved typedefs inside sequence<...>'" is re-reverted as now "the current offapi.rdb is generated via unoidl-write instead of idlc." Change-Id: I3d9d92f17326bc9f49dd934c85aab6a17951d06d
2013-09-19Update unoidl/READMEStephan Bergmann
Change-Id: Ib4cc138ab4c6de0d3d3a8ad55e40ba9ca30c15ae
2013-09-19Fix indentationStephan Bergmann
Change-Id: I7814547ef29ec728a5a815196427b661bf285256
2013-09-19-Werror,-Wunused-parameterStephan Bergmann
Change-Id: I331d769132d3b18c870c70c7abcbd9539135af55
2013-09-19Prevent conflicts on case-preserving file systemsStephan Bergmann
Change-Id: Ia40f0ce43086fd73cba60011001640a945fb3e26
2013-09-19Handle special case -(2^63) correctlyStephan Bergmann
Change-Id: Ia3d8931341b2d47ef76265d94410d83f51a068c0
2013-09-19typoStephan Bergmann
Change-Id: I79660ddd3ec9f78452fa484b33a9720cbf8ddc80
2013-09-18New unoidl-check tool to replace regcompareStephan Bergmann
...for checking compatibility with the reference rdbs. unoidl-check is no longer based on the legacy registry format, but can process all the various new UNOIDL registry formats. regcompare is still included in the SDK for now. (gb_UnoApi[Target]_set_reference_rdbfile now takes a non-empty sequence of rdb files, any necessary dependencies of the final rdf file preceding it just like it is required on the unoidl-check command line. Also, executing the unoidl-check now properly depends on those rdb files.) TODO: unoidl-check is too conservative for now and flags some changes as incompatible that are not. Change-Id: I92e4c69403c5e3fcb31707c98c65a2f509592dd4
2013-09-18Unpublished optional bases of published interfaces complicate thingsStephan Bergmann
Change-Id: I206b623fcc3c9e04fc5336cb3704315c44fb83b8
2013-09-18Some fixes of the generated .idl outputStephan Bergmann
Change-Id: I2d71e148f302ebfbf8d0fbfc74a7fb523b7bfcd4
2013-09-18-WshadowStephan Bergmann
Change-Id: I8299079b46be4ccb7070f5497d089166a953c939
2013-09-18Executable_unoidl-read needed only for DESKTOP platformsTor Lillqvist
Change-Id: Id1edf4fcebfe0d839162adb442695e9ce39e3f75
2013-09-17Missing includeStephan Bergmann
Change-Id: I93d35ca7b784fc6d1b228347053ef0f76904f039
2013-09-17Clean up includesStephan Bergmann
Change-Id: I784ba245526f6fbf933ee485df1604e82980d931
2013-09-17&& vs. & typosStephan Bergmann
Change-Id: I7475114158d64b8dbe64cd9d1de3415454c762f4
2013-09-17New unoidl-read tool to translate registries into readable .idl filesStephan Bergmann
Change-Id: Ibd6ce23d2698280105469fb75c4afa225dc237ee
2013-09-17Fix usage messageStephan Bergmann
Change-Id: I7d8b196d047b1e0075acdbf380a9b3ed750a7b90
2013-09-17Fix build with Bison 3Khaled Hosny
The Bison 3 generated sources do not seem to define YYID, so our YYLLOC_DEFAULT definition was broken. No idea what any of this means, but sberg said I can safely remove the YYID usage, so if it kills your pet, you know whom to blame. Change-Id: I464564be941e0a49da264057923bf8e8e82d5ffd
2013-09-17-Werror=shadowJulien Nabet
Change-Id: Ia344d5a68118ba9896672ebbf4cccaf0511f8186
2013-09-17WIP: additional unoidl::Provider that directly reads a single .idl fileStephan Bergmann
Change-Id: Iab795a34a657cb36ced24a1a05f6c21a6c1637aa
2013-09-17Rename SourceProvider -> SourceTreeProviderStephan Bergmann
Change-Id: Ic864f9c6f3dbbe9f75bdae76818c00f62825182d
2013-09-17Move full file parsing logic to sourceprovider-parser.yStephan Bergmann
...in preparation of SourceFile- vs. -TreeProvider. Change-Id: I4c8f37ade1ba26cb7b38f63211711613d1b98a73
2013-09-17Detect reuse of module names for other entitiesStephan Bergmann
Change-Id: Ifc8d95b4b15a7dd91195e6f727fdb7fa2a267be9
2013-09-16Clean up the unoidl Providers (no need to have them exported)Stephan Bergmann
Change-Id: I96b99e96b44f12b7ad7f376e4b3a68d7e9531643
2013-09-16Replace reg2unoidl with unoidl-writeStephan Bergmann
...that can also generate an .rdb containing a specific set of entities, intended to replace idlc (when reading directly from .idl source registries). Change-Id: I630ce4640828979d7952dc24dbbef80a42a8140a
2013-09-16Hook SourceProvider into unoidl::loadProviderStephan Bergmann
Change-Id: I0a499fd98a1008ced0efdeec3b10bff30df57c0e
2013-09-12WaE: C4805: '!=' : unsafe mix of type 'bool' and type 'sal_Bool' in operationTor Lillqvist
Change-Id: I3fd7508a3b9c362661ad1bfa66901be9f938b8e6
2013-09-12Fix C++11'ismStephan Bergmann
Change-Id: Ia2ecbbc9262b4e2b794914030f88e1c9d792cb5e
2013-09-12WIP: additional unoidl::Provider that directly reads from .idl filesStephan Bergmann
Change-Id: I30fa6400724f4ca6f0e1986c741500f05710b840
2013-07-09fdo#65589: Treat legacy types.rdb w/o /UCR key as emptyStephan Bergmann
...as they are encountered in the wild. Change-Id: Iae46d3b4b4aca18a09680caabc0e343f8a534989
2013-05-29fdo#60724 change spelling error REMOVEABLE -> REMOVABLE IIThomas Arnhold
Change-Id: I0057b9174af6a83f3fde0e27c3a91a4aeca95873 Signed-off-by: Stephan Bergmann <sbergman@redhat.com>
2013-05-16Support for annotations in the new UNOIDL formatStephan Bergmann
...used for now to transport @deprecated information. Also, improve Idx-String (formerly Idx-Name, but also used for UTF-8 annotations now) format, using the 0x80000000 for the indirection rather than the base case. (And the README erroneously used "Offset of" Idx-String all over the place.) Change-Id: I7003b1558ab536a11a9af308f9b16a7ef8840792
2013-05-08Minor improvements to UNOIDL binary formatStephan Bergmann
Change-Id: Ia215b34842ce85bfbd1ad90a286abcbae0884bd5
2013-05-08unoidl/README improvementsStephan Bergmann
Change-Id: I5123d984f8f9bf49f5d1ad8e8decebfaaa6e7769
2013-05-08unoidl/READMEStephan Bergmann
Change-Id: Ied31816571842118eb00de96df82ecb06465a65d
2013-04-24Copy/paste errorStephan Bergmann
Change-Id: I0c6e0ecc5c9e6289a2afe733d4752351416900a8
2013-04-24gbuild: drop uses of removed packagesDavid Tardon
Change-Id: I400fad08c0ae7b6b34bad63693f54856867e4dac Reviewed-on: https://gerrit.libreoffice.org/3502 Reviewed-by: David Tardon <dtardon@redhat.com> Tested-by: David Tardon <dtardon@redhat.com>
2013-04-23execute move of global headersBjoern Michaelsen
see https://gerrit.libreoffice.org/#/c/3367/ and Change-Id: I00c96fa77d04b33a6f8c8cd3490dfcd9bdc9e84a for details Change-Id: I199a75bc4042af20817265d5ef85b1134a96ff5a
2013-04-22Revert "Revert "WIP: Experimental new binary type.rdb format""Stephan Bergmann
This reverts commit 67e69a55820f50973ca0de75ccab2bb07d0bada8, applying a band- aid fix to cli_ure/source/climaker for now. Conflicts: stoc/inc/bootstrapservices.hxx stoc/source/tdmanager/lrucache.hxx stoc/source/tdmanager/tdmgr.cxx stoc/source/tdmanager/tdmgr_common.hxx stoc/source/tdmanager/tdmgr_tdenumeration.cxx stoc/source/tdmanager/tdmgr_tdenumeration.hxx Change-Id: Iae669985d0194f06fa349a4a39f0ebd230bc5d28
2013-04-09[API CHANGE] WIP: Experimental new binary type.rdb formatStephan Bergmann
Make cppumaker work on top of unoidl/ instead of registry/, as a first step to change all the various codemakers. * API CHANGE: cppumaker no longer supports the -B switch, as that is meaningless with the new format. When reading from an old-format .rdb file, /UCR is hard-coded as the prefix now. * TODO: The new format does not yet support deprecation annotations, so the generated .hdl/.hpp files lack any SAL_DEPRECATED_INTERNALs for now. * codemaker/typemanager.hxx is extended with access to unoidl/ functionality, so the various codemakers can use registry/ and unoidl/ in parallel for now. The access to registry/ functionality will be removed. (Added small throwaway helper functions u2b/b2u to easily map between OString and OUString at the remaining seams for now.) * Includes a selective revert of ba044b1e9613ed30906a9a540b7da8392923e4e3 "remove needless forward rtl::OUString declarations" in those parts of codemaker, unodevtools, unoidl that were covered by this local work-in-progress patch; I would otherwise have hard a hard time re-applying it. * The generated .hdl/.hpp files are mostly unchanged, except for a few minor things: ** Any SAL_DEPRECATED_INTERNALs are missing (see above). ** In comprehensive getCppuType definitions, some members were erroneously classified as TypeCalss_UNKNOWN. ** In comprehensive getCppuType definitions, some unnecessary calls like ::cppu::UnoType< ::sal_Int32 >::get(); can be removed. ** For typedef sequence<X>, the .hdl file need not include X.hdl, but only needs to forward-declare it. ** Unnecessary includes for optional bases of interfaces can be removed. ** Some numbering of local variable names (sMethodName1, ...) has changed. Change-Id: Icad98f248ac15177337f1b4ab709a755a8af6238
2013-04-07remove needless forward rtl::OUString declarationsLuboš Luňák
Change-Id: I97d91a758dd82d64768d75c1d2ddd279de5f6034
2013-04-07mass removal of rtl:: prefixes for O(U)String*Luboš Luňák
Modules sal, salhelper, cppu, cppuhelper, codemaker (selectively) and odk have kept them, in order not to break external API (the automatic using declaration is LO-internal). Change-Id: I588fc9e0c45b914f824f91c0376980621d730f09
2013-04-02Off-by-one errorStephan Bergmann
Change-Id: I2abd81782baf421ff4e70b158709dbe6da5e14e3