Blame src/eclipsehelp.cpp

Packit Service 50c9f2
/******************************************************************************
Packit Service 50c9f2
 *
Packit Service 50c9f2
 * Copyright (C) 1997-2015 by Dimitri van Heesch.
Packit Service 50c9f2
 *
Packit Service 50c9f2
 * Permission to use, copy, modify, and distribute this software and its
Packit Service 50c9f2
 * documentation under the terms of the GNU General Public License is hereby 
Packit Service 50c9f2
 * granted. No representations are made about the suitability of this software 
Packit Service 50c9f2
 * for any purpose. It is provided "as is" without express or implied warranty.
Packit Service 50c9f2
 * See the GNU General Public License for more details.
Packit Service 50c9f2
 *
Packit Service 50c9f2
 * Documents produced by Doxygen are derivative works derived from the
Packit Service 50c9f2
 * input used in their production; they are not affected by this license.
Packit Service 50c9f2
 *
Packit Service 50c9f2
 */
Packit Service 50c9f2
#include "eclipsehelp.h"
Packit Service 50c9f2
#include "util.h"
Packit Service 50c9f2
#include "config.h"
Packit Service 50c9f2
#include "message.h"
Packit Service 50c9f2
#include "doxygen.h"
Packit Service 50c9f2
#include <qfile.h>
Packit Service 50c9f2
Packit Service 50c9f2
EclipseHelp::EclipseHelp() : m_depth(0), m_endtag(FALSE), m_openTags(0), m_tocfile(0) 
Packit Service 50c9f2
{
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
EclipseHelp::~EclipseHelp() 
Packit Service 50c9f2
{
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
void EclipseHelp::indent()
Packit Service 50c9f2
{
Packit Service 50c9f2
  int i;
Packit Service 50c9f2
  for (i=0; i
Packit Service 50c9f2
  {
Packit Service 50c9f2
    m_tocstream << "  ";
Packit Service 50c9f2
  }
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
void EclipseHelp::closedTag()
Packit Service 50c9f2
{
Packit Service 50c9f2
  if (m_endtag) 
Packit Service 50c9f2
  {
Packit Service 50c9f2
    m_tocstream << "/>" << endl;
Packit Service 50c9f2
    m_endtag = FALSE;
Packit Service 50c9f2
  }
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
void EclipseHelp::openedTag()
Packit Service 50c9f2
{
Packit Service 50c9f2
  if (m_endtag) 
Packit Service 50c9f2
  {
Packit Service 50c9f2
    m_tocstream << ">" << endl;
Packit Service 50c9f2
    m_endtag = FALSE;
Packit Service 50c9f2
    ++m_openTags;
Packit Service 50c9f2
  }
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
/*!
Packit Service 50c9f2
 * \brief Initialize the Eclipse generator
Packit Service 50c9f2
 *
Packit Service 50c9f2
 * This method opens the XML TOC file and writes headers of the files.
Packit Service 50c9f2
 * \sa finalize()
Packit Service 50c9f2
 */
Packit Service 50c9f2
void EclipseHelp::initialize() 
Packit Service 50c9f2
{
Packit Service 50c9f2
  // -- read path prefix from the configuration
Packit Service 50c9f2
  //m_pathprefix = Config_getString(ECLIPSE_PATHPREFIX);
Packit Service 50c9f2
  //if (m_pathprefix.isEmpty()) m_pathprefix = "html/";
Packit Service 50c9f2
Packit Service 50c9f2
  // -- open the contents file 
Packit Service 50c9f2
  QCString name = Config_getString(HTML_OUTPUT) + "/toc.xml";
Packit Service 50c9f2
  m_tocfile = new QFile(name);
Packit Service 50c9f2
  if (!m_tocfile->open(IO_WriteOnly)) 
Packit Service 50c9f2
  {
Packit Service 50c9f2
    err("Could not open file %s for writing\n", name.data());
Packit Service 50c9f2
    exit(1);
Packit Service 50c9f2
  }
Packit Service 50c9f2
Packit Service 50c9f2
  // -- initialize its text stream
Packit Service 50c9f2
  m_tocstream.setDevice(m_tocfile);
Packit Service 50c9f2
  //m_tocstream.setEncoding(FTextStream::UnicodeUTF8);
Packit Service 50c9f2
Packit Service 50c9f2
  // -- write the opening tag
Packit Service 50c9f2
  QCString title = Config_getString(PROJECT_NAME);
Packit Service 50c9f2
  if (title.isEmpty())
Packit Service 50c9f2
  {
Packit Service 50c9f2
    title = "Doxygen generated documentation";
Packit Service 50c9f2
  }
Packit Service 50c9f2
  m_tocstream << "
Packit Service 50c9f2
              << "\" topic=\"" << convertToXML(m_pathprefix) 
Packit Service 50c9f2
              << "index" << Doxygen::htmlFileExtension << "\">" << endl;
Packit Service 50c9f2
  ++ m_depth;
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
/*!
Packit Service 50c9f2
 * \brief Finish generation of the Eclipse specific help files
Packit Service 50c9f2
 *
Packit Service 50c9f2
 * This method writes footers of the files and closes them.
Packit Service 50c9f2
 * \sa initialize()
Packit Service 50c9f2
 */
Packit Service 50c9f2
void EclipseHelp::finalize() 
Packit Service 50c9f2
{
Packit Service 50c9f2
  closedTag(); // -- close previous tag
Packit Service 50c9f2
Packit Service 50c9f2
  // -- write ending tag 
Packit Service 50c9f2
  --m_depth;
Packit Service 50c9f2
  m_tocstream << "</toc>" << endl;
Packit Service 50c9f2
Packit Service 50c9f2
  // -- close the content file
Packit Service 50c9f2
  m_tocstream.unsetDevice();
Packit Service 50c9f2
  m_tocfile->close();
Packit Service 50c9f2
  delete m_tocfile; m_tocfile = 0;
Packit Service 50c9f2
Packit Service 50c9f2
  QCString name = Config_getString(HTML_OUTPUT) + "/plugin.xml";
Packit Service 50c9f2
  QFile pluginFile(name);
Packit Service 50c9f2
  if (pluginFile.open(IO_WriteOnly))
Packit Service 50c9f2
  {
Packit Service 50c9f2
    QString docId = Config_getString(ECLIPSE_DOC_ID);
Packit Service 50c9f2
    FTextStream t(&pluginFile);
Packit Service 50c9f2
    t << "
Packit Service 50c9f2
    t << "        version=\"1.0.0\" provider-name=\"Doxygen\">" << endl;
Packit Service 50c9f2
    t << "  <extension point=\"org.eclipse.help.toc\">" << endl;
Packit Service 50c9f2
    t << "    <toc file=\"toc.xml\" primary=\"true\" />" << endl;
Packit Service 50c9f2
    t << "  </extension>" << endl;
Packit Service 50c9f2
    t << "</plugin>" << endl;
Packit Service 50c9f2
  }
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
/*!
Packit Service 50c9f2
 * \brief Increase the level of content hierarchy
Packit Service 50c9f2
 */
Packit Service 50c9f2
void EclipseHelp::incContentsDepth() 
Packit Service 50c9f2
{
Packit Service 50c9f2
  openedTag();
Packit Service 50c9f2
  ++m_depth;
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
/*!
Packit Service 50c9f2
 * \brief Decrease the level of content hierarchy
Packit Service 50c9f2
 *
Packit Service 50c9f2
 * It closes currently opened topic tag.
Packit Service 50c9f2
 */
Packit Service 50c9f2
void EclipseHelp::decContentsDepth() 
Packit Service 50c9f2
{
Packit Service 50c9f2
  // -- end of the opened topic
Packit Service 50c9f2
  closedTag();
Packit Service 50c9f2
  --m_depth;
Packit Service 50c9f2
Packit Service 50c9f2
  if (m_openTags==m_depth)
Packit Service 50c9f2
  {
Packit Service 50c9f2
    --m_openTags;
Packit Service 50c9f2
    indent();
Packit Service 50c9f2
    m_tocstream << "</topic>" << endl;
Packit Service 50c9f2
  }
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
/*!
Packit Service 50c9f2
 * \brief Add an item to the content
Packit Service 50c9f2
 *
Packit Service 50c9f2
 * @param isDir Flag whether the argument \a file is a directory or a file entry
Packit Service 50c9f2
 * @param name Name of the item
Packit Service 50c9f2
 * @param ref URL of the item
Packit Service 50c9f2
 * @param file Name of a file which the item is defined in (without extension)
Packit Service 50c9f2
 * @param anchor Name of an anchor of the item.
Packit Service 50c9f2
 * @param separateIndex not used.
Packit Service 50c9f2
 * @param addToNavIndex not used.
Packit Service 50c9f2
 * @param def not used.
Packit Service 50c9f2
 */
Packit Service 50c9f2
void EclipseHelp::addContentsItem(
Packit Service 50c9f2
    bool /* isDir */,
Packit Service 50c9f2
    const char *name,
Packit Service 50c9f2
    const char * /* ref */,
Packit Service 50c9f2
    const char *file,
Packit Service 50c9f2
    const char *anchor,
Packit Service 50c9f2
    bool /* separateIndex */,
Packit Service 50c9f2
    bool /* addToNavIndex */,
Packit Service 50c9f2
    Definition * /*def*/) 
Packit Service 50c9f2
{
Packit Service 50c9f2
  // -- write the topic tag 
Packit Service 50c9f2
  closedTag();
Packit Service 50c9f2
  if (file) 
Packit Service 50c9f2
  { 
Packit Service 50c9f2
    switch (file[0]) // check for special markers (user defined URLs)
Packit Service 50c9f2
    {
Packit Service 50c9f2
      case '^':
Packit Service 50c9f2
        // URL not supported by eclipse toc.xml
Packit Service 50c9f2
	break;
Packit Service 50c9f2
Packit Service 50c9f2
      case '!':
Packit Service 50c9f2
        indent();
Packit Service 50c9f2
        m_tocstream << "
Packit Service 50c9f2
        m_tocstream << " href=\"" << convertToXML(m_pathprefix) << &file[1] << "\"";
Packit Service 50c9f2
        m_endtag = TRUE;
Packit Service 50c9f2
	break;
Packit Service 50c9f2
Packit Service 50c9f2
      default:
Packit Service 50c9f2
        indent();
Packit Service 50c9f2
        m_tocstream << "
Packit Service 50c9f2
        m_tocstream << " href=\"" << convertToXML(m_pathprefix) 
Packit Service 50c9f2
                    << file << Doxygen::htmlFileExtension;
Packit Service 50c9f2
        if (anchor)
Packit Service 50c9f2
        {
Packit Service 50c9f2
          m_tocstream << "#" << anchor;
Packit Service 50c9f2
        }
Packit Service 50c9f2
        m_tocstream << "\"";
Packit Service 50c9f2
        m_endtag = TRUE;
Packit Service 50c9f2
	break;
Packit Service 50c9f2
    }
Packit Service 50c9f2
  }
Packit Service 50c9f2
  else
Packit Service 50c9f2
  {
Packit Service 50c9f2
    indent();
Packit Service 50c9f2
    m_tocstream << "
Packit Service 50c9f2
    m_endtag = TRUE;
Packit Service 50c9f2
  }
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
void EclipseHelp::addIndexItem(
Packit Service 50c9f2
    Definition * /* context */,
Packit Service 50c9f2
    MemberDef * /* md */,
Packit Service 50c9f2
    const char * /* sectionAnchor */,
Packit Service 50c9f2
    const char * /* title */)
Packit Service 50c9f2
{
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
void EclipseHelp::addIndexFile(const char * /* name */) 
Packit Service 50c9f2
{
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
void EclipseHelp::addImageFile(const char * /* name */) 
Packit Service 50c9f2
{
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
void EclipseHelp::addStyleSheetFile(const char * /* name */) 
Packit Service 50c9f2
{
Packit Service 50c9f2
}
Packit Service 50c9f2