
FreeCADs property system utilises some pointer math to calculate the offset between property and base class. Due to virtual inheritance of th ePropertyContainer the memory layout has been changed to rather random, which has lead to crashes dependend on the order of object initialisation. The solution is to not make PropertyContaner virtual but a class below, Base::Persitance. Then the memory layout is random for Persistance, but it is perfectly aligned for the base class chains from PropertyContainer onwards as well as from Extension onwards. Hence the proeprty system was changed to take the offset always from those two.
80 lines
3.4 KiB
C++
80 lines
3.4 KiB
C++
/***************************************************************************
|
|
* Copyright (c) Alexander Golubev (Fat-Zer) <fatzer2@gmail.com> 2015 *
|
|
* *
|
|
* 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 *
|
|
* *
|
|
***************************************************************************/
|
|
|
|
#ifndef ORIGINGROUP_H_QHTU73IF
|
|
#define ORIGINGROUP_H_QHTU73IF
|
|
|
|
#include "GeoFeatureGroupExtension.h"
|
|
#include "PropertyLinks.h"
|
|
|
|
namespace App {
|
|
class Origin;
|
|
|
|
/**
|
|
* Represents an abstact placeable group of objects with an associated Origin
|
|
*/
|
|
class AppExport OriginGroupExtension : public App::GeoFeatureGroupExtension
|
|
{
|
|
EXTENSION_PROPERTY_HEADER(App::OriginGroupExtension);
|
|
|
|
public:
|
|
OriginGroupExtension ();
|
|
virtual ~OriginGroupExtension ();
|
|
|
|
/// Returns the origin link or throws an exception
|
|
App::Origin *getOrigin () const;
|
|
|
|
/// returns the type name of the ViewProvider
|
|
virtual const char* getViewProviderName () const {
|
|
return "Gui::ViewProviderOriginGroup";
|
|
}
|
|
|
|
/**
|
|
* Returns the origin group which contains this object.
|
|
* In case this object is not part of any geoFeatureGroup 0 is returned.
|
|
* @param obj the object to search for
|
|
* @param indirect if true return if the group that so-called geoHas the object, @see geoHasObject()
|
|
* default is true
|
|
*/
|
|
static DocumentObject* getGroupOfObject (const DocumentObject* obj, bool indirect=true);
|
|
|
|
/// Returns true on changing OriginFeature set
|
|
virtual short extensionMustExecute () override;
|
|
|
|
/// Origin linked to the group
|
|
PropertyLink Origin;
|
|
|
|
protected:
|
|
/// Checks integrity of the Origin
|
|
virtual App::DocumentObjectExecReturn *extensionExecute () override;
|
|
/// Creates the corresponding Origin object
|
|
virtual void onExtendedSetupObject () override;
|
|
/// Removes all planes and axis if they are still linked to the document
|
|
virtual void onExtendedUnsetupObject () override;
|
|
};
|
|
|
|
typedef ExtensionPythonT<GroupExtensionPythonT<OriginGroupExtension>> OriginGroupExtensionPython;
|
|
|
|
} /* App */
|
|
|
|
#endif /* end of include guard: ORIGINGROUP_H_QHTU73IF */
|