/* * Copyright (C) 2006-2012 Dynare Team * * This file is part of Dynare. * * Dynare 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 3 of the License, or * (at your option) any later version. * * Dynare 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 Dynare. If not, see . */ #include "Statement.hh" ModFileStructure::ModFileStructure() : check_present(false), steady_present(false), simul_present(false), stoch_simul_present(false), estimation_present(false), osr_present(false), osr_params_present(false), optim_weights_present(false), ramsey_policy_present(false), discretionary_policy_present(false), planner_objective_present(false), order_option(0), bvar_present(false), svar_identification_present(false), identification_present(false), partial_information(false), shocks_present(false), histval_present(false), k_order_solver(false), calibrated_measurement_errors(false), dsge_prior_weight_in_estimated_params(false), dsge_var_calibrated(""), dsge_var_estimated(false), bayesian_irf_present(false), estimation_data_statement_present(false), last_markov_switching_chain(0) { } Statement::~Statement() { } void Statement::checkPass(ModFileStructure &mod_file_struct, WarningConsolidation &warnings) { } void Statement::computingPass() { } NativeStatement::NativeStatement(const string &native_statement_arg) : native_statement(native_statement_arg) { } void NativeStatement::writeOutput(ostream &output, const string &basename) const { output << native_statement << endl; } void OptionsList::writeOutput(ostream &output) const { for (num_options_t::const_iterator it = num_options.begin(); it != num_options.end(); it++) output << "options_." << it->first << " = " << it->second << ";" << endl; for (paired_num_options_t::const_iterator it = paired_num_options.begin(); it != paired_num_options.end(); it++) output << "options_." << it->first << " = [" << it->second.first << "; " << it->second.second << "];" << endl; for (string_options_t::const_iterator it = string_options.begin(); it != string_options.end(); it++) output << "options_." << it->first << " = '" << it->second << "';" << endl; for (date_options_t::const_iterator it = date_options.begin(); it != date_options.end(); it++) output << "options_." << it->first << " = dynDate('" << it->second << "');" << endl; for (symbol_list_options_t::const_iterator it = symbol_list_options.begin(); it != symbol_list_options.end(); it++) it->second.writeOutput("options_." + it->first, output); for (vec_int_options_t::const_iterator it = vector_int_options.begin(); it != vector_int_options.end(); it++) { output << "options_." << it->first << " = "; if (it->second.size() > 1) { output << "["; for (vector::const_iterator viit = it->second.begin(); viit != it->second.end(); viit++) output << *viit << ";"; output << "];" << endl; } else output << it->second.front() << ";" << endl; } } void OptionsList::writeOutput(ostream &output, const string &option_group) const { output << option_group << " = struct();" << endl; for (num_options_t::const_iterator it = num_options.begin(); it != num_options.end(); it++) output << option_group << "." << it->first << " = " << it->second << ";" << endl; for (paired_num_options_t::const_iterator it = paired_num_options.begin(); it != paired_num_options.end(); it++) output << option_group << "." << it->first << " = [" << it->second.first << "; " << it->second.second << "];" << endl; for (string_options_t::const_iterator it = string_options.begin(); it != string_options.end(); it++) output << option_group << "." << it->first << " = '" << it->second << "';" << endl; for (date_options_t::const_iterator it = date_options.begin(); it != date_options.end(); it++) output << option_group << "." << it->first << " = dynDate('" << it->second << "');" << endl; for (symbol_list_options_t::const_iterator it = symbol_list_options.begin(); it != symbol_list_options.end(); it++) it->second.writeOutput(option_group + "." + it->first, output); for (vec_int_options_t::const_iterator it = vector_int_options.begin(); it != vector_int_options.end(); it++) { output << option_group << "." << it->first << " = "; if (it->second.size() > 1) { output << "["; for (vector::const_iterator viit = it->second.begin(); viit != it->second.end(); viit++) output << *viit << ";"; output << "];" << endl; } else output << it->second.front() << ";" << endl; } } void OptionsList::clear() { num_options.clear(); paired_num_options.clear(); string_options.clear(); date_options.clear(); symbol_list_options.clear(); vector_int_options.clear(); }