forked from ornladios/ADIOS2
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* Derived Expressions Curl function with correctness test
- Loading branch information
1 parent
d4a80ea
commit e923816
Showing
30 changed files
with
6,174 additions
and
4,506 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
FUNCTION (SETUP_ADIOS_BISON_FLEX_SUB) | ||
|
||
set (BISON_FLEX_PRECOMPILE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/toolkit/derived/parser/pregen-source") | ||
|
||
ADD_CUSTOM_COMMAND(OUTPUT parser.cpp | ||
COMMAND ${CMAKE_COMMAND} -E copy ${BISON_FLEX_PRECOMPILE_DIR}/parser.cpp ${CMAKE_CURRENT_BINARY_DIR} | ||
COMMAND ${CMAKE_COMMAND} -E copy ${BISON_FLEX_PRECOMPILE_DIR}/parser.h ${CMAKE_CURRENT_BINARY_DIR} | ||
COMMAND ${CMAKE_COMMAND} -E copy ${BISON_FLEX_PRECOMPILE_DIR}/location.hh ${CMAKE_CURRENT_BINARY_DIR} | ||
COMMENT "Using pre-generated Bison Output from ${BISON_FLEX_PRECOMPILE_DIR}") | ||
ADD_CUSTOM_COMMAND(OUTPUT lexer.cpp | ||
COMMAND ${CMAKE_COMMAND} -E copy ${BISON_FLEX_PRECOMPILE_DIR}/lexer.cpp ${CMAKE_CURRENT_BINARY_DIR} | ||
COMMENT "Using pre-generated Flex Output from ${BISON_FLEX_PRECOMPILE_DIR}") | ||
|
||
set (BISON_Parser_OUTPUT_SOURCE parser.cpp PARENT_SCOPE) | ||
ENDFUNCTION() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -57,4 +57,4 @@ inline ExpressionOperator get_op(std::string op) { return string_to_op.at(op); } | |
|
||
} | ||
} | ||
#endif | ||
#endif |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,101 @@ | ||
#include "ASTDriver.h" | ||
|
||
namespace adios2 | ||
{ | ||
namespace detail | ||
{ | ||
|
||
using indx_type = std::vector<std::tuple<int, int, int>>; | ||
|
||
ASTDriver::ASTDriver() {} | ||
|
||
ASTDriver::ASTDriver(const std::string input) { ASTDriver::parse(input); } | ||
|
||
ASTDriver::~ASTDriver() | ||
{ | ||
while (holding.size() > 0) | ||
{ | ||
delete holding.top(); | ||
holding.pop(); | ||
} | ||
} | ||
|
||
ASTNode *ASTDriver::getAST() | ||
{ | ||
// TODO: check only one ASTNode remains in holding | ||
// else throw error that parsing failed | ||
resolve(holding.top()); | ||
return holding.top(); | ||
} | ||
|
||
void ASTDriver::resolve(ASTNode *node) | ||
{ | ||
if (!node->get_alias().empty()) | ||
{ | ||
std::tuple<std::string, indx_type> var_info; | ||
var_info = lookup_var(node->get_alias()); | ||
node->set_varname(std::get<0>(var_info)); | ||
node->set_indices(std::get<1>(var_info)); | ||
} | ||
for (ASTNode *subexpr : node->get_subexprs()) | ||
{ | ||
resolve(subexpr); | ||
} | ||
} | ||
|
||
std::tuple<std::string, indx_type> ASTDriver::lookup_var(const std::string alias) | ||
{ | ||
return aliases[alias]; | ||
} | ||
|
||
std::string ASTDriver::lookup_var_name(const std::string alias) | ||
{ | ||
std::tuple<std::string, indx_type> var = aliases[alias]; | ||
return std::get<0>(var); | ||
} | ||
|
||
indx_type ASTDriver::lookup_var_indices(const std::string alias) | ||
{ | ||
std::tuple<std::string, indx_type> var = aliases[alias]; | ||
return std::get<1>(var); | ||
} | ||
|
||
void ASTDriver::add_lookup_entry(std::string alias, std::string var_name, indx_type indices) | ||
{ | ||
aliases.insert({alias, {var_name, indices}}); | ||
} | ||
|
||
void ASTDriver::add_lookup_entry(std::string alias, std::string var_name) | ||
{ | ||
aliases.insert({alias, {var_name, {}}}); | ||
} | ||
|
||
void ASTDriver::createNode(std::string op_name, size_t numsubexprs) | ||
{ | ||
ASTNode *node = new ASTNode(op_name, numsubexprs); | ||
for (size_t i = 1; i <= numsubexprs; ++i) | ||
{ | ||
// TODO: check that holding contains ASTNode(s) | ||
// else throw error that parsing failed | ||
ASTNode *subexpr = holding.top(); | ||
node->insert_subexpr_n(subexpr, numsubexprs - i); | ||
holding.pop(); | ||
} | ||
holding.push(node); | ||
} | ||
|
||
void ASTDriver::createNode(std::string alias) | ||
{ | ||
ASTNode *node = new ASTNode("ALIAS", alias); | ||
holding.push(node); | ||
} | ||
|
||
void ASTDriver::createNode(std::string alias, indx_type indices) | ||
{ | ||
ASTNode *node = new ASTNode("INDEX", indices); | ||
node->pushback_subexpr(new ASTNode("ALIAS", alias)); | ||
holding.push(node); | ||
} | ||
|
||
} | ||
} |
Oops, something went wrong.