Class BinaryObject

java.lang.Object
de.bsvrz.puk.config.configFile.fileaccess.BinaryObject
Direct Known Subclasses:
BinaryConfigObject, BinaryDynamicObject

public abstract class BinaryObject extends Object
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 Details

    • CONFIG_OBJ_HEADER_SIZE

      public static final int CONFIG_OBJ_HEADER_SIZE
      Größ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_SIZE
      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)
      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

      public static BinaryObject fromDataInput(DataInput input) throws IOException
      Liest ein Objekt ein
      Parameters:
      input - Eingabe-Stream oder BufferedRandomAccessFile, 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

      public abstract int write(DataOutput output) throws IOException
      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