package com.esri.hadoop.hive;
import org.apache.hadoop.hive.ql.exec.Description;
import com.esri.core.geometry.OperatorCrosses;
import com.esri.core.geometry.OperatorSimpleRelation;
@Description(
name = "ST_Crosses",
value = "_FUNC_(geometry1, geometry2) - return true if geometry1 crosses geometry2",
extended = "Example:\n" +
"SELECT _FUNC_(st_linestring(0,0, 1,1), st_linestring(1,0, 0,1)) from src LIMIT 1; -- return true\n" +
"SELECT _FUNC_(st_linestring(2,0, 2,3), st_polygon(1,1, 1,4, 4,4, 4,1)) from src LIMIT 1; -- return true\n" +
"SELECT _FUNC_(st_linestring(0,2, 0,1), ST_linestring(2,0, 1,0)) from src LIMIT 1; -- return false"
)
public class ST_Crosses extends ST_GeometryRelational {
@Override
protected OperatorSimpleRelation getRelationOperator() {
return OperatorCrosses.local();
}
@Override
public String getDisplayString(String[] args) {
return String.format("returns true if %s crosses %s", args[0], args[1]);
}
}