2012-04-13 01:08:20 +00:00
|
|
|
|
// -*- mode: C++; c-file-style: "cc-mode" -*-
|
2006-08-26 11:35:28 +00:00
|
|
|
|
//*************************************************************************
|
|
|
|
|
// DESCRIPTION: Verilog::Preproc: Preprocess verilog code
|
|
|
|
|
//
|
2008-04-25 12:14:27 +00:00
|
|
|
|
// Code available from: http://www.veripool.org/verilator
|
2006-08-26 11:35:28 +00:00
|
|
|
|
//
|
|
|
|
|
//*************************************************************************
|
|
|
|
|
//
|
2018-01-02 23:05:06 +00:00
|
|
|
|
// Copyright 2000-2018 by Wilson Snyder. This program is free software;
|
2010-02-07 11:40:48 +00:00
|
|
|
|
// you can redistribute it and/or modify it under the terms of either the
|
|
|
|
|
// GNU Lesser General Public License Version 3 or the Perl Artistic License
|
|
|
|
|
// Version 2.0.
|
2006-08-26 11:35:28 +00:00
|
|
|
|
//
|
|
|
|
|
// 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.
|
|
|
|
|
//
|
|
|
|
|
//*************************************************************************
|
|
|
|
|
|
|
|
|
|
#ifndef _V3PREPROC_H_
|
|
|
|
|
#define _V3PREPROC_H_ 1
|
|
|
|
|
|
2006-12-18 19:20:45 +00:00
|
|
|
|
#include "config_build.h"
|
|
|
|
|
#include "verilatedos.h"
|
2006-08-26 11:35:28 +00:00
|
|
|
|
#include "V3Error.h"
|
2014-11-22 16:48:39 +00:00
|
|
|
|
#include "V3FileLine.h"
|
2006-08-26 11:35:28 +00:00
|
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
|
#include <map>
|
2010-04-07 00:20:44 +00:00
|
|
|
|
#include <list>
|
2006-08-26 11:35:28 +00:00
|
|
|
|
#include <iostream>
|
|
|
|
|
|
2010-07-10 22:30:16 +00:00
|
|
|
|
// Compatibility with Verilog-Perl's preprocessor
|
|
|
|
|
#define fatalSrc(msg) v3fatalSrc(msg)
|
|
|
|
|
|
2010-01-20 12:15:51 +00:00
|
|
|
|
class V3InFilter;
|
|
|
|
|
|
2006-08-26 11:35:28 +00:00
|
|
|
|
class V3PreProc {
|
|
|
|
|
// This defines a preprocessor. Functions are virtual so implementation can be hidden.
|
|
|
|
|
// After creating, call open(), then getline() in a loop. The class will to the rest...
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
// STATE
|
|
|
|
|
int m_debug; // Debugging
|
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
// CONSTANTS
|
|
|
|
|
enum MiscConsts {
|
2010-08-10 15:18:53 +00:00
|
|
|
|
DEFINE_RECURSION_LEVEL_MAX = 1000, // How many `def substitutions before an error
|
2010-07-10 22:30:16 +00:00
|
|
|
|
INCLUDE_DEPTH_MAX = 500, // How many `includes deep before an error
|
2012-02-24 02:37:49 +00:00
|
|
|
|
STREAM_DEPTH_LEVEL_MAX = 2000, // How many streams deep (sometimes `def deep) before an error
|
|
|
|
|
// // Set more than DEFINE_RECURSION_LEVEL_MAX or INCLUDE_DEPTH_MAX
|
2010-07-10 22:30:16 +00:00
|
|
|
|
NEWLINES_VS_TICKLINE = 20 // Use `line in place of this many newlines
|
2006-08-26 11:35:28 +00:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// ACCESSORS
|
|
|
|
|
// Insert given file into this point in input stream
|
2010-01-20 12:15:51 +00:00
|
|
|
|
virtual void openFile(FileLine* fileline, V3InFilter* filterp, const string& filename)=0;
|
2006-08-26 11:35:28 +00:00
|
|
|
|
virtual string getline()=0; // Return next line/lines. (Null if done.)
|
|
|
|
|
virtual bool isEof() const =0; // Return true on EOF.
|
|
|
|
|
virtual void insertUnreadback(const string& text) = 0;
|
|
|
|
|
|
|
|
|
|
int debug() const { return m_debug; }
|
|
|
|
|
void debug(int level) { m_debug = level; }
|
|
|
|
|
|
2010-07-10 22:30:16 +00:00
|
|
|
|
FileLine* fileline(); ///< File/Line number for last getline call
|
2006-08-26 11:35:28 +00:00
|
|
|
|
|
|
|
|
|
// CONTROL METHODS
|
|
|
|
|
// These options control how the parsing proceeds
|
2011-08-05 01:15:24 +00:00
|
|
|
|
static int keepComments() { return 2; } // Return comments, 0=no, 1=yes, 2=callback
|
|
|
|
|
static bool keepWhitespace() { return false; }
|
2014-06-07 00:22:20 +00:00
|
|
|
|
static bool lineDirectives() { // Insert `line directives
|
|
|
|
|
return !(v3Global.opt.preprocOnly() && v3Global.opt.preprocNoLine());
|
|
|
|
|
}
|
2011-08-05 01:15:24 +00:00
|
|
|
|
static bool pedantic() { return false; } // Obey standard; Don't substitute `error
|
2006-08-26 11:35:28 +00:00
|
|
|
|
|
|
|
|
|
// CALLBACK METHODS
|
|
|
|
|
// This probably will want to be overridden for given child users of this class.
|
|
|
|
|
virtual void comment(const string& cmt)=0; // Comment detected (if keepComments==2)
|
|
|
|
|
virtual void include(const string& filename)=0; // Request a include file be processed
|
|
|
|
|
|
|
|
|
|
virtual void undef(const string& name)=0; // Remove a definition
|
|
|
|
|
virtual void define(FileLine* fileline, const string& name,
|
2009-12-21 03:26:48 +00:00
|
|
|
|
const string& value, const string& params="", bool cmdline=false)=0; // `define without any parameters
|
|
|
|
|
virtual void defineCmdLine(FileLine* fileline, const string& name,
|
|
|
|
|
const string& value) { // `define without any parameters
|
|
|
|
|
define(fileline, name, value, "", true);
|
|
|
|
|
}
|
2006-08-26 11:35:28 +00:00
|
|
|
|
virtual string removeDefines(const string& text)=0; // Remove defines in a text string
|
|
|
|
|
|
2010-07-10 22:30:16 +00:00
|
|
|
|
// UTILITIES
|
2017-07-07 00:25:59 +00:00
|
|
|
|
void error(const string& msg) { fileline()->v3error(msg); } ///< Report a error
|
|
|
|
|
void fatal(const string& msg) { fileline()->v3fatalSrc(msg); } ///< Report a fatal error
|
2010-07-10 22:30:16 +00:00
|
|
|
|
|
2006-08-26 11:35:28 +00:00
|
|
|
|
protected:
|
|
|
|
|
// CONSTUCTORS
|
2010-07-10 22:30:16 +00:00
|
|
|
|
V3PreProc() {
|
2006-08-26 11:35:28 +00:00
|
|
|
|
m_debug=0;
|
|
|
|
|
};
|
2010-07-10 22:30:16 +00:00
|
|
|
|
void configure(FileLine* fl);
|
2006-08-26 11:35:28 +00:00
|
|
|
|
public:
|
|
|
|
|
static V3PreProc* createPreProc(FileLine* fileline);
|
2009-07-22 18:38:20 +00:00
|
|
|
|
virtual ~V3PreProc() {}
|
2006-08-26 11:35:28 +00:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
#endif // Guard
|