190 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
		
		
			
		
	
	
			190 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
|   | /*************************************************************************
 | ||
|  |  * | ||
|  |  *  $RCSfile: XMLPropertyBackpatcher.hxx,v $ | ||
|  |  * | ||
|  |  *  $Revision: 1.1 $ | ||
|  |  * | ||
|  |  *  last change: $Author: dvo $ $Date: 2000-09-27 15:58:45 $ | ||
|  |  * | ||
|  |  *  The Contents of this file are made available subject to the terms of | ||
|  |  *  either of the following licenses | ||
|  |  * | ||
|  |  *         - GNU Lesser General Public License Version 2.1 | ||
|  |  *         - Sun Industry Standards Source License Version 1.1 | ||
|  |  * | ||
|  |  *  Sun Microsystems Inc., October, 2000 | ||
|  |  * | ||
|  |  *  GNU Lesser General Public License Version 2.1 | ||
|  |  *  ============================================= | ||
|  |  *  Copyright 2000 by Sun Microsystems, Inc. | ||
|  |  *  901 San Antonio Road, Palo Alto, CA 94303, USA | ||
|  |  * | ||
|  |  *  This library is free software; you can redistribute it and/or | ||
|  |  *  modify it under the terms of the GNU Lesser General Public | ||
|  |  *  License version 2.1, as published by the Free Software Foundation. | ||
|  |  * | ||
|  |  *  This library is distributed in the hope that it will be useful, | ||
|  |  *  but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
|  |  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | ||
|  |  *  Lesser General Public License for more details. | ||
|  |  * | ||
|  |  *  You should have received a copy of the GNU Lesser General Public | ||
|  |  *  License along with this library; if not, write to the Free Software | ||
|  |  *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, | ||
|  |  *  MA  02111-1307  USA | ||
|  |  * | ||
|  |  * | ||
|  |  *  Sun Industry Standards Source License Version 1.1 | ||
|  |  *  ================================================= | ||
|  |  *  The contents of this file are subject to the Sun Industry Standards | ||
|  |  *  Source License Version 1.1 (the "License"); You may not use this file | ||
|  |  *  except in compliance with the License. You may obtain a copy of the | ||
|  |  *  License at http://www.openoffice.org/license.html.
 | ||
|  |  * | ||
|  |  *  Software provided under this License is provided on an "AS IS" basis, | ||
|  |  *  WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, | ||
|  |  *  WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS, | ||
|  |  *  MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING. | ||
|  |  *  See the License for the specific provisions governing your rights and | ||
|  |  *  obligations concerning the Software. | ||
|  |  * | ||
|  |  *  The Initial Developer of the Original Code is: Sun Microsystems, Inc. | ||
|  |  * | ||
|  |  *  Copyright: 2000 by Sun Microsystems, Inc. | ||
|  |  * | ||
|  |  *  All Rights Reserved. | ||
|  |  * | ||
|  |  *  Contributor(s): _______________________________________ | ||
|  |  * | ||
|  |  * | ||
|  |  ************************************************************************/ | ||
|  | 
 | ||
|  | 
 | ||
|  | #ifndef _XMLOFF_XMLPROPERTYBACKPATCHER_HXX
 | ||
|  | #define _XMLOFF_XMLPROPERTYBACKPATCHER_HXX
 | ||
|  | 
 | ||
|  | #ifndef __SGI_STL_MAP
 | ||
|  | #include <stl/map>
 | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #ifndef __SGI_STL_VECTOR
 | ||
|  | #include <stl/vector>
 | ||
|  | #endif
 | ||
|  | 
 | ||
|  | 
 | ||
|  | namespace rtl { class OUString; } | ||
|  | namespace com { namespace sun { namespace star { | ||
|  |     namespace beans { class XPropertySet; } | ||
|  |     namespace uno { template<class A> class Reference; } | ||
|  | } } } | ||
|  | 
 | ||
