1*cdf0e10cSrcweir /************************************************************************* 2*cdf0e10cSrcweir * 3*cdf0e10cSrcweir * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4*cdf0e10cSrcweir * 5*cdf0e10cSrcweir * Copyright 2000, 2010 Oracle and/or its affiliates. 6*cdf0e10cSrcweir * 7*cdf0e10cSrcweir * OpenOffice.org - a multi-platform office productivity suite 8*cdf0e10cSrcweir * 9*cdf0e10cSrcweir * This file is part of OpenOffice.org. 10*cdf0e10cSrcweir * 11*cdf0e10cSrcweir * OpenOffice.org is free software: you can redistribute it and/or modify 12*cdf0e10cSrcweir * it under the terms of the GNU Lesser General Public License version 3 13*cdf0e10cSrcweir * only, as published by the Free Software Foundation. 14*cdf0e10cSrcweir * 15*cdf0e10cSrcweir * OpenOffice.org is distributed in the hope that it will be useful, 16*cdf0e10cSrcweir * but WITHOUT ANY WARRANTY; without even the implied warranty of 17*cdf0e10cSrcweir * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18*cdf0e10cSrcweir * GNU Lesser General Public License version 3 for more details 19*cdf0e10cSrcweir * (a copy is included in the LICENSE file that accompanied this code). 20*cdf0e10cSrcweir * 21*cdf0e10cSrcweir * You should have received a copy of the GNU Lesser General Public License 22*cdf0e10cSrcweir * version 3 along with OpenOffice.org. If not, see 23*cdf0e10cSrcweir * <http://www.openoffice.org/license.html> 24*cdf0e10cSrcweir * for a copy of the LGPLv3 License. 25*cdf0e10cSrcweir * 26*cdf0e10cSrcweir ************************************************************************/ 27*cdf0e10cSrcweir 28*cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove 29*cdf0e10cSrcweir #include "precompiled_sfx2.hxx" 30*cdf0e10cSrcweir 31*cdf0e10cSrcweir #include <tools/urlobj.hxx> 32*cdf0e10cSrcweir 33*cdf0e10cSrcweir #include <sfx2/objsh.hxx> 34*cdf0e10cSrcweir #include <sfx2/docfile.hxx> 35*cdf0e10cSrcweir #include "openflag.hxx" 36*cdf0e10cSrcweir 37*cdf0e10cSrcweir #include <svtools/htmlkywd.hxx> 38*cdf0e10cSrcweir #include <svtools/htmltokn.h> 39*cdf0e10cSrcweir #include <svtools/imap.hxx> 40*cdf0e10cSrcweir #include <svtools/imapcirc.hxx> 41*cdf0e10cSrcweir #include <svtools/imapobj.hxx> 42*cdf0e10cSrcweir #include <svtools/imappoly.hxx> 43*cdf0e10cSrcweir #include <svtools/imaprect.hxx> 44*cdf0e10cSrcweir #ifndef _SVSTDARR_ULONGS_DECL 45*cdf0e10cSrcweir #define _SVSTDARR_ULONGS 46*cdf0e10cSrcweir #include <svl/svstdarr.hxx> 47*cdf0e10cSrcweir #endif 48*cdf0e10cSrcweir #include <svl/zforlist.hxx> 49*cdf0e10cSrcweir #include <rtl/tencinfo.h> 50*cdf0e10cSrcweir #include <tools/tenccvt.hxx> 51*cdf0e10cSrcweir 52*cdf0e10cSrcweir #include <sfx2/sfxhtml.hxx> 53*cdf0e10cSrcweir 54*cdf0e10cSrcweir #include <com/sun/star/beans/XPropertyContainer.hpp> 55*cdf0e10cSrcweir 56*cdf0e10cSrcweir 57*cdf0e10cSrcweir using namespace ::com::sun::star; 58*cdf0e10cSrcweir 59*cdf0e10cSrcweir 60*cdf0e10cSrcweir sal_Char __FAR_DATA sHTML_MIME_text[] = "text/"; 61*cdf0e10cSrcweir sal_Char __FAR_DATA sHTML_MIME_application[] = "application/"; 62*cdf0e10cSrcweir sal_Char __FAR_DATA sHTML_MIME_experimental[] = "x-"; 63*cdf0e10cSrcweir 64*cdf0e10cSrcweir // <INPUT TYPE=xxx> 65*cdf0e10cSrcweir static HTMLOptionEnum __READONLY_DATA aAreaShapeOptEnums[] = 66*cdf0e10cSrcweir { 67*cdf0e10cSrcweir { OOO_STRING_SVTOOLS_HTML_SH_rect, IMAP_OBJ_RECTANGLE }, 68*cdf0e10cSrcweir { OOO_STRING_SVTOOLS_HTML_SH_rectangle, IMAP_OBJ_RECTANGLE }, 69*cdf0e10cSrcweir { OOO_STRING_SVTOOLS_HTML_SH_circ, IMAP_OBJ_CIRCLE }, 70*cdf0e10cSrcweir { OOO_STRING_SVTOOLS_HTML_SH_circle, IMAP_OBJ_CIRCLE }, 71*cdf0e10cSrcweir { OOO_STRING_SVTOOLS_HTML_SH_poly, IMAP_OBJ_POLYGON }, 72*cdf0e10cSrcweir { OOO_STRING_SVTOOLS_HTML_SH_polygon, IMAP_OBJ_POLYGON }, 73*cdf0e10cSrcweir { 0, 0 } 74*cdf0e10cSrcweir }; 75*cdf0e10cSrcweir 76*cdf0e10cSrcweir SfxHTMLParser::SfxHTMLParser( SvStream& rStream, sal_Bool bIsNewDoc, 77*cdf0e10cSrcweir SfxMedium *pMed ) : 78*cdf0e10cSrcweir HTMLParser( rStream, bIsNewDoc ), 79*cdf0e10cSrcweir pMedium( pMed ), pDLMedium( 0 ), 80*cdf0e10cSrcweir nMetaTags( 0 ) 81*cdf0e10cSrcweir { 82*cdf0e10cSrcweir DBG_ASSERT( RTL_TEXTENCODING_DONTKNOW == GetSrcEncoding( ), 83*cdf0e10cSrcweir "SfxHTMLParser::SfxHTMLParser: Wo kommt der ZS her?" ); 84*cdf0e10cSrcweir DBG_ASSERT( !IsSwitchToUCS2(), 85*cdf0e10cSrcweir "SfxHTMLParser::SfxHTMLParser: Switch to UCS2?" ); 86*cdf0e10cSrcweir 87*cdf0e10cSrcweir // Altough the real default encoding is ISO8859-1, we use MS-1252 88*cdf0e10cSrcweir // als default encoding. 89*cdf0e10cSrcweir SetSrcEncoding( GetExtendedCompatibilityTextEncoding( RTL_TEXTENCODING_ISO_8859_1 ) ); 90*cdf0e10cSrcweir 91*cdf0e10cSrcweir // If the file starts with a BOM, switch to UCS2. 92*cdf0e10cSrcweir SetSwitchToUCS2( sal_True ); 93*cdf0e10cSrcweir } 94*cdf0e10cSrcweir 95*cdf0e10cSrcweir __EXPORT SfxHTMLParser::~SfxHTMLParser() 96*cdf0e10cSrcweir { 97*cdf0e10cSrcweir DBG_ASSERT( !pDLMedium, "Da ist ein File-Download stehengeblieben" ); 98*cdf0e10cSrcweir delete pDLMedium; 99*cdf0e10cSrcweir } 100*cdf0e10cSrcweir 101*cdf0e10cSrcweir sal_Bool SfxHTMLParser::ParseMapOptions(ImageMap * pImageMap, 102*cdf0e10cSrcweir const HTMLOptions * pOptions) 103*cdf0e10cSrcweir { 104*cdf0e10cSrcweir DBG_ASSERT( pImageMap, "ParseMapOptions: keine Image-Map" ); 105*cdf0e10cSrcweir DBG_ASSERT( pOptions, "ParseMapOptions: keine Optionen" ); 106*cdf0e10cSrcweir 107*cdf0e10cSrcweir String aName; 108*cdf0e10cSrcweir 109*cdf0e10cSrcweir for( sal_uInt16 i=pOptions->Count(); i; ) 110*cdf0e10cSrcweir { 111*cdf0e10cSrcweir const HTMLOption *pOption = (*pOptions)[--i]; 112*cdf0e10cSrcweir switch( pOption->GetToken() ) 113*cdf0e10cSrcweir { 114*cdf0e10cSrcweir case HTML_O_NAME: 115*cdf0e10cSrcweir aName = pOption->GetString(); 116*cdf0e10cSrcweir break; 117*cdf0e10cSrcweir } 118*cdf0e10cSrcweir } 119*cdf0e10cSrcweir 120*cdf0e10cSrcweir if( aName.Len() ) 121*cdf0e10cSrcweir pImageMap->SetName( aName ); 122*cdf0e10cSrcweir 123*cdf0e10cSrcweir return aName.Len() > 0; 124*cdf0e10cSrcweir } 125*cdf0e10cSrcweir 126*cdf0e10cSrcweir sal_Bool SfxHTMLParser::ParseAreaOptions(ImageMap * pImageMap, const String& rBaseURL, 127*cdf0e10cSrcweir const HTMLOptions * pOptions, 128*cdf0e10cSrcweir sal_uInt16 nEventMouseOver, 129*cdf0e10cSrcweir sal_uInt16 nEventMouseOut ) 130*cdf0e10cSrcweir { 131*cdf0e10cSrcweir DBG_ASSERT( pImageMap, "ParseAreaOptions: keine Image-Map" ); 132*cdf0e10cSrcweir DBG_ASSERT( pOptions, "ParseAreaOptions: keine Optionen" ); 133*cdf0e10cSrcweir 134*cdf0e10cSrcweir sal_uInt16 nShape = IMAP_OBJ_RECTANGLE; 135*cdf0e10cSrcweir SvULongs aCoords; 136*cdf0e10cSrcweir String aName, aHRef, aAlt, aTarget, sEmpty; 137*cdf0e10cSrcweir sal_Bool bNoHRef = sal_False; 138*cdf0e10cSrcweir SvxMacroTableDtor aMacroTbl; 139*cdf0e10cSrcweir 140*cdf0e10cSrcweir for( sal_uInt16 i=pOptions->Count(); i; ) 141*cdf0e10cSrcweir { 142*cdf0e10cSrcweir sal_uInt16 nEvent = 0; 143*cdf0e10cSrcweir ScriptType eScrpType = STARBASIC; 144*cdf0e10cSrcweir const HTMLOption *pOption = (*pOptions)[--i]; 145*cdf0e10cSrcweir switch( pOption->GetToken() ) 146*cdf0e10cSrcweir { 147*cdf0e10cSrcweir case HTML_O_NAME: 148*cdf0e10cSrcweir aName = pOption->GetString(); 149*cdf0e10cSrcweir break; 150*cdf0e10cSrcweir case HTML_O_SHAPE: 151*cdf0e10cSrcweir pOption->GetEnum( nShape, aAreaShapeOptEnums ); 152*cdf0e10cSrcweir break; 153*cdf0e10cSrcweir case HTML_O_COORDS: 154*cdf0e10cSrcweir pOption->GetNumbers( aCoords, sal_True ); 155*cdf0e10cSrcweir break; 156*cdf0e10cSrcweir case HTML_O_HREF: 157*cdf0e10cSrcweir aHRef = INetURLObject::GetAbsURL( rBaseURL, pOption->GetString() ); 158*cdf0e10cSrcweir break; 159*cdf0e10cSrcweir case HTML_O_NOHREF: 160*cdf0e10cSrcweir bNoHRef = sal_True; 161*cdf0e10cSrcweir break; 162*cdf0e10cSrcweir case HTML_O_ALT: 163*cdf0e10cSrcweir aAlt = pOption->GetString(); 164*cdf0e10cSrcweir break; 165*cdf0e10cSrcweir case HTML_O_TARGET: 166*cdf0e10cSrcweir aTarget = pOption->GetString(); 167*cdf0e10cSrcweir break; 168*cdf0e10cSrcweir 169*cdf0e10cSrcweir case HTML_O_ONMOUSEOVER: 170*cdf0e10cSrcweir eScrpType = JAVASCRIPT; 171*cdf0e10cSrcweir case HTML_O_SDONMOUSEOVER: 172*cdf0e10cSrcweir nEvent = nEventMouseOver; 173*cdf0e10cSrcweir goto IMAPOBJ_SETEVENT; 174*cdf0e10cSrcweir 175*cdf0e10cSrcweir case HTML_O_ONMOUSEOUT: 176*cdf0e10cSrcweir eScrpType = JAVASCRIPT; 177*cdf0e10cSrcweir case HTML_O_SDONMOUSEOUT: 178*cdf0e10cSrcweir nEvent = nEventMouseOut; 179*cdf0e10cSrcweir goto IMAPOBJ_SETEVENT; 180*cdf0e10cSrcweir IMAPOBJ_SETEVENT: 181*cdf0e10cSrcweir if( nEvent ) 182*cdf0e10cSrcweir { 183*cdf0e10cSrcweir String sTmp( pOption->GetString() ); 184*cdf0e10cSrcweir if( sTmp.Len() ) 185*cdf0e10cSrcweir { 186*cdf0e10cSrcweir sTmp.ConvertLineEnd(); 187*cdf0e10cSrcweir aMacroTbl.Insert( nEvent, 188*cdf0e10cSrcweir new SvxMacro( sTmp, sEmpty, eScrpType )); 189*cdf0e10cSrcweir } 190*cdf0e10cSrcweir } 191*cdf0e10cSrcweir break; 192*cdf0e10cSrcweir } 193*cdf0e10cSrcweir } 194*cdf0e10cSrcweir 195*cdf0e10cSrcweir if( bNoHRef ) 196*cdf0e10cSrcweir aHRef.Erase(); 197*cdf0e10cSrcweir 198*cdf0e10cSrcweir sal_Bool bNewArea = sal_True; 199*cdf0e10cSrcweir switch( nShape ) 200*cdf0e10cSrcweir { 201*cdf0e10cSrcweir case IMAP_OBJ_RECTANGLE: 202*cdf0e10cSrcweir if( aCoords.Count() >=4 ) 203*cdf0e10cSrcweir { 204*cdf0e10cSrcweir Rectangle aRec( aCoords[0], aCoords[1], 205*cdf0e10cSrcweir aCoords[2], aCoords[3] ); 206*cdf0e10cSrcweir IMapRectangleObject aMapRObj( aRec, aHRef, aAlt, String(), aTarget, aName, 207*cdf0e10cSrcweir !bNoHRef ); 208*cdf0e10cSrcweir if( aMacroTbl.Count() ) 209*cdf0e10cSrcweir aMapRObj.SetMacroTable( aMacroTbl ); 210*cdf0e10cSrcweir pImageMap->InsertIMapObject( aMapRObj ); 211*cdf0e10cSrcweir } 212*cdf0e10cSrcweir break; 213*cdf0e10cSrcweir case IMAP_OBJ_CIRCLE: 214*cdf0e10cSrcweir if( aCoords.Count() >=3 ) 215*cdf0e10cSrcweir { 216*cdf0e10cSrcweir Point aPoint( aCoords[0], aCoords[1] ); 217*cdf0e10cSrcweir IMapCircleObject aMapCObj( aPoint, aCoords[2],aHRef, aAlt, String(), 218*cdf0e10cSrcweir aTarget, aName, !bNoHRef ); 219*cdf0e10cSrcweir if( aMacroTbl.Count() ) 220*cdf0e10cSrcweir aMapCObj.SetMacroTable( aMacroTbl ); 221*cdf0e10cSrcweir pImageMap->InsertIMapObject( aMapCObj ); 222*cdf0e10cSrcweir } 223*cdf0e10cSrcweir break; 224*cdf0e10cSrcweir case IMAP_OBJ_POLYGON: 225*cdf0e10cSrcweir if( aCoords.Count() >=6 ) 226*cdf0e10cSrcweir { 227*cdf0e10cSrcweir sal_uInt16 nCount = aCoords.Count() / 2; 228*cdf0e10cSrcweir Polygon aPoly( nCount ); 229*cdf0e10cSrcweir for( sal_uInt16 i=0; i<nCount; i++ ) 230*cdf0e10cSrcweir aPoly[i] = Point( aCoords[2*i], aCoords[2*i+1] ); 231*cdf0e10cSrcweir IMapPolygonObject aMapPObj( aPoly, aHRef, aAlt, String(), aTarget, aName, 232*cdf0e10cSrcweir !bNoHRef ); 233*cdf0e10cSrcweir if( aMacroTbl.Count() ) 234*cdf0e10cSrcweir aMapPObj.SetMacroTable( aMacroTbl ); 235*cdf0e10cSrcweir pImageMap->InsertIMapObject( aMapPObj ); 236*cdf0e10cSrcweir } 237*cdf0e10cSrcweir break; 238*cdf0e10cSrcweir default: 239*cdf0e10cSrcweir bNewArea = sal_False; 240*cdf0e10cSrcweir } 241*cdf0e10cSrcweir 242*cdf0e10cSrcweir return bNewArea; 243*cdf0e10cSrcweir } 244*cdf0e10cSrcweir 245*cdf0e10cSrcweir 246*cdf0e10cSrcweir void SfxHTMLParser::StartFileDownload( const String& rURL, int nToken, 247*cdf0e10cSrcweir SfxObjectShell *pSh ) 248*cdf0e10cSrcweir { 249*cdf0e10cSrcweir DBG_ASSERT( !pDLMedium, "StartFileDwonload bei aktivem Download" ); 250*cdf0e10cSrcweir if( pDLMedium ) 251*cdf0e10cSrcweir return; 252*cdf0e10cSrcweir 253*cdf0e10cSrcweir pDLMedium = new SfxMedium( rURL, SFX_STREAM_READONLY, sal_False ); 254*cdf0e10cSrcweir if( pSh ) 255*cdf0e10cSrcweir { 256*cdf0e10cSrcweir // Medium registrieren, damit abgebrochen werden kann 257*cdf0e10cSrcweir pSh->RegisterTransfer( *pDLMedium ); 258*cdf0e10cSrcweir 259*cdf0e10cSrcweir // Target-Frame uebertragen, damit auch javascript:-URLs 260*cdf0e10cSrcweir // "geladen" werden koennen. 261*cdf0e10cSrcweir //const SfxMedium *pShMedium = pSh->GetMedium(); 262*cdf0e10cSrcweir //if( pShMedium ) 263*cdf0e10cSrcweir // pDLMedium->SetLoadTargetFrame( pShMedium->GetLoadTargetFrame() ); 264*cdf0e10cSrcweir } 265*cdf0e10cSrcweir 266*cdf0e10cSrcweir // Download anstossen (Achtung: Kann auch synchron sein). 267*cdf0e10cSrcweir if ( sal_True /*pMedium->GetDoneLink() == Link()*/ ) 268*cdf0e10cSrcweir pDLMedium->DownLoad(); 269*cdf0e10cSrcweir else 270*cdf0e10cSrcweir { 271*cdf0e10cSrcweir // Downloading-Flag auf sal_True setzen. Es werden dann auch 272*cdf0e10cSrcweir // Data-Available-Links, wenn wir in den Pending-Staus gelangen. 273*cdf0e10cSrcweir SetDownloadingFile( sal_True ); 274*cdf0e10cSrcweir pDLMedium->DownLoad( STATIC_LINK( this, SfxHTMLParser, FileDownloadDone ) ); 275*cdf0e10cSrcweir 276*cdf0e10cSrcweir // Wenn das Dowsnloading-Flag noch gesetzt ist erfolgt der Download 277*cdf0e10cSrcweir // asynchron. Wir gehen dann in den Pedning-Staus und warten dort. 278*cdf0e10cSrcweir // Solange sind alle Aufrufe des Data-Avaialble-Link gesperrt. 279*cdf0e10cSrcweir if( IsDownloadingFile() ) 280*cdf0e10cSrcweir { 281*cdf0e10cSrcweir // Den aktuellen Zustand einfrieren und in den Pending-Status gehen. 282*cdf0e10cSrcweir // Wenn der Download beendet oder abgebrochen wurde, wird ueber 283*cdf0e10cSrcweir // NewDataRead ein Continue mit dem uebergeben Token angesteossen. 284*cdf0e10cSrcweir SaveState( nToken ); 285*cdf0e10cSrcweir eState = SVPAR_PENDING; 286*cdf0e10cSrcweir } 287*cdf0e10cSrcweir } 288*cdf0e10cSrcweir } 289*cdf0e10cSrcweir 290*cdf0e10cSrcweir sal_Bool SfxHTMLParser::GetFileDownloadMIME( String& rMIME ) 291*cdf0e10cSrcweir { 292*cdf0e10cSrcweir return pDLMedium && pDLMedium->GetErrorCode()==0 && 293*cdf0e10cSrcweir pDLMedium->GetMIMEAndRedirect(rMIME)==0; 294*cdf0e10cSrcweir } 295*cdf0e10cSrcweir 296*cdf0e10cSrcweir sal_Bool SfxHTMLParser::FinishFileDownload( String& rStr ) 297*cdf0e10cSrcweir { 298*cdf0e10cSrcweir String aStr; 299*cdf0e10cSrcweir 300*cdf0e10cSrcweir sal_Bool bOK = pDLMedium && pDLMedium->GetErrorCode()==0; 301*cdf0e10cSrcweir if( bOK ) 302*cdf0e10cSrcweir { 303*cdf0e10cSrcweir SvStream* pStream = pDLMedium->GetInStream(); 304*cdf0e10cSrcweir DBG_ASSERT( pStream, "Kein In-Stream vom Medium erhalten" ); 305*cdf0e10cSrcweir 306*cdf0e10cSrcweir SvMemoryStream aStream; 307*cdf0e10cSrcweir if( pStream ) // HACK wegen #65563# 308*cdf0e10cSrcweir aStream << *pStream; 309*cdf0e10cSrcweir 310*cdf0e10cSrcweir aStream.Seek( STREAM_SEEK_TO_END ); 311*cdf0e10cSrcweir DBG_ASSERT( aStream.Tell() < STRING_MAXLEN, 312*cdf0e10cSrcweir "File zu lang fuer einen String, Ende abgeschnitten" ); 313*cdf0e10cSrcweir xub_StrLen nLen = aStream.Tell() < STRING_MAXLEN 314*cdf0e10cSrcweir ? (xub_StrLen)aStream.Tell() 315*cdf0e10cSrcweir : STRING_MAXLEN; 316*cdf0e10cSrcweir 317*cdf0e10cSrcweir // TODO: untested!!! 318*cdf0e10cSrcweir rtl_TextEncoding eEnc = 319*cdf0e10cSrcweir GetExtendedCompatibilityTextEncoding( RTL_TEXTENCODING_ISO_8859_1 ); 320*cdf0e10cSrcweir String sMime; 321*cdf0e10cSrcweir if( pDLMedium->GetMIMEAndRedirect( sMime ) == 0 ) 322*cdf0e10cSrcweir { 323*cdf0e10cSrcweir rtl_TextEncoding eMimeEnc = GetEncodingByMIME( sMime ); 324*cdf0e10cSrcweir if( RTL_TEXTENCODING_DONTKNOW != eMimeEnc ) 325*cdf0e10cSrcweir eEnc = eMimeEnc; 326*cdf0e10cSrcweir } 327*cdf0e10cSrcweir 328*cdf0e10cSrcweir ByteString sBuffer; 329*cdf0e10cSrcweir sal_Char* pBuffer = sBuffer.AllocBuffer(nLen); 330*cdf0e10cSrcweir aStream.Seek( 0 ); 331*cdf0e10cSrcweir aStream.Read((void*)pBuffer, nLen); 332*cdf0e10cSrcweir rStr = String( S2U(pBuffer) ); 333*cdf0e10cSrcweir } 334*cdf0e10cSrcweir 335*cdf0e10cSrcweir delete pDLMedium; 336*cdf0e10cSrcweir pDLMedium = 0; 337*cdf0e10cSrcweir 338*cdf0e10cSrcweir return bOK; 339*cdf0e10cSrcweir } 340*cdf0e10cSrcweir 341*cdf0e10cSrcweir IMPL_STATIC_LINK( SfxHTMLParser, FileDownloadDone, void*, EMPTYARG ) 342*cdf0e10cSrcweir { 343*cdf0e10cSrcweir // Der Download ist jetzt abgeschlossen. Ausserdem muss/darf der 344*cdf0e10cSrcweir // Data-Available-Link wieder durchgelassen werden. 345*cdf0e10cSrcweir pThis->SetDownloadingFile( sal_False ); 346*cdf0e10cSrcweir 347*cdf0e10cSrcweir // ... und einmal aufrufen, damit weitergelesen wird. 348*cdf0e10cSrcweir pThis->CallAsyncCallLink(); 349*cdf0e10cSrcweir 350*cdf0e10cSrcweir return 0; 351*cdf0e10cSrcweir } 352*cdf0e10cSrcweir 353*cdf0e10cSrcweir void SfxHTMLParser::GetScriptType_Impl( SvKeyValueIterator *pHTTPHeader ) 354*cdf0e10cSrcweir { 355*cdf0e10cSrcweir aScriptType = DEFINE_CONST_UNICODE(SVX_MACRO_LANGUAGE_JAVASCRIPT); 356*cdf0e10cSrcweir eScriptType = JAVASCRIPT; 357*cdf0e10cSrcweir if( pHTTPHeader ) 358*cdf0e10cSrcweir { 359*cdf0e10cSrcweir SvKeyValue aKV; 360*cdf0e10cSrcweir for( sal_Bool bCont = pHTTPHeader->GetFirst( aKV ); bCont; 361*cdf0e10cSrcweir bCont = pHTTPHeader->GetNext( aKV ) ) 362*cdf0e10cSrcweir { 363*cdf0e10cSrcweir if( aKV.GetKey().EqualsIgnoreCaseAscii( 364*cdf0e10cSrcweir OOO_STRING_SVTOOLS_HTML_META_content_script_type ) ) 365*cdf0e10cSrcweir { 366*cdf0e10cSrcweir if( aKV.GetValue().Len() ) 367*cdf0e10cSrcweir { 368*cdf0e10cSrcweir String aTmp( aKV.GetValue() ); 369*cdf0e10cSrcweir if( aTmp.EqualsIgnoreCaseAscii( sHTML_MIME_text, 0, 5 ) ) 370*cdf0e10cSrcweir aTmp.Erase( 0, 5 ); 371*cdf0e10cSrcweir else if( aTmp.EqualsIgnoreCaseAscii( sHTML_MIME_application, 372*cdf0e10cSrcweir 0, 12 ) ) 373*cdf0e10cSrcweir aTmp.Erase( 0, 12 ); 374*cdf0e10cSrcweir else 375*cdf0e10cSrcweir break; 376*cdf0e10cSrcweir 377*cdf0e10cSrcweir if( aTmp.EqualsIgnoreCaseAscii( sHTML_MIME_experimental, 0, 378*cdf0e10cSrcweir 2 ) ) 379*cdf0e10cSrcweir { 380*cdf0e10cSrcweir aTmp.Erase( 0, 2 ); 381*cdf0e10cSrcweir } 382*cdf0e10cSrcweir 383*cdf0e10cSrcweir if( aTmp.EqualsIgnoreCaseAscii( OOO_STRING_SVTOOLS_HTML_LG_starbasic ) ) 384*cdf0e10cSrcweir { 385*cdf0e10cSrcweir eScriptType = STARBASIC; 386*cdf0e10cSrcweir aScriptType = DEFINE_CONST_UNICODE(SVX_MACRO_LANGUAGE_STARBASIC); 387*cdf0e10cSrcweir } 388*cdf0e10cSrcweir if( !aTmp.EqualsIgnoreCaseAscii( OOO_STRING_SVTOOLS_HTML_LG_javascript ) ) 389*cdf0e10cSrcweir { 390*cdf0e10cSrcweir eScriptType = EXTENDED_STYPE; 391*cdf0e10cSrcweir aScriptType = aTmp; 392*cdf0e10cSrcweir } 393*cdf0e10cSrcweir } 394*cdf0e10cSrcweir break; 395*cdf0e10cSrcweir } 396*cdf0e10cSrcweir } 397*cdf0e10cSrcweir } 398*cdf0e10cSrcweir } 399*cdf0e10cSrcweir 400*cdf0e10cSrcweir ScriptType SfxHTMLParser::GetScriptType( SvKeyValueIterator *pHTTPHeader ) const 401*cdf0e10cSrcweir { 402*cdf0e10cSrcweir if( !aScriptType.Len() ) 403*cdf0e10cSrcweir ((SfxHTMLParser *)this)->GetScriptType_Impl( pHTTPHeader ); 404*cdf0e10cSrcweir 405*cdf0e10cSrcweir return eScriptType; 406*cdf0e10cSrcweir } 407*cdf0e10cSrcweir 408*cdf0e10cSrcweir const String& SfxHTMLParser::GetScriptTypeString( 409*cdf0e10cSrcweir SvKeyValueIterator *pHTTPHeader ) const 410*cdf0e10cSrcweir { 411*cdf0e10cSrcweir if( !aScriptType.Len() ) 412*cdf0e10cSrcweir ((SfxHTMLParser *)this)->GetScriptType_Impl( pHTTPHeader ); 413*cdf0e10cSrcweir 414*cdf0e10cSrcweir return aScriptType; 415*cdf0e10cSrcweir } 416*cdf0e10cSrcweir 417*cdf0e10cSrcweir double SfxHTMLParser::GetTableDataOptionsValNum( sal_uInt32& nNumForm, 418*cdf0e10cSrcweir LanguageType& eNumLang, const String& aValStr, const String& aNumStr, 419*cdf0e10cSrcweir SvNumberFormatter& rFormatter ) 420*cdf0e10cSrcweir { 421*cdf0e10cSrcweir LanguageType eParseLang = (LanguageType )aNumStr.ToInt32(); 422*cdf0e10cSrcweir sal_uInt32 nParseForm = 423*cdf0e10cSrcweir rFormatter.GetFormatForLanguageIfBuiltIn( 0, eParseLang ); 424*cdf0e10cSrcweir double fVal; 425*cdf0e10cSrcweir rFormatter.IsNumberFormat( aValStr, nParseForm, fVal ); 426*cdf0e10cSrcweir if ( aNumStr.GetTokenCount( ';' ) > 2 ) 427*cdf0e10cSrcweir { 428*cdf0e10cSrcweir eNumLang = (LanguageType)aNumStr.GetToken( 1, ';' ).ToInt32(); 429*cdf0e10cSrcweir xub_StrLen nPos = aNumStr.Search( ';' ); 430*cdf0e10cSrcweir nPos = aNumStr.Search( ';', nPos + 1 ); 431*cdf0e10cSrcweir String aFormat( aNumStr.Copy( nPos + 1 ) ); 432*cdf0e10cSrcweir xub_StrLen nCheckPos; 433*cdf0e10cSrcweir short nType; 434*cdf0e10cSrcweir if ( eNumLang != LANGUAGE_SYSTEM ) 435*cdf0e10cSrcweir rFormatter.PutEntry( aFormat, nCheckPos, nType, nNumForm, eNumLang ); 436*cdf0e10cSrcweir else 437*cdf0e10cSrcweir rFormatter.PutandConvertEntry( aFormat, nCheckPos, nType, nNumForm, 438*cdf0e10cSrcweir eParseLang, eNumLang ); 439*cdf0e10cSrcweir } 440*cdf0e10cSrcweir else 441*cdf0e10cSrcweir { 442*cdf0e10cSrcweir eNumLang = LANGUAGE_SYSTEM; 443*cdf0e10cSrcweir nNumForm = rFormatter.GetFormatForLanguageIfBuiltIn( 0, eNumLang ); 444*cdf0e10cSrcweir } 445*cdf0e10cSrcweir return fVal; 446*cdf0e10cSrcweir } 447*cdf0e10cSrcweir 448