Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / Data / System / Data / Filter / UnaryNode.cs / 1305376 / 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
- ObjectSelectorEditor.cs
- BrowserCapabilitiesCodeGenerator.cs
- NameScopePropertyAttribute.cs
- ReachDocumentReferenceCollectionSerializer.cs
- BlurEffect.cs
- WebPartManagerInternals.cs
- ServiceObjectContainer.cs
- _AcceptOverlappedAsyncResult.cs
- XmlDataSourceView.cs
- Perspective.cs
- ParallelQuery.cs
- Storyboard.cs
- CollectionAdapters.cs
- XmlTextReaderImplHelpers.cs
- BStrWrapper.cs
- QuadraticEase.cs
- ExpressionBuilder.cs
- XmlValidatingReaderImpl.cs
- ListBase.cs
- SynchronizedDispatch.cs
- ApplicationDirectoryMembershipCondition.cs
- OperationResponse.cs
- ConstructorBuilder.cs
- SRDisplayNameAttribute.cs
- PathNode.cs
- RTTrackingProfile.cs
- TimeIntervalCollection.cs
- Matrix3DValueSerializer.cs
- CreateUserErrorEventArgs.cs
- StrokeRenderer.cs
- Privilege.cs
- Win32PrintDialog.cs
- SessionStateSection.cs
- SupportingTokenDuplexChannel.cs
- DesignerView.Commands.cs
- ProofTokenCryptoHandle.cs
- Publisher.cs
- Hashtable.cs
- SmuggledIUnknown.cs
- RouteCollection.cs
- OdbcHandle.cs
- ParserHooks.cs
- DataServiceQuery.cs
- ListItemConverter.cs
- SizeChangedEventArgs.cs
- HashMembershipCondition.cs
- Variant.cs
- UnsafeNativeMethods.cs
- Misc.cs
- ReferenceConverter.cs
- PerspectiveCamera.cs
- CompositeScriptReference.cs
- followingsibling.cs
- InvalidPropValue.cs
- BasicBrowserDialog.cs
- Int32Rect.cs
- SystemColors.cs
- QilName.cs
- OleDbRowUpdatingEvent.cs
- Expander.cs
- ContentFileHelper.cs
- TextTreeText.cs
- BufferedStream.cs
- VariantWrapper.cs
- categoryentry.cs
- X509Certificate2.cs
- BinaryObjectWriter.cs
- MsmqIntegrationProcessProtocolHandler.cs
- WebServiceMethodData.cs
- KeyNotFoundException.cs
- SqlDependencyUtils.cs
- ListManagerBindingsCollection.cs
- BindingsCollection.cs
- EntityConnection.cs
- WebHeaderCollection.cs
- AbstractExpressions.cs
- JsonGlobals.cs
- PersonalizationProviderHelper.cs
- MSHTMLHost.cs
- ImageKeyConverter.cs
- MSHTMLHost.cs
- RoleManagerEventArgs.cs
- EntityReference.cs
- FixedTextBuilder.cs
- ProgressBarRenderer.cs
- ComplexTypeEmitter.cs
- ErrorHandler.cs
- EditorReuseAttribute.cs
- DelayedRegex.cs
- HtmlFormWrapper.cs
- LinqDataSourceView.cs
- GifBitmapDecoder.cs
- XmlWrappingReader.cs
- GridViewEditEventArgs.cs
- PassportAuthenticationModule.cs
- TrackingMemoryStreamFactory.cs
- XmlnsPrefixAttribute.cs
- SplayTreeNode.cs
- IntegerFacetDescriptionElement.cs
- FtpWebResponse.cs