/************************************************************************* * * $RCSfile: linkmgr2.cxx,v $ * * $Revision: 1.2 $ * * last change: $Author: kz $ $Date: 2004-10-04 20:45:28 $ * * 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 _DEBUG_HXX //autogen #include #endif #include "linkmgr.hxx" #include #include "lnkbase.hxx" //#include "linksrc.hxx" #include "impldde.hxx" //#include "svuidlg.hrc" //#include "iface.hxx" #include "app.hrc" #include "sfxresid.hxx" #pragma hdrstop #define _SVSTDARR_STRINGSDTOR #include namespace sfx2 { SV_IMPL_PTRARR( SvBaseLinks, SvBaseLinkRefPtr ) SvLinkManager::SvLinkManager() : pPersist( 0 ) { } SvLinkManager::~SvLinkManager() { SvBaseLinkRef** ppRef = (SvBaseLinkRef**)aLinkTbl.GetData(); for( USHORT n = aLinkTbl.Count(); n; --n, ++ppRef ) { if( (*ppRef)->Is() ) { (*(*ppRef))->Disconnect(); (*(*ppRef))->pLinkMgr = 0; } delete *ppRef; } } /************************************************************************ |* SvLinkManager::Remove() |* |* Beschreibung *************************************************************************/ void SvLinkManager::Remove( SvBaseLink *pLink ) { // keine Links doppelt einfuegen int bFound = FALSE; SvBaseLinkRef** ppRef = (SvBaseLinkRef**)aLinkTbl.GetData(); for( USHORT n = aLinkTbl.Count(); n; --n, ++ppRef ) { if( pLink == *(*ppRef) ) { (*(*ppRef))->Disconnect(); (*(*ppRef))->pLinkMgr = 0; (*(*ppRef)).Clear(); bFound = TRUE; } // falls noch leere rum stehen sollten, weg damit if( !(*ppRef)->Is() ) { delete *ppRef; aLinkTbl.Remove( aLinkTbl.Count() - n, 1 ); if( bFound ) return ; --ppRef; } } } void SvLinkManager::Remove( USHORT nPos, USHORT nCnt ) { if( nCnt && nPos < aLinkTbl.Count() ) { if( nPos + nCnt > aLinkTbl.Count() ) nCnt = aLinkTbl.Count() - nPos; SvBaseLinkRef** ppRef = (SvBaseLinkRef**)aLinkTbl.GetData() + nPos; for( USHORT n = nCnt; n; --n, ++ppRef ) { if( (*ppRef)->Is() ) { (*(*ppRef))->Disconnect(); (*(*ppRef))->pLinkMgr = 0; } delete *ppRef; } aLinkTbl.Remove( nPos, nCnt ); } } BOOL SvLinkManager::Insert( SvBaseLink* pLink ) { // keine Links doppelt einfuegen for( USHORT n = 0; n < aLinkTbl.Count(); ++n ) { SvBaseLinkRef* pTmp = aLinkTbl[ n ]; if( !pTmp->Is() ) aLinkTbl.DeleteAndDestroy( n-- ); if( pLink == *pTmp ) return FALSE; } SvBaseLinkRef* pTmp = new SvBaseLinkRef( pLink ); pLink->pLinkMgr = this; aLinkTbl.Insert( pTmp, aLinkTbl.Count() ); return TRUE; } BOOL SvLinkManager::InsertLink( SvBaseLink * pLink, USHORT nObjType, USHORT nUpdateMode, const String* pName ) { // unbedingt zuerst pLink->SetObjType( nObjType ); if( pName ) pLink->SetName( *pName ); pLink->SetUpdateMode( nUpdateMode ); return Insert( pLink ); } BOOL SvLinkManager::InsertDDELink( SvBaseLink * pLink, const String& rServer, const String& rTopic, const String& rItem ) { if( !( OBJECT_CLIENT_SO & pLink->GetObjType() ) ) return FALSE; String sCmd; ::sfx2::MakeLnkName( sCmd, &rServer, rTopic, rItem ); pLink->SetObjType( OBJECT_CLIENT_DDE ); pLink->SetName( sCmd ); return Insert( pLink ); } BOOL SvLinkManager::InsertDDELink( SvBaseLink * pLink ) { DBG_ASSERT( OBJECT_CLIENT_SO & pLink->GetObjType(), "no OBJECT_CLIENT_SO" ) if( !( OBJECT_CLIENT_SO & pLink->GetObjType() ) ) return FALSE; if( pLink->GetObjType() == OBJECT_CLIENT_SO ) pLink->SetObjType( OBJECT_CLIENT_DDE ); return Insert( pLink ); } // erfrage die Strings fuer den Dialog BOOL SvLinkManager::GetDisplayNames( const SvBaseLink * pLink, String* pType, String* pFile, String* pLinkStr, String* pFilter ) const { BOOL bRet = FALSE; String aLN = pLink->GetLinkSourceName(); if( aLN.Len() != 0 && pLink->GetObjType() == OBJECT_CLIENT_DDE ) { USHORT nTmp = 0; String sCmd( aLN ); String sServer( sCmd.GetToken( 0, cTokenSeperator, nTmp ) ); String sTopic( sCmd.GetToken( 0, cTokenSeperator, nTmp ) ); if( pType ) *pType = sServer; if( pFile ) *pFile = sTopic; if( pLinkStr ) *pLinkStr = sCmd.Copy( nTmp ); bRet = TRUE; } return bRet; } void SvLinkManager::UpdateAllLinks( BOOL bAskUpdate, BOOL bCallErrHdl, BOOL bUpdateGrfLinks, Window* pParentWin ) { SvStringsDtor aApps, aTopics, aItems; String sApp, sTopic, sItem; // erstmal eine Kopie vom Array machen, damit sich updatende Links in // Links in ... nicht dazwischen funken!! SvPtrarr aTmpArr( 255, 50 ); USHORT n; for( n = 0; n < aLinkTbl.Count(); ++n ) { SvBaseLink* pLink = *aLinkTbl[ n ]; if( !pLink ) { Remove( n-- ); continue; } aTmpArr.Insert( pLink, aTmpArr.Count() ); } for( n = 0; n < aTmpArr.Count(); ++n ) { SvBaseLink* pLink = (SvBaseLink*)aTmpArr[ n ]; // suche erstmal im Array nach dem Eintrag USHORT nFndPos = USHRT_MAX; for( USHORT i = 0; i < aLinkTbl.Count(); ++i ) if( pLink == *aLinkTbl[ i ] ) { nFndPos = i; break; } if( USHRT_MAX == nFndPos ) continue; // war noch nicht vorhanden! // Graphic-Links noch nicht updaten if( !pLink->IsVisible() || ( !bUpdateGrfLinks && OBJECT_CLIENT_GRF == pLink->GetObjType() )) continue; if( bAskUpdate ) { int nRet = QueryBox( pParentWin, WB_YES_NO | WB_DEF_YES, SfxResId( STR_QUERY_UPDATE_LINKS ) ).Execute(); if( RET_YES != nRet ) return ; // es soll nichts geupdatet werden bAskUpdate = FALSE; // einmal reicht } pLink->Update(); } } /************************************************************************ |* SvBaseLink::CreateObject() |* |* Beschreibung *************************************************************************/ SvLinkSourceRef SvLinkManager::CreateObj( SvBaseLink * pLink ) { if( OBJECT_CLIENT_DDE == pLink->GetObjType() ) return new SvDDEObject(); return SvLinkSourceRef(); } BOOL SvLinkManager::InsertServer( SvLinkSource* pObj ) { // keine doppelt einfuegen if( !pObj || USHRT_MAX != aServerTbl.GetPos( pObj ) ) return FALSE; aServerTbl.Insert( pObj, aServerTbl.Count() ); return TRUE; } void SvLinkManager::RemoveServer( SvLinkSource* pObj ) { USHORT nPos = aServerTbl.GetPos( pObj ); if( USHRT_MAX != nPos ) aServerTbl.Remove( nPos, 1 ); } void MakeLnkName( String& rName, const String* pType, const String& rFile, const String& rLink, const String* pFilter ) { if( pType ) (rName = *pType).EraseLeadingChars().EraseTrailingChars() += cTokenSeperator; else if( rName.Len() ) rName.Erase(); ((rName += rFile).EraseLeadingChars().EraseTrailingChars() += cTokenSeperator ).EraseLeadingChars().EraseTrailingChars() += rLink; if( pFilter ) ((rName += cTokenSeperator ) += *pFilter).EraseLeadingChars().EraseTrailingChars(); } }