⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cdblexpression.vb

📁 大名鼎鼎的mono是.NET平台的跨平台(支持linux
💻 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 + -