1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109
|
/*$Id: mg_out_root.cc,v 26.81 2008/05/27 05:33:43 al Exp $ -*- C++ -*-
* Copyright (C) 2001 Albert Davis
* Author: Albert Davis <aldavis@gnu.org>
*
* This file is part of "Gnucap", the Gnu Circuit Analysis Package
*
* 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 3, 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 Street, Fifth Floor, Boston, MA
* 02110-1301, USA.
*/
#include "md.h"
#include "mg_out.h"
/*--------------------------------------------------------------------------*/
static void make_header(std::ofstream& out, const File& in,
const std::string& dump_name)
{
out << in.head() <<
"/* This file is automatically generated. DO NOT EDIT */\n"
<< in.cc_headers() <<
"#include \"globals.h\"\n"
"#include \"e_elemnt.h\"\n"
"#include \"" << dump_name << ".h\"\n"
"/*--------------------------------------"
"------------------------------------*/\n"
"const double NA(NOT_INPUT);\n"
"const double INF(BIGBIG);\n"
"/*--------------------------------------"
"------------------------------------*/\n";
}
/*--------------------------------------------------------------------------*/
static void make_tail(std::ofstream& out, const File& in)
{
out << in.cc_direct() <<
"/*--------------------------------------"
"------------------------------------*/\n"
"/*--------------------------------------"
"------------------------------------*/\n";
}
/*--------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------*/
void make_cc_file(const File& in)
{
std::string dump_name = in.name();
{ // chop suffix .model
std::string::size_type loc = dump_name.rfind(".model");
if (loc == std::string::npos) {
untested();
loc = dump_name.rfind(".vams");
}else{
}
if (loc != std::string::npos) {
dump_name.erase(loc);
}else{
untested();
}
}
{ // chop prefix path
std::string::size_type loc = dump_name.find_last_of(ENDDIR);
if (loc != std::string::npos) {
dump_name.erase(0, loc+1);
}else{
itested();
}
}
// open file
std::ofstream out((dump_name+".cc").c_str());
if (!out) {
untested();
os_error(dump_name);
}
make_header(out, in, dump_name);
for (Model_List::const_iterator
m = in.models().begin();
m != in.models().end();
++m) {
make_cc_model(out, **m);
}
for (Device_List::const_iterator
m = in.devices().begin();
m != in.devices().end();
++m) {
out << "int DEV_" << (**m).name() << "::_count = -1;\n"
"int COMMON_" << (**m).name() << "::_count = -1;\n"
"static COMMON_" << (**m).name() << " Default_" << (**m).name()
<< "(CC_STATIC);\n"
"/*--------------------------------------"
"------------------------------------*/\n";
make_cc_common(out, **m);
make_cc_dev(out, **m);
}
make_tail(out, in);
}
/*--------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------*/
|