void Body::buildPartList(std::vector<GuiObjectLink*>* list, Part* p, int depth) { //debug_print("Depth: %i, Part: %s \n", depth, p->getId()); if (p->getType() == PartType::TYPE_ORGAN) { //Append to end of list "gui_list_indent_char [times depth] ORGAN_NAME" std::string str = ""; for (int i = 0; i <= depth; i++) { str.append(gui_list_indent_char); } str.append(p->getName()); list->push_back( new GuiObjectLink( p->getUUID(), new ColoredText(str, part_gui_list_color_organ) ) ); return; } if (p->getType() == PartType::TYPE_BODYPART) { //Append to end of list "gui_list_indent_char [times depth] BODYPART_NAME" BodyPart *bp = (BodyPart*)p; std::string str = ""; for (int i = 0; i <= depth; i++) { str.append(gui_list_indent_char); } str.append(bp->getName()); list->push_back( new GuiObjectLink( bp->getUUID(), new ColoredText(str, part_gui_list_color_bodypart) ) ); //Call this function on all children of the BodyPart for (auto it = bp->getChildListRW()->begin(); it != bp->getChildListRW()->end(); it++) { boost::shared_ptr<Part> part = getPartByUUID(*it); if (part == nullptr) { continue; } buildPartList(list, part.get(), depth + 1); } bp = nullptr; return; } debug_error("ERROR: Tried to call recursive part list building function on invalid Part* (neither TYPE_BODYPART nor TYPE_ORGAN)!\n"); return; }
void MainWindow::showBodyDetails( const Creature& creature, const BodyPart& body ) { getUiInspector().lst_body_details->addItem(QString( body.getName().c_str())); getUiInspector().lst_body_details->addItem(QString( (" Mass: " + TO_STRING(body.getMass())).c_str())); getUiInspector().lst_body_details->addItem(QString( (" Torque: " + TO_STRING(body.getMaxTorque())).c_str())); getUiInspector().lst_body_details->addItem(QString( std::string(" Size").c_str())); getUiInspector().lst_body_details->addItem(QString( (" [x]: " + TO_STRING(body.getSizeX())).c_str())); getUiInspector().lst_body_details->addItem(QString( (" [y]: " + TO_STRING(body.getSizeY())).c_str())); getUiInspector().lst_body_details->addItem(QString( (" [z]: " + TO_STRING(body.getSizeZ())).c_str())); //Angles BodyPart* parent = body.getParentId() == Creature::B_NONE ? NULL : &creature.getBodyPart(body.getParentId()); if (parent) { getUiInspector().lst_body_details->addItem(QString( (" Parent: " + parent->getName()).c_str())); // getUiInspector().lst_body_details->addItem(QString(std::string(" Angles:").c_str())); // getUiInspector().lst_body_details->addItem(QString( // (" XY:" + TO_STRING( // MathUtil::getAngle(MathUtil::XY, // parent->getRigidBody()->getCenterOfMassPosition(), // body.getRigidBody()->getCenterOfMassPosition()))).c_str())); // getUiInspector().lst_body_details->addItem(QString( // (" YZ:" + TO_STRING( // MathUtil::getAngle(MathUtil::YZ, // parent->getRigidBody()->getCenterOfMassPosition(), // body.getRigidBody()->getCenterOfMassPosition()))).c_str())); // getUiInspector().lst_body_details->addItem(QString( // (" ZX:" + TO_STRING( // MathUtil::getAngle(MathUtil::ZX, // parent->getRigidBody()->getCenterOfMassPosition(), // body.getRigidBody()->getCenterOfMassPosition()))).c_str())); } }
std::string evalute::evalute_BodyPart(Watch* watch) { std::string name = watch->MemberName; std::string result = ""; BodyPart* part = boost::get<BodyPart*>(watch->Object); if( name == "MaxKindleLevel") result = FloatToStr(part->getMaxKindleLevel()); else if( name == "MaxDampness") result = FloatToStr(part->getMaxDampness()); else if( name == "AcceptsCord") result = BoolToStr(part->getAcceptsCord()); else if( name == "Name") result = part->getName(); if(result == "") result = "Can't evalute"; return result; }
string Body::enter(rapidxml::xml_node<> *node, std::map<string, string>* child_map, std::map<string, string>* organ_link_map) { using namespace rapidxml; int organ_count, bodyparts, it; xml_node<> *temp; xml_node<> **organ_node_list; char *id = nullptr, *name = nullptr, *_name = nullptr; float surface = 0.0f; //Make a count of the body_part nodes in this node and parse all standard // nodes for the bodypart of this node temp = node->first_node(); bodyparts = 0; while (temp != nullptr){ _name = temp->name(); if (!strcmp(_name, "body_part")) { bodyparts++; } if (!strcmp(_name, "id")) { id = temp->value(); } if (!strcmp(_name, "name")) { name = temp->value(); } if (!strcmp(_name, "surface")) { surface = atof(temp->value()); } temp = temp->next_sibling(); } //if any of the mandatory vars for bodyparts are NULL, ERROR! if (id == nullptr || name == nullptr){ throw new bdef_parse_error("Not all mandatory BodyPart variables defined!", node); } //make the bodypart, make the pointer to it shared and store it in the part_map BodyPart* bp = new BodyPart((string)id, (string)name, surface, this); boost::shared_ptr<BodyPart> p (bp); part_map->insert( std::pair<std::string, boost::shared_ptr<Part>>( bp->getUUID(), boost::static_pointer_cast<Part>(p))); //reset temporary variables for reuse with the organs id = nullptr; name = nullptr; //DEBUG: Print new BodyPart debug_print("New BodyPart created: \n\tID: %s \n\tName: %s \n\tSurface: %f\n", bp->getId().c_str(), bp->getName().c_str(), bp->getSurface()); //If there are no body_part nodes... if (bodyparts == 0){ //...there must be organs instead! // variables Organ **organs; xml_attribute<> *attr; xml_node<> *tdef_node; char *connector = nullptr; bool symmetrical = false; it = 0; // temp vars for tissue definitions char *tdef_id, *tdef_custom_id, *tdef_name; float tdef_hit_prob; tissue_def *tdefs = nullptr; int tdef_count = 0, tdef_it = 0; //Reset back to the first node in the given node temp = node->first_node(); //scan for organ nodes in the given node organ_count = 0; while (temp != nullptr){ if (!strcmp(temp->name(),"organ")) { organ_count++; } temp = temp->next_sibling(); } //If there are no organs AND no bodyparts, ERROR! if (organ_count == 0){ throw bdef_parse_error("No body part and no organ definition!", node); } //compile a list of nodes holding the organ definitions //and parse the remaining nodes to make the bodypart organ_node_list = new xml_node<>*[organ_count]; temp = node->first_node(); while (temp != nullptr){ _name = temp->name(); if (!strcmp(_name,"organ")) { organ_node_list[it] = temp; it++; } temp = temp->next_sibling(); } //create temporary organ array organs = new Organ*[organ_count]; //parse each organ definition in the list for (int i=0; i < organ_count; i++){ //Enter into organ node temp = organ_node_list[i]->first_node(); //Iterate through all nodes within the organ node while (temp != nullptr){ _name = temp->name(); //Parse standard tags if (!strcmp(_name,"id")) { id = temp->value(); } if (!strcmp(_name,"name")) { name = temp->value(); } if (!strcmp(_name,"surface")) { surface = atof(temp->value()); } if (!strcmp(_name,"connector")) { connector = temp->value(); } //Parse the organ tissue definitions, create (or rather link) them // and add to the organs if (!strcmp(_name,"organ_tissue")) { attr = temp->first_attribute(); if (attr != nullptr && !strcmp(attr->name(), "symmetrical")){ symmetrical = true; } attr = nullptr; //Get the count of tissue defs tdef_count = 0; tdef_node = temp->first_node(); while (tdef_node != nullptr) { //If any other node than tissue_def, ERROR! if (strcmp(tdef_node->name(), "tissue_def")) { throw bdef_parse_error("Invalid node for organ tissue (only tissue_def allowed)!", temp); } tdef_count++; tdef_node = tdef_node->next_sibling(); } //Create organ tissue array, double size if organ is symmetrical tdefs = new tissue_def[tdef_count * (symmetrical+1)]; //Enter the organ_tissue node, create the tissue_def for // each tissue_def child and store it in tdefs[] array tdef_it = 0; tdef_node = temp->first_node(); while (tdef_node != nullptr){ //The value of a tissue_def node is the id of the tissue (e.g. M_ARTERY) tdef_id = tdef_node->value(); tdef_hit_prob = 0; tdef_name = nullptr; tdef_custom_id = nullptr; //Get the other parameters attr = tdef_node->first_attribute(); while (attr != nullptr){ if (!strcmp(attr->name(), "hit_prob")){ tdef_hit_prob = atof(attr->value()); } if (!strcmp(attr->name(), "name")) { tdef_name = attr->value(); } if (!strcmp(attr->name(), "custom_id")) { tdef_custom_id = attr->value(); } attr = attr->next_attribute(); } //Store the parameters in the tissue definition if (tdef_custom_id != nullptr) { tdefs[tdef_it].custom_id = string(tdef_custom_id); } else { tdefs[tdef_it].custom_id = ""; } if (tdef_name != nullptr) { tdefs[tdef_it].name = string(tdef_name); } else { tdefs[tdef_it].name = ""; } tdefs[tdef_it].hit_prob = tdef_hit_prob; //Link the tissue definition to it's base tissue // NOTE: the tissue_map variable is a POINTER to the // actual tissue map which is defined in the loadBody (super) // function, therefore it must be dereferenced before use. //If the base tissue cannot be linked, ERROR! std::string key = tdef_id; std::map<std::string, boost::shared_ptr<Tissue>>::const_iterator pos = tissue_map->find(key); if (pos == tissue_map->end()){ throw bdef_parse_error("Tissue not found!", tdef_node); } tdefs[tdef_it].tissue = pos->second; tdef_it++; tdef_node = tdef_node->next_sibling(); } } temp = temp->next_sibling(); } //Check whether all necessary data for organ creation has been read // if not, ERROR! if (id == nullptr || name == nullptr || connector == nullptr || tdefs == nullptr){ throw bdef_parse_error("Not all necessary data for organ creation found.", organ_node_list[i]); } //if organ is symmetrical, create the symmetry by duplicating all entries but the last // and appending them in reverse order int d; for (int j=tdef_count-2; j >= 0; j--) { d = (j - (tdef_count - 1))*-1; tdefs[(tdef_count-1)+d] = tdefs[j]; } //Create the organ organs[i] = new Organ(string(id), string(name), surface, this, tdefs, tdef_count, connector, !strcmp(connector, "_ROOT")); //DEBUG: Print Organ #ifdef _DEBUG debug_print("\tNew Organ created:\n\t\tID: %s \n\t\tName: %s \n\t\tSurface: %f \n\t\tRoot: %s \n\t\tTissues:", organs[i]->getId().c_str(), organs[i]->getName().c_str(), organs[i]->getSurface(), connector); for (int di = 0; di < (tdef_count * (symmetrical+1))-1; di++){ debug_print("\n\t\t\tBase Tissue Name: %s \n\t\t\t\tHit Prob.: %f", tdefs[di].tissue->getName().c_str(), tdefs[di].hit_prob); if (!tdefs[di].name.empty()){ debug_print("\n\t\t\t\tCustom Name: %s", tdefs[di].name.c_str()); } if (!tdefs[di].custom_id.empty()){ debug_print("\n\t\t\t\tCustom ID: %s", tdefs[di].custom_id.c_str()); } } debug_print("\n\tEND Organ.\n"); #endif } //...and add all organs to the part map. Add the "child note" // between the organs and the new bodypart to the child_map. // Add the "connector note" between the organs and their connectors to // the organ_link_map. for (int i = 0; i < organ_count; i++){ part_map->insert( std::pair<string, boost::shared_ptr<Part>>( organs[i]->getUUID(), boost::static_pointer_cast<Part>(boost::make_shared<Organ>(*(organs[i]))) )); child_map->insert( std::pair<string, string>( organs[i]->getUUID(), bp->getUUID() )); if (organs[i]->getConnectorId() != "_ROOT"){ organ_link_map->insert( std::pair<string, string>( organs[i]->getUUID(), dynamic_cast<Organ*>(organs[i])->getConnectorId() )); } } } else { //...its another BodyPart //Go through all nodes and call this function on every // node containing a part definition, add the returned BodyPart/Organ // to this ones' children (per child_map) temp = node->first_node(); it = 0; while (temp != nullptr){ _name = temp->name(); if (!strcmp(_name, "body_part")) { string child_uuid = enter(temp, child_map, organ_link_map); child_map->insert( std::pair<string, string>( child_uuid, bp->getUUID() )); //bp->addChild(enter(temp)); } temp = temp->next_sibling(); } } //return this bodyparts uuid return bp->getUUID(); }