|  | /** This class maintains an OUString->sal_Int16 mapping for cases in
 | ||
|  |  * which an XPropertySet needs to be filled with values that are not | ||
|  |  * yet known. | ||
|  |  * | ||
|  |  * A good example for appropriate use are footnotes and references to | ||
|  |  * footnoes. Internally, the StarOffice API numbers footnotes, and | ||
|  |  * references to footnotes refer to that internal numbering. In the | ||
|  |  * XML file format, these numbers are replaced with name strings. Now | ||
|  |  * if during import of a document a reference to a footnote is | ||
|  |  * encountered, two things can happen: 1) The footnote already | ||
|  |  * appeared in the document. In this case the name is already known | ||
|  |  * and the proper ID can be requested from the footnote. 2) The | ||
|  |  * footnote will appear later in the document. In this case the ID is | ||
|  |  * not yet known, and the reference-ID property of the reference | ||
|  |  * cannot be determined. Hence, the reference has to be stored and the | ||
|  |  * ID needs to bet set later, when the footnote is eventually found in | ||
|  |  * the document. | ||
|  |  * | ||
|  |  * This class simplifies this process: If the footnote is found, | ||
|  |  * ResolveId with the XML name and the ID is called. When a reference | ||
|  |  * is encountered, SetProperty gets called with the reference's | ||
|  |  * XPropertySet and the XML name. All remaining tasks are handled by | ||
|  |  * the class. | ||
|  |  */ | ||
|  | template <class A> | ||
|  | class XMLPropertyBackpatcher | ||
|  | { | ||
|  | 
 | ||
|  |     /// name of property that gets set or backpatched
 | ||
|  |      ::rtl::OUString sPropertyName; | ||
|  | 
 | ||
|  |     /// should a default value be set for unresolved properties
 | ||
|  |     sal_Bool bDefaultHandling; | ||
|  | 
 | ||
|  |     /// should the sPreservePropertyName be preserved
 | ||
|  |     sal_Bool bPreserveProperty; | ||
|  | 
 | ||
|  |     /// name of the property to preserve
 | ||
|  |     ::rtl::OUString sPreservePropertyName; | ||
|  | 
 | ||
|  |     /// default value for unresolved properties (if bDefaultHandling)
 | ||
|  |     A aDefault; | ||
|  | 
 | ||
|  |     /// backpatch list type
 | ||
|  |     typedef ::std::vector< | ||
|  |                 ::com::sun::star::uno::Reference< | ||
|  |                     ::com::sun::star::beans::XPropertySet> > BackpatchListType; | ||
|  | 
 | ||
|  |     /* use void* instead of BackpatchListType to avoid linker problems
 | ||
|  |        with long typenames. The real typename (commented out) contains | ||
|  |        >1200 chars. */ | ||
|  | 
 | ||
|  |     /// backpatch list for unresolved IDs
 | ||
|  |     //::std::map<const ::rtl::OUString, BackpatchListType*> aBackpatchListMap;
 | ||
|  |     ::std::map<const ::rtl::OUString, void* > aBackpatchListMap; | ||
|  | 
 | ||
|  |     /// mapping of names -> IDs
 | ||
|  |     ::std::map<const ::rtl::OUString, A> aIDMap; | ||
|  | 
 | ||
|  | public: | ||
|  | 
 | ||
|  |     XMLPropertyBackpatcher( | ||
|  |         const ::rtl::OUString& sPropertyName); | ||
|  | 
 | ||
|  |     XMLPropertyBackpatcher( | ||
|  |         const ::rtl::OUString& sPropertyName, | ||
|  |         const ::rtl::OUString& sPreservePropertyName, | ||
|  |         sal_Bool bDefault, | ||
|  |         A aDef); | ||
|  | 
 | ||
|  |     XMLPropertyBackpatcher( | ||
|  |         const sal_Char* pPropertyName); | ||
|  | 
 | ||
|  |     XMLPropertyBackpatcher( | ||
|  |         const sal_Char* pPropertyName, | ||
|  |         const sal_Char* pPreservePropertyName, | ||
|  |         sal_Bool bDefault, | ||
|  |         A aDef); | ||
|  | 
 | ||
|  |     ~XMLPropertyBackpatcher(); | ||
|  | 
 | ||
|  |     /// resolve a known ID.
 | ||
|  |     /// Call this as soon as the value for a particular name is known.
 | ||
|  |     void ResolveId( | ||
|  |         const ::rtl::OUString& sName, | ||
|  |         A aValue); | ||
|  | 
 | ||
|  |     /// Set property with the proper value for this name. If the value
 | ||
|  |     /// is not yet known, store the XPropertySet in the backpatch list.
 | ||
|  |     /// Use this whenever the value should be set, even if it is not yet known.
 | ||
|  |     /// const version
 | ||
|  |     void SetProperty( | ||
|  |         const ::com::sun::star::uno::Reference< | ||
|  |                 ::com::sun::star::beans::XPropertySet> & xPropSet, | ||
|  |         const ::rtl::OUString& sName); | ||
|  | 
 | ||
|  |     /// non-const version of SetProperty
 | ||
|  |     void SetProperty( | ||
|  |         ::com::sun::star::uno::Reference< | ||
|  |                 ::com::sun::star::beans::XPropertySet> & xPropSet, | ||
|  |         const ::rtl::OUString& sName); | ||
|  | 
 | ||
|  |     /// set default (if bDefaultHandling) for unresolved names
 | ||
|  |     /// called by destructor
 | ||
|  |     void SetDefault(); | ||
|  | 
 | ||
|  | }; | ||
|  | 
 | ||
|  | #endif
 |