📄 cdblexpression.vb
字号:
' ' Visual Basic.Net Compiler' Copyright (C) 2004 - 2007 Rolf Bjarne Kvinge, RKvinge@novell.com' ' This library is free software; you can redistribute it and/or' modify it under the terms of the GNU Lesser General Public' License as published by the Free Software Foundation; either' version 2.1 of the License, or (at your option) any later version.' ' This library is distributed in the hope that it will be useful,' but WITHOUT ANY WARRANTY; without even the implied warranty of' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU' Lesser General Public License for more details.' ' You should have received a copy of the GNU Lesser General Public' License along with this library; if not, write to the Free Software' Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA' Public Class CDblExpression Inherits ConversionExpression Sub New(ByVal Parent As ParsedObject, ByVal Expression As Expression) MyBase.New(Parent, Expression) End Sub Sub New(ByVal Parent As ParsedObject) MyBase.New(Parent) End Sub Protected Overrides Function GenerateCodeInternal(ByVal Info As EmitInfo) As Boolean Return GenerateCode(Me.Expression, Info) End Function Protected Overrides Function ResolveExpressionInternal(ByVal Info As ResolveInfo) As Boolean Dim result As Boolean = True result = MyBase.ResolveExpressionInternal(Info) AndAlso result result = Validate(Info, Expression.ExpressionType) AndAlso result Return result End Function Shared Function Validate(ByVal Info As ResolveInfo, ByVal SourceType As Type) As Boolean Dim result As Boolean = True Dim expType As Type = SourceType Dim expTypeCode As TypeCode = Helper.GetTypeCode(Info.Compiler, expType) Dim ExpressionType As Type = Info.Compiler.TypeCache.System_Double Select Case expTypeCode Case TypeCode.DateTime Info.Compiler.Report.ShowMessage(Messages.VBNC30532, expType.Name) result = False Case TypeCode.Char Info.Compiler.Report.ShowMessage(Messages.VBNC30311, expType.Name, ExpressionType.Name) result = False End Select Return result End Function Overloads Shared Function GenerateCode(ByVal Expression As Expression, ByVal Info As EmitInfo) As Boolean Dim result As Boolean = True Dim expType As Type = Expression.ExpressionType Dim expTypeCode As TypeCode = Helper.GetTypeCode(Info.Compiler, expType) result = Expression.Classification.GenerateCode(Info.Clone(expType)) AndAlso result Select Case expTypeCode Case TypeCode.Boolean Emitter.EmitLoadI4Value(Info, 0I, expType) Emitter.EmitGT_Un(Info, expType) Emitter.EmitNeg(Info) Emitter.EmitConv_R8(Info, expType) Case TypeCode.Double 'Nothing to do Case TypeCode.DateTime Info.Compiler.Report.ShowMessage(Messages.VBNC30532, expType.Name) result = False Case TypeCode.Char Info.Compiler.Report.ShowMessage(Messages.VBNC30311, expType.Name, expType.Name) result = False Case TypeCode.SByte, TypeCode.Int16, TypeCode.Int32, TypeCode.Int64 Emitter.EmitConv_R8(Info, expType) Case TypeCode.Byte, TypeCode.UInt16, TypeCode.UInt32, TypeCode.UInt64 Emitter.EmitConv_R8(Info, expType) Case TypeCode.Single Emitter.EmitConv_R8(Info, expType) Case TypeCode.Object If Helper.CompareType(expType, Info.Compiler.TypeCache.System_Object) Then Emitter.EmitCall(Info, Info.Compiler.TypeCache.MS_VB_CS_Conversions__ToDouble_Object) Else Helper.NotImplemented() End If Case TypeCode.String Emitter.EmitCall(Info, Info.Compiler.TypeCache.MS_VB_CS_Conversions__ToDouble_String) Case TypeCode.Decimal Emitter.EmitCall(Info, Info.Compiler.TypeCache.System_Convert__ToDouble_Decimal) Case Else Helper.NotImplemented() End Select Return result End Function Public Overrides ReadOnly Property IsConstant() As Boolean Get Return Expression.IsConstant AndAlso Helper.CompareType(Expression.ExpressionType, Compiler.TypeCache.System_String) = False End Get End Property Public Overrides ReadOnly Property ConstantValue() As Object Get Dim tpCode As TypeCode Dim originalValue As Object originalValue = Expression.ConstantValue tpCode = Helper.GetTypeCode(Compiler, originalValue.GetType) Select Case tpCode Case TypeCode.Boolean, TypeCode.SByte, TypeCode.Byte, TypeCode.Int16, TypeCode.UInt16, TypeCode.Int32, _ TypeCode.UInt32, TypeCode.UInt64, TypeCode.Int64, TypeCode.Single, TypeCode.Double, TypeCode.Decimal Return CDbl(originalValue) 'No range checking needed. Case TypeCode.DBNull Return CDbl(0) Case Else Compiler.Report.ShowMessage(Messages.VBNC30060, originalValue.ToString, ExpressionType.ToString) Return New Double End Select End Get End Property Overrides ReadOnly Property ExpressionType() As Type Get Return Compiler.TypeCache.System_Double '_Descriptor End Get End PropertyEnd Class
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -