icinga2/lib/config/configcompiler.hpp

178 lines
5.6 KiB
C++
Raw Normal View History

2012-05-31 09:14:44 +02:00
/******************************************************************************
* Icinga 2 *
2018-01-02 12:06:00 +01:00
* Copyright (C) 2012-2018 Icinga Development Team (https://www.icinga.com/) *
2012-05-31 09:14:44 +02:00
* *
* This program is free software; you can redistribute it and/or *
* modify it under the terms of the GNU General Public License *
* as published by the Free Software Foundation; either version 2 *
* of the License, or (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the Free Software Foundation *
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. *
******************************************************************************/
#ifndef CONFIGCOMPILER_H
#define CONFIGCOMPILER_H
2012-05-31 08:45:02 +02:00
2014-05-25 16:23:35 +02:00
#include "config/i2-config.hpp"
#include "config/expression.hpp"
#include "base/debuginfo.hpp"
2014-05-25 16:23:35 +02:00
#include "base/registry.hpp"
#include "base/initialize.hpp"
#include "base/singleton.hpp"
#include <future>
#include <iostream>
#include <stack>
2013-03-16 21:18:53 +01:00
typedef union YYSTYPE YYSTYPE;
typedef void *yyscan_t;
namespace icinga
{
struct CompilerDebugInfo
2012-05-31 09:14:44 +02:00
{
const char *Path;
int FirstLine;
int FirstColumn;
int LastLine;
int LastColumn;
operator DebugInfo() const
{
DebugInfo di;
di.Path = Path;
di.FirstLine = FirstLine;
di.FirstColumn = FirstColumn;
di.LastLine = LastLine;
di.LastColumn = LastColumn;
return di;
}
};
2012-05-31 09:14:44 +02:00
struct EItemInfo
{
bool SideEffect;
CompilerDebugInfo DebugInfo;
};
enum FlowControlType
{
FlowControlReturn = 1,
FlowControlContinue = 2,
FlowControlBreak = 4
};
struct ZoneFragment
{
String Tag;
String Path;
};
2012-09-17 14:47:43 +02:00
/**
* The configuration compiler can be used to compile a configuration file
2012-09-19 12:32:39 +02:00
* into a number of configuration items.
2012-09-17 14:47:43 +02:00
*
* @ingroup config
*/
2017-12-31 07:22:16 +01:00
class ConfigCompiler
2012-05-31 08:45:02 +02:00
{
public:
explicit ConfigCompiler(String path, std::istream *input,
String zone = String(), String package = String());
virtual ~ConfigCompiler();
2012-05-31 08:45:02 +02:00
std::unique_ptr<Expression> Compile();
2012-05-31 10:16:32 +02:00
static std::unique_ptr<Expression>CompileStream(const String& path, std::istream *stream,
const String& zone = String(), const String& package = String());
static std::unique_ptr<Expression>CompileFile(const String& path, const String& zone = String(),
const String& package = String());
static std::unique_ptr<Expression>CompileText(const String& path, const String& text,
const String& zone = String(), const String& package = String());
static void AddIncludeSearchDir(const String& dir);
const char *GetPath() const;
void SetZone(const String& zone);
String GetZone() const;
2017-12-13 12:54:14 +01:00
void SetPackage(const String& package);
String GetPackage() const;
void AddImport(const std::shared_ptr<Expression>& import);
std::vector<std::shared_ptr<Expression> > GetImports() const;
static void CollectIncludes(std::vector<std::unique_ptr<Expression> >& expressions,
const String& file, const String& zone, const String& package);
static std::unique_ptr<Expression> HandleInclude(const String& relativeBase, const String& path, bool search,
const String& zone, const String& package, const DebugInfo& debuginfo = DebugInfo());
static std::unique_ptr<Expression> HandleIncludeRecursive(const String& relativeBase, const String& path,
const String& pattern, const String& zone, const String& package, const DebugInfo& debuginfo = DebugInfo());
static std::unique_ptr<Expression> HandleIncludeZones(const String& relativeBase, const String& tag,
const String& path, const String& pattern, const String& package, const DebugInfo& debuginfo = DebugInfo());
2012-05-31 09:43:46 +02:00
size_t ReadInput(char *buffer, size_t max_bytes);
void *GetScanner() const;
2012-05-31 08:45:02 +02:00
static std::vector<ZoneFragment> GetZoneDirs(const String& zone);
static void RegisterZoneDir(const String& tag, const String& ppath, const String& zoneName);
static bool HasZoneConfigAuthority(const String& zoneName);
2012-05-31 08:45:02 +02:00
private:
std::promise<std::shared_ptr<Expression> > m_Promise;
String m_Path;
2013-03-16 21:18:53 +01:00
std::istream *m_Input;
String m_Zone;
String m_Package;
std::vector<std::shared_ptr<Expression> > m_Imports;
2012-05-31 09:43:46 +02:00
void *m_Scanner;
static std::vector<String> m_IncludeSearchDirs;
static boost::mutex m_ZoneDirsMutex;
static std::map<String, std::vector<ZoneFragment> > m_ZoneDirs;
void InitializeScanner();
void DestroyScanner();
static void HandleIncludeZone(const String& relativeBase, const String& tag, const String& path, const String& pattern, const String& package, std::vector<std::unique_ptr<Expression> >& expressions);
static bool IsAbsolutePath(const String& path);
public:
bool m_Eof;
int m_OpenBraces;
2012-05-31 09:43:46 +02:00
std::ostringstream m_LexBuffer;
CompilerDebugInfo m_LocationBegin;
std::stack<bool> m_IgnoreNewlines;
std::stack<bool> m_Apply;
std::stack<bool> m_ObjectAssign;
std::stack<bool> m_SeenAssign;
std::stack<bool> m_SeenIgnore;
std::stack<Expression *> m_Assign;
std::stack<Expression *> m_Ignore;
std::stack<String> m_FKVar;
std::stack<String> m_FVVar;
std::stack<Expression *> m_FTerm;
std::stack<int> m_FlowControlInfo;
2012-05-31 08:45:02 +02:00
};
2012-05-31 09:14:44 +02:00
}
#endif /* CONFIGCOMPILER_H */