| 
									
										
										
										
											2000-09-27 14:58:45 +00:00
										 |  |  | /*************************************************************************
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  $RCSfile: XMLPropertyBackpatcher.hxx,v $ | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2000-11-22 17:37:07 +00:00
										 |  |  |  *  $Revision: 1.3 $ | 
					
						
							| 
									
										
										
										
											2000-09-27 14:58:45 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2000-11-22 17:37:07 +00:00
										 |  |  |  *  last change: $Author: svesik $ $Date: 2000-11-22 18:37:07 $ | 
					
						
							| 
									
										
										
										
											2000-09-27 14:58:45 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  *  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
 | 
					
						
							| 
									
										
										
										
											2000-11-22 17:37:07 +00:00
										 |  |  | #include <map>
 | 
					
						
							| 
									
										
										
										
											2000-09-27 14:58:45 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef __SGI_STL_VECTOR
 | 
					
						
							| 
									
										
										
										
											2000-11-22 17:37:07 +00:00
										 |  |  | #include <vector>
 | 
					
						
							| 
									
										
										
										
											2000-09-27 14:58:45 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-28 17:27:14 +00:00
										 |  |  | #ifndef _XMLOFF_FUNCTIONAL_HXX
 | 
					
						
							|  |  |  | #include "functional.hxx"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-27 14:58:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace rtl { class OUString; } | 
					
						
							|  |  |  | namespace com { namespace sun { namespace star { | 
					
						
							|  |  |  |     namespace beans { class XPropertySet; } | 
					
						
							|  |  |  |     namespace uno { template<class A> class Reference; } | 
					
						
							|  |  |  | } } } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-28 17:27:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-09-27 14:58:45 +00:00
										 |  |  | /** 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;
 | 
					
						
							| 
									
										
										
										
											2000-09-28 17:27:14 +00:00
										 |  |  |     ::std::map<const ::rtl::OUString, void*, less_functor> aBackpatchListMap; | 
					
						
							| 
									
										
										
										
											2000-09-27 14:58:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// mapping of names -> IDs
 | 
					
						
							| 
									
										
										
										
											2000-09-28 17:27:14 +00:00
										 |  |  |     ::std::map<const ::rtl::OUString, A, less_functor> aIDMap; | 
					
						
							| 
									
										
										
										
											2000-09-27 14:58:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 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
 |