diff options
-rw-r--r-- | rsc/inc/rscclass.hxx | 2 | ||||
-rw-r--r-- | rsc/inc/rsctop.hxx | 25 | ||||
-rw-r--r-- | rsc/source/parser/rscicpx.cxx | 48 | ||||
-rw-r--r-- | rsc/source/parser/rscinit.cxx | 2 | ||||
-rw-r--r-- | rsc/source/res/rscclass.cxx | 84 |
5 files changed, 69 insertions, 92 deletions
diff --git a/rsc/inc/rscclass.hxx b/rsc/inc/rscclass.hxx index bc9b31237d7f..31bf1fd0e337 100644 --- a/rsc/inc/rscclass.hxx +++ b/rsc/inc/rscclass.hxx @@ -62,7 +62,7 @@ public: void Pre_dtor() override; ERRTYPE SetVariable( Atom nVarName, RscTop * pClass, RSCINST * pDflt = nullptr, - RSCVAR nVarType = 0, sal_uInt32 nMask = 0, + RSCVAR nVarType = RSCVAR::NONE, sal_uInt32 nMask = 0, Atom nDataBaseName = InvalidAtom ) override; virtual void EnumVariables( void * pData, VarEnumCallbackProc ) override; RSCINST GetVariable( const RSCINST & rInst, Atom nVarName, diff --git a/rsc/inc/rsctop.hxx b/rsc/inc/rsctop.hxx index b4feec0166f8..24d4082404b7 100644 --- a/rsc/inc/rsctop.hxx +++ b/rsc/inc/rsctop.hxx @@ -24,15 +24,20 @@ #include <rschash.hxx> #include <rscclobj.hxx> #include <rsc/rscsfx.hxx> - -typedef sal_uInt32 RSCVAR; -#define VAR_POINTER 0x0001 -#define VAR_HIDDEN 0x0002 -#define VAR_NODATAINST 0x0004 -#define VAR_NORC 0x0008 -#define VAR_SVDYNAMIC 0x0010 -#define VAR_NOENUM 0x0020 -#define VAR_EXTENDABLE 0x0040 /* class derivation can all be given */ +#include <o3tl/typed_flags_set.hxx> + +enum class RSCVAR { + NONE = 0x0000, + Pointer = 0x0001, + Hidden = 0x0002, + NoDataInst = 0x0004, + NoRc = 0x0008, + SvDynamic = 0x0010, + NoEnum = 0x0020 +}; +namespace o3tl { + template<> struct typed_flags<RSCVAR> : is_typed_flags<RSCVAR, 0x007f> {}; +} class RscTop : public RefNode { @@ -83,7 +88,7 @@ public: // sets the variable virtual ERRTYPE SetVariable( Atom nVarName, RscTop * pClass, RSCINST * pDflt = nullptr, - RSCVAR nVarType = 0, sal_uInt32 nMask = 0, + RSCVAR nVarType = RSCVAR::NONE, sal_uInt32 nMask = 0, Atom nDataBaseName = InvalidAtom ); // enumerate all variables diff --git a/rsc/source/parser/rscicpx.cxx b/rsc/source/parser/rscicpx.cxx index e03ce1e04422..05a692043d14 100644 --- a/rsc/source/parser/rscicpx.cxx +++ b/rsc/source/parser/rscicpx.cxx @@ -57,7 +57,7 @@ RscTop * RscTypCont::InitClassMgr() pClassMgr->SetVariable( nId, pCont ); }; nId = aNmTb.Put( "Comment", VARNAME ); - pClassMgr->SetVariable( nId, &aString, nullptr, VAR_NORC ); + pClassMgr->SetVariable( nId, &aString, nullptr, RSCVAR::NoRc ); pClass->SetTypeClass( pClassMgr ); @@ -92,7 +92,7 @@ RscTop * RscTypCont::InitClassBitmap( RscTop * pSuper ) // the class RscSysDepend handles variables "FILE" in a specific way nId = aNmTb.Put( "File", VARNAME ); - pClassBitmap->SetVariable( nId, &aLangString, nullptr, VAR_NORC ); + pClassBitmap->SetVariable( nId, &aLangString, nullptr, RSCVAR::NoRc ); return pClassBitmap; } @@ -110,7 +110,7 @@ RscTop * RscTypCont::InitClassImage( RscTop * pSuper, RscTop * pClassBitmap ) // initialize variables nId = aNmTb.Put( "ImageBitmap", VARNAME ); - pClassImage->SetVariable( nId, pClassBitmap, nullptr, 0, (sal_uInt32)RscImageFlags::ImageBitmap ); + pClassImage->SetVariable( nId, pClassBitmap, nullptr, RSCVAR::NONE, (sal_uInt32)RscImageFlags::ImageBitmap ); return pClassImage; } @@ -133,14 +133,14 @@ RscTop * RscTypCont::InitClassImageList( RscTop * pSuper, RscCont * pStrLst ) pCont->SetTypeClass( &aIdUShort ); aBaseLst.push_back( pCont ); nId = aNmTb.Put( "IdList", VARNAME ); - pClassImageList->SetVariable( nId, pCont, nullptr, 0, + pClassImageList->SetVariable( nId, pCont, nullptr, RSCVAR::NONE, (sal_uInt32)RscImageListFlags::IdList ); nId = aNmTb.Put( "FileList", VARNAME ); pClassImageList->SetVariable( nId, pStrLst ); nId = aNmTb.Put( "IdCount", VARNAME ); - pClassImageList->SetVariable( nId, &aUShort, nullptr, 0, + pClassImageList->SetVariable( nId, &aUShort, nullptr, RSCVAR::NONE, (sal_uInt32)RscImageListFlags::IdCount ); return pClassImageList; } @@ -177,7 +177,7 @@ RscTop * RscTypCont::InitClassKeyCode( RscTop * pSuper, RscEnum * pKey ) // add variable nVarId = aNmTb.Put( "_ModifierFlags", VARNAME ); pClassKeyCode->SetVariable( nVarId, pFlag, nullptr, - VAR_HIDDEN | VAR_NOENUM ); + RSCVAR::Hidden | RSCVAR::NoEnum ); // add client variables aBaseLst.push_back( @@ -185,14 +185,14 @@ RscTop * RscTypCont::InitClassKeyCode( RscTop * pSuper, RscEnum * pKey ) ); nId = aNmTb.Put( "Shift", VARNAME ); pClassKeyCode->SetVariable( nId, pClient, nullptr, - VAR_NODATAINST, 0, nVarId ); + RSCVAR::NoDataInst, 0, nVarId ); aBaseLst.push_back( pClient = new RscClient( pHS->getID( "sal_Bool" ), RSC_NOTYPE, pFlag, nMod1Id ) ); nId = aNmTb.Put( "Modifier1", VARNAME ); pClassKeyCode->SetVariable( nId, pClient, nullptr, - VAR_NODATAINST, 0, nVarId ); + RSCVAR::NoDataInst, 0, nVarId ); aBaseLst.push_back( @@ -200,7 +200,7 @@ RscTop * RscTypCont::InitClassKeyCode( RscTop * pSuper, RscEnum * pKey ) ); nId = aNmTb.Put( "Modifier2", VARNAME ); pClassKeyCode->SetVariable( nId, pClient, nullptr, - VAR_NODATAINST, 0, nVarId ); + RSCVAR::NoDataInst, 0, nVarId ); } { Atom nVarId; @@ -247,10 +247,10 @@ RscTop * RscTypCont::InitClassMenuItem( RscTop * pSuper ) // initialize variables nId = aNmTb.Put( "Separator", VARNAME ); - pClassMenuItem->SetVariable( nId, &aBool, nullptr, 0, + pClassMenuItem->SetVariable( nId, &aBool, nullptr, RSCVAR::NONE, (sal_uInt32)RscMenuItem::Separator ); nId = aNmTb.Put( "Identifier", VARNAME ); - pClassMenuItem->SetVariable( nId, &aIdNoZeroUShort, nullptr, 0, + pClassMenuItem->SetVariable( nId, &aIdNoZeroUShort, nullptr, RSCVAR::NONE, (sal_uInt32)RscMenuItem::Id ); { RscFlag * pFlag; @@ -275,7 +275,7 @@ RscTop * RscTypCont::InitClassMenuItem( RscTop * pSuper ) // add variable nVarId = aNmTb.Put( "_MenuItemFlags", VARNAME ); pClassMenuItem->SetVariable( nVarId, pFlag, nullptr, - VAR_HIDDEN | VAR_NOENUM, + RSCVAR::Hidden | RSCVAR::NoEnum, (sal_uInt32)RscMenuItem::Status ); // add client variables @@ -284,51 +284,51 @@ RscTop * RscTypCont::InitClassMenuItem( RscTop * pSuper ) ); nId = aNmTb.Put( "Checkable", VARNAME ); pClassMenuItem->SetVariable( nId, pClient, nullptr, - VAR_NODATAINST, 0, nVarId ); + RSCVAR::NoDataInst, 0, nVarId ); aBaseLst.push_back( pClient = new RscClient( pHS->getID( "sal_Bool" ), RSC_NOTYPE, pFlag, nAutoCheckId ) ); nId = aNmTb.Put( "AutoCheck", VARNAME ); pClassMenuItem->SetVariable( nId, pClient, nullptr, - VAR_NODATAINST, 0, nVarId ); + RSCVAR::NoDataInst, 0, nVarId ); aBaseLst.push_back( pClient = new RscClient( pHS->getID( "sal_Bool" ), RSC_NOTYPE, pFlag, nRadioCheckId ) ); nId = aNmTb.Put( "RadioCheck", VARNAME ); pClassMenuItem->SetVariable( nId, pClient, nullptr, - VAR_NODATAINST, 0, nVarId ); + RSCVAR::NoDataInst, 0, nVarId ); aBaseLst.push_back( pClient = new RscClient( pHS->getID( "sal_Bool" ), RSC_NOTYPE, pFlag, nAboutId ) ); nId = aNmTb.Put( "About", VARNAME ); pClassMenuItem->SetVariable( nId, pClient, nullptr, - VAR_NODATAINST, 0, nVarId ); + RSCVAR::NoDataInst, 0, nVarId ); aBaseLst.push_back( pClient = new RscClient( pHS->getID( "sal_Bool" ), RSC_NOTYPE, pFlag, nHelpId ) ); nId = aNmTb.Put( "Help", VARNAME ); pClassMenuItem->SetVariable( nId, pClient, nullptr, - VAR_NODATAINST, 0, nVarId ); + RSCVAR::NoDataInst, 0, nVarId ); } nId = aNmTb.Put( "Text", VARNAME ); - pClassMenuItem->SetVariable( nId, &aLangString, nullptr, 0, + pClassMenuItem->SetVariable( nId, &aLangString, nullptr, RSCVAR::NONE, (sal_uInt32)RscMenuItem::Text ); nId = aNmTb.Put( "HelpText", VARNAME ); - pClassMenuItem->SetVariable( nId, &aLangString, nullptr, 0, + pClassMenuItem->SetVariable( nId, &aLangString, nullptr, RSCVAR::NONE, (sal_uInt32)RscMenuItem::HelpText ); nId = aNmTb.Put( "HelpID", VARNAME ); - pClassMenuItem->SetVariable( nId, &aStringLiteral, nullptr, 0, + pClassMenuItem->SetVariable( nId, &aStringLiteral, nullptr, RSCVAR::NONE, (sal_uInt32)RscMenuItem::HelpId ); nId = aNmTb.Put( "Disable", VARNAME ); - pClassMenuItem->SetVariable( nId, &aBool, nullptr, 0, + pClassMenuItem->SetVariable( nId, &aBool, nullptr, RSCVAR::NONE, (sal_uInt32)RscMenuItem::Disable ); nId = aNmTb.Put( "Command", VARNAME ); - pClassMenuItem->SetVariable( nId, &aString, nullptr, 0, + pClassMenuItem->SetVariable( nId, &aString, nullptr, RSCVAR::NONE, (sal_uInt32)RscMenuItem::Command ); return pClassMenuItem; @@ -353,10 +353,10 @@ RscTop * RscTypCont::InitClassMenu( RscTop * pSuper, aBaseLst.push_back( pCont = new RscCont( pHS->getID( "ContMenuItem" ), RSC_NOTYPE ) ); pCont->SetTypeClass( pClassMenuItem ); nId = aNmTb.Put( "ItemList", VARNAME ); - pClassMenu->SetVariable( nId, pCont, nullptr, 0, (sal_uInt32)RscMenu::Items ); + pClassMenu->SetVariable( nId, pCont, nullptr, RSCVAR::NONE, (sal_uInt32)RscMenu::Items ); } nId = aNmTb.Put( "Text", VARNAME ); - pClassMenu->SetVariable( nId, &aLangString, nullptr, 0, (sal_uInt32)RscMenu::Text ); + pClassMenu->SetVariable( nId, &aLangString, nullptr, RSCVAR::NONE, (sal_uInt32)RscMenu::Text ); return pClassMenu; } diff --git a/rsc/source/parser/rscinit.cxx b/rsc/source/parser/rscinit.cxx index 13b8859ab35a..18b96a80fa0b 100644 --- a/rsc/source/parser/rscinit.cxx +++ b/rsc/source/parser/rscinit.cxx @@ -138,7 +138,7 @@ void RscTypCont::Init() // pClassMenu is only completely defined here nId = aNmTb.Put( "SubMenu", VARNAME ); - pClassMenuItem->SetVariable( nId, pClassMenu, nullptr, VAR_SVDYNAMIC, + pClassMenuItem->SetVariable( nId, pClassMenu, nullptr, RSCVAR::SvDynamic, (sal_uInt32)RscMenuItem::Menu ); } diff --git a/rsc/source/res/rscclass.cxx b/rsc/source/res/rscclass.cxx index 3e6e802b7ae6..fc1d08e1a967 100644 --- a/rsc/source/res/rscclass.cxx +++ b/rsc/source/res/rscclass.cxx @@ -78,7 +78,7 @@ RSCINST RscClass::GetInstData aInst.pClass = pVarTypeList[ nEle ].pClass; if( pData ) { - if( VAR_NODATAINST & pVarTypeList[ nEle ].nVarType ) + if( RSCVAR::NoDataInst & pVarTypeList[ nEle ].nVarType ) { RSCINST aTmpI; @@ -96,12 +96,9 @@ RSCINST RscClass::GetInstData RSCINST() ).pData; } - else if( VAR_POINTER & pVarTypeList[ nEle ].nVarType ) + else if( RSCVAR::Pointer & pVarTypeList[ nEle ].nVarType ) { - if( VAR_EXTENDABLE & pVarTypeList[ nEle ].nVarType ) - aInst = *reinterpret_cast<RSCINST *>(pData + pVarTypeList[ nEle ].nOffset); - else - aInst.pData = *reinterpret_cast<CLASS_DATA *>(pData + pVarTypeList[ nEle ].nOffset); + aInst.pData = *reinterpret_cast<CLASS_DATA *>(pData + pVarTypeList[ nEle ].nOffset); } else aInst.pData = pData + pVarTypeList[ nEle ].nOffset; @@ -167,19 +164,10 @@ RSCINST RscClass::Create( RSCINST * pInst, { aDfltI = GetInstData( bOwnClass ? rDflt.pData : nullptr, i, true ); - if( (VAR_POINTER & pVarTypeList[ i ].nVarType) && - !(VAR_NODATAINST & pVarTypeList[ i ].nVarType) ) + if( (RSCVAR::Pointer & pVarTypeList[ i ].nVarType) && + !(RSCVAR::NoDataInst & pVarTypeList[ i ].nVarType) ) { - CLASS_DATA * ppData; - if( VAR_EXTENDABLE & pVarTypeList[ i ].nVarType ) - { - RSCINST * pInstance = reinterpret_cast<RSCINST *>(aInst.pData + pVarTypeList[ i ].nOffset ); - pInstance->pClass = pVarTypeList[ i ].pClass; - ppData = &pInstance->pData; - } - else - ppData = reinterpret_cast<CLASS_DATA*>(aInst.pData + pVarTypeList[ i ].nOffset ); - + CLASS_DATA * ppData = reinterpret_cast<CLASS_DATA*>(aInst.pData + pVarTypeList[ i ].nOffset ); *ppData = nullptr; if( aDfltI.IsInst() ) { @@ -205,7 +193,7 @@ void RscClass::Destroy( const RSCINST & rInst ) for( i = 0; i < nEntries; i++ ) { - if( !(pVarTypeList[ i ].nVarType & VAR_NODATAINST) ) + if( !(pVarTypeList[ i ].nVarType & RSCVAR::NoDataInst) ) { RSCINST aTmpI; @@ -214,7 +202,7 @@ void RscClass::Destroy( const RSCINST & rInst ) { // destroy object aTmpI.pClass->Destroy( aTmpI ); - if( pVarTypeList[ i ].nVarType & VAR_POINTER ) + if( pVarTypeList[ i ].nVarType & RSCVAR::Pointer ) { // free memory rtl_freeMemory( aTmpI.pData ); @@ -251,18 +239,15 @@ ERRTYPE RscClass::SetVariable( Atom nVarName, else pVarTypeList[ nEntries ].pDefault = nullptr; - pVarTypeList[ nEntries ].nVarType = ~VAR_POINTER & nVarType; - if( pClass->Size() > 10 || (nVarType & VAR_EXTENDABLE) ) - pVarTypeList[ nEntries ].nVarType |= VAR_POINTER; + pVarTypeList[ nEntries ].nVarType = ~RSCVAR::Pointer & nVarType; + if( pClass->Size() > 10 ) + pVarTypeList[ nEntries ].nVarType |= RSCVAR::Pointer; - if( !(pVarTypeList[ nEntries ].nVarType & VAR_NODATAINST) ) + if( !(pVarTypeList[ nEntries ].nVarType & RSCVAR::NoDataInst) ) { - if( pVarTypeList[ nEntries ].nVarType & VAR_POINTER ) + if( pVarTypeList[ nEntries ].nVarType & RSCVAR::Pointer ) { - if( pVarTypeList[ nEntries ].nVarType & VAR_EXTENDABLE ) - nSize += sizeof( RSCINST ); - else - nSize += sizeof( CLASS_DATA ); + nSize += sizeof( CLASS_DATA ); } else nSize += pClass->Size(); @@ -284,7 +269,7 @@ void RscClass::EnumVariables( void * pData, VarEnumCallbackProc pProc ) RscTop::EnumVariables( pData, pProc ); for( i = 0; i < nEntries; i ++ ) { - if( !(pVarTypeList[ i ].nVarType & VAR_NOENUM) ) + if( !(pVarTypeList[ i ].nVarType & RSCVAR::NoEnum) ) (*pProc)( pData, pVarTypeList[ i ].pClass->GetClassType(), pVarTypeList[ i ].nVarName ); } } @@ -303,7 +288,7 @@ RSCINST RscClass::GetVariable( const RSCINST & rInst, if( i < nEntries ) { - if( VAR_NODATAINST & pVarTypeList[ i ].nVarType ) + if( RSCVAR::NoDataInst & pVarTypeList[ i ].nVarType ) { aTmpI = GetVariable( rInst, pVarTypeList[ i ].nDataBaseName, @@ -332,23 +317,10 @@ RSCINST RscClass::GetVariable( const RSCINST & rInst, } else { // is provided via pointer - if( VAR_EXTENDABLE & pVarTypeList[ i ].nVarType ) - { - RSCINST * pInst = reinterpret_cast<RSCINST *> - (rInst.pData + pVarTypeList[ i ].nOffset ); - if( pCreateClass && pCreateClass->InHierarchy( aTmpI.pClass ) ) - *pInst = pCreateClass->Create( nullptr, aDefInst ); - else - *pInst = aTmpI.pClass->Create( nullptr, aDefInst ); - aTmpI = *pInst; - } - else - { - CLASS_DATA * ppData - = reinterpret_cast<CLASS_DATA *>(rInst.pData + pVarTypeList[ i ].nOffset); - aTmpI = aTmpI.pClass->Create( nullptr, aDefInst ); - *ppData = aTmpI.pData; - } + CLASS_DATA * ppData + = reinterpret_cast<CLASS_DATA *>(rInst.pData + pVarTypeList[ i ].nOffset); + aTmpI = aTmpI.pClass->Create( nullptr, aDefInst ); + *ppData = aTmpI.pData; } } // set as non default @@ -370,7 +342,7 @@ RSCINST RscClass::GetCopyVar( const RSCINST & rInst, Atom nVarName) if( i < nEntries ) { - if( VAR_NODATAINST & pVarTypeList[ i ].nVarType ) + if( RSCVAR::NoDataInst & pVarTypeList[ i ].nVarType ) { aVarI = GetCopyVar( rInst, pVarTypeList[ i ].nDataBaseName ); aVarI.pClass = pVarTypeList[ i ].pClass; @@ -403,7 +375,7 @@ bool RscClass::IsConsistent( const RSCINST & rInst ) for( i = 0; i < nEntries; i++ ) { - if( !(VAR_NODATAINST & pVarTypeList[ i ].nVarType) ) + if( !(RSCVAR::NoDataInst & pVarTypeList[ i ].nVarType) ) { aTmpI = GetInstData( rInst.pData, i, true ); @@ -427,7 +399,7 @@ void RscClass::SetToDefault( const RSCINST & rInst ) for( i = 0; i < nEntries; i++ ) { // variables without own memory are set from "data server" to default - if( !(VAR_NODATAINST & pVarTypeList[ i ].nVarType) ) + if( !(RSCVAR::NoDataInst & pVarTypeList[ i ].nVarType) ) { aTmpI = GetInstData( rInst.pData, i, true ); if( aTmpI.IsInst() ) @@ -447,7 +419,7 @@ bool RscClass::IsDefault( const RSCINST & rInst ) for( i = 0; i < nEntries; i++ ) { // variables without own memory are looked for default in "data server" - if( !(VAR_NODATAINST & pVarTypeList[ i ].nVarType) ) + if( !(RSCVAR::NoDataInst & pVarTypeList[ i ].nVarType) ) if( !IsDflt( rInst.pData, i ) ) return false; } @@ -483,7 +455,7 @@ bool RscClass::IsValueDflt( CLASS_DATA pData, sal_uInt32 nEle ) if( aTmpI.IsInst() ) { - if( VAR_SVDYNAMIC & pVarTypeList[ nEle ].nVarType ) + if( RSCVAR::SvDynamic & pVarTypeList[ nEle ].nVarType ) return false; if( aTmpI.pClass == pVarTypeList[ nEle ].pClass ) @@ -566,7 +538,7 @@ void RscClass::WriteSrc( const RSCINST & rInst, for( i = 0; i < nEntries; i++ ) { - if( !(VAR_HIDDEN & pVarTypeList[ i ].nVarType) ) + if( !(RSCVAR::Hidden & pVarTypeList[ i ].nVarType) ) { if( !IsDflt( rInst.pData, i ) && !IsValueDflt( rInst.pData, i ) ) { @@ -616,7 +588,7 @@ ERRTYPE RscClass::WriteInstRc( const RSCINST & rInst, for( i = 0; i < nEntries && aError.IsOk(); i++ ) { - if( !((VAR_NODATAINST | VAR_NORC) & pVarTypeList[ i ].nVarType )) + if( !((RSCVAR::NoDataInst | RSCVAR::NoRc) & pVarTypeList[ i ].nVarType )) { if( pVarTypeList[ i ].nMask ) { @@ -749,7 +721,7 @@ void RscTupel::WriteSrc( const RSCINST & rInst, FILE * fOutput, fprintf( fOutput, "< " ); for( i = 0; i < nEntries; i++ ) { - if( !(VAR_HIDDEN & pVarTypeList[ i ].nVarType) ) + if( !(RSCVAR::Hidden & pVarTypeList[ i ].nVarType) ) { if( !IsDflt( rInst.pData, i ) && !IsValueDflt( rInst.pData, i ) ) |