xref: /trunk/main/sw/source/core/swg/SwXMLTextBlocks.cxx (revision cf6516809c57e1bb0a940545cca99cdad54d4ce2)
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
10cdf0e10cSrcweir  *
11efeef26fSAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12cdf0e10cSrcweir  *
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.
19cdf0e10cSrcweir  *
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