internal ITcAdsDataType ResolveType(ITcAdsDataType dataType, DataTypeResolveStrategy strategy) { ITcAdsDataType ret = dataType; if (strategy == DataTypeResolveStrategy.Alias) { while ((ret != null) && (ret.Category == DataTypeCategory.Alias)) { this.TryGetDataType(ret.BaseTypeName, out ret); } } else if (strategy == DataTypeResolveStrategy.AliasReference) { while ((ret != null) && ((ret.Category == DataTypeCategory.Alias) || (ret.Category == DataTypeCategory.Reference))) { if (ret.Category == DataTypeCategory.Alias) { this.TryGetDataType(ret.BaseTypeName, out ret); } else { string str; if (DataTypeStringParser.TryParseReference(ret.Name, out str)) { this.TryGetDataType(str, out ret); } else { ret = null; } } } } return(ret); }
internal TcAdsSymbolInfo CreateReferenceSymbol(TcAdsSymbolInfo parent, int subIndex) { if (parent == null) { throw new ArgumentNullException("parent"); } TcAdsSymbolInfo subSymbol = null; if (subIndex == 0) { TcAdsDataType dataType = (TcAdsDataType)parent.DataType; string referencedType = string.Empty; if (DataTypeStringParser.TryParseReference(parent.DataType.Name, out referencedType)) { TcAdsDataType typeByName = (TcAdsDataType)this._parser.GetTypeByName(referencedType); if (typeByName != null) { subSymbol = new TcAdsSymbolInfo(this._parser, parent, subIndex, typeByName); this.calcFieldAddress(parent, subSymbol, null, out subSymbol.indexGroup, out subSymbol.indexOffset); } else { object[] args = new object[] { referencedType }; Module.Trace.TraceWarning("Cannot create Reference Symbol. Dereferenced Type '{0}' not found!", args); } } } return(subSymbol); }
public IDataType ResolveType(DataTypeResolveStrategy type) { TcAdsDataType baseType = this; TcAdsDataType type3 = this; if (type == DataTypeResolveStrategy.Alias) { while (true) { if ((baseType == null) || (baseType.Category != DataTypeCategory.Alias)) { if ((baseType == null) && (this.Category == DataTypeCategory.Alias)) { object[] args = new object[] { type3.Name }; Module.Trace.TraceWarning("Cannot resolve type '{0}", args); } break; } type3 = baseType; baseType = (TcAdsDataType)baseType.BaseType; } } else if (type == DataTypeResolveStrategy.AliasReference) { while (true) { if ((baseType == null) || ((baseType.Category != DataTypeCategory.Alias) && (baseType.Category != DataTypeCategory.Reference))) { if ((baseType == null) && ((this.Category == DataTypeCategory.Alias) || (this.Category == DataTypeCategory.Reference))) { object[] args = new object[] { type3.Name }; Module.Trace.TraceWarning("Cannot resolve type '{0}", args); } break; } if (baseType.Category == DataTypeCategory.Alias) { type3 = baseType; baseType = (TcAdsDataType)baseType.BaseType; } else { string str; if (!DataTypeStringParser.TryParseReference(baseType.Name, out str)) { type3 = baseType; baseType = null; } else { type3 = baseType; IDataType type4 = null; this._table.TryResolveType(str, out type4); baseType = (TcAdsDataType)type4; } } } } return(baseType); }
public bool TryGetReference(out string referencedType) { ITcAdsDataType type = this.ResolveType(DataTypeResolveStrategy.AliasReference); string typeName = this.typeName; if (type != null) { typeName = type.Name; } return(DataTypeStringParser.TryParseReference(typeName, out referencedType)); }
public bool TryResolveType(string name, out IDataType ret) { if (string.IsNullOrEmpty(name)) { throw new ArgumentNullException("typeName"); } ITcAdsDataType type = null; if ((this._dataTypes != null) && !this._dataTypes.TryGetDataType(name, out type)) { int length = 0; bool isUnicode = false; AdsDatatypeArrayInfo[] dims = null; if (DataTypeStringParser.TryParseString(name, out length, out isUnicode)) { AdsDatatypeId dataType = isUnicode ? AdsDatatypeId.ADST_WSTRING : AdsDatatypeId.ADST_STRING; type = new TcAdsDataType(name, dataType, isUnicode ? ((uint)((length + 1) * 2)) : ((uint)(length + 1)), AdsDataTypeFlags.DataType, DataTypeCategory.String, typeof(string), this); } else { string str; if (DataTypeStringParser.TryParsePointer(name, out str)) { ITcAdsDataType type2 = (ITcAdsDataType)this.ResolveDataType(str); type = new TcAdsDataType(name, AdsDatatypeId.ADST_BIGTYPE, (uint)this.PlatformPointerSize, AdsDataTypeFlags.DataType, DataTypeCategory.Pointer, null, this); } else if (DataTypeStringParser.TryParseReference(name, out str)) { ITcAdsDataType type3 = (ITcAdsDataType)this.ResolveDataType(str); type = new TcAdsDataType(name, AdsDatatypeId.ADST_BIGTYPE, (uint)this.PlatformPointerSize, AdsDataTypeFlags.DataType, DataTypeCategory.Reference, null, this); } else if (DataTypeStringParser.TryParseArray(name, out dims, out str)) { ITcAdsDataType type4 = (ITcAdsDataType)this.ResolveDataType(str); if (type4 != null) { type = new TcAdsDataType(name, str, (uint)type4.Size, dims, this); } } } if (type == null) { this.OnTypeResolveError(name); } else { this._dataTypes.Add(type); this.OnTypeCreated(type); } } ret = type; return(ret != null); }
public override bool TryGetReference(out string referenceType) => DataTypeStringParser.TryParseReference(base.typeName, out referenceType);
public virtual bool TryGetReference(out string referenceType) => DataTypeStringParser.TryParseReference(this.entryName, out referenceType);
public static void ParseTypes(AdsStream dataTypeStream, Encoding encoding, IBinder binder, bool buildInTypesInStream, DataTypeCollection <IDataType> buildInTypes) { AdsBinaryReader reader = new AdsBinaryReader(dataTypeStream); string referencedType = null; while (dataTypeStream.Position < dataTypeStream.Length) { AdsDataTypeEntry entry = new AdsDataTypeEntry(true, encoding, reader); try { IDataType type = null; bool flag1 = buildInTypes.TryGetType(entry.entryName, out type); DataType type2 = (DataType)type; if (buildInTypesInStream && flag1) { continue; } DataType type3 = null; int length = 0; if (DataTypeStringParser.TryParseReference(entry.entryName, out referencedType)) { type3 = new ReferenceType(entry, referencedType); } else if (DataTypeStringParser.TryParsePointer(entry.entryName, out referencedType)) { type3 = new PointerType(entry, referencedType); } else { bool flag2; if (DataTypeStringParser.TryParseString(entry.entryName, out length, out flag2)) { type3 = !flag2 ? ((DataType) new StringType(length)) : ((DataType) new WStringType(length)); } else if (entry.methodCount > 0) { type3 = new RpcStructType(entry); } else if (entry.subItems > 0) { bool flag3 = false; bool flag4 = false; if (entry.subItems > 1) { int num2 = 0; AdsFieldEntry[] subEntries = entry.subEntries; int index = 0; while (true) { if (index >= subEntries.Length) { flag3 = entry.BitSize < num2; break; } AdsFieldEntry entry2 = subEntries[index]; if (!entry2.IsStatic && !entry2.IsProperty) { int num4 = 0; num4 = !entry2.IsBitType ? (entry2.Offset * 8) : entry2.Offset; flag4 |= num4 < num2; num2 += entry2.BitSize; } index++; } } type3 = !flag3 ? ((DataType) new StructType(entry)) : ((DataType) new UnionType(entry)); } else if (entry.arrayDim > 0) { type3 = new ArrayType(entry); } else if (entry.enumInfoCount <= 0) { if (DataTypeStringParser.TryParseSubRange(entry.entryName, out referencedType)) { type3 = (DataType)SubRangeTypeFactory.Create(entry, binder); } else if (((entry.baseTypeId > AdsDatatypeId.ADST_VOID) && (entry.typeName != null)) && (entry.typeName != string.Empty)) { type3 = new AliasType(entry); } else { DataTypeCategory cat = CategoryConverter.FromId(entry.DataTypeId); if (cat != DataTypeCategory.Unknown) { Type tp = null; if (PrimitiveTypeConverter.TryGetManagedType(entry.DataTypeId, out tp)) { if (cat == DataTypeCategory.Primitive) { type3 = new PrimitiveType(entry, PrimitiveTypeConverter.GetPrimitiveFlags(entry.DataTypeId), tp); } else if (cat == DataTypeCategory.String) { type3 = new StringType(entry); } } } if (type3 == null) { type3 = new DataType(cat, entry); } } } else { AdsDatatypeId baseTypeId = entry.baseTypeId; if (baseTypeId == AdsDatatypeId.ADST_INT16) { type3 = new EnumType <short>(entry); } else if (baseTypeId == AdsDatatypeId.ADST_INT32) { type3 = new EnumType <int>(entry); } else { switch (baseTypeId) { case AdsDatatypeId.ADST_INT8: type3 = new EnumType <sbyte>(entry); break; case AdsDatatypeId.ADST_UINT8: type3 = new EnumType <byte>(entry); break; case AdsDatatypeId.ADST_UINT16: type3 = new EnumType <ushort>(entry); break; case AdsDatatypeId.ADST_UINT32: type3 = new EnumType <uint>(entry); break; case AdsDatatypeId.ADST_INT64: type3 = new EnumType <long>(entry); break; case AdsDatatypeId.ADST_UINT64: type3 = new EnumType <ulong>(entry); break; default: throw new AdsException("Enum base type mismatch!"); } } } } binder.RegisterType(type3); } catch (Exception exception) { Module.Trace.TraceWarning($"Cannot parse DataTypeEntry. Skipping dataType '{entry.entryName}'!", exception); } } }
internal static bool TryParseType(string typeName, IBinder resolver, out IDataType type) { if (typeName == null) { throw new ArgumentNullException("typeName"); } if (resolver == null) { throw new ArgumentNullException("resolver"); } if (typeName == string.Empty) { throw new ArgumentException(); } DataType type2 = null; int length = -1; bool isUnicode = false; if (DataTypeStringParser.TryParseString(typeName, out length, out isUnicode)) { type2 = !isUnicode ? ((DataType) new StringType(length)) : ((DataType) new WStringType(length)); resolver.RegisterType(type2); resolver.OnTypeGenerated(type2); type = type2; return(true); } DimensionCollection dims = null; string baseType = null; if (DataTypeStringParser.TryParseArray(typeName, out dims, out baseType)) { IDataType type3 = null; if (resolver.TryResolveType(baseType, out type3)) { type2 = new ArrayType(typeName, (DataType)type3, dims, AdsDataTypeFlags.DataType); resolver.RegisterType(type2); resolver.OnTypeGenerated(type2); type = type2; return(true); } resolver.OnTypeResolveError(typeName); object[] args = new object[] { typeName }; Module.Trace.TraceWarning("Array Type '{0}' could not be resolved. Not in DataType tables. Ignoring Type!", args); type = null; return(false); } string referencedType = null; if (DataTypeStringParser.TryParsePointer(typeName, out referencedType)) { type2 = new PointerType(typeName, referencedType); resolver.RegisterType(type2); resolver.OnTypeGenerated(type2); type = type2; return(true); } if (DataTypeStringParser.TryParseReference(typeName, out referencedType)) { type2 = new ReferenceType(typeName, referencedType, resolver.PlatformPointerSize); resolver.RegisterType(type2); resolver.OnTypeGenerated(type2); type = type2; return(true); } type2 = (DataType)SubRangeTypeFactory.Create(typeName, resolver); if (type2 == null) { type = null; resolver.OnTypeResolveError(typeName); return(false); } resolver.RegisterType(type2); resolver.OnTypeGenerated(type2); type = type2; return(true); }
internal TcAdsDataType(AdsDataTypeEntry entry, IDataTypeResolver table) : this() { if (entry == null) { throw new ArgumentNullException("entry"); } if (table == null) { throw new ArgumentNullException("table"); } this._table = table; this._size = entry.size; this._typeName = entry.entryName; this._typeHashValue = entry.typeHashValue; this._comment = entry.Comment; this._flags = entry.flags; this._offset = entry.offset; this._dataTypeId = entry.baseTypeId; if (entry.nameLength > 0) { bool isUnicode = false; int length = 0; string referencedType = null; AdsDatatypeArrayInfo[] dims = null; string baseType = null; if (entry.IsArray) { if (DataTypeStringParser.TryParseArray(this._typeName, out dims, out baseType)) { this._category = DataTypeCategory.Array; this._arrayInfo = dims; this._baseTypeName = baseType; } else { this._arrayInfo = entry.arrayInfos; this._category = DataTypeCategory.Array; this._baseTypeName = entry.Name; } } else if (DataTypeStringParser.TryParseString(this._typeName, out length, out isUnicode)) { this._category = DataTypeCategory.String; } else if (DataTypeStringParser.TryParseReference(this._typeName, out referencedType)) { this._baseTypeName = referencedType; this._category = DataTypeCategory.Reference; } else if (DataTypeStringParser.TryParsePointer(this._typeName, out referencedType)) { this._baseTypeName = referencedType; this._category = DataTypeCategory.Pointer; } else if (DataTypeStringParser.TryParseSubRange(this._typeName, out referencedType)) { this._baseTypeName = entry.Name; this._category = DataTypeCategory.SubRange; } else if (!string.IsNullOrEmpty(entry.Name)) { this._baseTypeName = entry.Name; this._category = DataTypeCategory.Alias; } } if (entry.subItems <= 0) { if (entry.IsEnum) { this._enumInfos = entry.enums; this._category = DataTypeCategory.Enum; bool flag3 = PrimitiveTypeConverter.TryGetManagedType(this._dataTypeId, out this._managedType); } } else { this._subItems = new TcAdsSubItem[entry.subItems]; bool flag2 = false; int num2 = 0; int index = 0; while (true) { int num1; if (index < entry.subItems) { if (entry.subEntries[index] != null) { this._subItems[index] = new TcAdsSubItem(entry.subEntries[index], table); if (!this._subItems[index].IsStatic && !this._subItems[index].IsProperty) { int num4 = 0; num4 = !this._subItems[index].IsBitType ? (this._subItems[index].Offset * 8) : this._subItems[index].Offset; flag2 |= num4 < num2; num2 += this._subItems[index].BitSize; } index++; continue; } object[] args = new object[] { index, entry.Name }; Module.Trace.TraceError("SubEntry '{0}' missing in TcAdsDataType '{1}'", args); } if ((entry.subItems <= 1) || (entry.BitSize >= num2)) { num1 = 0; } else { num1 = (int)!entry.IsBitType; } this._category = ((num1 & flag2) == 0) ? DataTypeCategory.Struct : DataTypeCategory.Union; break; } } if (entry.HasAttributes) { this._attributes = entry.attributes; } if (entry.HasRpcMethods) { this._rpcMethodInfos = entry.methods; } if (this._category == DataTypeCategory.Unknown) { this._category = (entry.DataTypeId != AdsDatatypeId.ADST_BIGTYPE) ? DataTypeCategory.Primitive : DataTypeCategory.Interface; } if ((this._category == DataTypeCategory.Array) && string.IsNullOrEmpty(this._baseTypeName)) { string message = $"Base type of ARRAY '{this._typeName}' not defined!"; Module.Trace.TraceWarning(message); } }