kde-extraapps/kdevelop/languages/cpp/parser/rpp/preprocessor.h
2015-07-26 14:23:17 +03:00

83 lines
2.8 KiB
C++

/*
Copyright 2005 Harald Fernengel <harry@kdevelop.org>
Copyright 2006 Hamish Rodda <rodda@kde.org>
Permission to use, copy, modify, distribute, and sell this software and its
documentation for any purpose is hereby granted without fee, provided that
the above copyright notice appear in all copies and that both that
copyright notice and this permission notice appear in supporting
documentation.
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
KDEVELOP TEAM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
#ifndef PREPROCESSOR_H
#define PREPROCESSOR_H
#include <QtCore/QString>
#include <cppparserexport.h>
namespace KDevelop {
class IndexedString;
}
namespace rpp {
class Stream;
class KDEVCPPRPP_EXPORT Preprocessor
{
public:
enum IncludeType {
/// An include specified as being local (eg. "file.h")
IncludeLocal,
/// An include specified as being global (eg. &lt;file.h&gt;)
IncludeGlobal
};
virtual ~Preprocessor();
// QString processString(const QString& string);
/**
* This function is called by the preprocessor whenever
* it encounters an include directive.
*
* This class is permitted to modify \a fileName%; this
* value will be used when marking the file in the preprocessed
* output.
*
* \param fileName name of the source file to include
* \param type the way that the file was requested
* \param skipCurrentPath whether the path fileName was found in should be skipped(gcc extension include_next)
*
* \return a Stream with the appropriate contents to allow
* the file to be #included. Ownership of the Stream is yielded to
* class pp at this point.
*/
virtual Stream* sourceNeeded(QString& fileName, IncludeType type, int sourceLine, bool skipCurrentPath);
/**
* Is called when the header-section ended. The header-section is the top of the file, that consists only if #include, #define, and #ifdef statements, or comments.
* It ends as soon as anything else is found. You can use stream.toEnd() to stop the preprocessing.
* */
virtual void headerSectionEnded(rpp::Stream& stream);
/**
* Is called when a header-guard protection has been detected for the currently processed file
* */
virtual void foundHeaderGuard(rpp::Stream& stream, KDevelop::IndexedString guardName);
};
}
#endif