diff options
author | Martin Gallwey <mtg@openoffice.org> | 2001-08-16 11:10:24 +0000 |
---|---|---|
committer | Martin Gallwey <mtg@openoffice.org> | 2001-08-16 11:10:24 +0000 |
commit | 4fbc9dd48b7cebb304010e7337b1bbc3936c7923 (patch) | |
tree | 045b840bfba388dd52b4d19db4ace71774f77cbe /sw/inc | |
parent | dc5953ec144e4274d2fad488db2702d218b41944 (diff) |
#90968# Add two new methods to allow for disambiguation of user defined styles which clash with programmatic names
Diffstat (limited to 'sw/inc')
-rw-r--r-- | sw/inc/SwStyleNameMapper.hxx | 27 |
1 files changed, 24 insertions, 3 deletions
diff --git a/sw/inc/SwStyleNameMapper.hxx b/sw/inc/SwStyleNameMapper.hxx index c282c7a5ec5b..0fefac552bd8 100644 --- a/sw/inc/SwStyleNameMapper.hxx +++ b/sw/inc/SwStyleNameMapper.hxx @@ -2,9 +2,9 @@ * * $RCSfile: SwStyleNameMapper.hxx,v $ * - * $Revision: 1.2 $ + * $Revision: 1.3 $ * - * last change: $Author: mtg $ $Date: 2001-07-24 17:21:11 $ + * last change: $Author: mtg $ $Date: 2001-08-16 12:07:45 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses @@ -101,6 +101,22 @@ * 5. Numbering Rule contains the NumRule name array. */ +/* + * There is a further complication that came to light later. If someone enters + * a user-defined style name which is the same as a programmatic name, this + * name clash must be handled. + * + * Therefore, when there is a danger of a nameclash, the boolean bDisambiguate + * must be set to true in the SwStyleNameMapper call (it defaults to false). + * This will cause the following to happen: + * + * If the UI style name either equals a programmatic name or already ends + * with " (user)", then it must append " (user)" to the end. + * + * When a programmatic name is being converted to a UI name, if it ends in + * " (user)", we simply remove it. + */ + class SvStringsDtor; class String; struct SwTableEntry; @@ -211,11 +227,16 @@ protected: static void fillNameFromId ( sal_uInt16 nId, String &rName, sal_Bool bProgName ); static const String& getNameFromId ( sal_uInt16 nId, const String &rName, sal_Bool bProgName ); static const NameToIdHash& getHashTable ( SwGetPoolIdFromName, sal_Bool bProgName ); + static sal_Bool SuffixIsUser ( const String & rString ); + static void CheckSuffixAndDelete ( String & rString ); + public: // This gets the UI Name from the programmatic name static const String& GetUIName ( const String& rName, SwGetPoolIdFromName ); + static void FillUIName ( const String& rName, String& rFillName, SwGetPoolIdFromName, sal_Bool bDisambiguate = sal_False ); // Get the programmatic Name from the UI name - static const String& GetProgName( const String& rName, SwGetPoolIdFromName ); + static const String& GetProgName ( const String& rName, SwGetPoolIdFromName ); + static void FillProgName ( const String& rName, String& rFillName, SwGetPoolIdFromName, sal_Bool bDisambiguate = sal_False ); // This gets the UI Name from the Pool ID static void FillUIName ( sal_uInt16 nId, String& rFillName ); |