//
// aegis - project change supervisor
// Copyright (C) 2008 Peter Miller
//
// 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 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, see .
//
#include
type_string_code::~type_string_code()
{
}
type_string_code::type_string_code(generator *a_gen) :
type_string(a_gen)
{
}
type::pointer
type_string_code::create(generator *a_gen)
{
return pointer(new type_string_code(a_gen));
}
void
type_string_code::gen_body()
const
{
include_once("libaegis/io.h"); // for string_write
}
void
type_string_code::gen_declarator(const nstring &variable_name, bool is_a_list,
int, const nstring &) const
{
printf("string_write(fp, ");
if (is_a_list)
printf("(const char *)0");
else
printf("\"%s\"", variable_name.c_str());
printf(", this_thing->%s);\n", variable_name.c_str());
}
void
type_string_code::gen_call_xml(const nstring &form_name,
const nstring &member_name, int) const
{
printf
(
"string_write_xml(fp, \"%s\", this_thing->%s);\n",
form_name.c_str(),
member_name.c_str()
);
}
void
type_string_code::gen_copy(const nstring &member_name)
const
{
printf
(
"result->%s = str_copy(this_thing->%s);\n",
member_name.c_str(),
member_name.c_str()
);
}
void
type_string_code::gen_free_declarator(const nstring &variable_name, bool)
const
{
printf("str_free(this_thing->%s);\n", variable_name.c_str());
}
void
type_string_code::gen_trace(const nstring &vname, const nstring &value)
const
{
printf
(
"trace_string_real(\"%s\", %s);\n",
vname.c_str(),
value.c_str()
);
}