ExtrusionEntityCollection.xsp 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. %module{Slic3r::XS};
  2. %{
  3. #include <myinit.h>
  4. #include "libslic3r/ExtrusionEntityCollection.hpp"
  5. %}
  6. %name{Slic3r::ExtrusionPath::Collection} class ExtrusionEntityCollection {
  7. %name{_new} ExtrusionEntityCollection();
  8. Clone<ExtrusionEntityCollection> clone()
  9. %code{% RETVAL = THIS->clone(); %};
  10. void reverse();
  11. void clear()
  12. %code{% THIS->entities.clear(); %};
  13. ExtrusionEntityCollection* chained_path(bool no_reverse)
  14. %code{%
  15. RETVAL = new ExtrusionEntityCollection();
  16. THIS->chained_path(RETVAL, no_reverse);
  17. %};
  18. ExtrusionEntityCollection* chained_path_from(Point* start_near, bool no_reverse)
  19. %code{%
  20. RETVAL = new ExtrusionEntityCollection();
  21. THIS->chained_path_from(*start_near, RETVAL, no_reverse);
  22. %};
  23. Clone<Point> first_point();
  24. Clone<Point> last_point();
  25. int count()
  26. %code{% RETVAL = THIS->entities.size(); %};
  27. bool empty()
  28. %code{% RETVAL = THIS->entities.empty(); %};
  29. std::vector<size_t> orig_indices()
  30. %code{% RETVAL = THIS->orig_indices; %};
  31. Polygons grow();
  32. %{
  33. void
  34. ExtrusionEntityCollection::DESTROY()
  35. CODE:
  36. for (ExtrusionEntitiesPtr::iterator it = THIS->entities.begin(); it != THIS->entities.end(); ++it) {
  37. delete *it;
  38. }
  39. delete THIS;
  40. SV*
  41. ExtrusionEntityCollection::arrayref()
  42. CODE:
  43. AV* av = newAV();
  44. av_fill(av, THIS->entities.size()-1);
  45. int i = 0;
  46. for (ExtrusionEntitiesPtr::iterator it = THIS->entities.begin(); it != THIS->entities.end(); ++it) {
  47. SV* sv = newSV(0);
  48. // return our item by reference
  49. if (ExtrusionPath* path = dynamic_cast<ExtrusionPath*>(*it)) {
  50. sv_setref_pv( sv, perl_class_name_ref(path), path );
  51. } else if (ExtrusionLoop* loop = dynamic_cast<ExtrusionLoop*>(*it)) {
  52. sv_setref_pv( sv, perl_class_name_ref(loop), loop );
  53. } else if (ExtrusionEntityCollection* collection = dynamic_cast<ExtrusionEntityCollection*>(*it)) {
  54. sv_setref_pv( sv, perl_class_name_ref(collection), collection );
  55. } else {
  56. croak("Unexpected type in ExtrusionEntityCollection");
  57. }
  58. av_store(av, i++, sv);
  59. }
  60. RETVAL = newRV_noinc((SV*)av);
  61. OUTPUT:
  62. RETVAL
  63. void
  64. ExtrusionEntityCollection::append(...)
  65. CODE:
  66. for (unsigned int i = 1; i < items; i++) {
  67. if(!sv_isobject( ST(i) ) || (SvTYPE(SvRV( ST(i) )) != SVt_PVMG)) {
  68. croak("Argument %d is not object", i);
  69. }
  70. ExtrusionEntity* entity = (ExtrusionEntity *)SvIV((SV*)SvRV( ST(i) ));
  71. // append COPIES
  72. if (ExtrusionPath* path = dynamic_cast<ExtrusionPath*>(entity)) {
  73. THIS->entities.push_back( new ExtrusionPath(*path) );
  74. } else if (ExtrusionLoop* loop = dynamic_cast<ExtrusionLoop*>(entity)) {
  75. THIS->entities.push_back( new ExtrusionLoop(*loop) );
  76. } else if(ExtrusionEntityCollection* collection = dynamic_cast<ExtrusionEntityCollection*>(entity)) {
  77. THIS->entities.push_back( collection->clone() );
  78. } else {
  79. croak("Argument %d is of unknown type", i);
  80. }
  81. }
  82. bool
  83. ExtrusionEntityCollection::no_sort(...)
  84. CODE:
  85. if (items > 1) {
  86. THIS->no_sort = SvTRUE(ST(1));
  87. }
  88. RETVAL = THIS->no_sort;
  89. OUTPUT:
  90. RETVAL
  91. ExtrusionEntityCollection*
  92. ExtrusionEntityCollection::chained_path_indices(bool no_reverse)
  93. CODE:
  94. RETVAL = new ExtrusionEntityCollection();
  95. THIS->chained_path(RETVAL, no_reverse, &RETVAL->orig_indices);
  96. OUTPUT:
  97. RETVAL
  98. %}
  99. };