154 lines
4.9 KiB
C++
154 lines
4.9 KiB
C++
// SPDX-License-Identifier: LGPL-2.1-or-later
|
|
/****************************************************************************
|
|
* *
|
|
* Copyright (c) 2024 Ondsel <development@ondsel.com> *
|
|
* *
|
|
* This file is part of FreeCAD. *
|
|
* *
|
|
* FreeCAD is free software: you can redistribute it and/or modify it *
|
|
* under the terms of the GNU Lesser General Public License as *
|
|
* published by the Free Software Foundation, either version 2.1 of the *
|
|
* License, or (at your option) any later version. *
|
|
* *
|
|
* FreeCAD 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 *
|
|
* Lesser General Public License for more details. *
|
|
* *
|
|
* You should have received a copy of the GNU Lesser General Public *
|
|
* License along with FreeCAD. If not, see *
|
|
* <https://www.gnu.org/licenses/>. *
|
|
* *
|
|
***************************************************************************/
|
|
|
|
|
|
#include "PreCompiled.h"
|
|
|
|
// inclusion of the generated files (generated out of AssemblyObject.xml)
|
|
#include "AssemblyObjectPy.h"
|
|
#include "AssemblyObjectPy.cpp"
|
|
|
|
using namespace Assembly;
|
|
|
|
// returns a string which represents the object e.g. when printed in python
|
|
std::string AssemblyObjectPy::representation() const
|
|
{
|
|
return {"<Assembly object>"};
|
|
}
|
|
|
|
PyObject* AssemblyObjectPy::getCustomAttributes(const char* /*attr*/) const
|
|
{
|
|
return nullptr;
|
|
}
|
|
|
|
int AssemblyObjectPy::setCustomAttributes(const char* /*attr*/, PyObject* /*obj*/)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
PyObject* AssemblyObjectPy::solve(PyObject* args)
|
|
{
|
|
PyObject* enableUndoPy;
|
|
bool enableUndo;
|
|
|
|
if (!PyArg_ParseTuple(args, "O!", &PyBool_Type, &enableUndoPy)) {
|
|
PyErr_Clear();
|
|
if (!PyArg_ParseTuple(args, "")) {
|
|
return nullptr;
|
|
}
|
|
else {
|
|
enableUndo = false;
|
|
}
|
|
}
|
|
else {
|
|
enableUndo = Base::asBoolean(enableUndoPy);
|
|
}
|
|
|
|
int ret = this->getAssemblyObjectPtr()->solve(enableUndo);
|
|
return Py_BuildValue("i", ret);
|
|
}
|
|
|
|
PyObject* AssemblyObjectPy::ensureIdentityPlacements(PyObject* args)
|
|
{
|
|
if (!PyArg_ParseTuple(args, "")) {
|
|
return nullptr;
|
|
}
|
|
this->getAssemblyObjectPtr()->ensureIdentityPlacements();
|
|
Py_Return;
|
|
}
|
|
|
|
PyObject* AssemblyObjectPy::undoSolve(PyObject* args)
|
|
{
|
|
if (!PyArg_ParseTuple(args, "")) {
|
|
return nullptr;
|
|
}
|
|
this->getAssemblyObjectPtr()->undoSolve();
|
|
Py_Return;
|
|
}
|
|
|
|
PyObject* AssemblyObjectPy::clearUndo(PyObject* args)
|
|
{
|
|
if (!PyArg_ParseTuple(args, "")) {
|
|
return nullptr;
|
|
}
|
|
this->getAssemblyObjectPtr()->clearUndo();
|
|
Py_Return;
|
|
}
|
|
|
|
PyObject* AssemblyObjectPy::isPartConnected(PyObject* args)
|
|
{
|
|
PyObject* pyobj;
|
|
|
|
if (!PyArg_ParseTuple(args, "O", &pyobj)) {
|
|
return nullptr;
|
|
}
|
|
auto* obj = static_cast<App::DocumentObjectPy*>(pyobj)->getDocumentObjectPtr();
|
|
bool ok = this->getAssemblyObjectPtr()->isPartConnected(obj);
|
|
return Py_BuildValue("O", (ok ? Py_True : Py_False));
|
|
}
|
|
|
|
PyObject* AssemblyObjectPy::isPartGrounded(PyObject* args)
|
|
{
|
|
PyObject* pyobj;
|
|
|
|
if (!PyArg_ParseTuple(args, "O", &pyobj)) {
|
|
return nullptr;
|
|
}
|
|
auto* obj = static_cast<App::DocumentObjectPy*>(pyobj)->getDocumentObjectPtr();
|
|
bool ok = this->getAssemblyObjectPtr()->isPartGrounded(obj);
|
|
return Py_BuildValue("O", (ok ? Py_True : Py_False));
|
|
}
|
|
|
|
PyObject* AssemblyObjectPy::isJointConnectingPartToGround(PyObject* args)
|
|
{
|
|
PyObject* pyobj;
|
|
char* pname;
|
|
|
|
if (!PyArg_ParseTuple(args, "Os", &pyobj, &pname)) {
|
|
return nullptr;
|
|
}
|
|
auto* obj = static_cast<App::DocumentObjectPy*>(pyobj)->getDocumentObjectPtr();
|
|
bool ok = this->getAssemblyObjectPtr()->isJointConnectingPartToGround(obj, pname);
|
|
return Py_BuildValue("O", (ok ? Py_True : Py_False));
|
|
}
|
|
|
|
PyObject* AssemblyObjectPy::exportAsASMT(PyObject* args)
|
|
{
|
|
char* utf8Name;
|
|
if (!PyArg_ParseTuple(args, "et", "utf-8", &utf8Name)) {
|
|
return nullptr;
|
|
}
|
|
|
|
std::string fileName = utf8Name;
|
|
PyMem_Free(utf8Name);
|
|
|
|
if (fileName.empty()) {
|
|
PyErr_SetString(PyExc_ValueError, "Passed string is empty");
|
|
return nullptr;
|
|
}
|
|
|
|
this->getAssemblyObjectPtr()->exportAsASMT(fileName);
|
|
|
|
Py_Return;
|
|
}
|