X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2FDEVEL%2Fmathml_editor%2Fsrc%2FCMathMLFactoryXSLTDiff.cc;h=456f383b4911f918a6cc7ba842be5ebbe81532f4;hb=4167cea65ca58897d1a3dbb81ff95de5074700cc;hp=34d628147fae0039264491a9906df6a749170265;hpb=bf14e2772daee20783a7bc32ea3351662e362ae1;p=helm.git diff --git a/helm/DEVEL/mathml_editor/src/CMathMLFactoryXSLTDiff.cc b/helm/DEVEL/mathml_editor/src/CMathMLFactoryXSLTDiff.cc index 34d628147..456f383b4 100644 --- a/helm/DEVEL/mathml_editor/src/CMathMLFactoryXSLTDiff.cc +++ b/helm/DEVEL/mathml_editor/src/CMathMLFactoryXSLTDiff.cc @@ -1,5 +1,33 @@ +/* This file is part of EdiTeX, an editor of mathematical + * expressions based on TeX syntax. + * + * Copyright (C) 2002-2003 Luca Padovani , + * 2003 Paolo Marinelli . + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2.1 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 + * 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 + * + * For more information, please visit the project's home page + * http://helm.cs.unibo.it/editex/ + * or send an email to + */ + +#include +#include #include "dom.hh" +#include "timer.hh" #include "Diff.hh" #include "TNode.hh" #include "TDocument.hh" @@ -24,18 +52,24 @@ CMathMLFactoryXSLTDiff::documentModified(TDocument& doc) dirtyId.push_back(std::make_pair(DOM::GdomeString("id"), DOM::GdomeString("'" + std::string(dirty["id"]) + "'"))); #endif + long t0 = getTimer(); DOM::Document res = style.apply(doc.document()); + long t1 = getTimer(); assert(res); //cout << "*** THE TEX DOCUMENT" << endl; //style.save(doc.document(), stdout); - cout << "*** THE CURRENT DOCUMENT:" << endl; - if (result) style.save(result, stdout); - cout << "*** THE NEW DOCUMENT:" << endl; - style.save(res, stdout); - cout << "*** THE DIFF:" << endl; + //std::cout << "*** THE CURRENT DOCUMENT:" << std::endl; + //if (result) style.save(result, stdout); + //std::cout << "*** THE NEW DOCUMENT:" << std::endl; + //style.save(res, stdout); + //std::cout << "*** THE DIFF:" << std::endl; DOMX::Diff diff = DOMX::Diff::diff(result, res); - style.save(diff.document(), stdout); + //style.save(diff.document(), stdout); + long t2 = getTimer(); diff.patch(); + long t3 = getTimer(); + + //std::cout << "=== APPLY = " << (t1 - t0) / 1000 << " DIFF = " << (t2 - t1) / 1000 << " PATCH = " << (t3 - t2) / 1000 << std::endl; doc.clearDirty(); } @@ -48,7 +82,7 @@ CMathMLFactoryXSLTDiff::subst(const DOM::Element& e1, const DOM::GdomeString& id if (e1.getAttribute("xref") == id) { DOMX::Diff diff = DOMX::Diff::diff(e1, e2); - style.save(diff.document(), stdout); + //style.save(diff.document(), stdout); diff.patch(); return true; }