1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- #
- #
- # The Nim Compiler
- # (c) Copyright 2012 Andreas Rumpf
- #
- # See the file "copying.txt", included in this
- # distribution, for details about the copyright.
- #
- # This module implements a new documentation generator that runs after
- # semantic checking.
- import
- options, ast, msgs, passes, docgen, lineinfos, pathutils, packages
- from modulegraphs import ModuleGraph, PPassContext
- type
- TGen = object of PPassContext
- doc: PDoc
- module: PSym
- config: ConfigRef
- PGen = ref TGen
- proc shouldProcess(g: PGen): bool =
- (optWholeProject in g.doc.conf.globalOptions and g.doc.conf.belongsToProjectPackage(g.module)) or
- sfMainModule in g.module.flags or g.config.projectMainIdx == g.module.info.fileIndex
- template closeImpl(body: untyped) {.dirty.} =
- var g = PGen(p)
- let useWarning = sfMainModule notin g.module.flags
- let groupedToc = true
- if shouldProcess(g):
- finishGenerateDoc(g.doc)
- body
- try:
- generateIndex(g.doc)
- except IOError:
- discard
- proc close(graph: ModuleGraph; p: PPassContext, n: PNode): PNode =
- closeImpl:
- writeOutput(g.doc, useWarning, groupedToc)
- proc closeJson(graph: ModuleGraph; p: PPassContext, n: PNode): PNode =
- closeImpl:
- writeOutputJson(g.doc, useWarning)
- proc processNode(c: PPassContext, n: PNode): PNode =
- result = n
- var g = PGen(c)
- if shouldProcess(g):
- generateDoc(g.doc, n, n)
- proc processNodeJson(c: PPassContext, n: PNode): PNode =
- result = n
- var g = PGen(c)
- if shouldProcess(g):
- generateJson(g.doc, n, false)
- template myOpenImpl(ext: untyped) {.dirty.} =
- var g: PGen
- new(g)
- g.module = module
- g.config = graph.config
- var d = newDocumentor(AbsoluteFile toFullPath(graph.config, FileIndex module.position),
- graph.cache, graph.config, ext, module)
- d.hasToc = true
- g.doc = d
- result = g
- proc myOpen(graph: ModuleGraph; module: PSym; idgen: IdGenerator): PPassContext =
- myOpenImpl(HtmlExt)
- proc myOpenTex(graph: ModuleGraph; module: PSym; idgen: IdGenerator): PPassContext =
- myOpenImpl(TexExt)
- proc myOpenJson(graph: ModuleGraph; module: PSym; idgen: IdGenerator): PPassContext =
- myOpenImpl(JsonExt)
- const docgen2Pass* = makePass(open = myOpen, process = processNode, close = close)
- const docgen2TexPass* = makePass(open = myOpenTex, process = processNode,
- close = close)
- const docgen2JsonPass* = makePass(open = myOpenJson, process = processNodeJson,
- close = closeJson)
- proc finishDoc2Pass*(project: string) =
- discard
|