author | zecke <zecke> | 2004-01-09 19:13:35 (UTC) |
---|---|---|
committer | zecke <zecke> | 2004-01-09 19:13:35 (UTC) |
commit | 56bb9961db1158250bbfe971f4556b56c0bd6581 (patch) (unidiff) | |
tree | a4f40da98f695b5aadd845b68aaab41ac3d81826 /development/translation/shared/metatranslator.cpp | |
parent | 6875988077013544246ae0df7cc2e5d538a7f152 (diff) | |
download | opie-56bb9961db1158250bbfe971f4556b56c0bd6581.zip opie-56bb9961db1158250bbfe971f4556b56c0bd6581.tar.gz opie-56bb9961db1158250bbfe971f4556b56c0bd6581.tar.bz2 |
Update lupdate and shared to Qt3.3 qt-copy sources
Some special replacement for $$(OPIEDIR) to make ar_* happy
Diffstat (limited to 'development/translation/shared/metatranslator.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r-- | development/translation/shared/metatranslator.cpp | 34 |
1 files changed, 22 insertions, 12 deletions
diff --git a/development/translation/shared/metatranslator.cpp b/development/translation/shared/metatranslator.cpp index a01e1eb..51270c5 100644 --- a/development/translation/shared/metatranslator.cpp +++ b/development/translation/shared/metatranslator.cpp | |||
@@ -1,30 +1,36 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qt Linguist. | 4 | ** This file is part of Qt Linguist. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** Licensees holding valid Qt Enterprise Edition or Qt Professional Edition | ||
12 | ** licenses may use this file in accordance with the Qt Commercial License | ||
13 | ** Agreement provided with the Software. | ||
14 | ** | ||
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 15 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 16 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 17 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 18 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
19 | ** See http://www.trolltech.com/pricing.html or email sales@trolltech.com for | ||
20 | ** information about Qt Commercial License Agreements. | ||
15 | ** | 21 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 22 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 23 | ** not clear to you. |
18 | ** | 24 | ** |
19 | **********************************************************************/ | 25 | **********************************************************************/ |
20 | 26 | ||
21 | #include "metatranslator.h" | 27 | #include "metatranslator.h" |
22 | 28 | ||
23 | #include <qapplication.h> | 29 | #include <qapplication.h> |
24 | #include <qcstring.h> | 30 | #include <qcstring.h> |
25 | #include <qfile.h> | 31 | #include <qfile.h> |
26 | #include <qmessagebox.h> | 32 | #include <qmessagebox.h> |
27 | #include <qtextcodec.h> | 33 | #include <qtextcodec.h> |
28 | #include <qtextstream.h> | 34 | #include <qtextstream.h> |
29 | #include <qxml.h> | 35 | #include <qxml.h> |
30 | 36 | ||
@@ -125,37 +131,39 @@ bool TsHandler::startElement( const QString& /* namespaceURI */, | |||
125 | bool TsHandler::endElement( const QString& /* namespaceURI */, | 131 | bool TsHandler::endElement( const QString& /* namespaceURI */, |
126 | const QString& /* localName */, | 132 | const QString& /* localName */, |
127 | const QString& qName ) | 133 | const QString& qName ) |
128 | { | 134 | { |
129 | if ( qName == QString("codec") || qName == QString("defaultcodec") ) { | 135 | if ( qName == QString("codec") || qName == QString("defaultcodec") ) { |
130 | // "codec" is a pre-3.0 syntax | 136 | // "codec" is a pre-3.0 syntax |
131 | tor->setCodec( accum ); | 137 | tor->setCodec( accum ); |
132 | } else if ( qName == QString("name") ) { | 138 | } else if ( qName == QString("name") ) { |
133 | context = accum; | 139 | context = accum; |
134 | } else if ( qName == QString("source") ) { | 140 | } else if ( qName == QString("source") ) { |
135 | source = accum; | 141 | source = accum; |
136 | } else if ( qName == QString("comment") ) { | 142 | } else if ( qName == QString("comment") ) { |
137 | if ( inMessage ) { | 143 | if ( inMessage ) { |
138 | comment = accum; | 144 | comment = accum; |
139 | } else { | 145 | } else { |
140 | if ( contextIsUtf8 ) | 146 | if ( contextIsUtf8 ) |
141 | tor->insert( MetaTranslatorMessage(context.utf8(), "", | 147 | tor->insert( MetaTranslatorMessage(context.utf8(), |
148 | ContextComment, | ||
142 | accum.utf8(), QString::null, TRUE, | 149 | accum.utf8(), QString::null, TRUE, |
143 | MetaTranslatorMessage::Unfinished) ); | 150 | MetaTranslatorMessage::Unfinished) ); |
144 | else | 151 | else |
145 | tor->insert( MetaTranslatorMessage(context.ascii(), "", | 152 | tor->insert( MetaTranslatorMessage(context.ascii(), |
153 | ContextComment, | ||
146 | accum.ascii(), QString::null, FALSE, | 154 | accum.ascii(), QString::null, FALSE, |
147 | MetaTranslatorMessage::Unfinished) ); | 155 | MetaTranslatorMessage::Unfinished) ); |
148 | } | 156 | } |
149 | } else if ( qName == QString("translation") ) { | 157 | } else if ( qName == QString("translation") ) { |
150 | translation = accum; | 158 | translation = accum; |
151 | } else if ( qName == QString("message") ) { | 159 | } else if ( qName == QString("message") ) { |
152 | if ( messageIsUtf8 ) | 160 | if ( messageIsUtf8 ) |
153 | tor->insert( MetaTranslatorMessage(context.utf8(), source.utf8(), | 161 | tor->insert( MetaTranslatorMessage(context.utf8(), source.utf8(), |
154 | comment.utf8(), translation, | 162 | comment.utf8(), translation, |
155 | TRUE, type) ); | 163 | TRUE, type) ); |
156 | else | 164 | else |
157 | tor->insert( MetaTranslatorMessage(context.ascii(), source.ascii(), | 165 | tor->insert( MetaTranslatorMessage(context.ascii(), source.ascii(), |
158 | comment.ascii(), translation, | 166 | comment.ascii(), translation, |
159 | FALSE, type) ); | 167 | FALSE, type) ); |
160 | inMessage = FALSE; | 168 | inMessage = FALSE; |
161 | } | 169 | } |
@@ -302,102 +310,103 @@ bool MetaTranslatorMessage::operator==( const MetaTranslatorMessage& m ) const | |||
302 | return qstrcmp( context(), m.context() ) == 0 && | 310 | return qstrcmp( context(), m.context() ) == 0 && |
303 | qstrcmp( sourceText(), m.sourceText() ) == 0 && | 311 | qstrcmp( sourceText(), m.sourceText() ) == 0 && |
304 | qstrcmp( comment(), m.comment() ) == 0; | 312 | qstrcmp( comment(), m.comment() ) == 0; |
305 | } | 313 | } |
306 | 314 | ||
307 | bool MetaTranslatorMessage::operator<( const MetaTranslatorMessage& m ) const | 315 | bool MetaTranslatorMessage::operator<( const MetaTranslatorMessage& m ) const |
308 | { | 316 | { |
309 | int delta = qstrcmp( context(), m.context() ); | 317 | int delta = qstrcmp( context(), m.context() ); |
310 | if ( delta == 0 ) | 318 | if ( delta == 0 ) |
311 | delta = qstrcmp( sourceText(), m.sourceText() ); | 319 | delta = qstrcmp( sourceText(), m.sourceText() ); |
312 | if ( delta == 0 ) | 320 | if ( delta == 0 ) |
313 | delta = qstrcmp( comment(), m.comment() ); | 321 | delta = qstrcmp( comment(), m.comment() ); |
314 | return delta < 0; | 322 | return delta < 0; |
315 | } | 323 | } |
316 | 324 | ||
317 | MetaTranslator::MetaTranslator() | 325 | MetaTranslator::MetaTranslator() |
318 | : codecName( "ISO-8859-1" ), codec( 0 ) | ||
319 | { | 326 | { |
327 | clear(); | ||
320 | } | 328 | } |
321 | 329 | ||
322 | MetaTranslator::MetaTranslator( const MetaTranslator& tor ) | 330 | MetaTranslator::MetaTranslator( const MetaTranslator& tor ) |
323 | : mm( tor.mm ), codecName( tor.codecName ), codec( tor.codec ) | 331 | : mm( tor.mm ), codecName( tor.codecName ), codec( tor.codec ) |
324 | { | 332 | { |
325 | |||
326 | } | 333 | } |
327 | 334 | ||
328 | MetaTranslator& MetaTranslator::operator=( const MetaTranslator& tor ) | 335 | MetaTranslator& MetaTranslator::operator=( const MetaTranslator& tor ) |
329 | { | 336 | { |
330 | mm = tor.mm; | 337 | mm = tor.mm; |
331 | codecName = tor.codecName; | 338 | codecName = tor.codecName; |
332 | codec = tor.codec; | 339 | codec = tor.codec; |
333 | return *this; | 340 | return *this; |
334 | } | 341 | } |
335 | 342 | ||
336 | bool MetaTranslator::load( const QString& filename ) | 343 | void MetaTranslator::clear() |
337 | { | 344 | { |
338 | mm.clear(); | 345 | mm.clear(); |
346 | codecName = "ISO-8859-1"; | ||
347 | codec = 0; | ||
348 | } | ||
339 | 349 | ||
350 | bool MetaTranslator::load( const QString& filename ) | ||
351 | { | ||
340 | QFile f( filename ); | 352 | QFile f( filename ); |
341 | if ( !f.open(IO_ReadOnly) ) | 353 | if ( !f.open(IO_ReadOnly) ) |
342 | return FALSE; | 354 | return FALSE; |
343 | 355 | ||
344 | QTextStream t( &f ); | 356 | QTextStream t( &f ); |
345 | QXmlInputSource in( t ); | 357 | QXmlInputSource in( t ); |
346 | QXmlSimpleReader reader; | 358 | QXmlSimpleReader reader; |
347 | // don't click on these! | ||
348 | reader.setFeature( "http://xml.org/sax/features/namespaces", FALSE ); | 359 | reader.setFeature( "http://xml.org/sax/features/namespaces", FALSE ); |
349 | reader.setFeature( "http://xml.org/sax/features/namespace-prefixes", TRUE ); | 360 | reader.setFeature( "http://xml.org/sax/features/namespace-prefixes", TRUE ); |
350 | reader.setFeature( "http://trolltech.com/xml/features/report-whitespace" | 361 | reader.setFeature( "http://trolltech.com/xml/features/report-whitespace" |
351 | "-only-CharData", FALSE ); | 362 | "-only-CharData", FALSE ); |
352 | QXmlDefaultHandler *hand = new TsHandler( this ); | 363 | QXmlDefaultHandler *hand = new TsHandler( this ); |
353 | reader.setContentHandler( hand ); | 364 | reader.setContentHandler( hand ); |
354 | reader.setErrorHandler( hand ); | 365 | reader.setErrorHandler( hand ); |
355 | 366 | ||
356 | bool ok = reader.parse( in ); | 367 | bool ok = reader.parse( in ); |
357 | reader.setContentHandler( 0 ); | 368 | reader.setContentHandler( 0 ); |
358 | reader.setErrorHandler( 0 ); | 369 | reader.setErrorHandler( 0 ); |
359 | delete hand; | 370 | delete hand; |
360 | f.close(); | 371 | f.close(); |
361 | if ( !ok ) | ||
362 | mm.clear(); | ||
363 | return ok; | 372 | return ok; |
364 | } | 373 | } |
365 | 374 | ||
366 | bool MetaTranslator::save( const QString& filename ) const | 375 | bool MetaTranslator::save( const QString& filename ) const |
367 | { | 376 | { |
368 | QFile f( filename ); | 377 | QFile f( filename ); |
369 | if ( !f.open(IO_WriteOnly) ) | 378 | if ( !f.open(IO_WriteOnly) ) |
370 | return FALSE; | 379 | return FALSE; |
371 | 380 | ||
372 | QTextStream t( &f ); | 381 | QTextStream t( &f ); |
373 | t.setCodec( QTextCodec::codecForName("ISO-8859-1") ); | 382 | t.setCodec( QTextCodec::codecForName("ISO-8859-1") ); |
374 | 383 | ||
375 | t << "<!DOCTYPE TS><TS>\n"; | 384 | t << "<!DOCTYPE TS><TS>\n"; |
376 | if ( codecName != "ISO-8859-1" ) | 385 | if ( codecName != "ISO-8859-1" ) |
377 | t << "<defaultcodec>" << codecName << "</defaultcodec>\n"; | 386 | t << "<defaultcodec>" << codecName << "</defaultcodec>\n"; |
378 | TMM::ConstIterator m = mm.begin(); | 387 | TMM::ConstIterator m = mm.begin(); |
379 | while ( m != mm.end() ) { | 388 | while ( m != mm.end() ) { |
380 | TMMInv inv; | 389 | TMMInv inv; |
381 | TMMInv::Iterator i; | 390 | TMMInv::Iterator i; |
382 | bool contextIsUtf8 = m.key().utf8(); | 391 | bool contextIsUtf8 = m.key().utf8(); |
383 | QCString context = m.key().context(); | 392 | QCString context = m.key().context(); |
384 | QCString comment = ""; | 393 | QCString comment = ""; |
385 | 394 | ||
386 | do { | 395 | do { |
387 | if ( QCString(m.key().sourceText()).isEmpty() ) { | 396 | if ( QCString(m.key().sourceText()) == ContextComment ) { |
388 | if ( m.key().type() != MetaTranslatorMessage::Obsolete ) { | 397 | if ( m.key().type() != MetaTranslatorMessage::Obsolete ) { |
389 | contextIsUtf8 = m.key().utf8(); | 398 | contextIsUtf8 = m.key().utf8(); |
390 | comment = QCString( m.key().comment() ); | 399 | comment = QCString( m.key().comment() ); |
391 | } | 400 | } |
392 | } else { | 401 | } else { |
393 | inv.insert( *m, m.key() ); | 402 | inv.insert( *m, m.key() ); |
394 | } | 403 | } |
395 | } while ( ++m != mm.end() && QCString(m.key().context()) == context ); | 404 | } while ( ++m != mm.end() && QCString(m.key().context()) == context ); |
396 | 405 | ||
397 | t << "<context"; | 406 | t << "<context"; |
398 | if ( contextIsUtf8 ) | 407 | if ( contextIsUtf8 ) |
399 | t << " encoding=\"UTF-8\""; | 408 | t << " encoding=\"UTF-8\""; |
400 | t << ">\n"; | 409 | t << ">\n"; |
401 | t << " <name>" << evilBytes( context, contextIsUtf8 ) | 410 | t << " <name>" << evilBytes( context, contextIsUtf8 ) |
402 | << "</name>\n"; | 411 | << "</name>\n"; |
403 | if ( !comment.isEmpty() ) | 412 | if ( !comment.isEmpty() ) |
@@ -424,33 +433,34 @@ bool MetaTranslator::save( const QString& filename ) const | |||
424 | t << " <translation"; | 433 | t << " <translation"; |
425 | if ( (*i).type() == MetaTranslatorMessage::Unfinished ) | 434 | if ( (*i).type() == MetaTranslatorMessage::Unfinished ) |
426 | t << " type=\"unfinished\""; | 435 | t << " type=\"unfinished\""; |
427 | else if ( (*i).type() == MetaTranslatorMessage::Obsolete ) | 436 | else if ( (*i).type() == MetaTranslatorMessage::Obsolete ) |
428 | t << " type=\"obsolete\""; | 437 | t << " type=\"obsolete\""; |
429 | t << ">" << protect( (*i).translation().utf8() ) | 438 | t << ">" << protect( (*i).translation().utf8() ) |
430 | << "</translation>\n"; | 439 | << "</translation>\n"; |
431 | t << " </message>\n"; | 440 | t << " </message>\n"; |
432 | } | 441 | } |
433 | t << "</context>\n"; | 442 | t << "</context>\n"; |
434 | } | 443 | } |
435 | t << "</TS>\n"; | 444 | t << "</TS>\n"; |
436 | f.close(); | 445 | f.close(); |
437 | return TRUE; | 446 | return TRUE; |
438 | } | 447 | } |
439 | 448 | ||
440 | bool MetaTranslator::release( const QString& filename, bool verbose ) const | 449 | bool MetaTranslator::release( const QString& filename, bool verbose, |
450 | QTranslator::SaveMode mode ) const | ||
441 | { | 451 | { |
442 | QTranslator tor( 0 ); | 452 | QTranslator tor( 0 ); |
443 | int finished = 0; | 453 | int finished = 0; |
444 | int unfinished = 0; | 454 | int unfinished = 0; |
445 | int untranslated = 0; | 455 | int untranslated = 0; |
446 | TMM::ConstIterator m; | 456 | TMM::ConstIterator m; |
447 | 457 | ||
448 | for ( m = mm.begin(); m != mm.end(); ++m ) { | 458 | for ( m = mm.begin(); m != mm.end(); ++m ) { |
449 | if ( m.key().type() != MetaTranslatorMessage::Obsolete ) { | 459 | if ( m.key().type() != MetaTranslatorMessage::Obsolete ) { |
450 | if ( m.key().translation().isEmpty() ) { | 460 | if ( m.key().translation().isEmpty() ) { |
451 | untranslated++; | 461 | untranslated++; |
452 | } else { | 462 | } else { |
453 | if ( m.key().type() == MetaTranslatorMessage::Unfinished ) | 463 | if ( m.key().type() == MetaTranslatorMessage::Unfinished ) |
454 | unfinished++; | 464 | unfinished++; |
455 | else | 465 | else |
456 | finished++; | 466 | finished++; |
@@ -466,33 +476,33 @@ bool MetaTranslator::release( const QString& filename, bool verbose ) const | |||
466 | unless we already dropped the comment of (context, | 476 | unless we already dropped the comment of (context, |
467 | sourceText, comment0). | 477 | sourceText, comment0). |
468 | */ | 478 | */ |
469 | if ( comment.isEmpty() | 479 | if ( comment.isEmpty() |
470 | || contains(context, sourceText, "") | 480 | || contains(context, sourceText, "") |
471 | || !tor.findMessage(context, sourceText, "").translation() | 481 | || !tor.findMessage(context, sourceText, "").translation() |
472 | .isNull() ) { | 482 | .isNull() ) { |
473 | tor.insert( m.key() ); | 483 | tor.insert( m.key() ); |
474 | } else { | 484 | } else { |
475 | tor.insert( QTranslatorMessage(context, sourceText, "", | 485 | tor.insert( QTranslatorMessage(context, sourceText, "", |
476 | translation) ); | 486 | translation) ); |
477 | } | 487 | } |
478 | } | 488 | } |
479 | } | 489 | } |
480 | } | 490 | } |
481 | 491 | ||
482 | bool saved = tor.save( filename, QTranslator::Stripped ); | 492 | bool saved = tor.save( filename, mode ); |
483 | if ( saved && verbose ) | 493 | if ( saved && verbose ) |
484 | fprintf( stderr, | 494 | fprintf( stderr, |
485 | " %d finished, %d unfinished and %d untranslated messages\n", | 495 | " %d finished, %d unfinished and %d untranslated messages\n", |
486 | finished, unfinished, untranslated ); | 496 | finished, unfinished, untranslated ); |
487 | 497 | ||
488 | return saved; | 498 | return saved; |
489 | } | 499 | } |
490 | 500 | ||
491 | bool MetaTranslator::contains( const char *context, const char *sourceText, | 501 | bool MetaTranslator::contains( const char *context, const char *sourceText, |
492 | const char *comment ) const | 502 | const char *comment ) const |
493 | { | 503 | { |
494 | return mm.find( MetaTranslatorMessage(context, sourceText, comment) ) != | 504 | return mm.find( MetaTranslatorMessage(context, sourceText, comment) ) != |
495 | mm.end(); | 505 | mm.end(); |
496 | } | 506 | } |
497 | 507 | ||
498 | void MetaTranslator::insert( const MetaTranslatorMessage& m ) | 508 | void MetaTranslator::insert( const MetaTranslatorMessage& m ) |
@@ -510,33 +520,33 @@ void MetaTranslator::stripObsoleteMessages() | |||
510 | 520 | ||
511 | TMM::Iterator m = mm.begin(); | 521 | TMM::Iterator m = mm.begin(); |
512 | while ( m != mm.end() ) { | 522 | while ( m != mm.end() ) { |
513 | if ( m.key().type() != MetaTranslatorMessage::Obsolete ) | 523 | if ( m.key().type() != MetaTranslatorMessage::Obsolete ) |
514 | newmm.insert( m.key(), *m ); | 524 | newmm.insert( m.key(), *m ); |
515 | ++m; | 525 | ++m; |
516 | } | 526 | } |
517 | mm = newmm; | 527 | mm = newmm; |
518 | } | 528 | } |
519 | 529 | ||
520 | void MetaTranslator::stripEmptyContexts() | 530 | void MetaTranslator::stripEmptyContexts() |
521 | { | 531 | { |
522 | TMM newmm; | 532 | TMM newmm; |
523 | 533 | ||
524 | TMM::Iterator m = mm.begin(); | 534 | TMM::Iterator m = mm.begin(); |
525 | while ( m != mm.end() ) { | 535 | while ( m != mm.end() ) { |
526 | if ( QCString(m.key().sourceText()).isEmpty() ) { | 536 | if ( QCString(m.key().sourceText()) == ContextComment ) { |
527 | TMM::Iterator n = m; | 537 | TMM::Iterator n = m; |
528 | ++n; | 538 | ++n; |
529 | // the context comment is followed by other messages | 539 | // the context comment is followed by other messages |
530 | if ( n != newmm.end() && | 540 | if ( n != newmm.end() && |
531 | qstrcmp(m.key().context(), n.key().context()) == 0 ) | 541 | qstrcmp(m.key().context(), n.key().context()) == 0 ) |
532 | newmm.insert( m.key(), *m ); | 542 | newmm.insert( m.key(), *m ); |
533 | } else { | 543 | } else { |
534 | newmm.insert( m.key(), *m ); | 544 | newmm.insert( m.key(), *m ); |
535 | } | 545 | } |
536 | ++m; | 546 | ++m; |
537 | } | 547 | } |
538 | mm = newmm; | 548 | mm = newmm; |
539 | } | 549 | } |
540 | 550 | ||
541 | void MetaTranslator::setCodec( const char *name ) | 551 | void MetaTranslator::setCodec( const char *name ) |
542 | { | 552 | { |