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

com.prowidesoftware.swift.model.SwiftValueBlock Maven / Gradle / Ivy

/*
 * Copyright 2006-2023 Prowide
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.prowidesoftware.swift.model;

import java.io.Serializable;
import java.util.logging.Level;

/**
 * Base class for SWIFT blocks that contain its fields concatenated as a single fixed length value; blocks 1 and 2.
* This is an abstract class so specific block classes for each block should be instantiated. * * @author sebastian * @since 4.0 */ public abstract class SwiftValueBlock extends SwiftBlock implements Serializable { private static final long serialVersionUID = -3680693640473937755L; @SuppressWarnings("unused") private static final transient java.util.logging.Logger log = java.util.logging.Logger.getLogger(SwiftValueBlock.class.getName()); /** * Default constructor, shouldn't be used normally. * present only for subclasses */ protected SwiftValueBlock() {} /** * This method should be overwritten by subclasses, calling * this method will throw a java.lang.UnsupportedOperationException * * @return N/A */ public String getBlockValue() { throw new UnsupportedOperationException( "cannot call getBlockValue on SwiftValueBlock, must be on specific subclasses"); } /** * This method should be overwritten by subclasses, calling * this method will throw a java.lang.UnsupportedOperationException * * @param value unused */ public void setBlockValue(final String value) { throw new UnsupportedOperationException( "cannot call setBlockValue on SwiftValueBlock, must be on specific subclasses"); } /** * This method should be overwritten by subclasses, calling * this method will throw a java.lang.UnsupportedOperationException * * @return the blocks value as a single string */ public String getValue() { throw new UnsupportedOperationException( "cannot call getValue on SwiftValueBlock, must be on specific subclasses"); } /** * This method should be overwritten by subclasses and proper * parsing be done to set specific values of the block, calling * this method will throw a java.lang.UnsupportedOperationException * * @param value the blocks value as a single string */ public void setValue(final String value) { throw new UnsupportedOperationException( "cannot call setValue on SwiftValueBlock, must be on specific subclasses"); } /** * Tells if the block contains at least one field. * This method must be called on specific subclasses, calling it for SwiftValueBlock will throw * a java.lang.UnsupportedOperationException * * @return true if getValue returns a non null object */ public boolean isEmpty() { return this.getValue() == null; } /** * Tells the block's string value size (in chars).
* NOTICE this does not return the actual number of fields set * because value blocks are mostly fixed length. * This method must be called on specific subclasses, calling it for SwiftValueBlock will throw * a java.lang.UnsupportedOperationException * * @return the size of the value or zero if value is null */ public int size() { return this.getValue() == null ? 0 : this.getValue().length(); } /** * returns a fragment of the block value received (or null if value is not large enough).
* This method is used in derived classes to get value fragments. * * @param value the full block value * @param start the starting point of the fragment in the big block value * @param size the fragment size * @return the value fragment or null if value is not large enough */ protected String getValuePart(final String value, final int start, int size) { // prepare the result String s = null; // check start is within bounds if (start < value.length()) { // check start+size is within bounds int boundedSize; if (start + size >= value.length()) { boundedSize = value.length() - start; } else { boundedSize = size; } // get the fragment try { s = value.substring(start, start + boundedSize); } catch (final IndexOutOfBoundsException e) { log.log(Level.SEVERE, "Exception parsing value part", e); } } return s; } /** * Returns a fragment of the block value received from a starting index until the end of value * (or null if value is not large enough).
*

* This method is used in derived classes to get value fragments. * * @param value the full block value * @param start the starting point of the fragment in the big block value * @return the value fragment or null if value is not large enough * @since 7.7 */ protected String getValuePart(final String value, final int start) { // check start is within bounds if (start < value.length()) { return value.substring(start); } return null; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy