CloneTreeCreator.cpp 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. #include "CloneTreeCreator.hpp"
  2. #include <cstdio>
  3. namespace btInverseDynamics
  4. {
  5. #define CHECK_NULLPTR() \
  6. do \
  7. { \
  8. if (m_reference == 0x0) \
  9. { \
  10. bt_id_error_message("m_reference == 0x0\n"); \
  11. return -1; \
  12. } \
  13. } while (0)
  14. #define TRY(x) \
  15. do \
  16. { \
  17. if (x == -1) \
  18. { \
  19. bt_id_error_message("error calling " #x "\n"); \
  20. return -1; \
  21. } \
  22. } while (0)
  23. CloneTreeCreator::CloneTreeCreator(const MultiBodyTree* reference)
  24. {
  25. m_reference = reference;
  26. }
  27. CloneTreeCreator::~CloneTreeCreator() {}
  28. int CloneTreeCreator::getNumBodies(int* num_bodies) const
  29. {
  30. CHECK_NULLPTR();
  31. *num_bodies = m_reference->numBodies();
  32. return 0;
  33. }
  34. int CloneTreeCreator::getBody(const int body_index, int* parent_index, JointType* joint_type,
  35. vec3* parent_r_parent_body_ref, mat33* body_T_parent_ref,
  36. vec3* body_axis_of_motion, idScalar* mass, vec3* body_r_body_com,
  37. mat33* body_I_body, int* user_int, void** user_ptr) const
  38. {
  39. CHECK_NULLPTR();
  40. TRY(m_reference->getParentIndex(body_index, parent_index));
  41. TRY(m_reference->getJointType(body_index, joint_type));
  42. TRY(m_reference->getParentRParentBodyRef(body_index, parent_r_parent_body_ref));
  43. TRY(m_reference->getBodyTParentRef(body_index, body_T_parent_ref));
  44. TRY(m_reference->getBodyAxisOfMotion(body_index, body_axis_of_motion));
  45. TRY(m_reference->getBodyMass(body_index, mass));
  46. TRY(m_reference->getBodyFirstMassMoment(body_index, body_r_body_com));
  47. TRY(m_reference->getBodySecondMassMoment(body_index, body_I_body));
  48. TRY(m_reference->getUserInt(body_index, user_int));
  49. TRY(m_reference->getUserPtr(body_index, user_ptr));
  50. return 0;
  51. }
  52. } // namespace btInverseDynamics