##// END OF EJS Templates
Work in progress.
Work in progress.

File last commit:

r2:f40b36fd7205 tip default
r2:f40b36fd7205 tip default
Show More
vhdl_scanner.cpp
64 lines | 2.2 KiB | text/x-c | CppLexer
/*------------------------------------------------------------------------------
-- This file is a part of the VHDL Tools Software
-- Copyright (C) 2014, Plasma Physics Laboratory - CNRS
--
-- 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
-------------------------------------------------------------------------------*/
/*-- Author : Alexis Jeandet
-- Mail : alexis.jeandet@member.fsf.org
----------------------------------------------------------------------------*/
#include "vhdl_scanner.h"
#include <QDebug>
VHDL_Tools::vhdl_Scanner::vhdl_Scanner(std::istream *in, const QString &fileName)
: yyFlexLexer(in)
{
this->rootNode = new VHDL_Tools::VHDL_AST_Node(fileName,VHDL_Tools::rootNode);
this->currentNode = rootNode;
this->rootNode->setParent(this->rootNode);
}
VHDL_Tools::vhdl_Scanner::~vhdl_Scanner()
{
delete rootNode;
}
int VHDL_Tools::vhdl_Scanner::scan()
{
return( yylex() );
}
int VHDL_Tools::vhdl_Scanner::newFile(std::istream *in, const QString &fileName,bool trashPreviousTree)
{
switch_streams(in);
if(trashPreviousTree)
delete rootNode;
this->yylineno=1;
this->yycolumn=1;
this->rootNode = new VHDL_Tools::VHDL_AST_Node(fileName,VHDL_Tools::rootNode);
this->currentNode = rootNode;
this->rootNode->setParent(this->rootNode);
return 1;
}
void VHDL_Tools::vhdl_Scanner::appendNode(VHDL_Tools::VHDL_AST_Node *node)
{
node->move(currentNode);
// this->currentNode->childs.append(node);
// node->parent = this->currentNode;
this->currentNode = node;
}