Blame src/pagedef.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
Packit Service 50c9f2
#include <qregexp.h>
Packit Service 50c9f2
Packit Service 50c9f2
#include "pagedef.h"
Packit Service 50c9f2
#include "groupdef.h"
Packit Service 50c9f2
#include "docparser.h"
Packit Service 50c9f2
#include "config.h"
Packit Service 50c9f2
#include "util.h"
Packit Service 50c9f2
#include "outputlist.h"
Packit Service 50c9f2
#include "doxygen.h"
Packit Service 50c9f2
#include "language.h"
Packit Service 50c9f2
#include "namespacedef.h"
Packit Service 50c9f2
#include "reflist.h"
Packit Service 50c9f2
Packit Service 50c9f2
PageDef::PageDef(const char *f,int l,const char *n,
Packit Service 50c9f2
                 const char *d,const char *t)
Packit Service 50c9f2
 : Definition(f,l,1,n), m_title(t)
Packit Service 50c9f2
{
Packit Service 50c9f2
  setDocumentation(d,f,l);
Packit Service 50c9f2
  m_subPageDict = new PageSDict(7);
Packit Service 50c9f2
  m_pageScope = 0;
Packit Service 50c9f2
  m_nestingLevel = 0;
Packit Service 50c9f2
  m_fileName = ::convertNameToFile(n,FALSE,TRUE);
Packit Service 50c9f2
  m_showToc = FALSE;
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
PageDef::~PageDef()
Packit Service 50c9f2
{
Packit Service 50c9f2
  delete m_subPageDict;
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
void PageDef::findSectionsInDocumentation()
Packit Service 50c9f2
{
Packit Service 50c9f2
  docFindSections(documentation(),this,0,docFile());
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
GroupDef *PageDef::getGroupDef() const 
Packit Service 50c9f2
{ 
Packit Service 50c9f2
  GroupList *groups = partOfGroups();
Packit Service 50c9f2
  return groups!=0 ? groups->getFirst() : 0; 
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
QCString PageDef::getOutputFileBase() const 
Packit Service 50c9f2
{ 
Packit Service 50c9f2
  if (getGroupDef()) 
Packit Service 50c9f2
    return getGroupDef()->getOutputFileBase();
Packit Service 50c9f2
  else 
Packit Service 50c9f2
    return m_fileName; 
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
void PageDef::setFileName(const char *name)
Packit Service 50c9f2
{
Packit Service 50c9f2
  m_fileName = name;
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
void PageDef::addInnerCompound(Definition *def)
Packit Service 50c9f2
{
Packit Service 50c9f2
  if (def->definitionType()==Definition::TypePage)
Packit Service 50c9f2
  {
Packit Service 50c9f2
    PageDef *pd = (PageDef*)def;
Packit Service 50c9f2
    m_subPageDict->append(pd->name(),pd);
Packit Service 50c9f2
    def->setOuterScope(this);
Packit Service 50c9f2
    if (this==Doxygen::mainPage)
Packit Service 50c9f2
    {
Packit Service 50c9f2
      pd->setNestingLevel(m_nestingLevel);
Packit Service 50c9f2
    }
Packit Service 50c9f2
    else
Packit Service 50c9f2
    {
Packit Service 50c9f2
      pd->setNestingLevel(m_nestingLevel+1);
Packit Service 50c9f2
    }
Packit Service 50c9f2
  }
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
bool PageDef::hasParentPage() const
Packit Service 50c9f2
{
Packit Service 50c9f2
  return getOuterScope() && 
Packit Service 50c9f2
         getOuterScope()->definitionType()==Definition::TypePage;
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
void PageDef::writeTagFile(FTextStream &tagFile)
Packit Service 50c9f2
{
Packit Service 50c9f2
  bool found = name()=="citelist";
Packit Service 50c9f2
  QDictIterator<RefList> rli(*Doxygen::xrefLists);
Packit Service 50c9f2
  RefList *rl;
Packit Service 50c9f2
  for (rli.toFirst();(rl=rli.current()) && !found;++rli)
Packit Service 50c9f2
  {
Packit Service 50c9f2
    if (rl->listName()==name())
Packit Service 50c9f2
    {
Packit Service 50c9f2
      found=TRUE;
Packit Service 50c9f2
      break;
Packit Service 50c9f2
    }
Packit Service 50c9f2
  }
Packit Service 50c9f2
  if (!found) // not one of the generated related pages
Packit Service 50c9f2
  {
Packit Service 50c9f2
    tagFile << "  <compound kind=\"page\">" << endl;
Packit Service 50c9f2
    tagFile << "    <name>" << name() << "</name>" << endl;
Packit Service 50c9f2
    tagFile << "    <title>" << convertToXML(title()) << "</title>" << endl;
Packit Service 50c9f2
    tagFile << "    <filename>" << convertToXML(getOutputFileBase()) << "</filename>" << endl;
Packit Service 50c9f2
    writeDocAnchorsToTagFile(tagFile);
Packit Service 50c9f2
    tagFile << "  </compound>" << endl;
Packit Service 50c9f2
  }
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
void PageDef::writeDocumentation(OutputList &ol)
Packit Service 50c9f2
{
Packit Service 50c9f2
  static bool generateTreeView = Config_getBool(GENERATE_TREEVIEW);
Packit Service 50c9f2
Packit Service 50c9f2
  //outputList->disable(OutputGenerator::Man);
Packit Service 50c9f2
  QCString pageName,manPageName;
Packit Service 50c9f2
  pageName    = escapeCharsInString(name(),FALSE,TRUE);
Packit Service 50c9f2
  manPageName = escapeCharsInString(name(),TRUE,TRUE);
Packit Service 50c9f2
Packit Service 50c9f2
  //printf("PageDef::writeDocumentation: %s\n",getOutputFileBase().data());
Packit Service 50c9f2
Packit Service 50c9f2
  ol.pushGeneratorState();
Packit Service 50c9f2
  //1.{ 
Packit Service 50c9f2
Packit Service 50c9f2
  if (m_nestingLevel>0 
Packit Service 50c9f2
      //&& // a sub page
Packit Service 50c9f2
      //(Doxygen::mainPage==0 || getOuterScope()!=Doxygen::mainPage) // and not a subpage of the mainpage
Packit Service 50c9f2
     )
Packit Service 50c9f2
  {
Packit Service 50c9f2
    // do not generate sub page output for RTF and LaTeX, as these are
Packit Service 50c9f2
    // part of their parent page
Packit Service 50c9f2
    ol.disableAll();
Packit Service 50c9f2
    ol.enable(OutputGenerator::Man);
Packit Service 50c9f2
    ol.enable(OutputGenerator::Html);
Packit Service 50c9f2
  }
Packit Service 50c9f2
Packit Service 50c9f2
  ol.pushGeneratorState();
Packit Service 50c9f2
  //2.{ 
Packit Service 50c9f2
  ol.disableAllBut(OutputGenerator::Man);
Packit Service 50c9f2
  startFile(ol,getOutputFileBase(),manPageName,title(),HLI_Pages,!generateTreeView);
Packit Service 50c9f2
  ol.enableAll();
Packit Service 50c9f2
  ol.disable(OutputGenerator::Man);
Packit Service 50c9f2
  startFile(ol,getOutputFileBase(),pageName,title(),HLI_Pages,!generateTreeView);
Packit Service 50c9f2
  ol.popGeneratorState();
Packit Service 50c9f2
  //2.} 
Packit Service 50c9f2
Packit Service 50c9f2
  if (!generateTreeView)
Packit Service 50c9f2
  {
Packit Service 50c9f2
    if (getOuterScope()!=Doxygen::globalScope && !Config_getBool(DISABLE_INDEX))
Packit Service 50c9f2
    {
Packit Service 50c9f2
      getOuterScope()->writeNavigationPath(ol);
Packit Service 50c9f2
    }
Packit Service 50c9f2
    ol.endQuickIndices();
Packit Service 50c9f2
  }
Packit Service 50c9f2
  SectionInfo *si=Doxygen::sectionDict->find(name());
Packit Service 50c9f2
Packit Service 50c9f2
  // save old generator state and write title only to Man generator
Packit Service 50c9f2
  ol.pushGeneratorState();
Packit Service 50c9f2
  //2.{
Packit Service 50c9f2
  ol.disableAllBut(OutputGenerator::Man);
Packit Service 50c9f2
  ol.startTitleHead(manPageName);
Packit Service 50c9f2
  ol.endTitleHead(manPageName, manPageName);
Packit Service 50c9f2
  if (si)
Packit Service 50c9f2
  {
Packit Service 50c9f2
    ol.pushGeneratorState();
Packit Service 50c9f2
    ol.disableAllBut(OutputGenerator::Man);
Packit Service 50c9f2
    ol.writeString(" - ");
Packit Service 50c9f2
    ol.popGeneratorState();
Packit Service 50c9f2
Packit Service 50c9f2
    if (si->title != manPageName)
Packit Service 50c9f2
    {
Packit Service 50c9f2
      ol.generateDoc(docFile(),docLine(),this,0,si->title,TRUE,FALSE,0,TRUE,FALSE);
Packit Service 50c9f2
      ol.endSection(si->label,si->type);
Packit Service 50c9f2
    }
Packit Service 50c9f2
  }
Packit Service 50c9f2
  ol.popGeneratorState();
Packit Service 50c9f2
  //2.}
Packit Service 50c9f2
Packit Service 50c9f2
  // for Latex the section is already generated as a chapter in the index!
Packit Service 50c9f2
  ol.pushGeneratorState();
Packit Service 50c9f2
  //2.{
Packit Service 50c9f2
  ol.disable(OutputGenerator::Latex);
Packit Service 50c9f2
  ol.disable(OutputGenerator::RTF);
Packit Service 50c9f2
  ol.disable(OutputGenerator::Man);
Packit Service 50c9f2
  if (!title().isEmpty() && !name().isEmpty() && si!=0)
Packit Service 50c9f2
  {
Packit Service 50c9f2
    //ol.startSection(si->label,si->title,si->type);
Packit Service 50c9f2
    startTitle(ol,getOutputFileBase(),this);
Packit Service 50c9f2
    ol.generateDoc(docFile(),docLine(),this,0,si->title,TRUE,FALSE,0,TRUE,FALSE);
Packit Service 50c9f2
    //stringToSearchIndex(getOutputFileBase(),
Packit Service 50c9f2
    //                    theTranslator->trPage(TRUE,TRUE)+" "+si->title,
Packit Service 50c9f2
    //                    si->title);
Packit Service 50c9f2
    //ol.endSection(si->label,si->type);
Packit Service 50c9f2
    endTitle(ol,getOutputFileBase(),name());
Packit Service 50c9f2
  }
Packit Service 50c9f2
  ol.startContents();
Packit Service 50c9f2
  ol.popGeneratorState();
Packit Service 50c9f2
  //2.}
Packit Service 50c9f2
Packit Service 50c9f2
  if (m_showToc && hasSections())
Packit Service 50c9f2
  {
Packit Service 50c9f2
    writeToc(ol);
Packit Service 50c9f2
  }
Packit Service 50c9f2
Packit Service 50c9f2
  writePageDocumentation(ol);
Packit Service 50c9f2
Packit Service 50c9f2
  if (generateTreeView && getOuterScope()!=Doxygen::globalScope && !Config_getBool(DISABLE_INDEX))
Packit Service 50c9f2
  {
Packit Service 50c9f2
    ol.endContents();
Packit Service 50c9f2
    endFileWithNavPath(getOuterScope(),ol);
Packit Service 50c9f2
  }
Packit Service 50c9f2
  else
Packit Service 50c9f2
  {
Packit Service 50c9f2
    endFile(ol);
Packit Service 50c9f2
  }
Packit Service 50c9f2
Packit Service 50c9f2
  ol.popGeneratorState();
Packit Service 50c9f2
  //1.}
Packit Service 50c9f2
Packit Service 50c9f2
  Doxygen::indexList->addIndexItem(this,0,0,filterTitle(title()));
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
void PageDef::writePageDocumentation(OutputList &ol)
Packit Service 50c9f2
{
Packit Service 50c9f2
Packit Service 50c9f2
  bool markdownEnabled = Doxygen::markdownSupport;
Packit Service 50c9f2
  if (getLanguage()==SrcLangExt_Markdown)
Packit Service 50c9f2
  {
Packit Service 50c9f2
    Doxygen::markdownSupport = TRUE;
Packit Service 50c9f2
  }
Packit Service 50c9f2
Packit Service 50c9f2
  ol.startTextBlock();
Packit Service 50c9f2
  QCString docStr = documentation()+inbodyDocumentation();
Packit Service 50c9f2
  if (hasBriefDescription() && !Doxygen::sectionDict->find(name()))
Packit Service 50c9f2
  {
Packit Service 50c9f2
    ol.pushGeneratorState();
Packit Service 50c9f2
    ol.disableAllBut(OutputGenerator::Man);
Packit Service 50c9f2
    ol.writeString(" - ");
Packit Service 50c9f2
    ol.popGeneratorState();
Packit Service 50c9f2
  }
Packit Service 50c9f2
  ol.generateDoc(
Packit Service 50c9f2
      docFile(),           // fileName
Packit Service 50c9f2
      docLine(),           // startLine
Packit Service 50c9f2
      this,                // context
Packit Service 50c9f2
      0,                   // memberdef
Packit Service 50c9f2
      docStr,              // docStr
Packit Service 50c9f2
      TRUE,                // index words
Packit Service 50c9f2
      FALSE                // not an example
Packit Service 50c9f2
      );
Packit Service 50c9f2
  ol.endTextBlock();
Packit Service 50c9f2
Packit Service 50c9f2
  Doxygen::markdownSupport = markdownEnabled;
Packit Service 50c9f2
Packit Service 50c9f2
  if (hasSubPages())
Packit Service 50c9f2
  {
Packit Service 50c9f2
    // for printed documentation we write subpages as section's of the
Packit Service 50c9f2
    // parent page.
Packit Service 50c9f2
    ol.pushGeneratorState();
Packit Service 50c9f2
    ol.disableAll();
Packit Service 50c9f2
    ol.enable(OutputGenerator::Latex);
Packit Service 50c9f2
    ol.enable(OutputGenerator::RTF);
Packit Service 50c9f2
Packit Service 50c9f2
    PageSDict::Iterator pdi(*m_subPageDict);
Packit Service 50c9f2
    PageDef *subPage=pdi.toFirst();
Packit Service 50c9f2
    for (pdi.toFirst();(subPage=pdi.current());++pdi)
Packit Service 50c9f2
    {
Packit Service 50c9f2
      SectionInfo::SectionType sectionType = SectionInfo::Paragraph;
Packit Service 50c9f2
      switch (m_nestingLevel)
Packit Service 50c9f2
      {
Packit Service 50c9f2
        case  0: sectionType = SectionInfo::Page;          break;
Packit Service 50c9f2
        case  1: sectionType = SectionInfo::Section;       break;
Packit Service 50c9f2
        case  2: sectionType = SectionInfo::Subsection;    break;
Packit Service 50c9f2
        case  3: sectionType = SectionInfo::Subsubsection; break;
Packit Service 50c9f2
        default: sectionType = SectionInfo::Paragraph;     break;
Packit Service 50c9f2
      }
Packit Service 50c9f2
      QCString title = subPage->title();
Packit Service 50c9f2
      if (title.isEmpty()) title = subPage->name();
Packit Service 50c9f2
      ol.startSection(subPage->name(),title,sectionType);
Packit Service 50c9f2
      ol.parseText(title);
Packit Service 50c9f2
      ol.endSection(subPage->name(),sectionType);
Packit Service 50c9f2
      Doxygen::subpageNestingLevel++;
Packit Service 50c9f2
      subPage->writePageDocumentation(ol);
Packit Service 50c9f2
      Doxygen::subpageNestingLevel--;
Packit Service 50c9f2
    }
Packit Service 50c9f2
Packit Service 50c9f2
    ol.popGeneratorState();
Packit Service 50c9f2
  }
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
bool PageDef::visibleInIndex() const
Packit Service 50c9f2
{
Packit Service 50c9f2
  static bool externalPages = Config_getBool(EXTERNAL_PAGES);
Packit Service 50c9f2
  return // not part of a group
Packit Service 50c9f2
         !getGroupDef() && 
Packit Service 50c9f2
         // not an externally defined page
Packit Service 50c9f2
         (!isReference() || externalPages) 
Packit Service 50c9f2
         ;
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
bool PageDef::documentedPage() const
Packit Service 50c9f2
{
Packit Service 50c9f2
   return // not part of a group
Packit Service 50c9f2
          !getGroupDef() && 
Packit Service 50c9f2
          // not an externally defined page
Packit Service 50c9f2
          !isReference();
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
bool PageDef::hasSubPages() const
Packit Service 50c9f2
{
Packit Service 50c9f2
  return m_subPageDict->count()>0;
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
void PageDef::setNestingLevel(int l)
Packit Service 50c9f2
{
Packit Service 50c9f2
  m_nestingLevel = l;
Packit Service 50c9f2
}
Packit Service 50c9f2
Packit Service 50c9f2
void PageDef::setShowToc(bool b)
Packit Service 50c9f2
{
Packit Service 50c9f2
  m_showToc |= b;
Packit Service 50c9f2
}
Packit Service 50c9f2