// ************************************************************************* // // Copyleft 2004-2007 Bruno PAGES . // // This file is part of the BOUML Uml Toolkit. // // 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. // // e-mail : bouml@free.fr // home : http://bouml.free.fr // // ************************************************************************* #ifdef WIN32 #pragma warning (disable: 4150) #endif #include #include "BrowserState.h" #include "StateData.h" #include "StateDialog.h" #include "myio.h" #include "ToolCom.h" #include "mu.h" StateData::StateData() { } StateData::StateData(StateData * model, BrowserNode * bn) : SimpleData(model) { browser_node = bn; uml = model->uml; cpp = model->cpp; java = model->java; } StateData::~StateData() { } const StateBehavior & StateData::get_behavior(DrawingLanguage ln) const { switch (ln) { case CppView: return cpp; case JavaView: return java; default: return uml; } } void StateData::edit() { setName(browser_node->get_name()); (new StateDialog(this))->show(); } // void StateData::send_uml_def(ToolCom * com, BrowserNode * bn, const QString & comment) { SimpleData::send_uml_def(com, bn, comment); uml.send_def(com); } void StateData::send_cpp_def(ToolCom * com) { cpp.send_def(com); } void StateData::send_java_def(ToolCom * com) { java.send_def(com); } bool StateData::tool_cmd(ToolCom * com, const char * args, BrowserNode * bn, const QString & comment) { if (((unsigned char) args[-1]) >= firstSetCmd) { if (!bn->is_writable() && !root_permission()) com->write_ack(FALSE); else { switch ((unsigned char) args[-1]) { case setUmlEntryBehaviorCmd: uml.on_entry = args; break; case setUmlExitBehaviorCmd: uml.on_exit = args; break; case setUmlActivityCmd: uml.do_activity = args; break; case setCppEntryBehaviorCmd: cpp.on_entry = args; break; case setCppExitBehaviorCmd: cpp.on_exit = args; break; case setCppActivityCmd: cpp.do_activity = args; break; case setJavaEntryBehaviorCmd: java.on_entry = args; break; case setJavaExitBehaviorCmd: java.on_exit = args; break; case setJavaActivityCmd: java.do_activity = args; break; default: return BasicData::tool_cmd(com, args, bn, comment); } // ok case bn->package_modified(); modified(); com->write_ack(TRUE); } } else return BasicData::tool_cmd(com, args, bn, comment); return TRUE; } // void StateData::save(QTextStream & st, QString & warning) const { BasicData::save(st, warning); uml.save(st, "uml"); cpp.save(st, "cpp"); java.save(st, "java"); } void StateData::read(char * & st, char * & k) { BasicData::read(st, k); // updates k uml.read(st, k, "uml"); // updates k cpp.read(st, k, "cpp"); // updates k java.read(st, k, "java"); // updates k } // void StateBehavior::send_def(ToolCom * com) { com->write_string(on_entry); com->write_string(on_exit); com->write_string(do_activity); } void StateBehavior::save(QTextStream & st, const char * lang) const { indent(+1); if (!on_entry.isEmpty()) { nl_indent(st); st << lang << "_on_entry "; save_string(on_entry, st); } if (!on_exit.isEmpty()) { nl_indent(st); st << lang << "_on_exit "; save_string(on_exit, st); } if (!do_activity.isEmpty()) { nl_indent(st); st << lang << "_do_activity "; save_string(do_activity, st); } indent(-1); } void StateBehavior::read(char * & st, char * & k, const char * lang) { int ln = strlen(lang); if (!strncmp(k, lang, ln) && !strcmp(k+ln, "_on_entry")) { on_entry = read_string(st); k = read_keyword(st); } if (!strncmp(k, lang, ln) && !strcmp(k+ln, "_on_exit")) { on_exit = read_string(st); k = read_keyword(st); } if (!strncmp(k, lang, ln) && !strcmp(k+ln, "_do_activity")) { do_activity = read_string(st); k = read_keyword(st); } }