#include <config.h>
#include "insetnomencl.h"
#include <config.h>
#include "insetnomencl.h"
#include "dispatchresult.h"
#include "funcrequest.h"
#include "gettext.h"
#include "dispatchresult.h"
#include "funcrequest.h"
#include "gettext.h"
+#include "insetiterator.h"
#include "LaTeXFeatures.h"
#include "metricsinfo.h"
#include "sgml.h"
#include "LaTeXFeatures.h"
#include "metricsinfo.h"
#include "sgml.h"
InsetNomencl::InsetNomencl(InsetCommandParams const & p)
InsetNomencl::InsetNomencl(InsetCommandParams const & p)
- : InsetCommand(p, "nomenclature")
+ : glossary_entry_id(sgml::uniqueID(from_ascii("gloss"))),
+ InsetCommand(p, "nomenclature")
-int InsetNomencl::docbook(Buffer const &, odocstream & os,
- OutputParams const &) const
+int InsetNomencl::docbook(Buffer const & buf, odocstream & os,
+ OutputParams const & params) const
- // FIXME: This does not work, because the entry needs to be put
- // in the glossary.
-#if 0
- os << "<glossentry><glossterm>"
+ os << "<glossterm linkend=\"" << glossary_entry_id << "\">"
<< sgml::escapeString(getParam("symbol"))
<< sgml::escapeString(getParam("symbol"))
- << "</glossterm><glossdef><para>"
- << sgml::escapeString(getParam("description"))
- << "</para></glossdef></glossentry>";
-#endif
+int InsetNomencl::docbookGlossary(odocstream & os) const
+{
+ os << "<glossentry id=\"" << glossary_entry_id << "\">\n"
+ << "<glossterm>"
+ << sgml::escapeString(getParam("symbol"))
+ << "</glossterm>\n"
+ << "<glossdef><para>"
+ << sgml::escapeString(getParam("description"))
+ << "</para></glossdef>\n"
+ <<"</glossentry>\n";
+ return 4;
+}
+
+
void InsetNomencl::validate(LaTeXFeatures & features) const
{
features.require("nomencl");
void InsetNomencl::validate(LaTeXFeatures & features) const
{
features.require("nomencl");
-int InsetPrintNomencl::docbook(Buffer const &, odocstream & os,
- OutputParams const &) const
+int InsetPrintNomencl::docbook(Buffer const & buf, odocstream & os,
+ OutputParams const & params) const
- // FIXME This does not work, we need to define the entries here.
- //os << "<glossary><glossary/>";
- return 0;
+ os << "<glossary>\n";
+ int newlines = 2;
+ for (InsetIterator it = inset_iterator_begin(buf.inset()); it;) {
+ if (it->lyxCode() == InsetBase::NOMENCL_CODE) {
+ newlines += static_cast<InsetNomencl const &>(*it).docbookGlossary(os);
+ ++it;
+ } else if(it->lyxCode() == InsetBase::NOTE_CODE &&
+ static_cast<InsetNote const &>(*it).params().type == InsetNoteParams::Note) {
+ // Don't output anything nested in note insets
+ size_t const depth = it.depth();
+ ++it;
+ while (it.depth() > depth)
+ ++it;
+ } else {
+ ++it;
+ }
+ }
+ os << "</glossary>\n";
+ return newlines;
///
int docbook(Buffer const &, odocstream &,
OutputParams const &) const;
///
int docbook(Buffer const &, odocstream &,
OutputParams const &) const;
+ ///
+ int docbookGlossary(odocstream &) const;
private:
virtual std::auto_ptr<InsetBase> doClone() const {
return std::auto_ptr<InsetBase>(new InsetNomencl(params()));
}
private:
virtual std::auto_ptr<InsetBase> doClone() const {
return std::auto_ptr<InsetBase>(new InsetNomencl(params()));
}
+ /// unique id for this glossary entry for docbook export
+ docstring glossary_entry_id;