Class BinaryObject
java.lang.Object
de.bsvrz.puk.config.configFile.fileaccess.BinaryObject
- Direct Known Subclasses:
BinaryConfigObject,BinaryDynamicObject
Binäre Darstellung eines Objekts in der Konfigurationsdatei (
ConfigAreaFile).
Diese Klasse bietet einfache Methoden um Objekte aus DataInput-Objekten (wie DataInputStreams oder BufferedRandomAccessFiles) einzulesen und sie wieder zu schreiben.
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final intGröße des Headers fär Konfigurationsobjekte: ID (long), PidHashCode (int), Typ-ID (long), Objekttyp (byte), Ungültig (short), Gültig (short)static final intstatic final intGröße des Headers fär dynamische Objekte: ID (long), PidHashCode (int), Typ-ID (long), Objekttyp (byte), Ungültig (long), Gültig (long), Simulationsvariante (short)static final int -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionstatic BinaryObjectfromDataInput(DataInput input) Liest ein Objekt einabstract longGibt die Objekt-ID zurückabstract byte[]Gibt die gepackten Bytes zurück.abstract intGibt den Pid-Hashcode zurückabstract longGibt die ID des Objekttyps zuückabstract SystemObjectInformationtoSystemObjectInfo(ConfigAreaFile file, long position) abstract intwrite(DataOutput output) Schreibt das Objekt in den Ausgabe-Stream
-
Field Details
-
CONFIG_OBJ_HEADER_SIZE
public static final int CONFIG_OBJ_HEADER_SIZEGröße des Headers fär Konfigurationsobjekte: ID (long), PidHashCode (int), Typ-ID (long), Objekttyp (byte), Ungültig (short), Gültig (short)- See Also:
-
DYN_OBJ_HEADER_SIZE
public static final int DYN_OBJ_HEADER_SIZEGröße des Headers fär dynamische Objekte: ID (long), PidHashCode (int), Typ-ID (long), Objekttyp (byte), Ungültig (long), Gültig (long), Simulationsvariante (short)- See Also:
-
CONFIGURATION_OBJECT_TYPE
public static final int CONFIGURATION_OBJECT_TYPE- See Also:
-
DYNAMIC_OBJECT_TYPE
public static final int DYNAMIC_OBJECT_TYPE- See Also:
-
-
Constructor Details
-
BinaryObject
public BinaryObject()
-
-
Method Details
-
fromDataInput
Liest ein Objekt ein- Parameters:
input- Eingabe-Stream oderBufferedRandomAccessFile, das sich an der richtigen Position befindet. Der Stream befindet sich nach dem Einlesen garantiert an der Position nach dem Objekt (oder der Lücke), wo also ein weiteres Objekt gelesen werden kännte.- Returns:
- Eingelesenes Objekt oder null, wenn sich an dieser Position eine Lücke befindet.
- Throws:
IOException
-
write
Schreibt das Objekt in den Ausgabe-Stream- Parameters:
output- Ausgabe- Returns:
- Anzahl geschriebener Bytes
- Throws:
IOException
-
getObjectId
public abstract long getObjectId()Gibt die Objekt-ID zurück- Returns:
- die Objekt-ID oder 0 falls es sich um eine Lücke handelt
-
getPidHashCode
public abstract int getPidHashCode()Gibt den Pid-Hashcode zurück- Returns:
- den Pid-Hashcode
-
getTypeId
public abstract long getTypeId()Gibt die ID des Objekttyps zuück- Returns:
- die ID des Objekttyps
-
getPackedBytes
public abstract byte[] getPackedBytes()Gibt die gepackten Bytes zurück. Die gepackten Bytes enthalten weitere Objektinformationen wie die Name, Pid, Konfigurationsdaten usw.- Returns:
- die gepackten Bytes
-
toSystemObjectInfo
public abstract SystemObjectInformation toSystemObjectInfo(ConfigAreaFile file, long position) throws IOException, de.bsvrz.sys.funclib.dataSerializer.NoSuchVersionException - Throws:
IOExceptionde.bsvrz.sys.funclib.dataSerializer.NoSuchVersionException
-