/*************************************************************************** * Copyright (c) 2002 Jürgen Riegel * * * * This file is part of the FreeCAD CAx development system. * * * * This library is free software; you can redistribute it and/or * * modify it under the terms of the GNU Library General Public * * License as published by the Free Software Foundation; either * * version 2 of the License, or (at your option) any later version. * * * * This library 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 Library General Public License for more details. * * * * You should have received a copy of the GNU Library General Public * * License along with this library; see the file COPYING.LIB. If not, * * write to the Free Software Foundation, Inc., 59 Temple Place, * * Suite 330, Boston, MA 02111-1307, USA * * * ***************************************************************************/ #include "PreCompiled.h" #ifndef _PreComp_ #endif #include "GeoFeature.h" #include "GeoFeatureGroupExtension.h" #include using namespace App; PROPERTY_SOURCE(App::GeoFeature, App::DocumentObject) //=========================================================================== // Feature //=========================================================================== GeoFeature::GeoFeature(void) { ADD_PROPERTY_TYPE(Placement,(Base::Placement()),nullptr,Prop_NoRecompute,nullptr); } GeoFeature::~GeoFeature(void) { } void GeoFeature::transformPlacement(const Base::Placement &transform) { Base::Placement plm = this->Placement.getValue(); plm = transform * plm; this->Placement.setValue(plm); } Base::Placement GeoFeature::globalPlacement() const { auto* group = GeoFeatureGroupExtension::getGroupOfObject(this); if (group) { auto ext = group->getExtensionByType(); return ext->globalGroupPlacement() * Placement.getValue(); } return Placement.getValue(); } const PropertyComplexGeoData* GeoFeature::getPropertyOfGeometry() const { return nullptr; } PyObject* GeoFeature::getPyObject(void) { if (PythonObject.is(Py::_None())) { // ref counter is set to 1 PythonObject = Py::Object(new GeoFeaturePy(this),true); } return Py::new_reference_to(PythonObject); } std::pair GeoFeature::getElementName( const char *name, ElementNameType type) const { (void)type; std::pair ret; if(!name) return ret; ret.second = name; return ret; } DocumentObject *GeoFeature::resolveElement(DocumentObject *obj, const char *subname, std::pair &elementName, bool append, ElementNameType type, const DocumentObject *filter, const char **_element, GeoFeature **geoFeature) { if(!obj || !obj->getNameInDocument()) return 0; if(!subname) subname = ""; const char *element = Data::ComplexGeoData::findElementName(subname); if(_element) *_element = element; auto sobj = obj->getSubObject(subname); if(!sobj) return 0; obj = sobj->getLinkedObject(true); auto geo = dynamic_cast(obj); if(geoFeature) *geoFeature = geo; if(!obj || (filter && obj!=filter)) return 0; if(!element || !element[0]) { if(append) elementName.second = Data::ComplexGeoData::oldElementName(subname); return sobj; } if(!geo || hasHiddenMarker(element)) { if(!append) elementName.second = element; else elementName.second = Data::ComplexGeoData::oldElementName(subname); return sobj; } if(!append) elementName = geo->getElementName(element,type); else{ const auto &names = geo->getElementName(element,type); std::string prefix(subname,element-subname); if(names.first.size()) elementName.first = prefix + names.first; elementName.second = prefix + names.second; } return sobj; }