summaryrefslogtreecommitdiff
path: root/src/interfaces/jdbc/postgresql/util/PGmoney.java
blob: 0d094dbf10846552134f2f806269e220f3b770b3 (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
package postgresql.util;

import java.io.*;
import java.sql.*;

/**
 * This implements a class that handles the PostgreSQL money and cash types
 */
public class PGmoney extends PGobject implements Serializable,Cloneable
{
  /**
   * The value of the field
   */
  public double val;
  
  /**
   * @param value of field
   */
  public PGmoney(double value) {
    this();
    val = value;
  }
  
  /**
   * This is called mainly from the other geometric types, when a
   * point is imbeded within their definition.
   *
   * @param value Definition of this point in PostgreSQL's syntax
   */
  public PGmoney(String value) throws SQLException
  {
    this();
    setValue(value);
  }
  
  /**
   * Required by the driver
   */
  public PGmoney()
  {
    setType("money");
  }
  
  /**
   * @param s Definition of this point in PostgreSQL's syntax
   * @exception SQLException on conversion failure
   */
  public void setValue(String s) throws SQLException
  {
    try {
      String s1;
      boolean negative;

      negative = (s.charAt(0) == '-') ;

      s1 = s.substring(negative ? 2 : 1);
  
      int pos = s1.indexOf(',');
      while (pos != -1) {
        s1 = s1.substring(0,pos) + s1.substring(pos +1);
        pos = s1.indexOf(',');
      }

      val = Double.valueOf(s1).doubleValue();
      val = negative ? -val : val;

    } catch(NumberFormatException e) {
      throw new PSQLException("postgresql.money",e);
    }
  }
  
  /**
   * @param obj Object to compare with
   * @return true if the two boxes are identical
   */
  public boolean equals(Object obj)
  {
    if(obj instanceof PGmoney) {
      PGmoney p = (PGmoney)obj;
      return val == p.val;
    }
    return false;
  }
  
  /**
   * This must be overidden to allow the object to be cloned
   */
  public Object clone()
  {
    return new PGmoney(val);
  }
  
  /**
   * @return the PGpoint in the syntax expected by postgresql
   */
  public String getValue()
  {
    if (val < 0) {
      return "-$" + (-val);
    }
    else {
      return "$"+val;
    }
  }
}