Class GenericSaveable
java.lang.Object
ghidra.program.database.properties.GenericSaveable
- All Implemented Interfaces:
Saveable
GenericSaveable
is used by the DBPropertyMapManager
when the class can not be found and loaded for the class path name of a
property in the database. This allows the properties for that class to be
accessed in a generic way so that the manager can copy or remove the property
at a particular address. This allows the Diff and MultiUser Merge to compare
and manipulate the property as needed.-
Method Summary
Modifier and TypeMethodDescriptionboolean
Class<?>[]
Returns the field classes, in Java types, in the same order as usedSaveable.save(ghidra.util.ObjectStorage)
andSaveable.restore(ghidra.util.ObjectStorage)
.int
Get the storage schema version.int
hashCode()
boolean
Returns true if this saveable should not have it's changes broadcast.boolean
isUpgradeable
(int oldSchemaVersion) Determine if the implementation supports an storage upgrade of the specified oldSchemaVersion to the current schema version.void
restore
(ObjectStorage objStorage) Restore from the given ObjectStorage.void
save
(ObjectStorage objStorage) Save to the given ObjectStorage.toString()
boolean
upgrade
(ObjectStorage oldObjStorage, int oldSchemaVersion, ObjectStorage currentObjStorage) Upgrade an older stored object to the current storage schema.
-
Method Details
-
getObjectStorageFields
Description copied from interface:Saveable
Returns the field classes, in Java types, in the same order as usedSaveable.save(ghidra.util.ObjectStorage)
andSaveable.restore(ghidra.util.ObjectStorage)
.For example, if the save method calls
objStorage.putInt()
and thenobjStorage.putFloat()
, then this method must returnClass[]{ Integer.class, Float.class }
.- Specified by:
getObjectStorageFields
in interfaceSaveable
- Returns:
-
save
Description copied from interface:Saveable
Save to the given ObjectStorage. -
restore
Description copied from interface:Saveable
Restore from the given ObjectStorage. -
getSchemaVersion
public int getSchemaVersion()Description copied from interface:Saveable
Get the storage schema version. Any time there is a software release in which the implementing class has changed the data structure used for the save and restore methods, the schema version must be incremented. NOTE: While this could be a static method, the Saveable interface is unable to define such methods.- Specified by:
getSchemaVersion
in interfaceSaveable
- Returns:
- storage schema version.
-
isUpgradeable
public boolean isUpgradeable(int oldSchemaVersion) Description copied from interface:Saveable
Determine if the implementation supports an storage upgrade of the specified oldSchemaVersion to the current schema version.- Specified by:
isUpgradeable
in interfaceSaveable
- Parameters:
oldSchemaVersion
-- Returns:
- true if upgrading is supported for the older schema version.
-
upgrade
public boolean upgrade(ObjectStorage oldObjStorage, int oldSchemaVersion, ObjectStorage currentObjStorage) Description copied from interface:Saveable
Upgrade an older stored object to the current storage schema.- Specified by:
upgrade
in interfaceSaveable
- Parameters:
oldObjStorage
- the old stored objectoldSchemaVersion
- storage schema version number for the old objectcurrentObjStorage
- new object for storage in the current schema- Returns:
- true if data was upgraded to the currentObjStorage successfully.
-
isPrivate
public boolean isPrivate()Description copied from interface:Saveable
Returns true if this saveable should not have it's changes broadcast. -
hashCode
public int hashCode() -
equals
-
toString
-