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

📄 cboolexpression.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 CBoolExpression    Inherits ConversionExpression    Sub New(ByVal Parent As ParsedObject)        MyBase.New(Parent)    End Sub    Sub New(ByVal Parent As ParsedObject, ByVal Expression As Expression)        MyBase.New(Parent, Expression)    End Sub    Protected Overrides Function GenerateCodeInternal(ByVal Info As EmitInfo) As Boolean        Return GenerateCode(Me.Expression, Info)    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                'Nothing to do            Case TypeCode.Char, TypeCode.DateTime                Info.Compiler.Report.ShowMessage(Messages.VBNC30311, expType.Name, expType.Name)                result = False            Case TypeCode.Byte, TypeCode.UInt16, TypeCode.UInt32, TypeCode.SByte, TypeCode.Int16, TypeCode.Int32                Emitter.EmitLoadI4Value(Info, 0I, expType)                Emitter.EmitGT_Un(Info, expType)            Case TypeCode.Int64                Emitter.EmitLoadI8Value(Info, 0L, expType)                Emitter.EmitGT_Un(Info, expType)            Case TypeCode.UInt64                Emitter.EmitLoadI8Value(Info, 0UL, expType)                Emitter.EmitGT_Un(Info, expType)            Case TypeCode.Double                Emitter.EmitLoadR8Value(Info, 0.0, expType)                Emitter.EmitEquals(Info, expType)                Emitter.EmitLoadI4Value(Info, 0I, Info.Compiler.TypeCache.System_Boolean)                Emitter.EmitEquals(Info, Info.Compiler.TypeCache.System_Boolean)            Case TypeCode.Single                Emitter.EmitLoadR4Value(Info, 0.0!, expType)                Emitter.EmitEquals(Info, expType)                Emitter.EmitLoadI4Value(Info, 0I, info.Compiler.TypeCache.System_Boolean)                Emitter.EmitEquals(Info, Info.Compiler.TypeCache.System_Boolean)            Case TypeCode.Object                Helper.Assert(Info.Compiler.TypeCache.MS_VB_CS_Conversions__ToBoolean_Object IsNot Nothing, "MS_VB_CS_Conversions_ToBoolean__Object Is Nothing")                If Helper.CompareType(expType, Info.Compiler.TypeCache.System_Object) Then                    Emitter.EmitCall(Info, Info.Compiler.TypeCache.MS_VB_CS_Conversions__ToBoolean_Object)                ElseIf Helper.CompareType(expType, Info.Compiler.TypeCache.Nothing) Then                    Emitter.EmitCall(Info, Info.Compiler.TypeCache.MS_VB_CS_Conversions__ToBoolean_Object)                Else                    Helper.NotImplemented()                End If            Case TypeCode.String                Helper.Assert(Info.Compiler.TypeCache.MS_VB_CS_Conversions__ToBoolean_String IsNot Nothing, "MS_VB_CS_Conversions_ToBoolean__String Is Nothing")                Emitter.EmitCall(Info, Info.Compiler.TypeCache.MS_VB_CS_Conversions__ToBoolean_String)            Case TypeCode.Decimal                Helper.Assert(Info.Compiler.TypeCache.System_Convert__ToBoolean_Decimal IsNot Nothing, "System_Convert_ToBoolean__Decimal Is Nothing")                Emitter.EmitCall(Info, Info.Compiler.TypeCache.System_Convert__ToBoolean_Decimal)            Case Else                Helper.NotImplemented()        End Select        Return result    End Function    Protected Overrides Function ResolveExpressionInternal(ByVal Info As ResolveInfo) As Boolean        Dim result As Boolean = True        result = MyBase.ResolveExpressionInternal(Info) AndAlso result        If result = False Then Return 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)        Select Case expTypeCode            Case TypeCode.Char, TypeCode.DateTime                Info.Compiler.Report.ShowMessage(Messages.VBNC30311, expType.Name, Info.Compiler.TypeCache.System_Boolean.Name)                result = False        End Select        Return result    End Function    Public Overrides ReadOnly Property IsConstant() As Boolean        Get            'CHECK: Is this true?            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 CBool(originalValue) 'No range checking needed.                Case TypeCode.DBNull                    Return CBool(Nothing)                Case Else                    Compiler.Report.ShowMessage(Messages.VBNC30060, originalValue.ToString, ExpressionType.ToString)                    Return False            End Select        End Get    End Property    Overrides ReadOnly Property ExpressionType() As Type        Get            Return Compiler.TypeCache.System_Boolean '_Descriptor        End Get    End PropertyEnd Class

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -