/****************************************************************************** * * * * Copyright (C) 1997-2005 by Dimitri van Heesch. * * Permission to use, copy, modify, and distribute this software and its * documentation under the terms of the GNU General Public License is hereby * granted. No representations are made about the suitability of this software * for any purpose. It is provided "as is" without express or implied warranty. * See the GNU General Public License for more details. * * Documents produced by Doxygen are derivative works derived from the * input used in their production; they are not affected by this license. * */ /* This code is based on the work done by the MoxyPyDoxy team * (Linda Leong, Mike Rivera, Kim Truong, and Gabriel Estrada), executed * as part of CS179e (Compiler design project) at the UC Riverside, * under supervision of Peter H. Fröhlic. */ #ifndef PYSCANNER_H #define PYSCANNER_H #include "parserintf.h" /** \brief Python Language parser using state-based lexical scanning. * * This is the Python language parser for doxygen. */ class PythonLanguageScanner : public ParserInterface { public: void parseInput(const char * fileName, const char *fileBuf, Entry *root); bool needsPreprocessing(const QCString &extension); void parseCode(CodeOutputInterface &codeOutIntf, const char *scopeName, const QCString &input, bool isExampleBlock, const char *exampleName=0, FileDef *fileDef=0, int startLine=-1, int endLine=-1, bool inlineFragment=FALSE, MemberDef *memberDef=0 ); void resetCodeParserState(); void parsePrototype(const char *text); }; #endif