|
|
|
/* This file is part of KBabel
|
|
|
|
based Copyright (C) 1998, 1999 Torben Weis <weis@kde.org>
|
|
|
|
2002-2003 Stanislav Visnovsky <visnovsky@kde.org>
|
|
|
|
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU Library General Public
|
|
|
|
License as published by the Free Software Foundation; either
|
|
|
|
version 2 of the License, or (at your option) any later version.
|
|
|
|
|
|
|
|
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
|
|
|
|
Library General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Library General Public License
|
|
|
|
along with this library; see the file COPYING.LIB. If not, write to
|
|
|
|
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
|
|
Boston, MA 02110-1301, USA.
|
|
|
|
|
|
|
|
In addition, as a special exception, the copyright holders give
|
|
|
|
permission to link the code of this program with any edition of
|
|
|
|
the TQt library by Trolltech AS, Norway (or with modified versions
|
|
|
|
of TQt that use the same license as TQt), and distribute linked
|
|
|
|
combinations including the two. You must obey the GNU General
|
|
|
|
Public License in all respects for all of the code used other than
|
|
|
|
TQt. If you modify this file, you may extend this exception to
|
|
|
|
your version of the file, but you are not obligated to do so. If
|
|
|
|
you do not wish to do so, delete this exception statement from
|
|
|
|
your version.
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <resources.h>
|
|
|
|
#include "catalogitem.h"
|
|
|
|
#include "catalogsettings.h"
|
|
|
|
#include "main.h"
|
|
|
|
|
|
|
|
#include <tqdom.h>
|
|
|
|
|
|
|
|
#include <kconfig.h>
|
|
|
|
#include <kdebug.h>
|
|
|
|
#include <kgenericfactory.h>
|
|
|
|
#include <klibloader.h>
|
|
|
|
#include <klocale.h>
|
|
|
|
#include <kmessagebox.h>
|
|
|
|
|
|
|
|
/***************************************************
|
|
|
|
*
|
|
|
|
* Factory
|
|
|
|
*
|
|
|
|
***************************************************/
|
|
|
|
|
|
|
|
K_EXPORT_COMPONENT_FACTORY( kbabel_xmltool, KGenericFactory<XMLTool> ( "kbabeldatatool" ) )
|
|
|
|
|
|
|
|
using namespace KBabel;
|
|
|
|
|
|
|
|
XMLTool::XMLTool( TQObject* parent, const char* name, const TQStringList & )
|
|
|
|
: KDataTool( parent, name ), _cache_origin( 0 )
|
|
|
|
{
|
|
|
|
i18n( "what check found errors", "XML tags" );
|
|
|
|
}
|
|
|
|
|
|
|
|
bool XMLTool::run( const TQString& command, void* data, const TQString& datatype, const TQString& mimetype )
|
|
|
|
{
|
|
|
|
if ( command != "validate" )
|
|
|
|
{
|
|
|
|
kdDebug(KBABEL) << "XML Tool does only accept the command 'validate' and 'shortcut'" << endl;
|
|
|
|
kdDebug(KBABEL) << " The commands " << command << " is not accepted" << endl;
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check wether we can accept the data
|
|
|
|
if ( datatype != "CatalogItem" )
|
|
|
|
{
|
|
|
|
kdDebug(KBABEL) << "XML Tool only accepts datatype CatalogItem" << endl;
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( mimetype != "application/x-kbabel-catalogitem" )
|
|
|
|
{
|
|
|
|
kdDebug(KBABEL) << "XML Tool only accepts mimetype application/x-kbabel-catalogitem" << endl;
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if( command == "validate" )
|
|
|
|
{
|
|
|
|
CatalogItem* item = (CatalogItem*)(data);
|
|
|
|
|
|
|
|
if( _cache_origin != item->project() )
|
|
|
|
{
|
|
|
|
_context = item->project()->miscSettings().contextInfo;
|
|
|
|
_cache_origin = item->project();
|
|
|
|
}
|
|
|
|
|
|
|
|
uint correctnessLevel = 0;
|
|
|
|
TQString msgid = item->msgid().first();
|
|
|
|
msgid.replace( "\\\"", "\"" ); // Change '\"' to '"'
|
|
|
|
msgid.replace( TQRegExp( "&(?![a-zA-Z0-9]+;)" ), "&" );
|
|
|
|
msgid.replace( _context, "" );
|
|
|
|
msgid.replace("\n",""); // delete newlines
|
|
|
|
|
|
|
|
if( _levelCache.contains(msgid) )
|
|
|
|
{
|
|
|
|
correctnessLevel = _levelCache[msgid];
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// identify the level of correctness
|
|
|
|
if( isFullyCompliant(msgid) )
|
|
|
|
{
|
|
|
|
correctnessLevel = 0;
|
|
|
|
}
|
|
|
|
else if( isNonCaseCompliant(msgid) )
|
|
|
|
{
|
|
|
|
correctnessLevel = 1;
|
|
|
|
}
|
|
|
|
else if( isNonCaseWithoutCommonCompliant(msgid) )
|
|
|
|
{
|
|
|
|
correctnessLevel = 2;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
correctnessLevel = 3;
|
|
|
|
}
|
|
|
|
|
|
|
|
_levelCache[msgid] = correctnessLevel;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool hasError = false;
|
|
|
|
|
|
|
|
if(!item->isUntranslated())
|
|
|
|
{
|
|
|
|
TQStringList str = item->msgstr(true);
|
|
|
|
for( TQStringList::Iterator form = str.begin() ; form != str.end() ; form++ )
|
|
|
|
{
|
|
|
|
TQString text=(*form);
|
|
|
|
text.replace( "\\\"", "\"" ); // Change '\"' to '"'
|
|
|
|
text.replace( TQRegExp( "&(?![a-zA-Z0-9]+;)" ), "&" );
|
|
|
|
|
|
|
|
// isNonCaseWithoutCommonCompliant can fail
|
|
|
|
// even though higher level checks works
|
|
|
|
// see case 2.
|
|
|
|
switch( correctnessLevel )
|
|
|
|
{
|
|
|
|
case 0: hasError = !isFullyCompliant(text); break;
|
|
|
|
case 1: hasError = !isNonCaseCompliant(text); break;
|
|
|
|
case 2: hasError = !isNonCaseWithoutCommonCompliant(text);
|
|
|
|
if (hasError)
|
|
|
|
{
|
|
|
|
hasError = !isNonCaseCompliant(text) ||
|
|
|
|
!isFullyCompliant(text);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 3: hasError = false; break; // the original is broken
|
|
|
|
default: kdWarning() << "No compliance level, this should not happen" << endl;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if(hasError)
|
|
|
|
{
|
|
|
|
item->appendError( "XML tags" );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
item->removeError( "XML tags" );
|
|
|
|
}
|
|
|
|
|
|
|
|
return !hasError;
|
|
|
|
}
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool XMLTool::isFullyCompliant( const TQString& text)
|
|
|
|
{
|
|
|
|
TQDomDocument doc;
|
|
|
|
return doc.setContent("<para>" + text + "</para>" );
|
|
|
|
}
|
|
|
|
|
|
|
|
bool XMLTool::isNonCaseCompliant( const TQString& text)
|
|
|
|
{
|
|
|
|
TQDomDocument doc;
|
|
|
|
TQString test = text.lower();
|
|
|
|
return doc.setContent("<para>" + test + "</para>" );
|
|
|
|
}
|
|
|
|
|
|
|
|
bool XMLTool::isNonCaseWithoutCommonCompliant( const TQString& text)
|
|
|
|
{
|
|
|
|
TQDomDocument doc;
|
|
|
|
TQString test = text.lower();
|
|
|
|
TQRegExp rx( "(<br>)|(<hr>)|(<p>)||(<\\w+@(\\w+.)*\\w+>)" );
|
|
|
|
test.replace( rx, "" );
|
|
|
|
|
|
|
|
TQString a;
|
|
|
|
do
|
|
|
|
{
|
|
|
|
a = test;
|
|
|
|
test.replace( TQRegExp("<[^_:A-Za-z/]"), "" );
|
|
|
|
} while( a!=test);
|
|
|
|
|
|
|
|
test.replace( TQRegExp("<$"), "" );
|
|
|
|
|
|
|
|
return doc.setContent("<para>" + test + "</para>" );
|
|
|
|
}
|
|
|
|
|
|
|
|
#include "main.moc"
|