Class OmStringDefSeg
- java.lang.Object
-
- com.automation_pros.odva.cip.path.PathSegment
-
- com.automation_pros.odva.cip.path.DataDefinitionSeg
-
- com.automation_pros.odva.cip.path.OmStringDefSeg
-
- All Implemented Interfaces:
java.lang.Comparable<PathSegment>
public class OmStringDefSeg extends DataDefinitionSeg
Encapsulates an elementary data type annotation within a CIP Path definition. Type annotations are generally not passed on the wire, but delimit the path fragment that will go on the wire (before the data type) from the path fragment that will be applied to the payload on the wire.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classOmStringDefSeg.DecoderDecode bytes expected to contain one encoded path segment.static classOmStringDefSeg.ParserRegistered as "omstring".-
Nested classes/interfaces inherited from class com.automation_pros.odva.cip.path.DataDefinitionSeg
DataDefinitionSeg.DataDefinitionFragment
-
Nested classes/interfaces inherited from class com.automation_pros.odva.cip.path.PathSegment
PathSegment.HasAlternateHex
-
-
Field Summary
Fields Modifier and Type Field Description protected intallocationprotected booleanlocked-
Fields inherited from class com.automation_pros.odva.cip.path.DataDefinitionSeg
sLogger
-
Fields inherited from class com.automation_pros.odva.cip.path.PathSegment
identifierChars, segtype
-
-
Constructor Summary
Constructors Modifier Constructor Description OmStringDefSeg()protectedOmStringDefSeg(int allocation)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description intalignment(DataContext ctx)Alignment is normally the natural size of a primitive element.intcompareTo(PathSegment o)protected BaseDataType<?>construct(int[] dimensions, DataContext ctx)Construct an instance of the type represented by this definition, using the given dimensions.intgetAllocation()intgetBytes()Obtain the number of bytes needed to encode this segment instance in packed format.static OmStringDefSeggetCached(int allocation)protected intgetSizeImpl(DataContext ctx)Return the number of bytes occupied by a single instance of the given data type.java.util.List<java.lang.String>getTokens()booleanisStringData()Mark string implementations for special handling.OmStringDefSeglock()intmaxSize(DataContext ctx)Some data types need to offer a range of sizes for the encoded form of their data.intminSize(DataContext ctx)Some data types need to offer a range of sizes for the encoded form of their data.voidput(java.nio.ByteBuffer dest, boolean padded)Encode the current instance to the given destination.PathSegmentset(java.nio.ByteBuffer source, boolean padded)Replace the current instance content with the decoded source bytes.java.lang.StringsimpleString()Supply s simple descriptive name usable when browsing a hierarchy.-
Methods inherited from class com.automation_pros.odva.cip.path.DataDefinitionSeg
browseInner, construct, follow, followOffsets, fromClass, fromData, getPermItem, getSize, isBoolHost, isBoolImpl, nestedMaxSize, nestedMinSize, nestedSize, nestedSizeImpl
-
Methods inherited from class com.automation_pros.odva.cip.path.PathSegment
decode, decodeAll, equals, getSegtype, getWords, hexString, mergeTokens, registerHandler, setSegtype, toString
-
-
-
-
Method Detail
-
getCached
public static OmStringDefSeg getCached(int allocation)
-
lock
public OmStringDefSeg lock()
-
getAllocation
public int getAllocation()
-
isStringData
public boolean isStringData()
Description copied from class:DataDefinitionSegMark string implementations for special handling.- Overrides:
isStringDatain classDataDefinitionSeg- Returns:
-
getSizeImpl
protected int getSizeImpl(DataContext ctx)
Description copied from class:DataDefinitionSegReturn the number of bytes occupied by a single instance of the given data type. When the data is indirect, size is zero. When the data is variable length, size is -1;- Specified by:
getSizeImplin classDataDefinitionSeg- Returns:
- Number of bytes.
-
minSize
public int minSize(DataContext ctx)
Description copied from class:DataDefinitionSegSome data types need to offer a range of sizes for the encoded form of their data. The common case is fixed.- Overrides:
minSizein classDataDefinitionSeg- Returns:
-
maxSize
public int maxSize(DataContext ctx)
Description copied from class:DataDefinitionSegSome data types need to offer a range of sizes for the encoded form of their data. The common case is fixed.- Overrides:
maxSizein classDataDefinitionSeg- Returns:
-
alignment
public int alignment(DataContext ctx)
Description copied from class:DataDefinitionSegAlignment is normally the natural size of a primitive element. Structured types and variable length types must override this method.- Overrides:
alignmentin classDataDefinitionSeg- Returns:
-
construct
protected BaseDataType<?> construct(int[] dimensions, DataContext ctx)
Description copied from class:DataDefinitionSegConstruct an instance of the type represented by this definition, using the given dimensions. This is an implementation detail that permits a DecoratedDefSeg to create arrays.Use the provided context to look up any ambiguous data types.
- Specified by:
constructin classDataDefinitionSeg- Returns:
-
compareTo
public int compareTo(PathSegment o)
- Specified by:
compareToin interfacejava.lang.Comparable<PathSegment>- Overrides:
compareToin classPathSegment
-
simpleString
public java.lang.String simpleString()
Description copied from class:PathSegmentSupply s simple descriptive name usable when browsing a hierarchy. A simple type name for elementary types, a non-detailed description for complex types.- Specified by:
simpleStringin classPathSegment- Returns:
-
set
public PathSegment set(java.nio.ByteBuffer source, boolean padded)
Description copied from class:PathSegmentReplace the current instance content with the decoded source bytes.The caller must ensure that the instance is appropriate for the bytes supplied. This permits instance re-use in optimized applications.
- Specified by:
setin classPathSegment- Parameters:
source- The bytes to be decoded. The position will be left after the last byte of the decoded segment.padded- Alternate format selection. Packed format when false.- Returns:
- The same instance.
-
put
public void put(java.nio.ByteBuffer dest, boolean padded)Description copied from class:PathSegmentEncode the current instance to the given destination.- Specified by:
putin classPathSegment- Parameters:
dest- The buffer receiving the complete encoded instance.padded- Alternate format selection. Packed format when false.
-
getBytes
public int getBytes()
Description copied from class:PathSegmentObtain the number of bytes needed to encode this segment instance in packed format.- Specified by:
getBytesin classPathSegment- Returns:
- Number of bytes, assuming put() will be called with padded false.
-
getTokens
public java.util.List<java.lang.String> getTokens()
- Specified by:
getTokensin classPathSegment
-
-