#include <2geom/region.h> #include <2geom/utils.h> #include <2geom/shape.h> namespace Geom { Region Region::operator*(Affine const &m) const { Region r((m.flips() ? boundary.reverse() : boundary) * m, fill); if(box && m.isZoom()) r.box = (*box) * m; return r; } bool Region::invariants() const { return self_crossings(boundary).empty(); } unsigned outer_index(Regions const &ps) { if(ps.size() <= 1 || ps[0].contains(ps[1])) { return 0; } else { /* Since we've already shown that chunks[0] is not outside it can be used as an exemplar inner. */ Point exemplar = Path(ps[0]).initialPoint(); for(unsigned i = 1; i < ps.size(); i++) { if(ps[i].contains(exemplar)) { return i; } } } return ps.size(); } } /* Local Variables: mode:c++ c-file-style:"stroustrup" c-file-offsets:((innamespace . 0)(inline-open . 0)(case-label . +)) indent-tabs-mode:nil fill-column:99 End: */ // vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:fileencoding=utf-8:textwidth=99 :