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
- RuntimeUtils.cs
- WebPartDisplayModeEventArgs.cs
- ExtendedPropertyDescriptor.cs
- PropertyCondition.cs
- OdbcEnvironment.cs
- ClientRoleProvider.cs
- XmlSchemaException.cs
- FileLevelControlBuilderAttribute.cs
- SectionXmlInfo.cs
- Control.cs
- CollectionChangedEventManager.cs
- UnknownBitmapDecoder.cs
- ProtectedConfigurationProviderCollection.cs
- CreateUserErrorEventArgs.cs
- TextFormatterContext.cs
- Overlapped.cs
- Condition.cs
- Variable.cs
- Cursor.cs
- SourceFileBuildProvider.cs
- TreeNodeSelectionProcessor.cs
- WindowsListViewSubItem.cs
- DocumentViewerConstants.cs
- Point.cs
- InkCollectionBehavior.cs
- TemplateParser.cs
- HuffCodec.cs
- PriorityQueue.cs
- EventHandlerList.cs
- DataSourceSelectArguments.cs
- InvalidWMPVersionException.cs
- SimpleWebHandlerParser.cs
- ColorIndependentAnimationStorage.cs
- DiagnosticsConfigurationHandler.cs
- MethodCallConverter.cs
- AssemblyNameProxy.cs
- WebBaseEventKeyComparer.cs
- Internal.cs
- InkCanvasInnerCanvas.cs
- StorageComplexPropertyMapping.cs
- HttpProcessUtility.cs
- objectquery_tresulttype.cs
- DateTimeUtil.cs
- ObjectDataSourceMethodEditor.cs
- DocumentScope.cs
- HandledEventArgs.cs
- Msec.cs
- XmlHierarchicalEnumerable.cs
- EventWaitHandle.cs
- TypedDataSetSchemaImporterExtensionFx35.cs
- SamlDoNotCacheCondition.cs
- XmlDictionaryReader.cs
- Drawing.cs
- QueryContinueDragEventArgs.cs
- EmptyControlCollection.cs
- SafeViewOfFileHandle.cs
- TimelineCollection.cs
- ITextView.cs
- RequestReplyCorrelator.cs
- WorkflowDesigner.cs
- BitmapInitialize.cs
- Selection.cs
- TextDecorationLocationValidation.cs
- Trigger.cs
- RouteParametersHelper.cs
- PreProcessInputEventArgs.cs
- GetLedgerRequest.cs
- WebBrowserPermission.cs
- XsltSettings.cs
- XmlSerializationGeneratedCode.cs
- DbgCompiler.cs
- SecurityException.cs
- DataColumnCollection.cs
- Span.cs
- EncoderExceptionFallback.cs
- StringStorage.cs
- XmlSchemaAttribute.cs
- ImageFormat.cs
- DataMemberFieldEditor.cs
- PersonalizationStateInfoCollection.cs
- TransformCryptoHandle.cs
- StringBlob.cs
- JumpItem.cs
- CroppedBitmap.cs
- HttpListenerRequestUriBuilder.cs
- TimerElapsedEvenArgs.cs
- NavigationPropertyEmitter.cs
- InvalidOleVariantTypeException.cs
- StorageInfo.cs
- LastQueryOperator.cs
- TimerElapsedEvenArgs.cs
- XmlBoundElement.cs
- OleDbInfoMessageEvent.cs
- StaticSiteMapProvider.cs
- EventDescriptorCollection.cs
- BezierSegment.cs
- PartialArray.cs
- ThicknessKeyFrameCollection.cs
- ModelPerspective.cs
- Multiply.cs