gdv.xport.satz.model.SpartensatzX 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) 2011-2013 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 06.04.2011 by Oli B. ([email protected])
*/
package gdv.xport.satz.model;
import gdv.xport.satz.feld.FeldX;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import java.util.Map;
/**
* Dies ist die gemeinsame Oberklasse aller Saetze in diesem Package, die nach
* dem SOP-Muster aufgebaut sind und eine Sparte besitzen.
*
* Die alten Spartensatz-Klasse, die schon laengere Zeit als "deprecated"
* markiert war, wurde mit 2.0 entsorgt. Der Name "SpartensatzX" fuer diese
* Klasse wurde aber beibehalten.
*
*
* @author oliver ([email protected])
* @since 0.6 (06.04.2011)
* @deprecated Enums mit Annotationen werden ab v6 nicht mehr unterstuetzt
*/
@Deprecated
public abstract class SpartensatzX extends SatzX {
private static final Logger LOG = LogManager.getLogger(SpartensatzX.class);
/** Wird fuer den Default-Ctor gebraucht. */
protected static final int UNKNOWN_SPARTE = 0;
/**
* Instantiates a new spartensatz x.
*
* @param satzart the satzart
* @param felder the felder
*/
public SpartensatzX(final int satzart, final Enum[] felder) {
super(satzart, felder);
}
/**
* Instantiates a new spartensatz x.
*
* @param satzart the satzart
* @param sparte the sparte
*/
public SpartensatzX(final int satzart, final int sparte) {
super(satzart, FeldX.values());
this.setSparte(sparte);
}
/**
* Instantiates a new spartensatz x.
*
* @param satzart the satzart
* @param sparte the sparte
* @param felder the felder
*/
public SpartensatzX(final int satzart, final int sparte, final Enum[] felder) {
super(satzart, sparte, felder);
}
/**
* Liefert die Mapping-Tabelle der abgeleiteten Klasse.
*
* @return the mapping
*/
protected abstract Map getMapping();
/**
* Liefert die entsprechende Enum-Felder zur angeforderten Spalte zurueck.
*
* @param sparte Sparte
* @return the Enum-Felder
*/
protected Enum[] getFelderFor(final int sparte) {
Map map = this.getMapping();
Enum[] felder = map.get(sparte);
if (felder == null) {
return FeldX.values();
}
return felder;
}
/**
* Abhaengig von der Sparte muessen wir hier noch die verschiedenen
* Teildatensaetze aufsetzen.
*
* @param x Sparte (z.B. 30)
* @see gdv.xport.satz.Datensatz#setSparte(int)
*/
@Override
public void setSparte(final int x) {
if (this.getSparte() == x) {
LOG.debug("nothing to do here - old Sparte = new Sparte (" + x + ")");
return;
}
Enum[] felder = this.getFelderFor(x);
this.setUpTeildatensaetze(felder);
super.setSparte(x);
}
}