aboutsummaryrefslogtreecommitdiff
path: root/src/interfaces/jdbc/postgresql/geometric/PGpath.java
blob: 45c162ac8aa74b1cb183e91d4f31af7a3229e2d2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
package postgresql.geometric;

import java.io.*;
import java.sql.*;
import postgresql.util.*;

/**
 * This implements a path (a multiple segmented line, which may be closed)
 */
public class PGpath extends PGobject implements Serializable,Cloneable
{
  /**
   * True if the path is open, false if closed
   */
  public boolean open;
  
  /**
   * The points defining this path
   */
  public PGpoint points[];
  
  /**
   * @param points the PGpoints that define the path
   * @param open True if the path is open, false if closed
   */
  public PGpath(PGpoint[] points,boolean open)
  {
    this();
    this.points = points;
    this.open = open;
  }
  
  /**
   * Required by the driver
   */
  public PGpath()
  {
    setType("path");
  }
  
  /**
   * @param s definition of the circle in PostgreSQL's syntax.
   * @exception SQLException on conversion failure
   */
  public PGpath(String s) throws SQLException
  {
    this();
    setValue(s);
  }
  
  /**
   * @param s Definition of the path in PostgreSQL's syntax
   * @exception SQLException on conversion failure
   */
  public void setValue(String s) throws SQLException
  {
    // First test to see if were open
    if(s.startsWith("[") && s.endsWith("]")) {
      open = true;
      s = PGtokenizer.removeBox(s);
    } else if(s.startsWith("(") && s.endsWith(")")) {
      open = false;
      s = PGtokenizer.removePara(s);
    } else
      throw new SQLException("cannot tell if path is open or closed");
    
    PGtokenizer t = new PGtokenizer(s,',');
    int npoints = t.getSize();
    points = new PGpoint[npoints];
    for(int p=0;p<npoints;p++)
      points[p] = new PGpoint(t.getToken(p));
  }
  
  /**
   * @param obj Object to compare with
   * @return true if the two boxes are identical
   */
  public boolean equals(Object obj)
  {
    if(obj instanceof PGpath) {
      PGpath p = (PGpath)obj;
      
      if(p.points.length != points.length)
	return false;
      
      if(p.open != open)
	return false;
      
      for(int i=0;i<points.length;i++)
	if(!points[i].equals(p.points[i]))
	  return false;
      
      return true;
    }
    return false;
  }
  
  /**
   * This must be overidden to allow the object to be cloned
   */
  public Object clone()
  {
    PGpoint ary[] = new PGpoint[points.length];
    for(int i=0;i<points.length;i++)
      ary[i]=(PGpoint)points[i].clone();
    return new PGpath(ary,open);
  }
  
  /**
   * This returns the polygon in the syntax expected by postgresql
   */
  public String getValue()
  {
    StringBuffer b = new StringBuffer(open?"[":"(");
    
    for(int p=0;p<points.length;p++) {
      if(p>0) b.append(",");
      b.append(points[p].toString());
    }    
    b.append(open?"]":")");
    
    return b.toString();
  }
  
  public boolean isOpen()
  {
    return open;
  }
  
  public boolean isClosed()
  {
    return !open;
  }
  
  public void closePath()
  {
    open = false;
  }
  
  public void openPath()
  {
    open = true;
  }
  
}