/** * Returns the singleton instance of geometric class of the given type. * * @param string $type type of the geometric object * * @return GISGeometry the singleton instance of geometric class * of the given type * * @access public * @static */ public static function factory($type) { $type_lower = strtolower($type); $file = './libraries/gis/GIS' . ucfirst($type_lower) . '.php'; if (!PMA_isValid($type_lower, PMA\libraries\Util::getGISDatatypes()) || !file_exists($file)) { return false; } if (include_once $file) { switch (strtoupper($type)) { case 'MULTIPOLYGON': return GISMultipolygon::singleton(); case 'POLYGON': return GISPolygon::singleton(); case 'MULTIPOINT': return GISMultipoint::singleton(); case 'POINT': return GISPoint::singleton(); case 'MULTILINESTRING': return GISMultilinestring::singleton(); case 'LINESTRING': return GISLinestring::singleton(); case 'GEOMETRYCOLLECTION': return GISGeometrycollection::singleton(); default: return false; } } else { return false; } }
/** * Returns the singleton instance of geometric class of the given type. * * @param string $type type of the geometric object * * @return GISGeometry the singleton instance of geometric class * of the given type * * @access public * @static */ public static function factory($type) { switch (strtoupper($type)) { case 'MULTIPOLYGON': return GISMultipolygon::singleton(); case 'POLYGON': return GISPolygon::singleton(); case 'MULTIPOINT': return GISMultipoint::singleton(); case 'POINT': return GISPoint::singleton(); case 'MULTILINESTRING': return GISMultilinestring::singleton(); case 'LINESTRING': return GISLinestring::singleton(); case 'GEOMETRYCOLLECTION': return GISGeometrycollection::singleton(); default: return false; } }
/** * Sets up the fixture, for example, opens a network connection. * This method is called before a test is executed. * * @access protected * @return void */ protected function setUp() { $this->object = GISPolygon::singleton(); }