Algorithm-RectanglesContainingDot_XS
view release on metacpan or search on metacpan
RectanglesContainingDot_XS.xs view on Meta::CPAN
}
#ifdef MYDEBUG
struct alloc {
U32 size;
U32 _barrier;
};
void failed_assertion(pTHX_ char *str, int line, char *file) {
fprintf(stderr, "assertion %s failed at %s line %d\n", str, line, file);
fflush(stderr);
exit(1);
}
#define my_assert(a) if(!(a)) failed_assertion(aTHX_ #a, __LINE__, __FILE__)
void *
my_malloc(int count, int size) {
struct alloc *a = malloc(sizeof(struct alloc) + count * size + 1);
char *c = (char*)(a+1);
a->size = count * size;
RectanglesContainingDot_XS.xs view on Meta::CPAN
my_assert(left);
my_assert(right);
my_assert(left_size);
my_assert(right_size);
my_assert(right_size < size);
my_assert(left_size < size);
*left = allocate_division(aTHX_ left_size);
*right = allocate_division(aTHX_ right_size);
// fprintf(stderr, "%d => %d, %d\n", size, left_size, right_size);
rectsl = (*left)->rects;
rectsr = (*right)->rects;
for (i = 0; i < size; i++) {
struct rectangle *rect = rects[i];
if (dir == 'x') {
if (cut >= rect->x0) *(rectsl++) = rect;
if (cut < rect->x1) *(rectsr++) = rect;
}
RectanglesContainingDot_XS.xs view on Meta::CPAN
bestx = find_best_cut(aTHX_ rects, size, 'x', &bestxx, &sizelx, &sizerx);
if (bestx > 0)
besty = find_best_cut(aTHX_ rects, size, 'y', &bestyy, &sizely, &sizery);
else
besty = 1;
if (bestx < besty) {
if (bestx < bestreq) {
// fprintf(stderr, "bestx: %f, bestreq: %f\n", bestx, bestreq);
part_division(aTHX_ rects, size, bestxx, 'x', &(div->left), sizelx, &(div->right), sizerx);
div->cut = bestxx;
Safefry(div->rects);
div->rects = NULL;
return div->dir = 'x';
}
}
else {
if (besty < bestreq) {
// fprintf(stderr, "besty: %f, bestreq: %f\n", besty, bestreq);
part_division(aTHX_ rects, size, bestyy, 'y', &(div->left), sizely, &(div->right), sizery);
div->cut = bestyy;
Safefry(div->rects);
div->rects = NULL;
return div->dir = 'y';
}
}
}
return div->dir = 'n';
}
PerlIO_flush||5.007003|
PerlIO_get_base||5.007003|
PerlIO_get_bufsiz||5.007003|
PerlIO_get_cnt||5.007003|
PerlIO_get_ptr||5.007003|
PerlIO_read||5.007003|
PerlIO_seek||5.007003|
PerlIO_set_cnt||5.007003|
PerlIO_set_ptrcnt||5.007003|
PerlIO_setlinebuf||5.007003|
PerlIO_stderr||5.007003|
PerlIO_stdin||5.007003|
PerlIO_stdout||5.007003|
PerlIO_tell||5.007003|
PerlIO_unread||5.007003|
PerlIO_write||5.007003|
Poison|5.008000||p
RETVAL|||n
Renewc|||
Renew|||
SAVECLEARSV|||
vwarner||5.006000|
vwarn||5.006000|
wait4pid|||
warn_nocontext|||vn
warner_nocontext|||vn
warner||5.006000|v
warn|||v
watch|||
whichsig|||
write_no_mem|||
write_to_stderr|||
yyerror|||
yylex|||
yyparse|||
yywarn|||
);
if (exists $opt{'list-unsupported'}) {
my $f;
for $f (sort { lc $a cmp lc $b } keys %API) {
next unless $API{$f}{todo};
( run in 0.462 second using v1.01-cache-2.11-cpan-49f99fa48dc )