Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / Core / Microsoft / Scripting / Compiler / StackSpiller.Generated.cs / 1305376 / StackSpiller.Generated.cs
/* **************************************************************************** * * Copyright (c) Microsoft Corporation. * * This source code is subject to terms and conditions of the Microsoft Public License. A * copy of the license can be found in the License.html file at the root of this distribution. If * you cannot locate the Microsoft Public License, please send an email to * dlr@microsoft.com. By using this source code in any fashion, you are agreeing to be bound * by the terms of the Microsoft Public License. * * You must not remove this notice, or any other, from this software. * * * ***************************************************************************/ using System.Diagnostics; using System.Dynamic.Utils; namespace System.Linq.Expressions.Compiler { internal partial class StackSpiller { ////// Rewrite the expression /// /// /// Expression to rewrite /// State of the stack before the expression is emitted. ///Rewritten expression. [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Maintainability", "CA1505:AvoidUnmaintainableCode")] [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Maintainability", "CA1502:AvoidExcessiveComplexity")] private Result RewriteExpression(Expression node, Stack stack) { if (node == null) { return new Result(RewriteAction.None, null); } Result result; switch (node.NodeType) { #region Generated StackSpiller Switch // *** BEGIN GENERATED CODE *** // generated by function: gen_stackspiller_switch from: generate_tree.py case ExpressionType.Add: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.AddChecked: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.And: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.AndAlso: result = RewriteLogicalBinaryExpression(node, stack); break; case ExpressionType.ArrayLength: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.ArrayIndex: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.Call: result = RewriteMethodCallExpression(node, stack); break; case ExpressionType.Coalesce: result = RewriteLogicalBinaryExpression(node, stack); break; case ExpressionType.Conditional: result = RewriteConditionalExpression(node, stack); break; case ExpressionType.Convert: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.ConvertChecked: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.Divide: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.Equal: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.ExclusiveOr: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.GreaterThan: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.GreaterThanOrEqual: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.Invoke: result = RewriteInvocationExpression(node, stack); break; case ExpressionType.Lambda: result = RewriteLambdaExpression(node, stack); break; case ExpressionType.LeftShift: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.LessThan: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.LessThanOrEqual: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.ListInit: result = RewriteListInitExpression(node, stack); break; case ExpressionType.MemberAccess: result = RewriteMemberExpression(node, stack); break; case ExpressionType.MemberInit: result = RewriteMemberInitExpression(node, stack); break; case ExpressionType.Modulo: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.Multiply: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.MultiplyChecked: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.Negate: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.UnaryPlus: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.NegateChecked: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.New: result = RewriteNewExpression(node, stack); break; case ExpressionType.NewArrayInit: result = RewriteNewArrayExpression(node, stack); break; case ExpressionType.NewArrayBounds: result = RewriteNewArrayExpression(node, stack); break; case ExpressionType.Not: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.NotEqual: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.Or: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.OrElse: result = RewriteLogicalBinaryExpression(node, stack); break; case ExpressionType.Power: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.RightShift: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.Subtract: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.SubtractChecked: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.TypeAs: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.TypeIs: result = RewriteTypeBinaryExpression(node, stack); break; case ExpressionType.Assign: result = RewriteAssignBinaryExpression(node, stack); break; case ExpressionType.Block: result = RewriteBlockExpression(node, stack); break; case ExpressionType.Decrement: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.Dynamic: result = RewriteDynamicExpression(node, stack); break; case ExpressionType.Extension: result = RewriteExtensionExpression(node, stack); break; case ExpressionType.Goto: result = RewriteGotoExpression(node, stack); break; case ExpressionType.Increment: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.Index: result = RewriteIndexExpression(node, stack); break; case ExpressionType.Label: result = RewriteLabelExpression(node, stack); break; case ExpressionType.Loop: result = RewriteLoopExpression(node, stack); break; case ExpressionType.Switch: result = RewriteSwitchExpression(node, stack); break; case ExpressionType.Throw: result = RewriteThrowUnaryExpression(node, stack); break; case ExpressionType.Try: result = RewriteTryExpression(node, stack); break; case ExpressionType.Unbox: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.TypeEqual: result = RewriteTypeBinaryExpression(node, stack); break; case ExpressionType.OnesComplement: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.IsTrue: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.IsFalse: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.AddAssign: case ExpressionType.AndAssign: case ExpressionType.DivideAssign: case ExpressionType.ExclusiveOrAssign: case ExpressionType.LeftShiftAssign: case ExpressionType.ModuloAssign: case ExpressionType.MultiplyAssign: case ExpressionType.OrAssign: case ExpressionType.PowerAssign: case ExpressionType.RightShiftAssign: case ExpressionType.SubtractAssign: case ExpressionType.AddAssignChecked: case ExpressionType.MultiplyAssignChecked: case ExpressionType.SubtractAssignChecked: case ExpressionType.PreIncrementAssign: case ExpressionType.PreDecrementAssign: case ExpressionType.PostIncrementAssign: case ExpressionType.PostDecrementAssign: result = RewriteReducibleExpression(node, stack); break; case ExpressionType.Quote: case ExpressionType.Parameter: case ExpressionType.Constant: case ExpressionType.RuntimeVariables: case ExpressionType.Default: case ExpressionType.DebugInfo: return new Result(RewriteAction.None, node); // *** END GENERATED CODE *** #endregion default: throw ContractUtils.Unreachable; } VerifyRewrite(result, node); return result; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. /* **************************************************************************** * * Copyright (c) Microsoft Corporation. * * This source code is subject to terms and conditions of the Microsoft Public License. A * copy of the license can be found in the License.html file at the root of this distribution. If * you cannot locate the Microsoft Public License, please send an email to * dlr@microsoft.com. By using this source code in any fashion, you are agreeing to be bound * by the terms of the Microsoft Public License. * * You must not remove this notice, or any other, from this software. * * * ***************************************************************************/ using System.Diagnostics; using System.Dynamic.Utils; namespace System.Linq.Expressions.Compiler { internal partial class StackSpiller { ////// Rewrite the expression /// /// /// Expression to rewrite /// State of the stack before the expression is emitted. ///Rewritten expression. [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Maintainability", "CA1505:AvoidUnmaintainableCode")] [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Maintainability", "CA1502:AvoidExcessiveComplexity")] private Result RewriteExpression(Expression node, Stack stack) { if (node == null) { return new Result(RewriteAction.None, null); } Result result; switch (node.NodeType) { #region Generated StackSpiller Switch // *** BEGIN GENERATED CODE *** // generated by function: gen_stackspiller_switch from: generate_tree.py case ExpressionType.Add: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.AddChecked: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.And: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.AndAlso: result = RewriteLogicalBinaryExpression(node, stack); break; case ExpressionType.ArrayLength: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.ArrayIndex: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.Call: result = RewriteMethodCallExpression(node, stack); break; case ExpressionType.Coalesce: result = RewriteLogicalBinaryExpression(node, stack); break; case ExpressionType.Conditional: result = RewriteConditionalExpression(node, stack); break; case ExpressionType.Convert: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.ConvertChecked: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.Divide: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.Equal: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.ExclusiveOr: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.GreaterThan: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.GreaterThanOrEqual: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.Invoke: result = RewriteInvocationExpression(node, stack); break; case ExpressionType.Lambda: result = RewriteLambdaExpression(node, stack); break; case ExpressionType.LeftShift: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.LessThan: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.LessThanOrEqual: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.ListInit: result = RewriteListInitExpression(node, stack); break; case ExpressionType.MemberAccess: result = RewriteMemberExpression(node, stack); break; case ExpressionType.MemberInit: result = RewriteMemberInitExpression(node, stack); break; case ExpressionType.Modulo: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.Multiply: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.MultiplyChecked: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.Negate: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.UnaryPlus: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.NegateChecked: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.New: result = RewriteNewExpression(node, stack); break; case ExpressionType.NewArrayInit: result = RewriteNewArrayExpression(node, stack); break; case ExpressionType.NewArrayBounds: result = RewriteNewArrayExpression(node, stack); break; case ExpressionType.Not: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.NotEqual: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.Or: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.OrElse: result = RewriteLogicalBinaryExpression(node, stack); break; case ExpressionType.Power: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.RightShift: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.Subtract: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.SubtractChecked: result = RewriteBinaryExpression(node, stack); break; case ExpressionType.TypeAs: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.TypeIs: result = RewriteTypeBinaryExpression(node, stack); break; case ExpressionType.Assign: result = RewriteAssignBinaryExpression(node, stack); break; case ExpressionType.Block: result = RewriteBlockExpression(node, stack); break; case ExpressionType.Decrement: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.Dynamic: result = RewriteDynamicExpression(node, stack); break; case ExpressionType.Extension: result = RewriteExtensionExpression(node, stack); break; case ExpressionType.Goto: result = RewriteGotoExpression(node, stack); break; case ExpressionType.Increment: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.Index: result = RewriteIndexExpression(node, stack); break; case ExpressionType.Label: result = RewriteLabelExpression(node, stack); break; case ExpressionType.Loop: result = RewriteLoopExpression(node, stack); break; case ExpressionType.Switch: result = RewriteSwitchExpression(node, stack); break; case ExpressionType.Throw: result = RewriteThrowUnaryExpression(node, stack); break; case ExpressionType.Try: result = RewriteTryExpression(node, stack); break; case ExpressionType.Unbox: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.TypeEqual: result = RewriteTypeBinaryExpression(node, stack); break; case ExpressionType.OnesComplement: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.IsTrue: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.IsFalse: result = RewriteUnaryExpression(node, stack); break; case ExpressionType.AddAssign: case ExpressionType.AndAssign: case ExpressionType.DivideAssign: case ExpressionType.ExclusiveOrAssign: case ExpressionType.LeftShiftAssign: case ExpressionType.ModuloAssign: case ExpressionType.MultiplyAssign: case ExpressionType.OrAssign: case ExpressionType.PowerAssign: case ExpressionType.RightShiftAssign: case ExpressionType.SubtractAssign: case ExpressionType.AddAssignChecked: case ExpressionType.MultiplyAssignChecked: case ExpressionType.SubtractAssignChecked: case ExpressionType.PreIncrementAssign: case ExpressionType.PreDecrementAssign: case ExpressionType.PostIncrementAssign: case ExpressionType.PostDecrementAssign: result = RewriteReducibleExpression(node, stack); break; case ExpressionType.Quote: case ExpressionType.Parameter: case ExpressionType.Constant: case ExpressionType.RuntimeVariables: case ExpressionType.Default: case ExpressionType.DebugInfo: return new Result(RewriteAction.None, node); // *** END GENERATED CODE *** #endregion default: throw ContractUtils.Unreachable; } VerifyRewrite(result, node); return result; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- PerfService.cs
- DataGridViewBand.cs
- XmlSchemaSequence.cs
- BuiltInExpr.cs
- DataGridViewColumnCollectionDialog.cs
- DomainUpDown.cs
- NoResizeHandleGlyph.cs
- MatchingStyle.cs
- Dump.cs
- DataGridViewAutoSizeModeEventArgs.cs
- DayRenderEvent.cs
- SqlTrackingWorkflowInstance.cs
- LinkConverter.cs
- UIElement3DAutomationPeer.cs
- sqlser.cs
- NameValueSectionHandler.cs
- SessionSwitchEventArgs.cs
- Int32Animation.cs
- UiaCoreProviderApi.cs
- ValuePatternIdentifiers.cs
- XPathArrayIterator.cs
- ModuleElement.cs
- MtomMessageEncodingElement.cs
- LeaseManager.cs
- LinqDataSourceHelper.cs
- TableColumn.cs
- BlockExpression.cs
- MarkupProperty.cs
- ServiceHostingEnvironment.cs
- DataGridViewAdvancedBorderStyle.cs
- DialogWindow.cs
- _LazyAsyncResult.cs
- ObjectDataSourceMethodEventArgs.cs
- activationcontext.cs
- _NativeSSPI.cs
- TreeNodeBindingCollection.cs
- Preprocessor.cs
- ReadOnlyDictionary.cs
- UrlMapping.cs
- CustomErrorsSection.cs
- BamlLocalizabilityResolver.cs
- AuthenticationConfig.cs
- Evidence.cs
- CompositionTarget.cs
- LicenseManager.cs
- GradientBrush.cs
- KeyNotFoundException.cs
- SourceChangedEventArgs.cs
- ControlCachePolicy.cs
- MailMessageEventArgs.cs
- FindCompletedEventArgs.cs
- TextServicesProperty.cs
- BitmapEffectDrawingContextState.cs
- ObjectView.cs
- AnimatedTypeHelpers.cs
- DataGridViewComboBoxColumnDesigner.cs
- ReflectTypeDescriptionProvider.cs
- Thickness.cs
- CodeAttachEventStatement.cs
- ThemeDictionaryExtension.cs
- DataGridViewCellCollection.cs
- DesignOnlyAttribute.cs
- PeerNameRecordCollection.cs
- Timer.cs
- ResolveRequestResponseAsyncResult.cs
- SmiEventSink.cs
- UnsafeNativeMethods.cs
- TypedAsyncResult.cs
- ProfileProvider.cs
- Task.cs
- DeploymentSection.cs
- CssStyleCollection.cs
- ProcessModelSection.cs
- DecoratedNameAttribute.cs
- XmlDocument.cs
- MenuItem.cs
- OdbcReferenceCollection.cs
- RadioButtonAutomationPeer.cs
- Calendar.cs
- XmlFileEditor.cs
- GridViewPageEventArgs.cs
- FileDialog.cs
- QuaternionAnimation.cs
- AsmxEndpointPickerExtension.cs
- EntityProviderServices.cs
- LinkClickEvent.cs
- SmiMetaData.cs
- UInt64.cs
- Sentence.cs
- InfoCardX509Validator.cs
- CmsUtils.cs
- GlyphCache.cs
- DtcInterfaces.cs
- GACMembershipCondition.cs
- IHttpResponseInternal.cs
- DiagnosticsElement.cs
- TreeView.cs
- GZipStream.cs
- CompilerScope.Storage.cs
- future.cs