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 BufferedRandomAccessFile
s) einzulesen und sie wieder zu schreiben.
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final int
Größe des Headers fär Konfigurationsobjekte: ID (long), PidHashCode (int), Typ-ID (long), Objekttyp (byte), Ungültig (short), Gültig (short)static final int
static final int
Größ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 BinaryObject
fromDataInput
(DataInput input) Liest ein Objekt einabstract long
Gibt die Objekt-ID zurückabstract byte[]
Gibt die gepackten Bytes zurück.abstract int
Gibt den Pid-Hashcode zurückabstract long
Gibt die ID des Objekttyps zuückabstract SystemObjectInformation
toSystemObjectInfo
(ConfigAreaFile file, long position) abstract int
write
(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:
IOException
de.bsvrz.sys.funclib.dataSerializer.NoSuchVersionException
-