1efeef26fSAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3efeef26fSAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4efeef26fSAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5efeef26fSAndrew Rist  * distributed with this work for additional information
6efeef26fSAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7efeef26fSAndrew Rist  * to you under the Apache License, Version 2.0 (the
8efeef26fSAndrew Rist  * "License"); you may not use this file except in compliance
9efeef26fSAndrew Rist  * with the License.  You may obtain a copy of the License at
10efeef26fSAndrew Rist  *
11efeef26fSAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12efeef26fSAndrew Rist  *
13efeef26fSAndrew Rist  * Unless required by applicable law or agreed to in writing,
14efeef26fSAndrew Rist  * software distributed under the License is distributed on an
15efeef26fSAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16efeef26fSAndrew Rist  * KIND, either express or implied.  See the License for the
17efeef26fSAndrew Rist  * specific language governing permissions and limitations
18efeef26fSAndrew Rist  * under the License.
19efeef26fSAndrew Rist  *
20efeef26fSAndrew Rist  *************************************************************/
21efeef26fSAndrew Rist 
22efeef26fSAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
25cdf0e10cSrcweir #include "precompiled_sw.hxx"
26cdf0e10cSrcweir 
27cdf0e10cSrcweir #include <com/sun/star/embed/ElementModes.hpp>
28cdf0e10cSrcweir #include <com/sun/star/embed/XTransactedObject.hpp>
29cdf0e10cSrcweir #include <tools/urlobj.hxx>
30cdf0e10cSrcweir #include <sot/stg.hxx>
31cdf0e10cSrcweir #include <sfx2/docfile.hxx>
32cdf0e10cSrcweir #include <unotools/localfilehelper.hxx>
33cdf0e10cSrcweir #include <unotools/ucbstreamhelper.hxx>
34cdf0e10cSrcweir 
35cdf0e10cSrcweir #include <comphelper/storagehelper.hxx>
36cdf0e10cSrcweir #include <doc.hxx>
37cdf0e10cSrcweir #include <IDocumentUndoRedo.hxx>
38cdf0e10cSrcweir #include <docsh.hxx>
39cdf0e10cSrcweir #include <pam.hxx>
40cdf0e10cSrcweir #include <swblocks.hxx>
41cdf0e10cSrcweir #include <ndtxt.hxx>
42cdf0e10cSrcweir #include <shellio.hxx>
43cdf0e10cSrcweir #include <poolfmt.hxx>
44cdf0e10cSrcweir #include <SwXMLTextBlocks.hxx>
45cdf0e10cSrcweir #include <errhdl.hxx>
46cdf0e10cSrcweir #include <SwXMLBlockImport.hxx>
47cdf0e10cSrcweir #include <SwXMLBlockExport.hxx>
48cdf0e10cSrcweir #include <swerror.h>
49cdf0e10cSrcweir 
50cdf0e10cSrcweir #define STREAM_STGREAD  ( STREAM_READ | STREAM_SHARE_DENYWRITE | STREAM_NOCREATE )
51cdf0e10cSrcweir #define STREAM_STGWRITE ( STREAM_READ | STREAM_WRITE | STREAM_SHARE_DENYWRITE )
52cdf0e10cSrcweir 
53cdf0e10cSrcweir using namespace ::com::sun::star;
54cdf0e10cSrcweir 
55cdf0e10cSrcweir 
InitBlockMode(const uno::Reference<embed::XStorage> & rStorage)56cdf0e10cSrcweir void SwXMLTextBlocks::InitBlockMode ( const uno::Reference < embed::XStorage >& rStorage )
57cdf0e10cSrcweir {
58cdf0e10cSrcweir 	xBlkRoot = rStorage;
59cdf0e10cSrcweir     xRoot = 0;
60cdf0e10cSrcweir }
61cdf0e10cSrcweir 
ResetBlockMode()62cdf0e10cSrcweir void SwXMLTextBlocks::ResetBlockMode ( )
63cdf0e10cSrcweir {
64cdf0e10cSrcweir     xBlkRoot = 0;
65cdf0e10cSrcweir     xRoot = 0;
66cdf0e10cSrcweir }
67cdf0e10cSrcweir 
SwXMLTextBlocks(const String & rFile)68cdf0e10cSrcweir SwXMLTextBlocks::SwXMLTextBlocks( const String& rFile )
69cdf0e10cSrcweir : SwImpBlocks( rFile ), bAutocorrBlock( sal_False ), nFlags ( 0 )
70cdf0e10cSrcweir {
71cdf0e10cSrcweir 	SwDocShell* pDocSh = new SwDocShell ( SFX_CREATE_MODE_INTERNAL );
72cdf0e10cSrcweir 	if( !pDocSh->DoInitNew( 0 ) )
73cdf0e10cSrcweir 		return;
74cdf0e10cSrcweir 	bReadOnly = sal_True;
75cdf0e10cSrcweir 	pDoc = pDocSh->GetDoc();
76cdf0e10cSrcweir 	xDocShellRef = pDocSh;
77cdf0e10cSrcweir 	pDoc->SetOle2Link( Link() );
78cdf0e10cSrcweir     pDoc->GetIDocumentUndoRedo().DoUndo(false);
79cdf0e10cSrcweir 	pDoc->acquire();
80cdf0e10cSrcweir 	uno::Reference< embed::XStorage > refStg;
81cdf0e10cSrcweir 	if( !aDateModified.GetDate() || !aTimeModified.GetTime() )
82cdf0e10cSrcweir 		Touch();		// falls neu angelegt -> neuen ZeitStempel besorgen
83cdf0e10cSrcweir 	try
84cdf0e10cSrcweir 	{
85cdf0e10cSrcweir         refStg  = comphelper::OStorageHelper::GetStorageFromURL( rFile, embed::ElementModes::READWRITE );
86cdf0e10cSrcweir         bReadOnly = sal_False;
87cdf0e10cSrcweir 	}
88cdf0e10cSrcweir 	catch( const uno::Exception& )
89cdf0e10cSrcweir 	{
90cdf0e10cSrcweir 		//couldn't open the file - maybe it's readonly
91cdf0e10cSrcweir 	}
92cdf0e10cSrcweir 	if( !refStg.is())
93cdf0e10cSrcweir 	{
94cdf0e10cSrcweir 		try
95cdf0e10cSrcweir 		{
96cdf0e10cSrcweir 			refStg = comphelper::OStorageHelper::GetStorageFromURL( rFile, embed::ElementModes::READ );
97cdf0e10cSrcweir 		}
98cdf0e10cSrcweir 		catch( const uno::Exception& )
99cdf0e10cSrcweir 		{
100cdf0e10cSrcweir 			DBG_ERROR("exception while creating AutoText storage");
101cdf0e10cSrcweir 		}
102cdf0e10cSrcweir 	}
103cdf0e10cSrcweir 	InitBlockMode ( refStg );
104cdf0e10cSrcweir 	ReadInfo();
105cdf0e10cSrcweir 	ResetBlockMode ();
106cdf0e10cSrcweir 	bInfoChanged = sal_False;
107cdf0e10cSrcweir }
108cdf0e10cSrcweir 
SwXMLTextBlocks(const uno::Reference<embed::XStorage> & rStg,const String & rName)109cdf0e10cSrcweir SwXMLTextBlocks::SwXMLTextBlocks( const uno::Reference < embed::XStorage >& rStg, const String& rName )
110cdf0e10cSrcweir : SwImpBlocks( rName )
111cdf0e10cSrcweir , bAutocorrBlock( sal_True )
112cdf0e10cSrcweir , nFlags ( 0 )
113cdf0e10cSrcweir {
114cdf0e10cSrcweir 	SwDocShell* pDocSh = new SwDocShell ( SFX_CREATE_MODE_INTERNAL );
115cdf0e10cSrcweir 	if( !pDocSh->DoInitNew( 0 ) )
116cdf0e10cSrcweir 		return;
117cdf0e10cSrcweir 	bReadOnly = sal_False;
118cdf0e10cSrcweir 	pDoc = pDocSh->GetDoc();
119cdf0e10cSrcweir 	xDocShellRef = pDocSh;
120cdf0e10cSrcweir 	pDoc->SetOle2Link( Link() );
121cdf0e10cSrcweir     pDoc->GetIDocumentUndoRedo().DoUndo(false);
122cdf0e10cSrcweir 	pDoc->acquire();
123cdf0e10cSrcweir 
124cdf0e10cSrcweir     InitBlockMode ( rStg );
125cdf0e10cSrcweir 	ReadInfo();
126cdf0e10cSrcweir 	bInfoChanged = sal_False;
127cdf0e10cSrcweir }
128cdf0e10cSrcweir 
~SwXMLTextBlocks()129cdf0e10cSrcweir SwXMLTextBlocks::~SwXMLTextBlocks()
130cdf0e10cSrcweir {
131cdf0e10cSrcweir 	if ( bInfoChanged )
132cdf0e10cSrcweir 		WriteInfo();
133cdf0e10cSrcweir 	ResetBlockMode ();
134cdf0e10cSrcweir 	if(xDocShellRef.Is())
135cdf0e10cSrcweir         xDocShellRef->DoClose();
136cdf0e10cSrcweir     xDocShellRef = 0;
137cdf0e10cSrcweir     if( pDoc && !pDoc->release() )
138cdf0e10cSrcweir 		delete pDoc;
139cdf0e10cSrcweir }
140cdf0e10cSrcweir 
ClearDoc()141cdf0e10cSrcweir void SwXMLTextBlocks::ClearDoc()
142cdf0e10cSrcweir {
143cdf0e10cSrcweir 	SwDocShell * pDocShell = pDoc->GetDocShell();
144cdf0e10cSrcweir 	pDocShell->InvalidateModel();
145cdf0e10cSrcweir 	pDocShell->ReactivateModel();
146cdf0e10cSrcweir 
147cdf0e10cSrcweir 	pDoc->ClearDoc();
148cdf0e10cSrcweir     pDocShell->ClearEmbeddedObjects();
149cdf0e10cSrcweir }
AddName(const String & rShort,const String & rLong,sal_Bool bOnlyTxt)150cdf0e10cSrcweir void SwXMLTextBlocks::AddName( const String& rShort, const String& rLong, sal_Bool bOnlyTxt )
151cdf0e10cSrcweir {
152cdf0e10cSrcweir 	sal_uInt16 nIdx = GetIndex( rShort );
153cdf0e10cSrcweir 	SwBlockName* pNew = NULL;
154cdf0e10cSrcweir 	if( nIdx != (sal_uInt16) -1 )
155cdf0e10cSrcweir 		aNames.DeleteAndDestroy( nIdx );
156cdf0e10cSrcweir 
157cdf0e10cSrcweir 	GeneratePackageName( rShort, aPackageName );
158cdf0e10cSrcweir 	pNew = new SwBlockName( rShort, rLong, aPackageName );
159cdf0e10cSrcweir 
160cdf0e10cSrcweir 	pNew->bIsOnlyTxtFlagInit = sal_True;
161cdf0e10cSrcweir 	pNew->bIsOnlyTxt = bOnlyTxt;
162cdf0e10cSrcweir 	aNames.C40_PTR_INSERT( SwBlockName, pNew );
163cdf0e10cSrcweir 	bInfoChanged = sal_True;
164cdf0e10cSrcweir }
AddName(const String & rShort,const String & rLong,const String & rPackageName,sal_Bool bOnlyTxt)165cdf0e10cSrcweir void SwXMLTextBlocks::AddName( const String& rShort, const String& rLong,
166cdf0e10cSrcweir 						   const String& rPackageName, sal_Bool bOnlyTxt )
167cdf0e10cSrcweir {
168cdf0e10cSrcweir 	sal_uInt16 nIdx = GetIndex( rShort );
169cdf0e10cSrcweir 	if( nIdx != (sal_uInt16) -1 )
170cdf0e10cSrcweir 		aNames.DeleteAndDestroy( nIdx );
171cdf0e10cSrcweir 	SwBlockName* pNew = new SwBlockName( rShort, rLong, rPackageName );
172cdf0e10cSrcweir 	pNew->bIsOnlyTxtFlagInit = sal_True;
173cdf0e10cSrcweir 	pNew->bIsOnlyTxt = bOnlyTxt;
174cdf0e10cSrcweir 	aNames.C40_PTR_INSERT( SwBlockName, pNew );
175cdf0e10cSrcweir 	bInfoChanged = sal_True;
176cdf0e10cSrcweir }
177cdf0e10cSrcweir 
Delete(sal_uInt16 n)178cdf0e10cSrcweir sal_uLong SwXMLTextBlocks::Delete( sal_uInt16 n )
179cdf0e10cSrcweir {
180cdf0e10cSrcweir 	String aPckName (aNames[ n ]->aPackageName);
181cdf0e10cSrcweir     uno::Reference < container::XNameAccess > xAccess( xBlkRoot, uno::UNO_QUERY );
182cdf0e10cSrcweir     if ( xAccess.is() &&
183cdf0e10cSrcweir             xAccess->hasByName( aPckName ) && xBlkRoot->isStreamElement( aPckName ) )
184cdf0e10cSrcweir 	{
185cdf0e10cSrcweir         try
186cdf0e10cSrcweir         {
187cdf0e10cSrcweir             xBlkRoot->removeElement ( aPckName );
188cdf0e10cSrcweir             uno::Reference < embed::XTransactedObject > xTrans( xBlkRoot, uno::UNO_QUERY );
189cdf0e10cSrcweir             if ( xTrans.is() )
190cdf0e10cSrcweir                 xTrans->commit();
191cdf0e10cSrcweir             return 0;
192cdf0e10cSrcweir         }
193cdf0e10cSrcweir         catch ( uno::Exception)
194cdf0e10cSrcweir         {
195cdf0e10cSrcweir             return ERR_SWG_WRITE_ERROR;
196cdf0e10cSrcweir         }
197cdf0e10cSrcweir 	}
198cdf0e10cSrcweir 	return 0;
199cdf0e10cSrcweir }
200cdf0e10cSrcweir 
Rename(sal_uInt16 nIdx,const String & rNewShort,const String &)201cdf0e10cSrcweir sal_uLong SwXMLTextBlocks::Rename( sal_uInt16 nIdx, const String& rNewShort, const String& )
202cdf0e10cSrcweir {
203cdf0e10cSrcweir 	DBG_ASSERT( xBlkRoot.is(), "No storage set" );
204cdf0e10cSrcweir     if(!xBlkRoot.is())
205cdf0e10cSrcweir         return 0;
206cdf0e10cSrcweir 	String aOldName (aNames[ nIdx ]->aPackageName);
207cdf0e10cSrcweir 	aShort = rNewShort;
208cdf0e10cSrcweir 	GeneratePackageName( aShort, aPackageName );
209cdf0e10cSrcweir 	if (IsOnlyTextBlock ( nIdx ) )
210cdf0e10cSrcweir 	{
211cdf0e10cSrcweir 		String sExt( String::CreateFromAscii( ".xml" ));
212cdf0e10cSrcweir         String aOldStreamName( aOldName ); aOldStreamName += sExt;
213cdf0e10cSrcweir         String aNewStreamName( aPackageName ); aNewStreamName += sExt;
214cdf0e10cSrcweir 
215cdf0e10cSrcweir         xRoot = xBlkRoot->openStorageElement( aOldName, embed::ElementModes::READWRITE );
216cdf0e10cSrcweir         xRoot->renameElement ( aOldStreamName, aNewStreamName );
217cdf0e10cSrcweir         uno::Reference < embed::XTransactedObject > xTrans( xRoot, uno::UNO_QUERY );
218cdf0e10cSrcweir         if ( xTrans.is() )
219cdf0e10cSrcweir             xTrans->commit();
220cdf0e10cSrcweir         xRoot = 0;
221cdf0e10cSrcweir 	}
222cdf0e10cSrcweir 
223cdf0e10cSrcweir     if(aOldName != aPackageName)
224cdf0e10cSrcweir     {
225cdf0e10cSrcweir 		try
226cdf0e10cSrcweir         {
227cdf0e10cSrcweir             xBlkRoot->renameElement ( aOldName, aPackageName );
228cdf0e10cSrcweir         }
229cdf0e10cSrcweir         catch( const container::ElementExistException& rEx )
230cdf0e10cSrcweir         {
231cdf0e10cSrcweir             (void)rEx;
232cdf0e10cSrcweir         }
233cdf0e10cSrcweir     }
234cdf0e10cSrcweir     uno::Reference < embed::XTransactedObject > xTrans( xBlkRoot, uno::UNO_QUERY );
235cdf0e10cSrcweir     if ( xTrans.is() )
236cdf0e10cSrcweir         xTrans->commit();
237cdf0e10cSrcweir 	// No need to commit xBlkRoot here as SwTextBlocks::Rename calls
238cdf0e10cSrcweir 	// WriteInfo which does the commit
239cdf0e10cSrcweir 	return 0;
240cdf0e10cSrcweir }
241cdf0e10cSrcweir 
CopyBlock(SwImpBlocks & rDestImp,String & rShort,const String & rLong)242cdf0e10cSrcweir sal_uLong SwXMLTextBlocks::CopyBlock( SwImpBlocks& rDestImp, String& rShort,
243cdf0e10cSrcweir 													const String& rLong)
244cdf0e10cSrcweir {
245cdf0e10cSrcweir 	sal_uLong nError = 0;
246cdf0e10cSrcweir 	OpenFile(sal_True);
247cdf0e10cSrcweir 	rDestImp.OpenFile(sal_False);
248cdf0e10cSrcweir 	String aGroup( rShort );
249cdf0e10cSrcweir 	sal_Bool bTextOnly = IsOnlyTextBlock ( rShort ) ;//pImp->pBlkRoot->IsStream( aGroup );
250cdf0e10cSrcweir 	sal_uInt16 nIndex = GetIndex ( rShort );
251cdf0e10cSrcweir 	String sDestShortName( GetPackageName (nIndex) );
252cdf0e10cSrcweir 	sal_uInt16 nIdx = 0;
253cdf0e10cSrcweir 
254cdf0e10cSrcweir 	DBG_ASSERT( xBlkRoot.is(), "No storage set" );
255cdf0e10cSrcweir     if(!xBlkRoot.is())
256cdf0e10cSrcweir         return ERR_SWG_WRITE_ERROR;
257cdf0e10cSrcweir 
258cdf0e10cSrcweir     uno::Reference < container::XNameAccess > xAccess( ((SwXMLTextBlocks&)rDestImp).xBlkRoot, uno::UNO_QUERY );
259cdf0e10cSrcweir     while ( xAccess->hasByName( sDestShortName ) )
260cdf0e10cSrcweir 	{
261cdf0e10cSrcweir 		++nIdx;
262cdf0e10cSrcweir 		//falls wirklich mal einer so verrueckt ist
263cdf0e10cSrcweir 		if(USHRT_MAX == nIdx)
264cdf0e10cSrcweir 		{
265cdf0e10cSrcweir 			CloseFile();
266cdf0e10cSrcweir 			rDestImp.CloseFile();
267cdf0e10cSrcweir 			return ERR_SWG_WRITE_ERROR;
268cdf0e10cSrcweir 		}
269cdf0e10cSrcweir 		sDestShortName += String::CreateFromInt32( nIdx );
270cdf0e10cSrcweir 	}
271cdf0e10cSrcweir 
272cdf0e10cSrcweir     try
273cdf0e10cSrcweir 	{
274cdf0e10cSrcweir         uno::Reference < embed::XStorage > rSourceRoot = xBlkRoot->openStorageElement( aGroup, embed::ElementModes::READ );
275cdf0e10cSrcweir         uno::Reference < embed::XStorage > rDestRoot = ((SwXMLTextBlocks&)rDestImp).xBlkRoot->openStorageElement( sDestShortName, embed::ElementModes::READWRITE );
276cdf0e10cSrcweir         //if(!rSourceRoot.Is())
277cdf0e10cSrcweir         //    nError = ERR_SWG_READ_ERROR;
278cdf0e10cSrcweir         //else
279cdf0e10cSrcweir         //{
280cdf0e10cSrcweir         rSourceRoot->copyToStorage( rDestRoot );
281cdf0e10cSrcweir     }
282cdf0e10cSrcweir     catch ( uno::Exception& )
283cdf0e10cSrcweir     {
284cdf0e10cSrcweir         nError = ERR_SWG_WRITE_ERROR;
285cdf0e10cSrcweir     }
286cdf0e10cSrcweir 
287cdf0e10cSrcweir     /* I think this should work now that text only blocks are in sub-storages as well
288cdf0e10cSrcweir 	else
289cdf0e10cSrcweir 	{
290cdf0e10cSrcweir 		SvStorageStreamRef rSourceStream = xBlkRoot->OpenStream( aGroup, STREAM_STGREAD );
291cdf0e10cSrcweir 		SvStorageStreamRef rDestStream = ((SwXMLTextBlocks&)rDestImp).xBlkRoot-> OpenStream( sDestShortName, STREAM_STGWRITE );
292cdf0e10cSrcweir 		if(!rDestStream.Is())
293cdf0e10cSrcweir 			nError = ERR_SWG_WRITE_ERROR;
294cdf0e10cSrcweir 		else
295cdf0e10cSrcweir 		{
296cdf0e10cSrcweir 			if(!rSourceStream->CopyTo(&rDestStream))
297cdf0e10cSrcweir 				nError = ERR_SWG_WRITE_ERROR;
298cdf0e10cSrcweir 			else
299cdf0e10cSrcweir 				rDestStream->Commit();
300cdf0e10cSrcweir 		}
301cdf0e10cSrcweir 	}
302cdf0e10cSrcweir     */
303cdf0e10cSrcweir 	if(!nError)
304cdf0e10cSrcweir 	{
305cdf0e10cSrcweir 		rShort = sDestShortName;
306cdf0e10cSrcweir         //((SwXMLTextBlocks&)rDestImp).xBlkRoot->Commit();
307cdf0e10cSrcweir 		((SwXMLTextBlocks&)rDestImp).AddName( rShort, rLong, bTextOnly );
308cdf0e10cSrcweir 		((SwXMLTextBlocks&)rDestImp).MakeBlockList();
309cdf0e10cSrcweir 	}
310cdf0e10cSrcweir 	CloseFile();
311cdf0e10cSrcweir 	rDestImp.CloseFile();
312cdf0e10cSrcweir 	return nError;
313cdf0e10cSrcweir }
314cdf0e10cSrcweir 
315cdf0e10cSrcweir 
StartPutBlock(const String & rShort,const String & rPackageName)316cdf0e10cSrcweir sal_uLong SwXMLTextBlocks::StartPutBlock( const String& rShort, const String& rPackageName )
317cdf0e10cSrcweir {
318cdf0e10cSrcweir 	DBG_ASSERT( xBlkRoot.is(), "No storage set" );
319cdf0e10cSrcweir     if(!xBlkRoot.is())
320cdf0e10cSrcweir         return 0;
321cdf0e10cSrcweir     GetIndex ( rShort );
322cdf0e10cSrcweir 	/*
323cdf0e10cSrcweir 	if( xBlkRoot->IsContained( rPackageName ) )
324cdf0e10cSrcweir 	{
325cdf0e10cSrcweir 		xBlkRoot->Remove( rPackageName );
326cdf0e10cSrcweir 		xBlkRoot->Commit();
327cdf0e10cSrcweir 	}
328cdf0e10cSrcweir 	*/
329cdf0e10cSrcweir     try
330cdf0e10cSrcweir     {
331cdf0e10cSrcweir         xRoot = xBlkRoot->openStorageElement( rPackageName, embed::ElementModes::READWRITE );
332cdf0e10cSrcweir 
333cdf0e10cSrcweir 		uno::Reference< beans::XPropertySet > xRootProps( xRoot, uno::UNO_QUERY_THROW );
334cdf0e10cSrcweir 		::rtl::OUString aPropName( RTL_CONSTASCII_USTRINGPARAM("MediaType") );
335cdf0e10cSrcweir 		::rtl::OUString aMime( SotExchange::GetFormatMimeType( SOT_FORMATSTR_ID_STARWRITER_8 ) );
336cdf0e10cSrcweir 		xRootProps->setPropertyValue( aPropName, uno::makeAny( aMime ) );
337cdf0e10cSrcweir     }
338cdf0e10cSrcweir     catch (uno::Exception&)
339cdf0e10cSrcweir     {
340cdf0e10cSrcweir     }
341cdf0e10cSrcweir 	return 0;
342cdf0e10cSrcweir }
BeginPutDoc(const String & rShort,const String & rLong)343cdf0e10cSrcweir sal_uLong SwXMLTextBlocks::BeginPutDoc( const String& rShort, const String& rLong )
344cdf0e10cSrcweir {
345cdf0e10cSrcweir 	// In der Basisklasse ablegen!
346cdf0e10cSrcweir 	aShort = rShort;
347cdf0e10cSrcweir 	aLong = rLong;
348cdf0e10cSrcweir 	GeneratePackageName( rShort, aPackageName );
349cdf0e10cSrcweir     SetIsTextOnly( rShort, sal_False);
350cdf0e10cSrcweir 	return StartPutBlock (rShort, aPackageName);
351cdf0e10cSrcweir }
352cdf0e10cSrcweir 
PutBlock(SwPaM &,const String &)353cdf0e10cSrcweir sal_uLong SwXMLTextBlocks::PutBlock( SwPaM& , const String& )
354cdf0e10cSrcweir {
355cdf0e10cSrcweir 	sal_uLong nRes = 0;
356cdf0e10cSrcweir 	sal_uInt16 nCommitFlags = nFlags & (SWXML_CONVBLOCK|SWXML_NOROOTCOMMIT);
357cdf0e10cSrcweir 
358cdf0e10cSrcweir 	nFlags |= nCommitFlags;
359cdf0e10cSrcweir 
360cdf0e10cSrcweir 	WriterRef xWrt;
361cdf0e10cSrcweir     ::GetXMLWriter ( aEmptyStr, GetBaseURL(), xWrt);
362cdf0e10cSrcweir     SwWriter aWriter (xRoot, *pDoc );
363cdf0e10cSrcweir 
364cdf0e10cSrcweir 	xWrt->bBlock = sal_True;
365cdf0e10cSrcweir 	nRes = aWriter.Write ( xWrt );
366cdf0e10cSrcweir 	xWrt->bBlock = sal_False;
367cdf0e10cSrcweir 	// Save OLE objects if there are some
368cdf0e10cSrcweir 	SwDocShell *pDocSh = pDoc->GetDocShell();
369cdf0e10cSrcweir 
370cdf0e10cSrcweir     sal_Bool bHasChildren = pDocSh && pDocSh->GetEmbeddedObjectContainer().HasEmbeddedObjects();
371cdf0e10cSrcweir     if( !nRes && bHasChildren )
372cdf0e10cSrcweir 	{
373cdf0e10cSrcweir 		// we have to write to the temporary storage first, since the used below functions are optimized
374cdf0e10cSrcweir 		// TODO/LATER: it is only a temporary solution, that should be changed soon, the used methods should be
375cdf0e10cSrcweir 		// called without optimization
376cdf0e10cSrcweir 
377cdf0e10cSrcweir         sal_Bool bOK = sal_False;
378cdf0e10cSrcweir 
379cdf0e10cSrcweir         if ( xRoot.is() )
380cdf0e10cSrcweir         {
381cdf0e10cSrcweir             SfxMedium* pTmpMedium = NULL;
382cdf0e10cSrcweir 		    try
383cdf0e10cSrcweir 		    {
384cdf0e10cSrcweir 		        uno::Reference< embed::XStorage > xTempStorage =
385cdf0e10cSrcweir 				    ::comphelper::OStorageHelper::GetTemporaryStorage();
386cdf0e10cSrcweir 
387cdf0e10cSrcweir 			    xRoot->copyToStorage( xTempStorage );
388cdf0e10cSrcweir 
389cdf0e10cSrcweir                 // TODO/LATER: no progress bar?!
390cdf0e10cSrcweir                 // TODO/MBA: strange construct
391cdf0e10cSrcweir                 pTmpMedium = new SfxMedium( xTempStorage, GetBaseURL() );
392cdf0e10cSrcweir                 sal_Bool bTmpOK = pDocSh->SaveAsChildren( *pTmpMedium );
393cdf0e10cSrcweir 		        if( bTmpOK )
394cdf0e10cSrcweir                     bTmpOK = pDocSh->SaveCompletedChildren( sal_False );
395cdf0e10cSrcweir 
396cdf0e10cSrcweir 		        xTempStorage->copyToStorage( xRoot );
397cdf0e10cSrcweir                 bOK = bTmpOK;
398cdf0e10cSrcweir 		    }
399cdf0e10cSrcweir 		    catch( uno::Exception& )
400cdf0e10cSrcweir 		    {
401cdf0e10cSrcweir             }
402cdf0e10cSrcweir 
403cdf0e10cSrcweir             if ( pTmpMedium )
404cdf0e10cSrcweir                 DELETEZ( pTmpMedium );
405cdf0e10cSrcweir         }
406cdf0e10cSrcweir 
407cdf0e10cSrcweir 		if( !bOK )
408cdf0e10cSrcweir 			nRes = ERR_SWG_WRITE_ERROR;
409cdf0e10cSrcweir 	}
410cdf0e10cSrcweir 
411cdf0e10cSrcweir     try
412cdf0e10cSrcweir     {
413cdf0e10cSrcweir         uno::Reference < embed::XTransactedObject > xTrans( xRoot, uno::UNO_QUERY );
414cdf0e10cSrcweir         if ( xTrans.is() )
415cdf0e10cSrcweir             xTrans->commit();
416cdf0e10cSrcweir         xRoot = 0;
417cdf0e10cSrcweir         if ( !nCommitFlags )
418cdf0e10cSrcweir         {
419cdf0e10cSrcweir             uno::Reference < embed::XTransactedObject > xTmpTrans( xBlkRoot, uno::UNO_QUERY );
420cdf0e10cSrcweir             if ( xTmpTrans.is() )
421cdf0e10cSrcweir                 xTmpTrans->commit();
422cdf0e10cSrcweir         }
423cdf0e10cSrcweir     }
424cdf0e10cSrcweir     catch (uno::Exception&)
425cdf0e10cSrcweir     {
426cdf0e10cSrcweir     }
427cdf0e10cSrcweir 
428cdf0e10cSrcweir     //TODO/LATER: error handling
429cdf0e10cSrcweir     /*
430cdf0e10cSrcweir 	sal_uLong nErr = xBlkRoot->GetError();
431cdf0e10cSrcweir 	if( nErr == SVSTREAM_DISK_FULL )
432cdf0e10cSrcweir 		nRes = ERR_W4W_WRITE_FULL;
433cdf0e10cSrcweir 	else if( nErr != SVSTREAM_OK )
434cdf0e10cSrcweir 		nRes = ERR_SWG_WRITE_ERROR;
435cdf0e10cSrcweir 	nFlags |= nCommitFlags;
436cdf0e10cSrcweir     return nErr;*/
437cdf0e10cSrcweir     return 0;
438cdf0e10cSrcweir }
439cdf0e10cSrcweir 
PutDoc()440cdf0e10cSrcweir sal_uLong SwXMLTextBlocks::PutDoc()
441cdf0e10cSrcweir {
442cdf0e10cSrcweir 	SwPaM* pPaM = MakePaM();
443cdf0e10cSrcweir     sal_uLong nErr = PutBlock(*pPaM, aLong);
444cdf0e10cSrcweir 	delete pPaM;
445cdf0e10cSrcweir 	return nErr;
446cdf0e10cSrcweir }
447cdf0e10cSrcweir 
GetText(sal_uInt16 nIdx,String & rText)448cdf0e10cSrcweir sal_uLong SwXMLTextBlocks::GetText( sal_uInt16 nIdx, String& rText )
449cdf0e10cSrcweir {
450cdf0e10cSrcweir 	return GetBlockText( aNames[ nIdx ]->aShort, rText );
451cdf0e10cSrcweir }
452cdf0e10cSrcweir 
GetText(const String & rShort,String & rText)453cdf0e10cSrcweir sal_uLong SwXMLTextBlocks::GetText( const String& rShort, String& rText )
454cdf0e10cSrcweir {
455cdf0e10cSrcweir 	return GetBlockText( rShort, rText );
456cdf0e10cSrcweir }
457cdf0e10cSrcweir 
458cdf0e10cSrcweir 
MakeBlockList()459cdf0e10cSrcweir sal_uLong SwXMLTextBlocks::MakeBlockList()
460cdf0e10cSrcweir {
461cdf0e10cSrcweir 	WriteInfo();
462cdf0e10cSrcweir 	return 0;
463cdf0e10cSrcweir }
464cdf0e10cSrcweir 
PutMuchEntries(sal_Bool bOn)465cdf0e10cSrcweir sal_Bool SwXMLTextBlocks::PutMuchEntries( sal_Bool bOn )
466cdf0e10cSrcweir {
467cdf0e10cSrcweir 	sal_Bool bRet = sal_False;
468cdf0e10cSrcweir 	if( bOn )
469cdf0e10cSrcweir 	{
470cdf0e10cSrcweir 		if( bInPutMuchBlocks )
471cdf0e10cSrcweir 		{
472*870262e3SDon Lewis 			ASSERT( sal_False, "nested calls are not allowed" );
473cdf0e10cSrcweir 		}
474cdf0e10cSrcweir 		else if( !IsFileChanged() )
475cdf0e10cSrcweir 		{
476cdf0e10cSrcweir 			bRet = 0 == OpenFile( sal_False );
477cdf0e10cSrcweir 			if( bRet )
478cdf0e10cSrcweir 			{
479cdf0e10cSrcweir 				nFlags |= SWXML_NOROOTCOMMIT;
480cdf0e10cSrcweir 				bInPutMuchBlocks = sal_True;
481cdf0e10cSrcweir 			}
482cdf0e10cSrcweir 		}
483cdf0e10cSrcweir 	}
484cdf0e10cSrcweir 	else if( bInPutMuchBlocks )
485cdf0e10cSrcweir 	{
486cdf0e10cSrcweir 		nFlags &= ~SWXML_NOROOTCOMMIT;
487cdf0e10cSrcweir         if( xBlkRoot.is() )
488cdf0e10cSrcweir 		{
489cdf0e10cSrcweir             try
490cdf0e10cSrcweir             {
491cdf0e10cSrcweir                 uno::Reference < embed::XTransactedObject > xTrans( xBlkRoot, uno::UNO_QUERY );
492cdf0e10cSrcweir                 if ( xTrans.is() )
493cdf0e10cSrcweir                     xTrans->commit();
494cdf0e10cSrcweir 				MakeBlockList();
495cdf0e10cSrcweir 				CloseFile();
496cdf0e10cSrcweir 				Touch();
497cdf0e10cSrcweir 				bInPutMuchBlocks = sal_False;
498cdf0e10cSrcweir 				bRet = sal_True;
499cdf0e10cSrcweir             }
500cdf0e10cSrcweir             catch (uno::Exception&)
501cdf0e10cSrcweir             {
502cdf0e10cSrcweir             }
503cdf0e10cSrcweir 		}
504cdf0e10cSrcweir 	}
505cdf0e10cSrcweir 	return bRet;
506cdf0e10cSrcweir }
507cdf0e10cSrcweir 
OpenFile(sal_Bool bRdOnly)508cdf0e10cSrcweir sal_uLong SwXMLTextBlocks::OpenFile( sal_Bool bRdOnly )
509cdf0e10cSrcweir {
510cdf0e10cSrcweir 	if( bAutocorrBlock )
511cdf0e10cSrcweir 		return 0;
512cdf0e10cSrcweir     sal_uLong nRet = 0;
513cdf0e10cSrcweir     try
514cdf0e10cSrcweir     {
515cdf0e10cSrcweir         uno::Reference < embed::XStorage > refStg  = comphelper::OStorageHelper::GetStorageFromURL( aFile,
516cdf0e10cSrcweir                 bRdOnly ? embed::ElementModes::READ : embed::ElementModes::READWRITE );
517cdf0e10cSrcweir         InitBlockMode ( refStg );
518cdf0e10cSrcweir     }
519cdf0e10cSrcweir     catch ( uno::Exception& )
520cdf0e10cSrcweir     {
521cdf0e10cSrcweir         //TODO/LATER: error handling
522cdf0e10cSrcweir         nRet = 1;
523cdf0e10cSrcweir     }
524cdf0e10cSrcweir 
525cdf0e10cSrcweir     return nRet;
526cdf0e10cSrcweir }
527cdf0e10cSrcweir 
CloseFile()528cdf0e10cSrcweir void SwXMLTextBlocks::CloseFile()
529cdf0e10cSrcweir {
530cdf0e10cSrcweir 	if ( !bAutocorrBlock )
531cdf0e10cSrcweir 	{
532cdf0e10cSrcweir 		if (bInfoChanged)
533cdf0e10cSrcweir 			WriteInfo();
534cdf0e10cSrcweir 		ResetBlockMode();
535cdf0e10cSrcweir 	}
536cdf0e10cSrcweir }
537cdf0e10cSrcweir 
SetIsTextOnly(const String & rShort,sal_Bool bNewValue)538cdf0e10cSrcweir void SwXMLTextBlocks::SetIsTextOnly( const String& rShort, sal_Bool bNewValue )
539cdf0e10cSrcweir {
540cdf0e10cSrcweir 	sal_uInt16 nIdx = GetIndex ( rShort );
541cdf0e10cSrcweir 	if (nIdx != (sal_uInt16) -1  && nIdx != USHRT_MAX)
542cdf0e10cSrcweir 		aNames[nIdx]->bIsOnlyTxt = bNewValue;
543cdf0e10cSrcweir }
544cdf0e10cSrcweir 
SetIsTextOnly(sal_uInt16 nIdx,sal_Bool bNewValue)545cdf0e10cSrcweir void SwXMLTextBlocks::SetIsTextOnly( sal_uInt16 nIdx, sal_Bool bNewValue )
546cdf0e10cSrcweir {
547cdf0e10cSrcweir 	aNames[nIdx]->bIsOnlyTxt = bNewValue;
548cdf0e10cSrcweir }
549cdf0e10cSrcweir 
IsOnlyTextBlock(const String & rShort) const550cdf0e10cSrcweir sal_Bool SwXMLTextBlocks::IsOnlyTextBlock( const String& rShort ) const
551cdf0e10cSrcweir {
552cdf0e10cSrcweir 	sal_uInt16 nIdx = GetIndex ( rShort );
553cdf0e10cSrcweir 	sal_Bool bRet = sal_False;
554cdf0e10cSrcweir 	if (nIdx != (sal_uInt16) -1  && nIdx != USHRT_MAX)
555cdf0e10cSrcweir 	{
556cdf0e10cSrcweir 		bRet = aNames[nIdx]->bIsOnlyTxt;
557cdf0e10cSrcweir 	}
558cdf0e10cSrcweir 	return bRet;
559cdf0e10cSrcweir }
IsOnlyTextBlock(sal_uInt16 nIdx) const560cdf0e10cSrcweir sal_Bool SwXMLTextBlocks::IsOnlyTextBlock( sal_uInt16 nIdx ) const
561cdf0e10cSrcweir {
562cdf0e10cSrcweir 	return aNames[nIdx]->bIsOnlyTxt;
563cdf0e10cSrcweir }
564cdf0e10cSrcweir 
IsFileUCBStorage(const String & rFileName)565cdf0e10cSrcweir sal_Bool SwXMLTextBlocks::IsFileUCBStorage( const String & rFileName)
566cdf0e10cSrcweir {
567cdf0e10cSrcweir 	String aName( rFileName );
568cdf0e10cSrcweir     INetURLObject aObj( aName );
569cdf0e10cSrcweir     if ( aObj.GetProtocol() == INET_PROT_NOT_VALID )
570cdf0e10cSrcweir     {
571cdf0e10cSrcweir         String aURL;
572cdf0e10cSrcweir         ::utl::LocalFileHelper::ConvertPhysicalNameToURL( aName, aURL );
573cdf0e10cSrcweir         aObj.SetURL( aURL );
574cdf0e10cSrcweir 		aName = aObj.GetMainURL( INetURLObject::NO_DECODE );
575cdf0e10cSrcweir     }
576cdf0e10cSrcweir 
577cdf0e10cSrcweir 	SvStream * pStm = ::utl::UcbStreamHelper::CreateStream( aName, STREAM_STD_READ );
578cdf0e10cSrcweir     sal_Bool bRet = UCBStorage::IsStorageFile( pStm );
579cdf0e10cSrcweir 	delete pStm;
580cdf0e10cSrcweir 	return bRet;
581cdf0e10cSrcweir }
582cdf0e10cSrcweir 
583cdf0e10cSrcweir 
584cdf0e10cSrcweir 
GetFileType(void) const585cdf0e10cSrcweir short SwXMLTextBlocks::GetFileType ( void ) const
586cdf0e10cSrcweir {
587cdf0e10cSrcweir 	return SWBLK_XML;
588cdf0e10cSrcweir }
589cdf0e10cSrcweir 
GeneratePackageName(const String & rShort,String & rPackageName)590cdf0e10cSrcweir void SwXMLTextBlocks::GeneratePackageName ( const String& rShort, String& rPackageName )
591cdf0e10cSrcweir {
592cdf0e10cSrcweir 	rPackageName = rShort;
593cdf0e10cSrcweir 	xub_StrLen nPos = 0;
594cdf0e10cSrcweir 	sal_Unicode pDelims[] = { '!', '/', ':', '.', '\\', 0 };
595cdf0e10cSrcweir 	ByteString sByte ( rPackageName, RTL_TEXTENCODING_UTF7);
596cdf0e10cSrcweir 	rPackageName = String (sByte, RTL_TEXTENCODING_ASCII_US);
597cdf0e10cSrcweir 	while( STRING_NOTFOUND != ( nPos = rPackageName.SearchChar( pDelims, nPos )))
598cdf0e10cSrcweir 	{
599cdf0e10cSrcweir 		rPackageName.SetChar( nPos, '_' );
600cdf0e10cSrcweir 		++nPos;
601cdf0e10cSrcweir 	}
602cdf0e10cSrcweir }
603cdf0e10cSrcweir 
PutText(const String & rShort,const String & rName,const String & rText)604cdf0e10cSrcweir sal_uLong SwXMLTextBlocks::PutText( const String& rShort, const String& rName,
605cdf0e10cSrcweir 								const String& rText )
606cdf0e10cSrcweir {
607cdf0e10cSrcweir 	sal_uLong nRes = 0;
608cdf0e10cSrcweir 	aShort = rShort;
609cdf0e10cSrcweir 	aLong = rName;
610cdf0e10cSrcweir 	aCur = rText;
611cdf0e10cSrcweir     SetIsTextOnly( aShort, sal_True );
612cdf0e10cSrcweir 	GeneratePackageName( rShort, aPackageName );
613cdf0e10cSrcweir 	ClearDoc();
614cdf0e10cSrcweir 	nRes = PutBlockText( rShort, rName, rText, aPackageName );
615cdf0e10cSrcweir 	return nRes;
616cdf0e10cSrcweir }
617cdf0e10cSrcweir 
MakeBlockText(const String & rText)618cdf0e10cSrcweir void SwXMLTextBlocks::MakeBlockText( const String& rText )
619cdf0e10cSrcweir {
620cdf0e10cSrcweir 	SwTxtNode* pTxtNode = pDoc->GetNodes()[ pDoc->GetNodes().GetEndOfContent().
621cdf0e10cSrcweir 										GetIndex() - 1 ]->GetTxtNode();
622cdf0e10cSrcweir 	//JP 18.09.98: Bug 56706 - Standard sollte zumindest gesetzt sein!
623cdf0e10cSrcweir 	if( pTxtNode->GetTxtColl() == pDoc->GetDfltTxtFmtColl() )
624cdf0e10cSrcweir 		pTxtNode->ChgFmtColl( pDoc->GetTxtCollFromPool( RES_POOLCOLL_STANDARD ));
625cdf0e10cSrcweir 
626cdf0e10cSrcweir 	xub_StrLen nPos = 0;
627cdf0e10cSrcweir 	do
628cdf0e10cSrcweir 	{
629cdf0e10cSrcweir 		if ( nPos )
630cdf0e10cSrcweir 		{
631cdf0e10cSrcweir 			pTxtNode = (SwTxtNode*)pTxtNode->AppendNode( SwPosition( *pTxtNode ) );
632cdf0e10cSrcweir 		}
633cdf0e10cSrcweir 		SwIndex aIdx( pTxtNode );
634cdf0e10cSrcweir 		String sTemp(rText.GetToken( 0, '\015', nPos ) );
635cdf0e10cSrcweir         pTxtNode->InsertText( sTemp, aIdx );
636cdf0e10cSrcweir 	} while ( STRING_NOTFOUND != nPos );
637cdf0e10cSrcweir }
638