com.ibm.as400.access.DateFieldDescription Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jt400 Show documentation
Show all versions of jt400 Show documentation
The Open Source version of the IBM Toolbox for Java
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (AS/400 Toolbox for Java - OSS version)
//
// Filename: DateFieldDescription.java
//
// The source code contained herein is licensed under the IBM Public License
// Version 1.0, which has been approved by the Open Source Initiative.
// Copyright (C) 1997-2000 International Business Machines Corporation and
// others. All rights reserved.
//
///////////////////////////////////////////////////////////////////////////////
package com.ibm.as400.access;
import java.io.Serializable;
import java.util.Vector;
//@B0A
import java.util.Date;
import java.util.HashSet;
import java.text.SimpleDateFormat;
/**
*Represents the description of the data in a date field.
*It allows:
*
*- The user to describe a date field to the RecordFormat object.
*
- The RecordFormat object to describe a date field to the user.
*
*Click hereto see an example.
**/
public class DateFieldDescription extends FieldDescription implements Serializable
{
static final long serialVersionUID = 4L;
static HashSet formatsWithFixedSeparators_;
// The date format for this field
private String dateFormat_ = null;
// The date separator for this field
private String dateSeparator_ = null;
/**
*Constructs a DateFieldDescription object.
**/
public DateFieldDescription()
{
}
/**
*Constructs a DateFieldDescription object. It uses the specified data type and name
*of the field.
*The length of the field will be the length specified on the AS400Text object.
*@param dataType Describes the field and provides
* the conversion capability for the contents of the field.
*@param name The name of the field.
**/
public DateFieldDescription(AS400Text dataType, String name)
{
super(dataType, name);
}
/**
*Constructs a DateFieldDescription object. It uses the specified data type, name, and
*DDS name of the field.
*@param dataType Describes the field and provides
* the conversion capability for the contents of the field.
*@param name The name of the field.
*@param ddsName The DDS name of this field. This is the
* name of the field as it would appear in a DDS description of the
* field. The length of ddsName must be 10 characters or less.
**/
public DateFieldDescription(AS400Text dataType, String name, String ddsName)
{
super(dataType, name, ddsName);
}
/**
*Constructs a DateFieldDescription object. It uses the specified data type and name
*of the field.
*The length of the field will be the length reported by the AS400Date object.
*@param dataType Describes the field and provides
* the conversion capability for the contents of the field.
*@param name The name of the field.
**/
public DateFieldDescription(AS400Date dataType, String name)
{
super(dataType, name);
}
/**
*Constructs a DateFieldDescription object. It uses the specified data type, name, and
*DDS name of the field.
*@param dataType Describes the field and provides
* the conversion capability for the contents of the field.
*@param name The name of the field.
*@param ddsName The DDS name of this field. This is the
* name of the field as it would appear in a DDS description of the
* field. The length of ddsName must be 10 characters or less.
**/
public DateFieldDescription(AS400Date dataType, String name, String ddsName)
{
super(dataType, name, ddsName);
}
/**
*Returns the value specified for the DATFMT keyword for this field.
*@return The value specified for DATFMT for
* this field. If DATFMT was not specified for this field,
* an empty string is returned.
**/
public String getDATFMT()
{
return (dateFormat_ == null ? "" : dateFormat_);
}
/**
*Returns the value specified for the DATSEP keyword for this field.
*@return The value specified for DATSEP for
* this field. If DATSEP was not specified for this field,
* an empty string is returned.
**/
public String getDATSEP()
{
return dateSeparator_ == null ? "" : dateSeparator_;
}
/**
*Returns the DDS description for the field. This is a string containing
*the description of the field as it would be specified in a DDS source file.
*This method is used by AS400File.createDDSSourceFile (called by the AS400File.create methods)
*to specify the field
*in the DDS source file which is used to create the file for the user who
*has passed in a RecordFormat object.
*@return The DDS description of this field properly formatted for entry
*into a DDS source file.
**/
String[] getDDSDescription()
{
Vector v = new Vector();
// Name columns (10)
StringBuffer desc = new StringBuffer(ddsName_);
// Blank pad the ddsName to 10 characters.
while(desc.length() < 10)
{
desc.append(" ");
}
// Reference column (1)
if (!refFld_.equals(""))
{
desc.append("R");
}
else
{
desc.append(" ");
}
// Get length as 5 digit string, right justified
// Length columns (5)
desc.append(" "); // No length can be specified for a date field
// Type column (1)
desc.append("L");
// Decimal positions columns (2)
desc.append(" ");
// Not used columns (7)
desc.append(" ");
// Add fixed portion of DDS description to Vector
v.addElement(desc.toString());
// Add the field level keywords
String[] keywords = super.getFieldFunctions();
if (keywords != null)
{
for (int i = 0; i < keywords.length; ++i)
{
v.addElement(keywords[i]);
}
}
if (dateFormat_ != null)
{
v.addElement("DATFMT(" + dateFormat_ + ") ");
}
if (dateSeparator_ != null)
{
if (!formatHasFixedSeparator(dateFormat_)) {
v.addElement("DATSEP('" + dateSeparator_ + "') ");
}
else {
if (Trace.traceOn_) Trace.log(Trace.DIAGNOSTIC, "DDS date format " + dateFormat_ + " has a fixed separator.");
}
}
if (defaultValue_ != null)
{
v.addElement("DFT('" + defaultValue_.toString() + "') ");
}
//@B0A
else if (isDFTNull_)
{
v.addElement("DFT(*NULL) ");
}
String[] s = new String[v.size()];
v.copyInto(s);
return s;
}
static boolean formatHasFixedSeparator(String format)
{
// According to the DDS spec for DATSEP:
// "If you specify the *ISO, *USA, *EUR, or *JIS date format value on the DATFMT keyword, you cannot specify the DATSEP keyword. These formats have a fixed date separator."
// Similarly, according to the DDS spec for TIMTSEP:
// "If you specify *ISO, *USA, *EUR, or *JIS time format on the TIMFMT keyword, you cannot specify the TIMSEP keyword. These formats have a fixed separator."
if (getFormatsWithFixedSeparators().contains(format)) return true;
else return false;
}
private static HashSet getFormatsWithFixedSeparators()
{
if (formatsWithFixedSeparators_ == null)
{
synchronized (DateFieldDescription.class)
{
if (formatsWithFixedSeparators_ == null)
{
formatsWithFixedSeparators_ = new HashSet(6);
formatsWithFixedSeparators_.add("*ISO");
formatsWithFixedSeparators_.add("*USA");
formatsWithFixedSeparators_.add("*EUR");
formatsWithFixedSeparators_.add("*JIS");
}
}
}
return formatsWithFixedSeparators_;
}
/**
*Sets the AS400DataType object describing this field.
*@param dataType The AS400DataType that describes this field. The dataType
*cannot be null.
**/
public void setDataType(AS400Text dataType)
{
// Verify parameters
if (dataType == null)
{
throw new NullPointerException("dataType");
}
dataType_ = dataType;
// Set the length of the field based on the data type
length_ = dataType.getByteLength();
}
/**
*Sets the AS400DataType object describing this field.
*@param dataType The AS400DataType that describes this field. The dataType
*cannot be null.
**/
public void setDataType(AS400Date dataType)
{
// Verify parameters
if (dataType == null)
{
throw new NullPointerException("dataType");
}
dataType_ = dataType;
// Set the length of the field based on the data type
length_ = dataType.getByteLength();
}
/**
*Sets the value to specify for the DATFMT keyword for this field.
*@param dateFormat The value to specify for DATFMT for
* this field. The dateFormat cannot be null.
**/
public void setDATFMT(String dateFormat)
{
if (dateFormat == null) throw new NullPointerException("dateFormat");
if (dateFormat.startsWith("*")) {
dateFormat_ = dateFormat.toUpperCase();
}
else {
dateFormat_ = "*" + dateFormat.toUpperCase();
}
// Inform the AS400Date object of the format.
if (dataType_ instanceof AS400Date) {
((AS400Date)dataType_).setFormat(dateFormat);
}
}
/**
*Sets the value to specify for the DATSEP keyword for this field.
*@param separator The value to specify for DATSEP for this field.
*A null value indicates "no separator".
**/
public void setDATSEP(String separator)
{
// Inform the AS400Date object of the separator.
if (dataType_ instanceof AS400Date)
{
if (separator != null && separator.length() > 1) {
throw new ExtendedIllegalArgumentException("separator (" + separator + ")", ExtendedIllegalArgumentException.LENGTH_NOT_VALID);
}
Character sep = ( separator == null ? null : Character.valueOf(separator.charAt(0)));
((AS400Date)dataType_).setSeparator(sep);
}
dateSeparator_ = separator;
}
//@B0C - javadoc
/**
*Sets the value for the DFT keyword for this field.
*@param defaultValue The default value for this
* field. The defaultValuecannot be null.
*To set a default value of *NULL, use the setDFTNull() method.
**/
public void setDFT(String defaultValue)
{
if (defaultValue == null)
{
throw new NullPointerException("defaultValue");
}
defaultValue_ = defaultValue;
isDFTNull_ = false; //@B0A
isDFTCurrent_ = false; //@B0A
DFTCurrentValue_ = null; //@B0A
}
//@B0A
/**
*Sets the default value for this field to be the current date.
*Calling this method will replace the DFT keyword that was previously
*set on a call to setDFT(String) or setDFTNull().
**/
public void setDFTCurrent()
{
isDFTCurrent_ = true;
isDFTNull_ = false;
defaultValue_ = null;
DFTCurrentValue_ = (new SimpleDateFormat("yyyy-MM-dd")).format(new Date());
}
//@B0A
/**
*Sets the value for the DFT keyword to be *NULL for this field.
*Calling this method will replace the DFT keyword that was previously
*set on a call to setDFT(String) or setDFTCurrent(). Note: This field
*must also have its ALWNULL keyword set to true to prevent DDS errors.
**/
public void setDFTNull()
{
isDFTNull_ = true;
defaultValue_ = null;
isDFTCurrent_ = false;
DFTCurrentValue_ = null;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy