blob: 5d7b2953a603ba06c93337828a8913c50007e683 [file] [log] [blame]
/**************************************************************
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (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.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*************************************************************/
// MARKER(update_precomp.py): autogen include statement, do not remove
#include "precompiled_svtools.hxx"
#include <tools/urlobj.hxx>
#include <svl/zformat.hxx>
#include <svl/macitem.hxx>
#include <tools/cachestr.hxx>
#include <vcl/svapp.hxx>
#include <svl/zforlist.hxx>
#include <svtools/htmlout.hxx>
#include <svtools/htmlkywd.hxx>
#include <svtools/imap.hxx>
#include <svtools/imaprect.hxx>
#include <svtools/imapcirc.hxx>
#include <svtools/imappoly.hxx>
#include "svl/urihelper.hxx"
#ifndef RTL_CONSTASCII_STRINGPARAM
#define RTL_CONSTASCII_STRINGPARAM( c ) c, sizeof(c)-1
#endif
#if defined(UNX)
const sal_Char HTMLOutFuncs::sNewLine = '\012';
#else
const sal_Char __FAR_DATA HTMLOutFuncs::sNewLine[] = "\015\012";
#endif
#define TXTCONV_BUFFER_SIZE 20
HTMLOutContext::HTMLOutContext( rtl_TextEncoding eDestEnc )
{
m_eDestEnc = RTL_TEXTENCODING_DONTKNOW == eDestEnc
? gsl_getSystemTextEncoding()
: eDestEnc;
m_hConv = rtl_createUnicodeToTextConverter( eDestEnc );
DBG_ASSERT( m_hConv,
"HTMLOutContext::HTMLOutContext: no converter for source encoding" );
m_hContext = m_hConv ? rtl_createUnicodeToTextContext( m_hConv )
: (rtl_TextToUnicodeContext)1;
}
HTMLOutContext::~HTMLOutContext()
{
rtl_destroyUnicodeToTextContext( m_hConv, m_hContext );
rtl_destroyUnicodeToTextConverter( m_hConv );
}
const sal_Char *lcl_svhtml_GetEntityForChar( sal_Unicode c,
rtl_TextEncoding eDestEnc )
{
const sal_Char* pStr = 0;
// Note: We currently handle special cases for ISO-8859-2 here simply because
// the code was already submitted. But we should also handle other code pages
// as well as the code becomes available.
if( eDestEnc == RTL_TEXTENCODING_ISO_8859_2 || eDestEnc == RTL_TEXTENCODING_MS_1250 )
{
// Don't handle the following characters for Easter European (ISO-8859-2).
switch ( c )
{
case 164: // curren
case 184: // ccedil
case 193: // Aacute
case 194: // Acirc
case 196: // Auml
case 199: // Ccedil
case 201: // Eacute
case 203: // Euml
case 205: // Iacute
case 206: // Icirc
case 211: // Oacute
case 212: // Ocirc
case 214: // Ouml
case 215: // times
case 218: // Uacute
case 220: // Uuml
case 221: // Yacute
case 225: // aacute
case 226: // acirc
case 228: // auml
case 233: // eacute
case 235: // euml
case 237: // iacute
case 238: // icirc
case 243: // oacute
case 244: // ocirc
case 246: // ouml
case 247: // divide
case 250: // uacute
case 252: // uuml
case 253: // yacute
case 352: // Scaron
case 353: // scaron
return pStr;
}
}
// TODO: handle more special cases for other code pages.
switch( c )
{
// case '\x0a': return HTMLOutFuncs::Out_Tag( rStream, OOO_STRING_SVTOOLS_HTML_linebreak );
case '<': pStr = OOO_STRING_SVTOOLS_HTML_C_lt; break;
case '>': pStr = OOO_STRING_SVTOOLS_HTML_C_gt; break;
case '&': pStr = OOO_STRING_SVTOOLS_HTML_C_amp; break;
case '"': pStr = OOO_STRING_SVTOOLS_HTML_C_quot; break;
case 161: pStr = OOO_STRING_SVTOOLS_HTML_S_iexcl; break;
case 162: pStr = OOO_STRING_SVTOOLS_HTML_S_cent; break;
case 163: pStr = OOO_STRING_SVTOOLS_HTML_S_pound; break;
case 164: pStr = OOO_STRING_SVTOOLS_HTML_S_curren; break;
case 165: pStr = OOO_STRING_SVTOOLS_HTML_S_yen; break;
case 166: pStr = OOO_STRING_SVTOOLS_HTML_S_brvbar; break;
case 167: pStr = OOO_STRING_SVTOOLS_HTML_S_sect; break;
case 168: pStr = OOO_STRING_SVTOOLS_HTML_S_uml; break;
case 169: pStr = OOO_STRING_SVTOOLS_HTML_S_copy; break;
case 170: pStr = OOO_STRING_SVTOOLS_HTML_S_ordf; break;
case 171: pStr = OOO_STRING_SVTOOLS_HTML_S_laquo; break;
case 172: pStr = OOO_STRING_SVTOOLS_HTML_S_not; break;
case 174: pStr = OOO_STRING_SVTOOLS_HTML_S_reg; break;
case 175: pStr = OOO_STRING_SVTOOLS_HTML_S_macr; break;
case 176: pStr = OOO_STRING_SVTOOLS_HTML_S_deg; break;
case 177: pStr = OOO_STRING_SVTOOLS_HTML_S_plusmn; break;
case 178: pStr = OOO_STRING_SVTOOLS_HTML_S_sup2; break;
case 179: pStr = OOO_STRING_SVTOOLS_HTML_S_sup3; break;
case 180: pStr = OOO_STRING_SVTOOLS_HTML_S_acute; break;
case 181: pStr = OOO_STRING_SVTOOLS_HTML_S_micro; break;
case 182: pStr = OOO_STRING_SVTOOLS_HTML_S_para; break;
case 183: pStr = OOO_STRING_SVTOOLS_HTML_S_middot; break;
case 184: pStr = OOO_STRING_SVTOOLS_HTML_S_cedil; break;
case 185: pStr = OOO_STRING_SVTOOLS_HTML_S_sup1; break;
case 186: pStr = OOO_STRING_SVTOOLS_HTML_S_ordm; break;
case 187: pStr = OOO_STRING_SVTOOLS_HTML_S_raquo; break;
case 188: pStr = OOO_STRING_SVTOOLS_HTML_S_frac14; break;
case 189: pStr = OOO_STRING_SVTOOLS_HTML_S_frac12; break;
case 190: pStr = OOO_STRING_SVTOOLS_HTML_S_frac34; break;
case 191: pStr = OOO_STRING_SVTOOLS_HTML_S_iquest; break;
case 192: pStr = OOO_STRING_SVTOOLS_HTML_C_Agrave; break;
case 193: pStr = OOO_STRING_SVTOOLS_HTML_C_Aacute; break;
case 194: pStr = OOO_STRING_SVTOOLS_HTML_C_Acirc; break;
case 195: pStr = OOO_STRING_SVTOOLS_HTML_C_Atilde; break;
case 196: pStr = OOO_STRING_SVTOOLS_HTML_C_Auml; break;
case 197: pStr = OOO_STRING_SVTOOLS_HTML_C_Aring; break;
case 198: pStr = OOO_STRING_SVTOOLS_HTML_C_AElig; break;
case 199: pStr = OOO_STRING_SVTOOLS_HTML_C_Ccedil; break;
case 200: pStr = OOO_STRING_SVTOOLS_HTML_C_Egrave; break;
case 201: pStr = OOO_STRING_SVTOOLS_HTML_C_Eacute; break;
case 202: pStr = OOO_STRING_SVTOOLS_HTML_C_Ecirc; break;
case 203: pStr = OOO_STRING_SVTOOLS_HTML_C_Euml; break;
case 204: pStr = OOO_STRING_SVTOOLS_HTML_C_Igrave; break;
case 205: pStr = OOO_STRING_SVTOOLS_HTML_C_Iacute; break;
case 206: pStr = OOO_STRING_SVTOOLS_HTML_C_Icirc; break;
case 207: pStr = OOO_STRING_SVTOOLS_HTML_C_Iuml; break;
case 208: pStr = OOO_STRING_SVTOOLS_HTML_C_ETH; break;
case 209: pStr = OOO_STRING_SVTOOLS_HTML_C_Ntilde; break;
case 210: pStr = OOO_STRING_SVTOOLS_HTML_C_Ograve; break;
case 211: pStr = OOO_STRING_SVTOOLS_HTML_C_Oacute; break;
case 212: pStr = OOO_STRING_SVTOOLS_HTML_C_Ocirc; break;
case 213: pStr = OOO_STRING_SVTOOLS_HTML_C_Otilde; break;
case 214: pStr = OOO_STRING_SVTOOLS_HTML_C_Ouml; break;
case 215: pStr = OOO_STRING_SVTOOLS_HTML_S_times; break;
case 216: pStr = OOO_STRING_SVTOOLS_HTML_C_Oslash; break;
case 217: pStr = OOO_STRING_SVTOOLS_HTML_C_Ugrave; break;
case 218: pStr = OOO_STRING_SVTOOLS_HTML_C_Uacute; break;
case 219: pStr = OOO_STRING_SVTOOLS_HTML_C_Ucirc; break;
case 220: pStr = OOO_STRING_SVTOOLS_HTML_C_Uuml; break;
case 221: pStr = OOO_STRING_SVTOOLS_HTML_C_Yacute; break;
case 222: pStr = OOO_STRING_SVTOOLS_HTML_C_THORN; break;
case 223: pStr = OOO_STRING_SVTOOLS_HTML_C_szlig; break;
case 224: pStr = OOO_STRING_SVTOOLS_HTML_S_agrave; break;
case 225: pStr = OOO_STRING_SVTOOLS_HTML_S_aacute; break;
case 226: pStr = OOO_STRING_SVTOOLS_HTML_S_acirc; break;
case 227: pStr = OOO_STRING_SVTOOLS_HTML_S_atilde; break;
case 228: pStr = OOO_STRING_SVTOOLS_HTML_S_auml; break;
case 229: pStr = OOO_STRING_SVTOOLS_HTML_S_aring; break;
case 230: pStr = OOO_STRING_SVTOOLS_HTML_S_aelig; break;
case 231: pStr = OOO_STRING_SVTOOLS_HTML_S_ccedil; break;
case 232: pStr = OOO_STRING_SVTOOLS_HTML_S_egrave; break;
case 233: pStr = OOO_STRING_SVTOOLS_HTML_S_eacute; break;
case 234: pStr = OOO_STRING_SVTOOLS_HTML_S_ecirc; break;
case 235: pStr = OOO_STRING_SVTOOLS_HTML_S_euml; break;
case 236: pStr = OOO_STRING_SVTOOLS_HTML_S_igrave; break;
case 237: pStr = OOO_STRING_SVTOOLS_HTML_S_iacute; break;
case 238: pStr = OOO_STRING_SVTOOLS_HTML_S_icirc; break;
case 239: pStr = OOO_STRING_SVTOOLS_HTML_S_iuml; break;
case 240: pStr = OOO_STRING_SVTOOLS_HTML_S_eth; break;
case 241: pStr = OOO_STRING_SVTOOLS_HTML_S_ntilde; break;
case 242: pStr = OOO_STRING_SVTOOLS_HTML_S_ograve; break;
case 243: pStr = OOO_STRING_SVTOOLS_HTML_S_oacute; break;
case 244: pStr = OOO_STRING_SVTOOLS_HTML_S_ocirc; break;
case 245: pStr = OOO_STRING_SVTOOLS_HTML_S_otilde; break;
case 246: pStr = OOO_STRING_SVTOOLS_HTML_S_ouml; break;
case 247: pStr = OOO_STRING_SVTOOLS_HTML_S_divide; break;
case 248: pStr = OOO_STRING_SVTOOLS_HTML_S_oslash; break;
case 249: pStr = OOO_STRING_SVTOOLS_HTML_S_ugrave; break;
case 250: pStr = OOO_STRING_SVTOOLS_HTML_S_uacute; break;
case 251: pStr = OOO_STRING_SVTOOLS_HTML_S_ucirc; break;
case 252: pStr = OOO_STRING_SVTOOLS_HTML_S_uuml; break;
case 253: pStr = OOO_STRING_SVTOOLS_HTML_S_yacute; break;
case 254: pStr = OOO_STRING_SVTOOLS_HTML_S_thorn; break;
case 255: pStr = OOO_STRING_SVTOOLS_HTML_S_yuml; break;
case 338: pStr = OOO_STRING_SVTOOLS_HTML_S_OElig; break;
case 339: pStr = OOO_STRING_SVTOOLS_HTML_S_oelig; break;
case 352: pStr = OOO_STRING_SVTOOLS_HTML_S_Scaron; break;
case 353: pStr = OOO_STRING_SVTOOLS_HTML_S_scaron; break;
case 376: pStr = OOO_STRING_SVTOOLS_HTML_S_Yuml; break;
case 402: pStr = OOO_STRING_SVTOOLS_HTML_S_fnof; break;
case 710: pStr = OOO_STRING_SVTOOLS_HTML_S_circ; break;
case 732: pStr = OOO_STRING_SVTOOLS_HTML_S_tilde; break;
// Greek chars are handled later,
// since they should *not* be transformed to entities
// when generating Greek text (== using Greek encoding)
case 8194: pStr = OOO_STRING_SVTOOLS_HTML_S_ensp; break;
case 8195: pStr = OOO_STRING_SVTOOLS_HTML_S_emsp; break;
case 8201: pStr = OOO_STRING_SVTOOLS_HTML_S_thinsp; break;
case 8204: pStr = OOO_STRING_SVTOOLS_HTML_S_zwnj; break;
case 8205: pStr = OOO_STRING_SVTOOLS_HTML_S_zwj; break;
case 8206: pStr = OOO_STRING_SVTOOLS_HTML_S_lrm; break;
case 8207: pStr = OOO_STRING_SVTOOLS_HTML_S_rlm; break;
case 8211: pStr = OOO_STRING_SVTOOLS_HTML_S_ndash; break;
case 8212: pStr = OOO_STRING_SVTOOLS_HTML_S_mdash; break;
case 8216: pStr = OOO_STRING_SVTOOLS_HTML_S_lsquo; break;
case 8217: pStr = OOO_STRING_SVTOOLS_HTML_S_rsquo; break;
case 8218: pStr = OOO_STRING_SVTOOLS_HTML_S_sbquo; break;
case 8220: pStr = OOO_STRING_SVTOOLS_HTML_S_ldquo; break;
case 8221: pStr = OOO_STRING_SVTOOLS_HTML_S_rdquo; break;
case 8222: pStr = OOO_STRING_SVTOOLS_HTML_S_bdquo; break;
case 8224: pStr = OOO_STRING_SVTOOLS_HTML_S_dagger; break;
case 8225: pStr = OOO_STRING_SVTOOLS_HTML_S_Dagger; break;
case 8226: pStr = OOO_STRING_SVTOOLS_HTML_S_bull; break;
case 8230: pStr = OOO_STRING_SVTOOLS_HTML_S_hellip; break;
case 8240: pStr = OOO_STRING_SVTOOLS_HTML_S_permil; break;
case 8242: pStr = OOO_STRING_SVTOOLS_HTML_S_prime; break;
case 8243: pStr = OOO_STRING_SVTOOLS_HTML_S_Prime; break;
case 8249: pStr = OOO_STRING_SVTOOLS_HTML_S_lsaquo; break;
case 8250: pStr = OOO_STRING_SVTOOLS_HTML_S_rsaquo; break;
case 8254: pStr = OOO_STRING_SVTOOLS_HTML_S_oline; break;
case 8260: pStr = OOO_STRING_SVTOOLS_HTML_S_frasl; break;
case 8364: pStr = OOO_STRING_SVTOOLS_HTML_S_euro; break;
case 8465: pStr = OOO_STRING_SVTOOLS_HTML_S_image; break;
case 8472: pStr = OOO_STRING_SVTOOLS_HTML_S_weierp; break;
case 8476: pStr = OOO_STRING_SVTOOLS_HTML_S_real; break;
case 8482: pStr = OOO_STRING_SVTOOLS_HTML_S_trade; break;
case 8501: pStr = OOO_STRING_SVTOOLS_HTML_S_alefsym; break;
case 8592: pStr = OOO_STRING_SVTOOLS_HTML_S_larr; break;
case 8593: pStr = OOO_STRING_SVTOOLS_HTML_S_uarr; break;
case 8594: pStr = OOO_STRING_SVTOOLS_HTML_S_rarr; break;
case 8595: pStr = OOO_STRING_SVTOOLS_HTML_S_darr; break;
case 8596: pStr = OOO_STRING_SVTOOLS_HTML_S_harr; break;
case 8629: pStr = OOO_STRING_SVTOOLS_HTML_S_crarr; break;
case 8656: pStr = OOO_STRING_SVTOOLS_HTML_S_lArr; break;
case 8657: pStr = OOO_STRING_SVTOOLS_HTML_S_uArr; break;
case 8658: pStr = OOO_STRING_SVTOOLS_HTML_S_rArr; break;
case 8659: pStr = OOO_STRING_SVTOOLS_HTML_S_dArr; break;
case 8660: pStr = OOO_STRING_SVTOOLS_HTML_S_hArr; break;
case 8704: pStr = OOO_STRING_SVTOOLS_HTML_S_forall; break;
case 8706: pStr = OOO_STRING_SVTOOLS_HTML_S_part; break;
case 8707: pStr = OOO_STRING_SVTOOLS_HTML_S_exist; break;
case 8709: pStr = OOO_STRING_SVTOOLS_HTML_S_empty; break;
case 8711: pStr = OOO_STRING_SVTOOLS_HTML_S_nabla; break;
case 8712: pStr = OOO_STRING_SVTOOLS_HTML_S_isin; break;
case 8713: pStr = OOO_STRING_SVTOOLS_HTML_S_notin; break;
case 8715: pStr = OOO_STRING_SVTOOLS_HTML_S_ni; break;
case 8719: pStr = OOO_STRING_SVTOOLS_HTML_S_prod; break;
case 8721: pStr = OOO_STRING_SVTOOLS_HTML_S_sum; break;
case 8722: pStr = OOO_STRING_SVTOOLS_HTML_S_minus; break;
case 8727: pStr = OOO_STRING_SVTOOLS_HTML_S_lowast; break;
case 8730: pStr = OOO_STRING_SVTOOLS_HTML_S_radic; break;
case 8733: pStr = OOO_STRING_SVTOOLS_HTML_S_prop; break;
case 8734: pStr = OOO_STRING_SVTOOLS_HTML_S_infin; break;
case 8736: pStr = OOO_STRING_SVTOOLS_HTML_S_ang; break;
case 8743: pStr = OOO_STRING_SVTOOLS_HTML_S_and; break;
case 8744: pStr = OOO_STRING_SVTOOLS_HTML_S_or; break;
case 8745: pStr = OOO_STRING_SVTOOLS_HTML_S_cap; break;
case 8746: pStr = OOO_STRING_SVTOOLS_HTML_S_cup; break;
case 8747: pStr = OOO_STRING_SVTOOLS_HTML_S_int; break;
case 8756: pStr = OOO_STRING_SVTOOLS_HTML_S_there4; break;
case 8764: pStr = OOO_STRING_SVTOOLS_HTML_S_sim; break;
case 8773: pStr = OOO_STRING_SVTOOLS_HTML_S_cong; break;
case 8776: pStr = OOO_STRING_SVTOOLS_HTML_S_asymp; break;
case 8800: pStr = OOO_STRING_SVTOOLS_HTML_S_ne; break;
case 8801: pStr = OOO_STRING_SVTOOLS_HTML_S_equiv; break;
case 8804: pStr = OOO_STRING_SVTOOLS_HTML_S_le; break;
case 8805: pStr = OOO_STRING_SVTOOLS_HTML_S_ge; break;
case 8834: pStr = OOO_STRING_SVTOOLS_HTML_S_sub; break;
case 8835: pStr = OOO_STRING_SVTOOLS_HTML_S_sup; break;
case 8836: pStr = OOO_STRING_SVTOOLS_HTML_S_nsub; break;
case 8838: pStr = OOO_STRING_SVTOOLS_HTML_S_sube; break;
case 8839: pStr = OOO_STRING_SVTOOLS_HTML_S_supe; break;
case 8853: pStr = OOO_STRING_SVTOOLS_HTML_S_oplus; break;
case 8855: pStr = OOO_STRING_SVTOOLS_HTML_S_otimes; break;
case 8869: pStr = OOO_STRING_SVTOOLS_HTML_S_perp; break;
case 8901: pStr = OOO_STRING_SVTOOLS_HTML_S_sdot; break;
case 8968: pStr = OOO_STRING_SVTOOLS_HTML_S_lceil; break;
case 8969: pStr = OOO_STRING_SVTOOLS_HTML_S_rceil; break;
case 8970: pStr = OOO_STRING_SVTOOLS_HTML_S_lfloor; break;
case 8971: pStr = OOO_STRING_SVTOOLS_HTML_S_rfloor; break;
case 9001: pStr = OOO_STRING_SVTOOLS_HTML_S_lang; break;
case 9002: pStr = OOO_STRING_SVTOOLS_HTML_S_rang; break;
case 9674: pStr = OOO_STRING_SVTOOLS_HTML_S_loz; break;
case 9824: pStr = OOO_STRING_SVTOOLS_HTML_S_spades; break;
case 9827: pStr = OOO_STRING_SVTOOLS_HTML_S_clubs; break;
case 9829: pStr = OOO_STRING_SVTOOLS_HTML_S_hearts; break;
case 9830: pStr = OOO_STRING_SVTOOLS_HTML_S_diams; break;
}
// Greek chars: if we do not produce a Greek encoding,
// transform them into entities
if( !pStr &&
( eDestEnc != RTL_TEXTENCODING_ISO_8859_7 ) &&
( eDestEnc != RTL_TEXTENCODING_MS_1253 ) )
{
switch( c )
{
case 913: pStr = OOO_STRING_SVTOOLS_HTML_S_Alpha; break;
case 914: pStr = OOO_STRING_SVTOOLS_HTML_S_Beta; break;
case 915: pStr = OOO_STRING_SVTOOLS_HTML_S_Gamma; break;
case 916: pStr = OOO_STRING_SVTOOLS_HTML_S_Delta; break;
case 917: pStr = OOO_STRING_SVTOOLS_HTML_S_Epsilon; break;
case 918: pStr = OOO_STRING_SVTOOLS_HTML_S_Zeta; break;
case 919: pStr = OOO_STRING_SVTOOLS_HTML_S_Eta; break;
case 920: pStr = OOO_STRING_SVTOOLS_HTML_S_Theta; break;
case 921: pStr = OOO_STRING_SVTOOLS_HTML_S_Iota; break;
case 922: pStr = OOO_STRING_SVTOOLS_HTML_S_Kappa; break;
case 923: pStr = OOO_STRING_SVTOOLS_HTML_S_Lambda; break;
case 924: pStr = OOO_STRING_SVTOOLS_HTML_S_Mu; break;
case 925: pStr = OOO_STRING_SVTOOLS_HTML_S_Nu; break;
case 926: pStr = OOO_STRING_SVTOOLS_HTML_S_Xi; break;
case 927: pStr = OOO_STRING_SVTOOLS_HTML_S_Omicron; break;
case 928: pStr = OOO_STRING_SVTOOLS_HTML_S_Pi; break;
case 929: pStr = OOO_STRING_SVTOOLS_HTML_S_Rho; break;
case 931: pStr = OOO_STRING_SVTOOLS_HTML_S_Sigma; break;
case 932: pStr = OOO_STRING_SVTOOLS_HTML_S_Tau; break;
case 933: pStr = OOO_STRING_SVTOOLS_HTML_S_Upsilon; break;
case 934: pStr = OOO_STRING_SVTOOLS_HTML_S_Phi; break;
case 935: pStr = OOO_STRING_SVTOOLS_HTML_S_Chi; break;
case 936: pStr = OOO_STRING_SVTOOLS_HTML_S_Psi; break;
case 937: pStr = OOO_STRING_SVTOOLS_HTML_S_Omega; break;
case 945: pStr = OOO_STRING_SVTOOLS_HTML_S_alpha; break;
case 946: pStr = OOO_STRING_SVTOOLS_HTML_S_beta; break;
case 947: pStr = OOO_STRING_SVTOOLS_HTML_S_gamma; break;
case 948: pStr = OOO_STRING_SVTOOLS_HTML_S_delta; break;
case 949: pStr = OOO_STRING_SVTOOLS_HTML_S_epsilon; break;
case 950: pStr = OOO_STRING_SVTOOLS_HTML_S_zeta; break;
case 951: pStr = OOO_STRING_SVTOOLS_HTML_S_eta; break;
case 952: pStr = OOO_STRING_SVTOOLS_HTML_S_theta; break;
case 953: pStr = OOO_STRING_SVTOOLS_HTML_S_iota; break;
case 954: pStr = OOO_STRING_SVTOOLS_HTML_S_kappa; break;
case 955: pStr = OOO_STRING_SVTOOLS_HTML_S_lambda; break;
case 956: pStr = OOO_STRING_SVTOOLS_HTML_S_mu; break;
case 957: pStr = OOO_STRING_SVTOOLS_HTML_S_nu; break;
case 958: pStr = OOO_STRING_SVTOOLS_HTML_S_xi; break;
case 959: pStr = OOO_STRING_SVTOOLS_HTML_S_omicron; break;
case 960: pStr = OOO_STRING_SVTOOLS_HTML_S_pi; break;
case 961: pStr = OOO_STRING_SVTOOLS_HTML_S_rho; break;
case 962: pStr = OOO_STRING_SVTOOLS_HTML_S_sigmaf; break;
case 963: pStr = OOO_STRING_SVTOOLS_HTML_S_sigma; break;
case 964: pStr = OOO_STRING_SVTOOLS_HTML_S_tau; break;
case 965: pStr = OOO_STRING_SVTOOLS_HTML_S_upsilon; break;
case 966: pStr = OOO_STRING_SVTOOLS_HTML_S_phi; break;
case 967: pStr = OOO_STRING_SVTOOLS_HTML_S_chi; break;
case 968: pStr = OOO_STRING_SVTOOLS_HTML_S_psi; break;
case 969: pStr = OOO_STRING_SVTOOLS_HTML_S_omega; break;
case 977: pStr = OOO_STRING_SVTOOLS_HTML_S_thetasym;break;
case 978: pStr = OOO_STRING_SVTOOLS_HTML_S_upsih; break;
case 982: pStr = OOO_STRING_SVTOOLS_HTML_S_piv; break;
}
}
return pStr;
}
void lcl_ConvertCharToHTML( sal_Unicode c, ByteString& rDest,
HTMLOutContext& rContext,
String *pNonConvertableChars )
{
DBG_ASSERT( RTL_TEXTENCODING_DONTKNOW != rContext.m_eDestEnc,
"wrong destination encoding" );
const sal_Char *pStr = 0;
switch( c )
{
case 0xA0: // is a hard blank
//!! the TextConverter has a problem with this character - so change it to
// a hard space - that's the same as our 5.2
case 0x2011: // is a hard hyphen
pStr = OOO_STRING_SVTOOLS_HTML_S_nbsp;
break;
case 0xAD: // is a soft hyphen
pStr = OOO_STRING_SVTOOLS_HTML_S_shy;
break;
default:
// There may be an entity for the character.
// The new HTML4 entities above 255 are not used for UTF-8,
// because Netscape 4 does support UTF-8 but does not support
// these entities.
if( c < 128 || RTL_TEXTENCODING_UTF8 != rContext.m_eDestEnc )
pStr = lcl_svhtml_GetEntityForChar( c, rContext.m_eDestEnc );
break;
}
sal_Char cBuffer[TXTCONV_BUFFER_SIZE];
sal_uInt32 nInfo = 0;
sal_Size nSrcChars;
const sal_uInt32 nFlags = RTL_UNICODETOTEXT_FLAGS_NONSPACING_IGNORE|
RTL_UNICODETOTEXT_FLAGS_CONTROL_IGNORE|
RTL_UNICODETOTEXT_FLAGS_UNDEFINED_ERROR|
RTL_UNICODETOTEXT_FLAGS_INVALID_ERROR;
if( pStr )
{
sal_Size nLen = rtl_convertUnicodeToText(
rContext.m_hConv, rContext.m_hContext, &c, 0,
cBuffer, TXTCONV_BUFFER_SIZE,
nFlags|RTL_UNICODETOTEXT_FLAGS_FLUSH,
&nInfo, &nSrcChars );
DBG_ASSERT( (nInfo & (RTL_UNICODETOTEXT_INFO_ERROR|RTL_UNICODETOTEXT_INFO_DESTBUFFERTOSMALL)) == 0, "HTMLOut: error while flushing" );
sal_Char *pBuffer = cBuffer;
while( nLen-- )
rDest += *pBuffer++;
((rDest += '&') += pStr) += ';';
}
else
{
sal_Size nLen = rtl_convertUnicodeToText( rContext.m_hConv,
rContext.m_hContext, &c, 1,
cBuffer, TXTCONV_BUFFER_SIZE,
nFlags,
&nInfo, &nSrcChars );
if( nLen > 0 && (nInfo & (RTL_UNICODETOTEXT_INFO_ERROR|RTL_UNICODETOTEXT_INFO_DESTBUFFERTOSMALL)) == 0 )
{
sal_Char *pBuffer = cBuffer;
while( nLen-- )
rDest += *pBuffer++;
}
else
{
// If the character could not be converted to the destination
// character set, the UNICODE character is exported as character
// entity.
nLen = rtl_convertUnicodeToText(
rContext.m_hConv, rContext.m_hContext, &c, 0,
cBuffer, TXTCONV_BUFFER_SIZE,
nFlags|RTL_UNICODETOTEXT_FLAGS_FLUSH,
&nInfo, &nSrcChars );
DBG_ASSERT( (nInfo & (RTL_UNICODETOTEXT_INFO_ERROR|RTL_UNICODETOTEXT_INFO_DESTBUFFERTOSMALL)) == 0, "HTMLOut: error while flushing" );
sal_Char *pBuffer = cBuffer;
while( nLen-- )
rDest += *pBuffer++;
(((rDest += '&') += '#') +=
ByteString::CreateFromInt64( (sal_uInt32)c )) += ';';
if( pNonConvertableChars &&
STRING_NOTFOUND == pNonConvertableChars->Search( c ) )
pNonConvertableChars->Append( c );
}
}
}
sal_Bool lcl_FlushToAscii( ByteString& rDest, HTMLOutContext& rContext )
{
sal_Unicode c = 0;
sal_Char cBuffer[TXTCONV_BUFFER_SIZE];
sal_uInt32 nInfo = 0;
sal_Size nSrcChars;
const sal_uInt32 nFlags = RTL_UNICODETOTEXT_FLAGS_NONSPACING_IGNORE|
RTL_UNICODETOTEXT_FLAGS_CONTROL_IGNORE|
RTL_UNICODETOTEXT_FLAGS_UNDEFINED_ERROR|
RTL_UNICODETOTEXT_FLAGS_FLUSH|
RTL_UNICODETOTEXT_FLAGS_INVALID_ERROR;
sal_Size nLen = rtl_convertUnicodeToText(
rContext.m_hConv, rContext.m_hContext, &c, 0,
cBuffer, TXTCONV_BUFFER_SIZE, nFlags,
&nInfo, &nSrcChars );
DBG_ASSERT( (nInfo & (RTL_UNICODETOTEXT_INFO_ERROR|RTL_UNICODETOTEXT_INFO_DESTBUFFERTOSMALL)) == 0, "HTMLOut: error while flushing" );
sal_Bool bRet = nLen > 0;
sal_Char *pBuffer = cBuffer;
while( nLen-- )
rDest += *pBuffer++;
return bRet;
}
void HTMLOutFuncs::ConvertStringToHTML( const String& rSrc,
ByteString& rDest,
rtl_TextEncoding eDestEnc,
String *pNonConvertableChars )
{
HTMLOutContext aContext( eDestEnc );
for( sal_uInt32 i=0UL, nLen = rSrc.Len(); i < nLen; i++ )
lcl_ConvertCharToHTML( rSrc.GetChar( (xub_StrLen)i ), rDest, aContext,
pNonConvertableChars );
lcl_FlushToAscii( rDest, aContext );
}
SvStream& HTMLOutFuncs::Out_AsciiTag( SvStream& rStream, const sal_Char *pStr,
sal_Bool bOn, rtl_TextEncoding )
{
sal_Char sStt[3] = "</";
if( bOn )
sStt[1] = 0;
return (rStream << sStt << pStr << '>');
}
SvStream& HTMLOutFuncs::Out_Char( SvStream& rStream, sal_Unicode c,
HTMLOutContext& rContext,
String *pNonConvertableChars )
{
ByteString sOut;
lcl_ConvertCharToHTML( c, sOut, rContext, pNonConvertableChars );
rStream << sOut.GetBuffer();
return rStream;
}
SvStream& HTMLOutFuncs::Out_String( SvStream& rStream, const String& rStr,
rtl_TextEncoding eDestEnc,
String *pNonConvertableChars )
{
HTMLOutContext aContext( eDestEnc );
xub_StrLen nLen = rStr.Len();
for( xub_StrLen n = 0; n < nLen; n++ )
HTMLOutFuncs::Out_Char( rStream, rStr.GetChar( (xub_StrLen)n ),
aContext, pNonConvertableChars );
HTMLOutFuncs::FlushToAscii( rStream, aContext );
return rStream;
}
SvStream& HTMLOutFuncs::FlushToAscii( SvStream& rStream,
HTMLOutContext& rContext )
{
ByteString sOut;
if( lcl_FlushToAscii( sOut, rContext ) )
rStream << sOut.GetBuffer();
return rStream;
}
SvStream& HTMLOutFuncs::Out_Hex( SvStream& rStream, sal_uLong nHex, sal_uInt8 nLen,
rtl_TextEncoding )
{ // in einen Stream aus
sal_Char aNToABuf[] = "0000000000000000";
DBG_ASSERT( nLen < sizeof(aNToABuf), "zu viele Stellen" );
if( nLen>=sizeof(aNToABuf) )
nLen = (sizeof(aNToABuf)-1);
// Pointer an das Bufferende setzen
sal_Char *pStr = aNToABuf + (sizeof(aNToABuf)-1);
for( sal_uInt8 n = 0; n < nLen; ++n )
{
*(--pStr) = (sal_Char)(nHex & 0xf ) + 48;
if( *pStr > '9' )
*pStr += 39;
nHex >>= 4;
}
return rStream << pStr;
}
SvStream& HTMLOutFuncs::Out_Color( SvStream& rStream, const Color& rColor,
rtl_TextEncoding )
{
rStream << "\"#";
if( rColor.GetColor() == COL_AUTO )
{
rStream << "000000";
}
else
{
Out_Hex( rStream, rColor.GetRed(), 2 );
Out_Hex( rStream, rColor.GetGreen(), 2 );
Out_Hex( rStream, rColor.GetBlue(), 2 );
}
rStream << '\"';
return rStream;
}
SvStream& HTMLOutFuncs::Out_ImageMap( SvStream& rStream,
const String& rBaseURL,
const ImageMap& rIMap,
const String& rName,
const HTMLOutEvent *pEventTable,
sal_Bool bOutStarBasic,
const sal_Char *pDelim,
const sal_Char *pIndentArea,
const sal_Char *pIndentMap,
rtl_TextEncoding eDestEnc,
String *pNonConvertableChars )
{
if( RTL_TEXTENCODING_DONTKNOW == eDestEnc )
eDestEnc = gsl_getSystemTextEncoding();
const String& rOutName = rName.Len() ? rName : rIMap.GetName();
DBG_ASSERT( rOutName.Len(), "Kein ImageMap-Name" );
if( !rOutName.Len() )
return rStream;
ByteString sOut( '<' );
sOut.Append( RTL_CONSTASCII_STRINGPARAM(OOO_STRING_SVTOOLS_HTML_map ) );
sOut.Append( ' ' );
sOut.Append( RTL_CONSTASCII_STRINGPARAM(OOO_STRING_SVTOOLS_HTML_O_name) );
sOut.Append( RTL_CONSTASCII_STRINGPARAM("=\"") );
rStream << sOut.GetBuffer();
sOut.Erase();
Out_String( rStream, rOutName, eDestEnc, pNonConvertableChars );
rStream << "\">";
for( sal_uInt16 i=0U; i<rIMap.GetIMapObjectCount(); i++ )
{
const IMapObject* pObj = rIMap.GetIMapObject( i );
DBG_ASSERT( pObj, "Wo ist das ImageMap-Object?" );
if( pObj )
{
const sal_Char *pShape = 0;
ByteString aCoords;
switch( pObj->GetType() )
{
case( IMAP_OBJ_RECTANGLE ):
{
const IMapRectangleObject* pRectObj =
(const IMapRectangleObject *)pObj;
pShape = OOO_STRING_SVTOOLS_HTML_SH_rect;
Rectangle aRect( pRectObj->GetRectangle() );
((((((aCoords =
ByteString::CreateFromInt32(aRect.Left())) += ',')
+= ByteString::CreateFromInt32(aRect.Top())) += ',')
+= ByteString::CreateFromInt32(aRect.Right())) += ',')
+= ByteString::CreateFromInt32(aRect.Bottom());
}
break;
case( IMAP_OBJ_CIRCLE ):
{
const IMapCircleObject* pCirc =
(const IMapCircleObject *)pObj;
pShape= OOO_STRING_SVTOOLS_HTML_SH_circ;
Point aCenter( pCirc->GetCenter() );
long nOff = pCirc->GetRadius();
((((aCoords =
ByteString::CreateFromInt32(aCenter.X())) += ',')
+= ByteString::CreateFromInt32(aCenter.Y())) += ',')
+= ByteString::CreateFromInt32(nOff);
}
break;
case( IMAP_OBJ_POLYGON ):
{
const IMapPolygonObject* pPolyObj =
(const IMapPolygonObject *)pObj;
pShape= OOO_STRING_SVTOOLS_HTML_SH_poly;
Polygon aPoly( pPolyObj->GetPolygon() );
sal_uInt16 nCount = aPoly.GetSize();
if( nCount>0 )
{
const Point& rPoint = aPoly[0];
((aCoords =
ByteString::CreateFromInt32(rPoint.X())) += ',')
+= ByteString::CreateFromInt32(rPoint.Y());
}
for( sal_uInt16 j=1; j<nCount; j++ )
{
const Point& rPoint = aPoly[j];
(((aCoords += ',')
+= ByteString::CreateFromInt32(rPoint.X())) += ',')
+= ByteString::CreateFromInt32(rPoint.Y());
}
}
break;
default:
DBG_ASSERT( pShape, "unbekanntes IMapObject" );
break;
}
if( pShape )
{
if( pDelim )
rStream << pDelim;
if( pIndentArea )
rStream << pIndentArea;
((((((((((sOut = '<') += OOO_STRING_SVTOOLS_HTML_area) += ' ')
+= OOO_STRING_SVTOOLS_HTML_O_shape) += '=') += pShape) += ' ')
+= OOO_STRING_SVTOOLS_HTML_O_coords) += "=\"") += aCoords) += "\" ";
rStream << sOut.GetBuffer();
String aURL( pObj->GetURL() );
if( aURL.Len() && pObj->IsActive() )
{
aURL = URIHelper::simpleNormalizedMakeRelative(
rBaseURL, aURL );
(sOut = OOO_STRING_SVTOOLS_HTML_O_href) += "=\"";
rStream << sOut.GetBuffer();
Out_String( rStream, aURL, eDestEnc, pNonConvertableChars ) << '\"';
}
else
rStream << OOO_STRING_SVTOOLS_HTML_O_nohref;
const String& rObjName = pObj->GetName();
if( rObjName.Len() )
{
((sOut = ' ') += OOO_STRING_SVTOOLS_HTML_O_name) += "=\"";
rStream << sOut.GetBuffer();
Out_String( rStream, rObjName, eDestEnc, pNonConvertableChars ) << '\"';
}
const String& rTarget = pObj->GetTarget();
if( rTarget.Len() && pObj->IsActive() )
{
((sOut = ' ') += OOO_STRING_SVTOOLS_HTML_O_target) += "=\"";
rStream << sOut.GetBuffer();
Out_String( rStream, rTarget, eDestEnc, pNonConvertableChars ) << '\"';
}
String rDesc( pObj->GetAltText() );
if( rDesc.Len() == 0 )
rDesc = pObj->GetDesc();
if( rDesc.Len() )
{
((sOut = ' ') += OOO_STRING_SVTOOLS_HTML_O_alt) += "=\"";
rStream << sOut.GetBuffer();
Out_String( rStream, rDesc, eDestEnc, pNonConvertableChars ) << '\"';
}
const SvxMacroTableDtor& rMacroTab = pObj->GetMacroTable();
if( pEventTable && rMacroTab.Count() )
Out_Events( rStream, rMacroTab, pEventTable,
bOutStarBasic, eDestEnc, pNonConvertableChars );
rStream << '>';
}
}
}
if( pDelim )
rStream << pDelim;
if( pIndentMap )
rStream << pIndentMap;
Out_AsciiTag( rStream, OOO_STRING_SVTOOLS_HTML_map, sal_False );
return rStream;
}
SvStream& HTMLOutFuncs::OutScript( SvStream& rStrm,
const String& rBaseURL,
const String& rSource,
const String& rLanguage,
ScriptType eScriptType,
const String& rSrc,
const String *pSBLibrary,
const String *pSBModule,
rtl_TextEncoding eDestEnc,
String *pNonConvertableChars )
{
if( RTL_TEXTENCODING_DONTKNOW == eDestEnc )
eDestEnc = gsl_getSystemTextEncoding();
// Script wird komplett nicht eingerueckt!
ByteString sOut( '<' );
sOut.Append( RTL_CONSTASCII_STRINGPARAM(OOO_STRING_SVTOOLS_HTML_script) );
if( rLanguage.Len() )
{
sOut.Append( ' ' );
sOut.Append( RTL_CONSTASCII_STRINGPARAM(OOO_STRING_SVTOOLS_HTML_O_language) );
sOut.Append( RTL_CONSTASCII_STRINGPARAM("=\"") );
rStrm << sOut.GetBuffer();
Out_String( rStrm, rLanguage, eDestEnc, pNonConvertableChars );
sOut = '\"';
}
if( rSrc.Len() )
{
((sOut += ' ') += OOO_STRING_SVTOOLS_HTML_O_src) += "=\"";
rStrm << sOut.GetBuffer();
Out_String( rStrm, URIHelper::simpleNormalizedMakeRelative(rBaseURL, rSrc), eDestEnc, pNonConvertableChars );
sOut = '\"';
}
if( STARBASIC != eScriptType && pSBLibrary )
{
((sOut += ' ') += OOO_STRING_SVTOOLS_HTML_O_sdlibrary) += "=\"";
rStrm << sOut.GetBuffer();
Out_String( rStrm, *pSBLibrary, eDestEnc, pNonConvertableChars );
sOut = '\"';
}
if( STARBASIC != eScriptType && pSBModule )
{
((sOut += ' ') += OOO_STRING_SVTOOLS_HTML_O_sdmodule) += "=\"";
rStrm << sOut.GetBuffer();
Out_String( rStrm, *pSBModule, eDestEnc, pNonConvertableChars );
sOut = '\"';
}
sOut += '>';
rStrm << sOut.GetBuffer();
if( rSource.Len() || pSBLibrary || pSBModule )
{
rStrm << sNewLine;
if( JAVASCRIPT != eScriptType )
{
rStrm << "<!--"
<< sNewLine;
}
if( STARBASIC == eScriptType )
{
if( pSBLibrary )
{
sOut.Assign( RTL_CONSTASCII_STRINGPARAM("' ") );
sOut.Append( RTL_CONSTASCII_STRINGPARAM(OOO_STRING_SVTOOLS_HTML_SB_library) );
sOut.Append( ' ' );
ByteString sTmp( *pSBLibrary, eDestEnc );
sOut.Append( sTmp );
rStrm << sOut.GetBuffer() << sNewLine;
}
if( pSBModule )
{
sOut.Assign( RTL_CONSTASCII_STRINGPARAM("' ") );
sOut.Append( RTL_CONSTASCII_STRINGPARAM(OOO_STRING_SVTOOLS_HTML_SB_module) );
sOut.Append( ' ' );
ByteString sTmp( *pSBModule, eDestEnc );
sOut.Append( sTmp );
rStrm << sOut.GetBuffer() << sNewLine;
}
}
if( rSource.Len() )
{
// Wir schreiben das Modul mm ANSI-Zeichensatz, aber mit
// System-Zeilenumbruechen raus.
ByteString sSource( rSource, eDestEnc );
sSource.ConvertLineEnd( GetSystemLineEnd() );
rStrm << sSource.GetBuffer();
}
rStrm << sNewLine;
if( JAVASCRIPT != eScriptType )
{
// MIB/MM: Wenn es kein StarBasic ist, kann ein // natuerlich
// falsch sein. Da der Kommentar aber beim Einlesen wider
// entfernt wird, schickt uns das nicht weiter ...
rStrm << (STARBASIC == eScriptType ? "' -->" : "// -->")
<< sNewLine;
}
}
HTMLOutFuncs::Out_AsciiTag( rStrm, OOO_STRING_SVTOOLS_HTML_script, sal_False );
return rStrm;
}
SvStream& HTMLOutFuncs::Out_Events( SvStream& rStrm,
const SvxMacroTableDtor& rMacroTable,
const HTMLOutEvent *pEventTable,
sal_Bool bOutStarBasic,
rtl_TextEncoding eDestEnc,
String *pNonConvertableChars )
{
sal_uInt16 i=0;
while( pEventTable[i].pBasicName || pEventTable[i].pJavaName )
{
const SvxMacro *pMacro =
rMacroTable.Get( pEventTable[i].nEvent );
if( pMacro && pMacro->GetMacName().Len() &&
( JAVASCRIPT == pMacro->GetScriptType() || bOutStarBasic ))
{
const sal_Char *pStr = STARBASIC == pMacro->GetScriptType()
? pEventTable[i].pBasicName
: pEventTable[i].pJavaName;
if( pStr )
{
ByteString sOut( ' ' );
(sOut += pStr) += "=\"";
rStrm << sOut.GetBuffer();
Out_String( rStrm, pMacro->GetMacName(), eDestEnc, pNonConvertableChars ) << '\"';
}
}
i++;
}
return rStrm;
}
ByteString& HTMLOutFuncs::CreateTableDataOptionsValNum( ByteString& aStrTD,
sal_Bool bValue,
double fVal, sal_uLong nFormat, SvNumberFormatter& rFormatter,
rtl_TextEncoding eDestEnc, String* pNonConvertableChars )
{
if ( bValue )
{
// printf / scanf ist zu ungenau
String aValStr;
rFormatter.GetInputLineString( fVal, 0, aValStr );
ByteString sTmp( aValStr, eDestEnc );
((((aStrTD += ' ') += OOO_STRING_SVTOOLS_HTML_O_SDval) += "=\"") += sTmp) += '\"';
}
if ( bValue || nFormat )
{
((aStrTD += ' ') += OOO_STRING_SVTOOLS_HTML_O_SDnum) += "=\"";
(aStrTD += ByteString::CreateFromInt32(
Application::GetSettings().GetLanguage() ))
+= ';'; // Language fuer Format 0
if ( nFormat )
{
ByteString aNumStr;
LanguageType nLang;
const SvNumberformat* pFormatEntry = rFormatter.GetEntry( nFormat );
if ( pFormatEntry )
{
ConvertStringToHTML( pFormatEntry->GetFormatstring(), aNumStr,
eDestEnc, pNonConvertableChars );
nLang = pFormatEntry->GetLanguage();
}
else
nLang = LANGUAGE_SYSTEM;
((aStrTD += ByteString::CreateFromInt32(nLang)) += ';') += aNumStr;
}
aStrTD += '\"';
}
return aStrTD;
}
sal_Bool HTMLOutFuncs::PrivateURLToInternalImg( String& rURL )
{
if( rURL.Len() > 14UL &&
rURL.CompareToAscii( OOO_STRING_SVTOOLS_HTML_private_image, 14UL ) == COMPARE_EQUAL )
{
rURL.Erase( 0UL, 14UL );
return sal_True;
}
return sal_False;
}