Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / fx / src / Data / System / Data / Filter / UnaryNode.cs / 1 / UnaryNode.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //[....] //[....] //----------------------------------------------------------------------------- namespace System.Data { using System; using System.Collections.Generic; using System.Diagnostics; using System.Data.Common; using System.Data.SqlTypes; internal sealed class UnaryNode : ExpressionNode { internal readonly int op; internal ExpressionNode right; internal UnaryNode(DataTable table, int op, ExpressionNode right) : base(table) { this.op = op; this.right = right; } internal override void Bind(DataTable table, Listlist) { BindTable(table); right.Bind(table, list); } internal override object Eval() { return Eval(null, DataRowVersion.Default); } internal override object Eval(DataRow row, DataRowVersion version) { return EvalUnaryOp(op, right.Eval(row, version)); } internal override object Eval(int[] recordNos) { return right.Eval(recordNos); } private object EvalUnaryOp(int op, object vl) { object value = DBNull.Value; if (DataExpression.IsUnknown(vl)) return DBNull.Value; StorageType storageType; switch (op) { case Operators.Noop: return vl; case Operators.UnaryPlus: storageType = DataStorage.GetStorageType(vl.GetType()); if (ExpressionNode.IsNumericSql(storageType)) { return vl; } throw ExprException.TypeMismatch(this.ToString()); case Operators.Negative: // the have to be better way for doing this.. storageType = DataStorage.GetStorageType(vl.GetType()); if (ExpressionNode.IsNumericSql(storageType)) { switch(storageType) { case StorageType.Byte: value = -(Byte) vl; break; case StorageType.Int16: value = -(Int16) vl; break; case StorageType.Int32: value = -(Int32) vl; break; case StorageType.Int64: value = -(Int64) vl; break; case StorageType.Single: value = -(Single) vl; break; case StorageType.Double: value = -(Double) vl; break; case StorageType.Decimal: value = -(Decimal) vl; break; case StorageType.SqlDecimal: value = -(SqlDecimal) vl; break; case StorageType.SqlDouble: value = -(SqlDouble) vl; break; case StorageType.SqlSingle: value = -(SqlSingle) vl; break; case StorageType.SqlMoney: value = -(SqlMoney) vl; break; case StorageType.SqlInt64: value = -(SqlInt64) vl; break; case StorageType.SqlInt32: value = -(SqlInt32) vl; break; case StorageType.SqlInt16: value = -(SqlInt16) vl; break; default: Debug.Assert(false, "Missing a type conversion"); value = DBNull.Value; break; } return value; } throw ExprException.TypeMismatch(this.ToString()); case Operators.Not: if (vl is SqlBoolean){ if (((SqlBoolean)vl).IsFalse){ return SqlBoolean.True; } else if (((SqlBoolean)vl).IsTrue) { return SqlBoolean.False; } throw ExprException.UnsupportedOperator(op); // or should the result of not SQLNull be SqlNull ? } else{ if (DataExpression.ToBoolean(vl) != false) return false; return true; } default: throw ExprException.UnsupportedOperator(op); } } internal override bool IsConstant() { return(right.IsConstant()); } internal override bool IsTableConstant() { return(right.IsTableConstant()); } internal override bool HasLocalAggregate() { return(right.HasLocalAggregate()); } internal override bool HasRemoteAggregate() { return(right.HasRemoteAggregate()); } internal override bool DependsOn(DataColumn column) { return(right.DependsOn(column)); } internal override ExpressionNode Optimize() { right = right.Optimize(); if (this.IsConstant()) { object val = this.Eval(); return new ConstNode(table, ValueType.Object, val, false); } else return this; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ // // Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //[....] //[....] //----------------------------------------------------------------------------- namespace System.Data { using System; using System.Collections.Generic; using System.Diagnostics; using System.Data.Common; using System.Data.SqlTypes; internal sealed class UnaryNode : ExpressionNode { internal readonly int op; internal ExpressionNode right; internal UnaryNode(DataTable table, int op, ExpressionNode right) : base(table) { this.op = op; this.right = right; } internal override void Bind(DataTable table, Listlist) { BindTable(table); right.Bind(table, list); } internal override object Eval() { return Eval(null, DataRowVersion.Default); } internal override object Eval(DataRow row, DataRowVersion version) { return EvalUnaryOp(op, right.Eval(row, version)); } internal override object Eval(int[] recordNos) { return right.Eval(recordNos); } private object EvalUnaryOp(int op, object vl) { object value = DBNull.Value; if (DataExpression.IsUnknown(vl)) return DBNull.Value; StorageType storageType; switch (op) { case Operators.Noop: return vl; case Operators.UnaryPlus: storageType = DataStorage.GetStorageType(vl.GetType()); if (ExpressionNode.IsNumericSql(storageType)) { return vl; } throw ExprException.TypeMismatch(this.ToString()); case Operators.Negative: // the have to be better way for doing this.. storageType = DataStorage.GetStorageType(vl.GetType()); if (ExpressionNode.IsNumericSql(storageType)) { switch(storageType) { case StorageType.Byte: value = -(Byte) vl; break; case StorageType.Int16: value = -(Int16) vl; break; case StorageType.Int32: value = -(Int32) vl; break; case StorageType.Int64: value = -(Int64) vl; break; case StorageType.Single: value = -(Single) vl; break; case StorageType.Double: value = -(Double) vl; break; case StorageType.Decimal: value = -(Decimal) vl; break; case StorageType.SqlDecimal: value = -(SqlDecimal) vl; break; case StorageType.SqlDouble: value = -(SqlDouble) vl; break; case StorageType.SqlSingle: value = -(SqlSingle) vl; break; case StorageType.SqlMoney: value = -(SqlMoney) vl; break; case StorageType.SqlInt64: value = -(SqlInt64) vl; break; case StorageType.SqlInt32: value = -(SqlInt32) vl; break; case StorageType.SqlInt16: value = -(SqlInt16) vl; break; default: Debug.Assert(false, "Missing a type conversion"); value = DBNull.Value; break; } return value; } throw ExprException.TypeMismatch(this.ToString()); case Operators.Not: if (vl is SqlBoolean){ if (((SqlBoolean)vl).IsFalse){ return SqlBoolean.True; } else if (((SqlBoolean)vl).IsTrue) { return SqlBoolean.False; } throw ExprException.UnsupportedOperator(op); // or should the result of not SQLNull be SqlNull ? } else{ if (DataExpression.ToBoolean(vl) != false) return false; return true; } default: throw ExprException.UnsupportedOperator(op); } } internal override bool IsConstant() { return(right.IsConstant()); } internal override bool IsTableConstant() { return(right.IsTableConstant()); } internal override bool HasLocalAggregate() { return(right.HasLocalAggregate()); } internal override bool HasRemoteAggregate() { return(right.HasRemoteAggregate()); } internal override bool DependsOn(DataColumn column) { return(right.DependsOn(column)); } internal override ExpressionNode Optimize() { right = right.Optimize(); if (this.IsConstant()) { object val = this.Eval(); return new ConstNode(table, ValueType.Object, val, false); } else return this; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- StandardMenuStripVerb.cs
- FileVersionInfo.cs
- IPHostEntry.cs
- ProxyWebPartManager.cs
- ComponentManagerBroker.cs
- Stroke2.cs
- ChainOfResponsibility.cs
- LocalClientSecuritySettings.cs
- FamilyTypefaceCollection.cs
- OdbcParameter.cs
- TextRunCacheImp.cs
- _UncName.cs
- SelectionItemPattern.cs
- XamlPathDataSerializer.cs
- DesignObjectWrapper.cs
- DataTemplateSelector.cs
- DataServiceHostFactory.cs
- BaseResourcesBuildProvider.cs
- Profiler.cs
- TableItemPattern.cs
- DecimalAnimationUsingKeyFrames.cs
- ContainsRowNumberChecker.cs
- BCryptNative.cs
- OleDbDataAdapter.cs
- QilTernary.cs
- _ReceiveMessageOverlappedAsyncResult.cs
- FixedDSBuilder.cs
- InkPresenter.cs
- SerializableAttribute.cs
- StateManagedCollection.cs
- PointAnimationBase.cs
- ToolStripActionList.cs
- ModelUtilities.cs
- PointCollectionValueSerializer.cs
- AsymmetricSignatureFormatter.cs
- XmlAttribute.cs
- MultipleViewProviderWrapper.cs
- PerformanceCounterManager.cs
- securitycriticaldataformultiplegetandset.cs
- RoleGroupCollectionEditor.cs
- SimpleTypeResolver.cs
- DispatcherHooks.cs
- TrustLevel.cs
- ModulesEntry.cs
- cache.cs
- _NestedSingleAsyncResult.cs
- CreateUserErrorEventArgs.cs
- LineGeometry.cs
- HttpCacheVaryByContentEncodings.cs
- ExceptionTrace.cs
- Msec.cs
- UnsafeNativeMethodsMilCoreApi.cs
- TypeSource.cs
- RepeaterItem.cs
- DataGridBoundColumn.cs
- Mouse.cs
- HandoffBehavior.cs
- ConnectionInterfaceCollection.cs
- BitmapEffectDrawingContent.cs
- SoapConverter.cs
- EncodingStreamWrapper.cs
- PeerInputChannelListener.cs
- DelegatingTypeDescriptionProvider.cs
- AsmxEndpointPickerExtension.cs
- CacheMode.cs
- KnownTypesHelper.cs
- InstanceCreationEditor.cs
- ILGenerator.cs
- HotCommands.cs
- RuleValidation.cs
- ProfileService.cs
- Query.cs
- VisualTreeHelper.cs
- XamlToRtfParser.cs
- DataSourceCollectionBase.cs
- LinkLabelLinkClickedEvent.cs
- WindowsRichEditRange.cs
- UriScheme.cs
- HtmlFormWrapper.cs
- DataGridHyperlinkColumn.cs
- DataGridViewRowsAddedEventArgs.cs
- ServiceChannelProxy.cs
- Rotation3DAnimationBase.cs
- MustUnderstandSoapException.cs
- AdRotator.cs
- AliasExpr.cs
- DefaultTextStoreTextComposition.cs
- ThemeDictionaryExtension.cs
- TextMarkerSource.cs
- HttpCapabilitiesEvaluator.cs
- FragmentQuery.cs
- ExpressionBuilder.cs
- TextTreeText.cs
- ClientSideProviderDescription.cs
- Adorner.cs
- MethodExpr.cs
- DoWhileDesigner.xaml.cs
- DatePickerDateValidationErrorEventArgs.cs
- WebHeaderCollection.cs
- IBuiltInEvidence.cs