ExtrusionEntityCollection.xsp 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. %module{Slic3r::XS};
  2. %{
  3. #include <xsinit.h>
  4. #include "libslic3r/ExtrusionEntityCollection.hpp"
  5. %}
  6. %name{Slic3r::ExtrusionPath::Collection} class ExtrusionEntityCollection {
  7. %name{_new} ExtrusionEntityCollection();
  8. ~ExtrusionEntityCollection();
  9. Clone<ExtrusionEntityCollection> clone()
  10. %code{% RETVAL = (ExtrusionEntityCollection*)THIS->clone(); %};
  11. void reverse();
  12. void clear();
  13. ExtrusionEntityCollection* chained_path(bool no_reverse, ExtrusionRole role = erMixed)
  14. %code{%
  15. RETVAL = new ExtrusionEntityCollection();
  16. THIS->chained_path(RETVAL, no_reverse, role);
  17. %};
  18. ExtrusionEntityCollection* chained_path_from(Point* start_near, bool no_reverse, ExtrusionRole role = erMixed)
  19. %code{%
  20. RETVAL = new ExtrusionEntityCollection();
  21. THIS->chained_path_from(*start_near, RETVAL, no_reverse, role);
  22. %};
  23. Clone<Point> first_point();
  24. Clone<Point> last_point();
  25. int count()
  26. %code{% RETVAL = THIS->entities.size(); %};
  27. int items_count()
  28. %code{% RETVAL = THIS->items_count(); %};
  29. ExtrusionEntityCollection* flatten()
  30. %code{%
  31. RETVAL = new ExtrusionEntityCollection();
  32. *RETVAL = THIS->flatten();
  33. %};
  34. double min_mm3_per_mm();
  35. bool empty()
  36. %code{% RETVAL = THIS->entities.empty(); %};
  37. Polygons polygons_covered_by_width();
  38. Polygons polygons_covered_by_spacing();
  39. %{
  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 (ExtrusionMultiPath* multipath = dynamic_cast<ExtrusionMultiPath*>(*it)) {
  52. sv_setref_pv( sv, perl_class_name_ref(multipath), multipath );
  53. } else if (ExtrusionLoop* loop = dynamic_cast<ExtrusionLoop*>(*it)) {
  54. sv_setref_pv( sv, perl_class_name_ref(loop), loop );
  55. } else if (ExtrusionEntityCollection* collection = dynamic_cast<ExtrusionEntityCollection*>(*it)) {
  56. sv_setref_pv( sv, perl_class_name_ref(collection), collection );
  57. } else {
  58. croak("Unexpected type in ExtrusionEntityCollection");
  59. }
  60. av_store(av, i++, sv);
  61. }
  62. RETVAL = newRV_noinc((SV*)av);
  63. OUTPUT:
  64. RETVAL
  65. void
  66. ExtrusionEntityCollection::append(...)
  67. CODE:
  68. for (unsigned int i = 1; i < items; i++) {
  69. if(!sv_isobject( ST(i) ) || (SvTYPE(SvRV( ST(i) )) != SVt_PVMG)) {
  70. croak("Argument %d is not object", i);
  71. }
  72. ExtrusionEntity* entity = (ExtrusionEntity *)SvIV((SV*)SvRV( ST(i) ));
  73. // append COPIES
  74. if (ExtrusionPath* path = dynamic_cast<ExtrusionPath*>(entity)) {
  75. THIS->entities.push_back( new ExtrusionPath(*path) );
  76. } else if (ExtrusionMultiPath* multipath = dynamic_cast<ExtrusionMultiPath*>(entity)) {
  77. THIS->entities.push_back( new ExtrusionMultiPath(*multipath) );
  78. } else if (ExtrusionLoop* loop = dynamic_cast<ExtrusionLoop*>(entity)) {
  79. THIS->entities.push_back( new ExtrusionLoop(*loop) );
  80. } else if(ExtrusionEntityCollection* collection = dynamic_cast<ExtrusionEntityCollection*>(entity)) {
  81. THIS->entities.push_back( collection->clone() );
  82. } else {
  83. croak("Argument %d is of unknown type", i);
  84. }
  85. }
  86. bool
  87. ExtrusionEntityCollection::no_sort(...)
  88. CODE:
  89. if (items > 1) {
  90. THIS->no_sort = SvTRUE(ST(1));
  91. }
  92. RETVAL = THIS->no_sort;
  93. OUTPUT:
  94. RETVAL
  95. %}
  96. };