📄 cboolexpression.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 + -