/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #ifndef INCLUDED_UNOIDL_SOURCE_SOURCEPROVIDER_SCANNER_HXX #define INCLUDED_UNOIDL_SOURCE_SOURCEPROVIDER_SCANNER_HXX #include "sal/config.h" #include #include #include #include "rtl/ref.hxx" #include "rtl/ustring.hxx" #include "sal/types.h" #include "salhelper/simplereferenceobject.hxx" #include "unoidl/unoidl.hxx" #include "sourceprovider-parser-requires.hxx" #include "sourceprovider-parser.hxx" namespace unoidl { namespace detail { class SourceProviderEntityPad: public salhelper::SimpleReferenceObject { public: bool isPublished() const { return published_; } protected: explicit SourceProviderEntityPad(bool published): published_(published) {} virtual ~SourceProviderEntityPad() {} private: bool const published_; }; class SourceProviderEnumTypeEntityPad: public SourceProviderEntityPad { public: explicit SourceProviderEnumTypeEntityPad(bool published): SourceProviderEntityPad(published) {} std::vector members; private: virtual ~SourceProviderEnumTypeEntityPad() throw () {} }; class SourceProviderPlainStructTypeEntityPad: public SourceProviderEntityPad { public: SourceProviderPlainStructTypeEntityPad( bool published, OUString theBaseName, rtl::Reference const & theBaseEntity): SourceProviderEntityPad(published), baseName(theBaseName), baseEntity(theBaseEntity) { assert(theBaseName.isEmpty() != (bool) theBaseEntity.is()); } OUString const baseName; rtl::Reference const baseEntity; std::vector members; private: virtual ~SourceProviderPlainStructTypeEntityPad() throw () {} }; class SourceProviderPolymorphicStructTypeTemplateEntityPad: public SourceProviderEntityPad { public: SourceProviderPolymorphicStructTypeTemplateEntityPad(bool published): SourceProviderEntityPad(published) {} std::vector typeParameters; std::vector members; private: virtual ~SourceProviderPolymorphicStructTypeTemplateEntityPad() throw () {} }; class SourceProviderExceptionTypeEntityPad: public SourceProviderEntityPad { public: SourceProviderExceptionTypeEntityPad( bool published, OUString theBaseName, rtl::Reference const & theBaseEntity): SourceProviderEntityPad(published), baseName(theBaseName), baseEntity(theBaseEntity) { assert(theBaseName.isEmpty() != (bool) theBaseEntity.is()); } OUString const baseName; rtl::Reference const baseEntity; std::vector members; private: virtual ~SourceProviderExceptionTypeEntityPad() throw () {} }; class SourceProviderInterfaceTypeEntityPad: public SourceProviderEntityPad { public: struct Base { Base( OUString const & theName, rtl::Reference const & theEntity, std::vector const & theAnnotations): name(theName), entity(theEntity), annotations(theAnnotations) {} OUString name; rtl::Reference entity; std::vector annotations; }; SourceProviderInterfaceTypeEntityPad( bool published, OUString singleBaseName, rtl::Reference const & singleBaseEntity): SourceProviderEntityPad(published), singleBase(!singleBaseName.isEmpty()) { assert(singleBaseName.isEmpty() != (bool) singleBaseEntity.is()); if (singleBase) { mandatoryBases.push_back( Base( singleBaseName, singleBaseEntity, std::vector())); } } bool singleBase; std::vector mandatoryBases; std::vector optionalBases; std::vector attributes; std::vector methods; private: virtual ~SourceProviderInterfaceTypeEntityPad() throw () {} }; class SourceProviderConstantGroupEntityPad: public SourceProviderEntityPad { public: explicit SourceProviderConstantGroupEntityPad(bool published): SourceProviderEntityPad(published) {} std::vector members; private: virtual ~SourceProviderConstantGroupEntityPad() throw () {} }; class SourceProviderSingleInterfaceBasedServiceEntityPad: public SourceProviderEntityPad { public: struct Constructor { struct Parameter { Parameter( rtl::OUString const & theName, SourceProviderType const & theType, bool theRest): name(theName), type(theType), rest(theRest) {} rtl::OUString name; SourceProviderType type; bool rest; }; Constructor( rtl::OUString const & theName, std::vector< rtl::OUString > const & theAnnotations): name(theName), annotations(theAnnotations) {} rtl::OUString name; std::vector< Parameter > parameters; std::vector< rtl::OUString > exceptions; std::vector< rtl::OUString > annotations; }; explicit SourceProviderSingleInterfaceBasedServiceEntityPad( bool published, OUString const & theBase): SourceProviderEntityPad(published), base(theBase) {} OUString const base; std::vector constructors; private: virtual ~SourceProviderSingleInterfaceBasedServiceEntityPad() throw () {} }; class SourceProviderAccumulationBasedServiceEntityPad: public SourceProviderEntityPad { public: explicit SourceProviderAccumulationBasedServiceEntityPad(bool published): SourceProviderEntityPad(published) {} std::vector directMandatoryBaseServices; std::vector directOptionalBaseServices; std::vector directMandatoryBaseInterfaces; std::vector directOptionalBaseInterfaces; std::vector directProperties; private: virtual ~SourceProviderAccumulationBasedServiceEntityPad() throw () {} }; struct SourceProviderEntity { enum Kind { KIND_EXTERNAL, KIND_LOCAL, KIND_INTERFACE_DECL, KIND_MODULE }; explicit SourceProviderEntity( Kind theKind, rtl::Reference const & externalEntity): kind(theKind), entity(externalEntity) { assert(theKind <= KIND_LOCAL); assert(externalEntity.is()); } explicit SourceProviderEntity( rtl::Reference const & localPad): kind(KIND_LOCAL), pad(localPad) { assert(localPad.is()); } explicit SourceProviderEntity(Kind theKind): kind(theKind) { assert(theKind >= KIND_INTERFACE_DECL); } SourceProviderEntity() {} // needed for std::map::operator [] Kind kind; rtl::Reference entity; rtl::Reference pad; }; struct SourceProviderScannerData { SourceProviderScannerData( rtl::Reference const & theManager): manager(theManager), errorLine(0) { assert(manager.is()); } void setSource(void const * address, sal_uInt64 size) { sourcePosition = static_cast(address); sourceEnd = sourcePosition + size; } rtl::Reference manager; char const * sourcePosition; char const * sourceEnd; YYLTYPE errorLine; OString parserError; OUString errorMessage; std::map entities; std::vector modules; OUString currentName; }; bool parse(OUString const & uri, SourceProviderScannerData * data); } } int yylex_init_extra( unoidl::detail::SourceProviderScannerData * user_defined, yyscan_t * yyscanner); int yylex_destroy(yyscan_t yyscanner); int yylex(YYSTYPE * yylval_param, YYLTYPE * yylloc_param, yyscan_t yyscanner); unoidl::detail::SourceProviderScannerData * yyget_extra(yyscan_t yyscanner); #endif /* vim:set shiftwidth=4 softtabstop=4 expandtab: */