GeometryReverseTest.java

package org.locationtech.jts.geom;

import test.jts.GeometryTestCase;
import test.jts.GeometryTestData;

public class GeometryReverseTest  extends GeometryTestCase {

  public static void main(String[] args) throws Exception {
    junit.textui.TestRunner.run(GeometryReverseTest.class);
  }

  public GeometryReverseTest(String name) {
    super(name);
  }

  public void testReverse() {
    for (String wkt : GeometryTestData.WKT_ALL) {
      checkReverse( read( wkt ));
    }
  }

  private void checkReverse(final Geometry g) {
    int SRID = 123;
    g.setSRID(SRID );

    //User data left out for now
    //Object DATA = new Integer(999);
    //g.setUserData(DATA);

    Geometry reverse = g.reverse();

    assertTrue( g.getGeometryType() + ": Geometry types are not the same", g.getGeometryType() == reverse.getGeometryType());
    assertEquals(g.getGeometryType() +": Geometry.getSRID() values are not the same", g.getSRID(), reverse.getSRID());

    assertTrue( g.getGeometryType() +": Sequences are not opposite", checkSequences(g, reverse) );
  }

  private boolean checkSequences(Geometry g1, Geometry g2) {
    int numGeometries = g1.getNumGeometries();
    if (numGeometries != g2.getNumGeometries())
      return false;
    for (int i = 0; i < numGeometries; i++)
    {
      Geometry gt1 = g1.getGeometryN(i);
      int j = i; //g1 instanceof MultiLineString ? numGeometries - i - 1 : i;
      Geometry gt2 = g2.getGeometryN(j);

      if (gt1.getGeometryType() != gt2.getGeometryType())
        return false;

      if (gt1 instanceof Point) {
        if (!checkSequences(((Point)gt1).getCoordinateSequence(), ((Point)gt2).getCoordinateSequence()))
          return false;
      }
      else if (gt1 instanceof LineString) {
        if (!checkSequences(((LineString)gt1).getCoordinateSequence(), ((LineString)gt2).getCoordinateSequence()))
          return false;
      }
      else if (gt1 instanceof Polygon) {
        Polygon pt1 = (Polygon)gt1;
        Polygon pt2 = (Polygon)gt2;
        if (!checkSequences(pt1.getExteriorRing().getCoordinateSequence(),
                            pt2.getExteriorRing().getCoordinateSequence()))
          return false;
        for (int k = 0; k < pt1.getNumInteriorRing(); k++) {
          if (!checkSequences(pt1.getInteriorRingN(k).getCoordinateSequence(),
                              pt2.getInteriorRingN(k).getCoordinateSequence()))
            return false;
        }
      }
      else if (gt1 instanceof GeometryCollection) {
        checkSequences(gt1, gt2);
      }
      else {
        return false;
      }
    }
    return true;
  }

  private boolean checkSequences(CoordinateSequence c1, CoordinateSequence c2) {

    if (c1.size() != c2.size())
      return false;
    if (c1.getDimension() != c2.getDimension())
      return false;
    if (c1.getMeasures() != c2.getMeasures())
      return false;

    for (int i = 0; i < c1.size(); i++)
    {
      int j = c1.size() - i - 1;
      for (int k = 0; k < c1.getDimension(); k++)
        if (c1.getOrdinate(i, k) != c2.getOrdinate(j, k))
          if (!(Double.isNaN(c1.getOrdinate(i, k)) && Double.isNaN(c2.getOrdinate(j, k))))
            return false;
    }
    return true;
  }
}