New Slic3r::ExPolygon::XS class
This commit is contained in:
parent
c2d63bcd09
commit
5a11d4df89
9 changed files with 138 additions and 3 deletions
|
@ -18,6 +18,7 @@ src/admesh/stlinit.c
|
||||||
src/admesh/stlinit.o
|
src/admesh/stlinit.o
|
||||||
src/admesh/util.c
|
src/admesh/util.c
|
||||||
src/admesh/util.o
|
src/admesh/util.o
|
||||||
|
src/ExPolygon.hpp
|
||||||
src/myinit.h
|
src/myinit.h
|
||||||
src/Point.cpp
|
src/Point.cpp
|
||||||
src/Point.hpp
|
src/Point.hpp
|
||||||
|
@ -30,6 +31,8 @@ src/ZTable.hpp
|
||||||
t/01_trianglemesh.t
|
t/01_trianglemesh.t
|
||||||
t/02_object.t
|
t/02_object.t
|
||||||
t/03_point.t
|
t/03_point.t
|
||||||
|
t/04_expolygon.t
|
||||||
|
xsp/ExPolygon.xsp
|
||||||
xsp/my.map
|
xsp/my.map
|
||||||
xsp/mytype.map
|
xsp/mytype.map
|
||||||
xsp/Object.xsp
|
xsp/Object.xsp
|
||||||
|
|
|
@ -11,4 +11,8 @@ package Slic3r::Point::XS;
|
||||||
use overload
|
use overload
|
||||||
'@{}' => sub { $_[0]->_toPerl };
|
'@{}' => sub { $_[0]->_toPerl };
|
||||||
|
|
||||||
|
package Slic3r::ExPolygon::XS;
|
||||||
|
use overload
|
||||||
|
'@{}' => sub { $_[0]->_toPerl };
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
|
52
xs/src/ExPolygon.hpp
Normal file
52
xs/src/ExPolygon.hpp
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
#ifndef slic3r_ExPolygon_hpp_
|
||||||
|
#define slic3r_ExPolygon_hpp_
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
#include "EXTERN.h"
|
||||||
|
#include "perl.h"
|
||||||
|
#include "XSUB.h"
|
||||||
|
#include "ppport.h"
|
||||||
|
}
|
||||||
|
|
||||||
|
#include "Point.hpp"
|
||||||
|
|
||||||
|
typedef std::vector<Point> Polygon;
|
||||||
|
typedef std::vector<Polygon> Polygons;
|
||||||
|
|
||||||
|
class ExPolygon
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
Polygon contour;
|
||||||
|
Polygons holes;
|
||||||
|
SV* _toPerl();
|
||||||
|
};
|
||||||
|
|
||||||
|
Polygon*
|
||||||
|
perl2polygon(SV* poly_sv)
|
||||||
|
{
|
||||||
|
AV* poly_av = (AV*)SvRV(poly_sv);
|
||||||
|
const unsigned int num_points = av_len(poly_av)+1;
|
||||||
|
Polygon* retval = new Polygon(num_points);
|
||||||
|
|
||||||
|
for (unsigned int i = 0; i < num_points; i++) {
|
||||||
|
SV** point_sv = av_fetch(poly_av, i, 0);
|
||||||
|
AV* point_av = (AV*)SvRV(*point_sv);
|
||||||
|
Point& p = (*retval)[i];
|
||||||
|
p.x = (unsigned long)SvIV(*av_fetch(point_av, 0, 0));
|
||||||
|
p.y = (unsigned long)SvIV(*av_fetch(point_av, 1, 0));
|
||||||
|
}
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
SV*
|
||||||
|
polygon2perl(Polygon& poly) {
|
||||||
|
const unsigned int num_points = poly.size();
|
||||||
|
AV* av = newAV();
|
||||||
|
av_extend(av, num_points-1);
|
||||||
|
for (unsigned int i = 0; i < num_points; i++) {
|
||||||
|
av_store(av, i, poly[i]._toPerl());
|
||||||
|
}
|
||||||
|
return (SV*)newRV_noinc((SV*)av);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
|
@ -1,7 +1,6 @@
|
||||||
#include "myinit.h"
|
#include "myinit.h"
|
||||||
#include "Point.hpp"
|
#include "Point.hpp"
|
||||||
|
|
||||||
Point::Point(unsigned long x, unsigned long y) {}
|
|
||||||
Point::~Point() {}
|
Point::~Point() {}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@ class Point
|
||||||
public:
|
public:
|
||||||
unsigned long x;
|
unsigned long x;
|
||||||
unsigned long y;
|
unsigned long y;
|
||||||
Point(unsigned long _x, unsigned long _y): x(_x), y(_y) {};
|
Point(unsigned long _x = 0, unsigned long _y = 0): x(_x), y(_y) {};
|
||||||
~Point();
|
~Point();
|
||||||
SV* _toPerl();
|
SV* _toPerl();
|
||||||
};
|
};
|
||||||
|
|
25
xs/t/04_expolygon.t
Normal file
25
xs/t/04_expolygon.t
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
#!/usr/bin/perl
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
|
||||||
|
use Slic3r::XS;
|
||||||
|
use Test::More tests => 1;
|
||||||
|
|
||||||
|
my $square = [ # ccw
|
||||||
|
[100, 100],
|
||||||
|
[200, 100],
|
||||||
|
[200, 200],
|
||||||
|
[100, 200],
|
||||||
|
];
|
||||||
|
my $hole_in_square = [ # cw
|
||||||
|
[140, 140],
|
||||||
|
[140, 160],
|
||||||
|
[160, 160],
|
||||||
|
[160, 140],
|
||||||
|
];
|
||||||
|
|
||||||
|
my $expolygon = Slic3r::ExPolygon::XS->new($square, $hole_in_square);
|
||||||
|
is_deeply [ @$expolygon ], [$square, $hole_in_square], 'expolygon roundtrip';
|
||||||
|
|
||||||
|
__END__
|
51
xs/xsp/ExPolygon.xsp
Normal file
51
xs/xsp/ExPolygon.xsp
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
%module{Slic3r::XS};
|
||||||
|
|
||||||
|
%{
|
||||||
|
#include <myinit.h>
|
||||||
|
#include "ExPolygon.hpp"
|
||||||
|
%}
|
||||||
|
|
||||||
|
%name{Slic3r::ExPolygon::XS} class ExPolygon {
|
||||||
|
%{
|
||||||
|
|
||||||
|
ExPolygon*
|
||||||
|
ExPolygon::new(...)
|
||||||
|
CODE:
|
||||||
|
RETVAL = new ExPolygon ();
|
||||||
|
// ST(0) is class name, ST(1) is contour and others are holes
|
||||||
|
RETVAL->contour = *perl2polygon(ST(1));
|
||||||
|
for (unsigned int i = 2; i < items; i++) {
|
||||||
|
RETVAL->holes.push_back(*perl2polygon(ST(i)));
|
||||||
|
}
|
||||||
|
OUTPUT:
|
||||||
|
RETVAL
|
||||||
|
|
||||||
|
SV*
|
||||||
|
ExPolygon::_toPerl()
|
||||||
|
CODE:
|
||||||
|
const unsigned int num_holes = THIS->holes.size();
|
||||||
|
AV* av = newAV();
|
||||||
|
av_fill(av, num_holes); // -1 +1
|
||||||
|
av_store(av, 0, polygon2perl(THIS->contour));
|
||||||
|
for (unsigned int i = 0; i < num_holes; i++) {
|
||||||
|
av_store(av, i+1, polygon2perl(THIS->holes[i]));
|
||||||
|
}
|
||||||
|
RETVAL = (SV*)newRV_noinc((SV*)av);
|
||||||
|
OUTPUT:
|
||||||
|
RETVAL
|
||||||
|
|
||||||
|
%}
|
||||||
|
};
|
||||||
|
|
||||||
|
%package{Slic3r::ExPolygon::XS};
|
||||||
|
|
||||||
|
%{
|
||||||
|
PROTOTYPES: DISABLE
|
||||||
|
|
||||||
|
std::string
|
||||||
|
hello_world()
|
||||||
|
CODE:
|
||||||
|
RETVAL = "Hello world!";
|
||||||
|
OUTPUT:
|
||||||
|
RETVAL
|
||||||
|
%}
|
|
@ -6,7 +6,7 @@
|
||||||
%}
|
%}
|
||||||
|
|
||||||
%name{Slic3r::Point::XS} class Point {
|
%name{Slic3r::Point::XS} class Point {
|
||||||
Point(unsigned long _x, unsigned long _y);
|
Point(unsigned long _x = 0, unsigned long _y = 0);
|
||||||
~Point();
|
~Point();
|
||||||
SV* _toPerl();
|
SV* _toPerl();
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
ZTable* O_OBJECT
|
ZTable* O_OBJECT
|
||||||
TriangleMesh* O_OBJECT
|
TriangleMesh* O_OBJECT
|
||||||
Point* O_OBJECT
|
Point* O_OBJECT
|
||||||
|
ExPolygon* O_OBJECT
|
||||||
std::vector< unsigned int >* T_STD_VECTOR_UINT_PTR
|
std::vector< unsigned int >* T_STD_VECTOR_UINT_PTR
|
||||||
|
|
Loading…
Reference in a new issue