gdv.xport.feld.Betrag Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gdv-xport-lib Show documentation
Show all versions of gdv-xport-lib Show documentation
gdv-xport-lib ist die Java-Bibliothek fuer den Umgang mit dem GDV-Format.
Sie erleichtert den Export und Export dieses Datenformats.
/*
* Copyright (c) 2009 - 2012 by Oli B.
*
* 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 orimplied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* (c)reated 11.10.2009 by Oli B. ([email protected])
*/
package gdv.xport.feld;
import gdv.xport.annotation.FeldInfo;
/**
* Standardmaessig hat das Beitrags-Feld 12,2 Stellen (12 Vorkommastellen +
* 2 Nachkommastellen.
*
* @author oliver
* @since 11.10.2009
* @version $Revision$
*/
public class Betrag extends NumFeld {
/**
* Legt ein neues Betrags-Feld an. Die Informationen dazu werden
* aus der uebergebenen Enum bezogen.
*
* TODO: Wird mit v6 entfernt.
*
*
* @param feldX Enum mit den Feldinformationen
* @since 0.9
* @deprecated Enums werden ab v6 nicht mehr unterstuetzt
*/
@Deprecated
public Betrag(final Enum feldX) {
super(feldX);
}
/**
* Instantiiert ein neuen Betrag.
*
* TODO: Wird mit v6 entfernt.
*
*
* @param feldX Feld
* @param info mit der Start-Adresse und weiteren Angaben
* @since 0.6
* @deprecated Enums werden ab v6 nicht mehr unterstuetzt
*/
@Deprecated
public Betrag(final Enum feldX, final FeldInfo info) {
super(feldX, info);
}
/**
* Instantiiert einen neuen Betrag.
*
* @param name Name des Feldes
* @param length Laenge
* @param start Start-Byte (beginnend bei 1)
* @since 1.0
*/
public Betrag(final Bezeichner name, final int length, final int start) {
super(name, length, start, 0, 2);
}
/**
* Instantiiert einen neuen Betrag.
*
* TODO: Wird mit v6 entfernt.
*
*
* @param name Bezeichner
* @param info mit der Start-Adresse und weiteren Angaben
* @since 1.0
* @deprecated Enums werden ab v6 nicht mehr unterstuetzt
*/
@Deprecated
public Betrag(final Bezeichner name, final FeldInfo info) {
super(name, info);
}
/**
* Dies ist der Copy-Constructor, mit dem man ein bestehendes Feld
* kopieren kann.
*
* @param other das originale Feld
*/
public Betrag(final Feld other) {
super(other);
}
/* (non-Javadoc)
* @see gdv.xport.feld.NumFeld#setInhalt(int)
*/
@Override
public void setInhalt(final int n) {
assert n >= 0 : "Betrag can't store negative number (" + n + ")";
super.setInhalt(n * 100);
}
/**
* Setzt den Inhalt eines Feldes neu.
* @param x der neue Inhalt
*/
public void setInhalt(final double x) {
assert x >= 0 : "Betrag can't store negative number (" + x + ")";
long n = Math.round(x * 100);
super.setInhalt(n);
}
/* (non-Javadoc)
* @see gdv.xport.feld.NumFeld#toInt()
*/
@Override
public int toInt() {
return super.toInt() / 100;
}
@Override
public long toLong() {
return super.toLong() / 100L;
}
@Override
public double toDouble() {
return super.toLong() / 100.0;
}
/* (non-Javadoc)
* @see gdv.xport.feld.Feld#clone()
*/
@SuppressWarnings("squid:S2975")
@Override
public Object clone() {
return new Betrag(this);
}
public static Betrag of(Feld feld) {
Betrag betrag = new Betrag(feld.getBezeichner(), feld.getAnzahlBytes(), feld.getByteAdresse());
betrag.setInhalt(feld.getInhalt());
return betrag;
}
}