All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.firebirdsql.gds.ng.fields.RowDescriptor Maven / Gradle / Ivy

There is a newer version: 6.0.0-beta-1
Show newest version
/*
 * Public Firebird Java API.
 *
 * Redistribution and use in source and binary forms, with or without 
 * modification, are permitted provided that the following conditions are met:
 *    1. Redistributions of source code must retain the above copyright notice, 
 *       this list of conditions and the following disclaimer.
 *    2. Redistributions in binary form must reproduce the above copyright 
 *       notice, this list of conditions and the following disclaimer in the 
 *       documentation and/or other materials provided with the distribution. 
 *    3. The name of the author may not be used to endorse or promote products 
 *       derived from this software without specific prior written permission.
 * 
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED 
 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 
 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO 
 * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 
 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 
 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 
 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */
package org.firebirdsql.gds.ng.fields;

import org.firebirdsql.encodings.IEncodingFactory;
import org.firebirdsql.gds.ng.DatatypeCoder;

import java.util.Iterator;
import java.util.List;

import static java.util.Objects.requireNonNull;

/**
 * The class {@code RowDescriptor} is a java mapping of the XSQLDA server data structure used to describe the row
 * metadata of one row for input or output.
 * 

* RowDescriptor is immutable, values of a row are maintained separately in a {@link RowValue}. *

* * @author Mark Rotteveel * @version 3.0 */ public final class RowDescriptor implements Iterable { private static final FieldDescriptor[] NO_DESCRIPTORS = new FieldDescriptor[0]; private final List fieldDescriptors; private final DatatypeCoder datatypeCoder; private int hash; /** * Creates an instance of {@code RowDescriptor} with the supplied array of * {@link FieldDescriptor} instances. * * @param fieldDescriptors * field descriptors (array is copied before use) * @param datatypeCoder * datatype coder for the connection that uses this RowDescriptor. */ private RowDescriptor(FieldDescriptor[] fieldDescriptors, DatatypeCoder datatypeCoder) { this.fieldDescriptors = List.of(fieldDescriptors); this.datatypeCoder = requireNonNull(datatypeCoder, "dataTypeCoder should not be null"); } /** * @return The {@link org.firebirdsql.gds.ng.DatatypeCoder}. */ public DatatypeCoder getDatatypeCoder() { return datatypeCoder; } /** * @return The {@link org.firebirdsql.encodings.IEncodingFactory}. */ public IEncodingFactory getEncodingFactory() { return datatypeCoder.getEncodingFactory(); } /** * @return The number of fields. */ public int getCount() { return fieldDescriptors.size(); } /** * Gets the {@link FieldDescriptor} at the specified (0-based) index. * * @param index * 0-based index of the field * @return FieldDescriptor * @throws java.lang.IndexOutOfBoundsException * if index is not {@code 0 <= index < getCount} */ public FieldDescriptor getFieldDescriptor(int index) { return fieldDescriptors.get(index); } /** * @return An immutable List of the {@link FieldDescriptor} instances of this row. */ public List getFieldDescriptors() { return fieldDescriptors; } /** * Creates a {@link RowValue} instance with default ({@code null}) values for each field. *

* All fields are marked as uninitialized. *

*

* The (0-based) index of the each field value in the {@link RowValue} corresponds with the (0-based) index of the * {@link FieldDescriptor} within this {@code RowDescriptor}. *

* * @return Uninitialized and empty {@code RowValue} instance for a row described by this descriptor. * @see RowValue#defaultFor(RowDescriptor) */ public RowValue createDefaultFieldValues() { return RowValue.defaultFor(this); } /** * Creates a deleted row marker. *

* A deleted row marker is used in JDBC result sets for deleted rows, and to discern them from (updated) rows that * are simply all {@code NULL}. This is for Jaybird internal implementation needs only. *

* * @return Deleted row marker with {@code count} number of rows, all set to null */ public RowValue createDeletedRowMarker() { return RowValue.deletedRowMarker(getCount()); } @Override public Iterator iterator() { return fieldDescriptors.iterator(); } @Override public String toString() { StringBuilder sb = new StringBuilder("RowDescriptor: ["); for (int idx = 0; idx < fieldDescriptors.size(); idx++) { sb.append(idx).append('='); FieldDescriptor descriptor = fieldDescriptors.get(idx); if (descriptor != null) { descriptor.appendFieldDescriptor(sb); } else { sb.append("[null]"); } sb.append(','); } if (!fieldDescriptors.isEmpty()) { // Remove last ',' sb.setLength(sb.length() - 1); } sb.append(']'); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (!(obj instanceof RowDescriptor other)) return false; return this.fieldDescriptors.equals(other.fieldDescriptors); } @Override public int hashCode() { if (hash != 0) return hash; int newHash = fieldDescriptors.hashCode(); return hash = newHash != 0 ? newHash : 1; } /** * Creates an instance of {@code RowDescriptor} with the supplied {@link FieldDescriptor} instances. * * @param fieldDescriptors * field descriptors (array is cloned before use) * @param datatypeCoder * datatype coder for the connection that uses this RowDescriptor. * @return {@code RowDescriptor} instance */ public static RowDescriptor createRowDescriptor(FieldDescriptor[] fieldDescriptors, DatatypeCoder datatypeCoder) { return new RowDescriptor(fieldDescriptors, datatypeCoder); } /** * Returns an empty row descriptor with the specified datatype coder. * * @param datatypeCoder * datatype coder for the connection that uses this RowDescriptor. * @return Empty row descriptor */ public static RowDescriptor empty(DatatypeCoder datatypeCoder) { return new RowDescriptor(NO_DESCRIPTORS, datatypeCoder); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy