Package ghidra.program.model.data
Class BadDataType
- java.lang.Object
- 
- ghidra.program.model.data.AbstractDataType
- 
- ghidra.program.model.data.DataTypeImpl
- 
- ghidra.program.model.data.BuiltIn
- 
- ghidra.program.model.data.BadDataType
 
 
 
 
- 
- All Implemented Interfaces:
- BuiltInDataType,- DataType,- Dynamic,- ExtensionPoint,- java.util.EventListener,- javax.swing.event.ChangeListener
 
 public class BadDataType extends BuiltIn implements Dynamic Provides an implementation of a data type that is not valid (bad) as it is used in the program. For example, the class for the underlying data type may no longer be available or the data type may not fit where it has been placed in the program.This field is not meant to be loaded by the ClassSearcher, hence the X in the name.
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from interface ghidra.util.classfinder.ExtensionPointExtensionPoint.Exclude, ExtensionPoint.Util
 
- 
 - 
Field SummaryFields Modifier and Type Field Description static BadDataTypedataType- 
Fields inherited from class ghidra.program.model.data.DataTypeImpldefaultSettings
 - 
Fields inherited from class ghidra.program.model.data.AbstractDataTypecategoryPath, dataMgr, name
 - 
Fields inherited from interface ghidra.program.model.data.DataTypeCONFLICT_SUFFIX, DEFAULT, NO_LAST_CHANGE_TIME, NO_SOURCE_SYNC_TIME, VOID
 
- 
 - 
Constructor SummaryConstructors Constructor Description BadDataType()BadDataType(DataTypeManager dtm)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description booleancanSpecifyLength()Returns true if a user-specified length can be usedDataTypeclone(DataTypeManager dtm)Returns a new instance of this DataType with its universalID and SourceArchive identity retained.java.lang.StringgetDescription()Get a String briefly describing this DataType.intgetLength()Get the length (number of 8-bit bytes) of this DataType.intgetLength(MemBuffer buf, int maxLength)Compute the length for this data-type which corresponds to the specified memory location.java.lang.StringgetMnemonic(Settings settings)Get the mnemonic for this DataType.DataTypegetReplacementBaseType()Returns a suitable replacement base data-type for pointers and arrays when exporting to C codejava.lang.StringgetRepresentation(MemBuffer buf, Settings settings, int length)Get bytes from memory in a printable format for this type.java.lang.ObjectgetValue(MemBuffer buf, Settings settings, int length)Get the data in the form of the appropriate Object for this DataType.booleanisDynamicallySized()Indicates if this data-type is dynamically sized based upon DataOrganization.booleanisEquivalent(DataType dt)Returns true if the given dataType is equivalent to this dataType.- 
Methods inherited from class ghidra.program.model.data.BuiltInaddParent, copy, dataTypeDeleted, dataTypeNameChanged, dataTypeReplaced, dataTypeSizeChanged, dependsOn, getBuiltInSettingsDefinitions, getCTypeDeclaration, getCTypeDeclaration, getCTypeDeclaration, getCTypeDeclaration, getDecompilerDisplayName, getLastChangeTime, getSettingsDefinitions, getUniversalID, removeParent, setCategoryPath, setName, setNameAndCategory
 - 
Methods inherited from class ghidra.program.model.data.DataTypeImplequals, getAlignment, getDefaultSettings, getLastChangeTimeInSourceArchive, getParents, getPathName, getSourceArchive, getValueClass, hashCode, notifyDeleted, notifyNameChanged, notifyReplaced, notifySizeChanged, replaceWith, setDefaultSettings, setDescription, setLastChangeTime, setLastChangeTimeInSourceArchive, setSourceArchive, stateChanged
 - 
Methods inherited from class ghidra.program.model.data.AbstractDataTypegetCategoryPath, getDataOrganization, getDataTypeManager, getDataTypePath, getDefaultAbbreviatedLabelPrefix, getDefaultLabelPrefix, getDefaultLabelPrefix, getDefaultOffcutLabelPrefix, getDisplayName, getDocs, getName, isDeleted, isNotYetDefined, toString
 - 
Methods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface ghidra.program.model.data.BuiltInDataTypegetCTypeDeclaration
 - 
Methods inherited from interface ghidra.program.model.data.DataTypeaddParent, copy, dataTypeDeleted, dataTypeNameChanged, dataTypeReplaced, dataTypeSizeChanged, dependsOn, getAlignment, getCategoryPath, getDataOrganization, getDataTypeManager, getDataTypePath, getDefaultAbbreviatedLabelPrefix, getDefaultLabelPrefix, getDefaultLabelPrefix, getDefaultOffcutLabelPrefix, getDefaultSettings, getDisplayName, getDocs, getLastChangeTime, getLastChangeTimeInSourceArchive, getName, getParents, getPathName, getSettingsDefinitions, getSourceArchive, getUniversalID, getValueClass, isDeleted, isNotYetDefined, removeParent, replaceWith, setCategoryPath, setDefaultSettings, setDescription, setLastChangeTime, setLastChangeTimeInSourceArchive, setName, setNameAndCategory, setSourceArchive
 
- 
 
- 
- 
- 
Field Detail- 
dataTypepublic static final BadDataType dataType 
 
- 
 - 
Constructor Detail- 
BadDataTypepublic BadDataType() 
 - 
BadDataTypepublic BadDataType(DataTypeManager dtm) 
 
- 
 - 
Method Detail- 
getMnemonicpublic java.lang.String getMnemonic(Settings settings) Description copied from interface:DataTypeGet the mnemonic for this DataType.- Specified by:
- getMnemonicin interface- DataType
- Overrides:
- getMnemonicin class- AbstractDataType
- Returns:
- the mnemonic for this DataType.
- See Also:
- DataType.getMnemonic(Settings)
 
 - 
getLengthpublic int getLength() Description copied from interface:DataTypeGet the length (number of 8-bit bytes) of this DataType.- Specified by:
- getLengthin interface- DataType
- Returns:
- the length of this DataType
- See Also:
- DataType.getLength()
 
 - 
isDynamicallySizedpublic boolean isDynamicallySized() Description copied from interface:DataTypeIndicates if this data-type is dynamically sized based upon DataOrganization.- Specified by:
- isDynamicallySizedin interface- DataType
- Overrides:
- isDynamicallySizedin class- AbstractDataType
- See Also:
- DataType.isDynamicallySized()
 
 - 
getDescriptionpublic java.lang.String getDescription() Description copied from interface:DataTypeGet a String briefly describing this DataType.- Specified by:
- getDescriptionin interface- DataType
- Returns:
- a one-liner describing this DataType.
- See Also:
- DataType.getDescription()
 
 - 
getValuepublic java.lang.Object getValue(MemBuffer buf, Settings settings, int length) Description copied from interface:DataTypeGet the data in the form of the appropriate Object for this DataType. For instance if the data type is an AddressDT, return an Address object. a Byte, return a Scalar* (maybe this should be a Byte) a Float, return a Float- Specified by:
- getValuein interface- DataType
- Parameters:
- buf- the data buffer.
- settings- the settings to use.
- length- the number of bytes to get the value from.
- Returns:
- the data Object.
- See Also:
- DataType.getValue(ghidra.program.model.mem.MemBuffer, ghidra.docking.settings.Settings, int)
 
 - 
isEquivalentpublic boolean isEquivalent(DataType dt) Description copied from interface:DataTypeReturns true if the given dataType is equivalent to this dataType. The precise meaning of "equivalent" is dataType dependent.- Specified by:
- isEquivalentin interface- DataType
- Overrides:
- isEquivalentin class- BuiltIn
- Parameters:
- dt- the dataType being tested for equivalence.
- Returns:
- true if the if the given dataType is equivalent to this dataType.
 
 - 
getRepresentationpublic java.lang.String getRepresentation(MemBuffer buf, Settings settings, int length) Description copied from interface:DataTypeGet bytes from memory in a printable format for this type.- Specified by:
- getRepresentationin interface- DataType
- Parameters:
- buf- the data.
- settings- the settings to use for the representation.
- length- the number of bytes to represent.
- Returns:
- the representation of the data in this format, never null.
- See Also:
- DataType.getRepresentation(MemBuffer, Settings, int)
 
 - 
clonepublic DataType clone(DataTypeManager dtm) Description copied from interface:DataTypeReturns a new instance of this DataType with its universalID and SourceArchive identity retained. Note: for built-in DataType's, clone and copy should have the same affect.
 - 
canSpecifyLengthpublic boolean canSpecifyLength() Description copied from interface:DynamicReturns true if a user-specified length can be used- Specified by:
- canSpecifyLengthin interface- Dynamic
 
 - 
getLengthpublic int getLength(MemBuffer buf, int maxLength) Description copied from interface:DynamicCompute the length for this data-type which corresponds to the specified memory location.- Specified by:
- getLengthin interface- Dynamic
- Parameters:
- buf- memory location
- maxLength- maximum number of bytes to consume in computing length, or -1 for unspecified.
- Returns:
- data length or -1 if it could not be determined. Returned length may exceed maxLength if data-type does not supported constrained lengths.
 
 - 
getReplacementBaseTypepublic DataType getReplacementBaseType() Description copied from interface:DynamicReturns a suitable replacement base data-type for pointers and arrays when exporting to C code- Specified by:
- getReplacementBaseTypein interface- Dynamic
- Returns:
- suitable base data-type for this Dynamic data-type
 
 
- 
 
-