Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / xsp / System / Web / AspNetSynchronizationContext.cs / 1305376 / AspNetSynchronizationContext.cs
//------------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//-----------------------------------------------------------------------------
using System;
using System.ComponentModel;
using System.Security.Permissions;
using System.Threading;
using System.Web;
using System.Web.Util;
namespace System.Web {
internal class AspNetSynchronizationContext : SynchronizationContext {
private HttpApplication _application;
private bool _disabled;
private bool _syncCaller;
private bool _invalidOperationEncountered;
private int _pendingCount;
private Exception _error;
private WaitCallback _lastCompletionWorkItemCallback;
internal AspNetSynchronizationContext(HttpApplication app) {
_application = app;
}
private void CallCallback(SendOrPostCallback callback, Object state) {
// don't take app lock for [....] caller to avoid deadlocks in case they poll for result
if (_syncCaller) {
CallCallbackPossiblyUnderLock(callback, state);
}
else {
lock (_application) {
CallCallbackPossiblyUnderLock(callback, state);
}
}
}
private void CallCallbackPossiblyUnderLock(SendOrPostCallback callback, Object state) {
HttpApplication.ThreadContext threadContext = null;
try {
threadContext = _application.OnThreadEnter();
try {
callback(state);
}
catch (Exception e) {
_error = e;
}
}
finally {
if (threadContext != null) {
threadContext.Leave();
}
}
}
internal int PendingOperationsCount {
get { return _pendingCount; }
}
internal Exception Error {
get { return _error; }
}
internal void ClearError() {
_error = null;
}
internal void SetLastCompletionWorkItem(WaitCallback callback) {
Debug.Assert(_lastCompletionWorkItemCallback == null); // only one at a time
_lastCompletionWorkItemCallback = callback;
}
public override void Send(SendOrPostCallback callback, Object state) {
#if DBG
Debug.Trace("Async", "Send");
Debug.Trace("AsyncStack", "Send from:\r\n" + System.Environment.StackTrace);
#endif
CallCallback(callback, state);
}
public override void Post(SendOrPostCallback callback, Object state) {
#if DBG
Debug.Trace("Async", "Post");
Debug.Trace("AsyncStack", "Post from:\r\n" + System.Environment.StackTrace);
#endif
CallCallback(callback, state);
}
#if DBG
[EnvironmentPermission(SecurityAction.Assert, Unrestricted=true)]
private void CreateCopyDumpStack() {
Debug.Trace("Async", "CreateCopy");
Debug.Trace("AsyncStack", "CreateCopy from:\r\n" + System.Environment.StackTrace);
}
#endif
public override SynchronizationContext CreateCopy() {
#if DBG
CreateCopyDumpStack();
#endif
AspNetSynchronizationContext context = new AspNetSynchronizationContext(_application);
context._disabled = _disabled;
context._syncCaller = _syncCaller;
return context;
}
public override void OperationStarted() {
if (_invalidOperationEncountered || (_disabled && _pendingCount == 0)) {
_invalidOperationEncountered = true;
throw new InvalidOperationException(SR.GetString(SR.Async_operation_disabled));
}
Interlocked.Increment(ref _pendingCount);
#if DBG
Debug.Trace("Async", "OperationStarted(count=" + _pendingCount + ")");
Debug.Trace("AsyncStack", "OperationStarted(count=" + _pendingCount + ") from:\r\n" + System.Environment.StackTrace);
#endif
}
public override void OperationCompleted() {
if (_invalidOperationEncountered || (_disabled && _pendingCount == 0)) {
// throw from operation started could cause extra operation completed
return;
}
bool lastOperationCompleted = (Interlocked.Decrement(ref _pendingCount) == 0);
#if DBG
Debug.Trace("Async", "OperationCompleted(count=" + _pendingCount + ")");
Debug.Trace("AsyncStack", "OperationCompleted(count=" + _pendingCount + ") from:\r\n" + System.Environment.StackTrace);
#endif
if (lastOperationCompleted && _lastCompletionWorkItemCallback != null) {
// notify (once) about the last completion to resume the async work
WaitCallback cb = _lastCompletionWorkItemCallback;
_lastCompletionWorkItemCallback = null;
Debug.Trace("Async", "Queueing LastCompletionWorkItemCallback");
ThreadPool.QueueUserWorkItem(cb);
}
}
internal bool Enabled {
get { return !_disabled; }
}
internal void Enable() {
_disabled = false;
}
internal void Disable() {
_disabled = true;
}
internal void SetSyncCaller() {
_syncCaller = true;
}
internal void ResetSyncCaller() {
_syncCaller = false;
}
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
//------------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//-----------------------------------------------------------------------------
using System;
using System.ComponentModel;
using System.Security.Permissions;
using System.Threading;
using System.Web;
using System.Web.Util;
namespace System.Web {
internal class AspNetSynchronizationContext : SynchronizationContext {
private HttpApplication _application;
private bool _disabled;
private bool _syncCaller;
private bool _invalidOperationEncountered;
private int _pendingCount;
private Exception _error;
private WaitCallback _lastCompletionWorkItemCallback;
internal AspNetSynchronizationContext(HttpApplication app) {
_application = app;
}
private void CallCallback(SendOrPostCallback callback, Object state) {
// don't take app lock for [....] caller to avoid deadlocks in case they poll for result
if (_syncCaller) {
CallCallbackPossiblyUnderLock(callback, state);
}
else {
lock (_application) {
CallCallbackPossiblyUnderLock(callback, state);
}
}
}
private void CallCallbackPossiblyUnderLock(SendOrPostCallback callback, Object state) {
HttpApplication.ThreadContext threadContext = null;
try {
threadContext = _application.OnThreadEnter();
try {
callback(state);
}
catch (Exception e) {
_error = e;
}
}
finally {
if (threadContext != null) {
threadContext.Leave();
}
}
}
internal int PendingOperationsCount {
get { return _pendingCount; }
}
internal Exception Error {
get { return _error; }
}
internal void ClearError() {
_error = null;
}
internal void SetLastCompletionWorkItem(WaitCallback callback) {
Debug.Assert(_lastCompletionWorkItemCallback == null); // only one at a time
_lastCompletionWorkItemCallback = callback;
}
public override void Send(SendOrPostCallback callback, Object state) {
#if DBG
Debug.Trace("Async", "Send");
Debug.Trace("AsyncStack", "Send from:\r\n" + System.Environment.StackTrace);
#endif
CallCallback(callback, state);
}
public override void Post(SendOrPostCallback callback, Object state) {
#if DBG
Debug.Trace("Async", "Post");
Debug.Trace("AsyncStack", "Post from:\r\n" + System.Environment.StackTrace);
#endif
CallCallback(callback, state);
}
#if DBG
[EnvironmentPermission(SecurityAction.Assert, Unrestricted=true)]
private void CreateCopyDumpStack() {
Debug.Trace("Async", "CreateCopy");
Debug.Trace("AsyncStack", "CreateCopy from:\r\n" + System.Environment.StackTrace);
}
#endif
public override SynchronizationContext CreateCopy() {
#if DBG
CreateCopyDumpStack();
#endif
AspNetSynchronizationContext context = new AspNetSynchronizationContext(_application);
context._disabled = _disabled;
context._syncCaller = _syncCaller;
return context;
}
public override void OperationStarted() {
if (_invalidOperationEncountered || (_disabled && _pendingCount == 0)) {
_invalidOperationEncountered = true;
throw new InvalidOperationException(SR.GetString(SR.Async_operation_disabled));
}
Interlocked.Increment(ref _pendingCount);
#if DBG
Debug.Trace("Async", "OperationStarted(count=" + _pendingCount + ")");
Debug.Trace("AsyncStack", "OperationStarted(count=" + _pendingCount + ") from:\r\n" + System.Environment.StackTrace);
#endif
}
public override void OperationCompleted() {
if (_invalidOperationEncountered || (_disabled && _pendingCount == 0)) {
// throw from operation started could cause extra operation completed
return;
}
bool lastOperationCompleted = (Interlocked.Decrement(ref _pendingCount) == 0);
#if DBG
Debug.Trace("Async", "OperationCompleted(count=" + _pendingCount + ")");
Debug.Trace("AsyncStack", "OperationCompleted(count=" + _pendingCount + ") from:\r\n" + System.Environment.StackTrace);
#endif
if (lastOperationCompleted && _lastCompletionWorkItemCallback != null) {
// notify (once) about the last completion to resume the async work
WaitCallback cb = _lastCompletionWorkItemCallback;
_lastCompletionWorkItemCallback = null;
Debug.Trace("Async", "Queueing LastCompletionWorkItemCallback");
ThreadPool.QueueUserWorkItem(cb);
}
}
internal bool Enabled {
get { return !_disabled; }
}
internal void Enable() {
_disabled = false;
}
internal void Disable() {
_disabled = true;
}
internal void SetSyncCaller() {
_syncCaller = true;
}
internal void ResetSyncCaller() {
_syncCaller = false;
}
}
}
// 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
- TaskSchedulerException.cs
- WebPartMinimizeVerb.cs
- SchemaName.cs
- KeysConverter.cs
- OutputCacheSection.cs
- StoreItemCollection.cs
- GetUserPreferenceRequest.cs
- ListBoxChrome.cs
- OutputCacheSection.cs
- xmlfixedPageInfo.cs
- RegexStringValidator.cs
- ScriptResourceHandler.cs
- SerializableAttribute.cs
- LocatorPartList.cs
- ReadWriteSpinLock.cs
- ProfileParameter.cs
- Visitors.cs
- Transform.cs
- WindowsMenu.cs
- AutomationPatternInfo.cs
- DropShadowBitmapEffect.cs
- SevenBitStream.cs
- ImmutableObjectAttribute.cs
- UnsafePeerToPeerMethods.cs
- SettingsProviderCollection.cs
- MiniCustomAttributeInfo.cs
- PartialToken.cs
- TypedElement.cs
- lengthconverter.cs
- SharedStatics.cs
- SocketAddress.cs
- Expression.DebuggerProxy.cs
- _TLSstream.cs
- ProxyManager.cs
- CodeStatementCollection.cs
- SQLInt32.cs
- SettingsPropertyNotFoundException.cs
- SimpleWebHandlerParser.cs
- DeferredTextReference.cs
- Claim.cs
- NumericUpDownAcceleration.cs
- FunctionCommandText.cs
- Exceptions.cs
- CryptoApi.cs
- ValidationResult.cs
- NativeMethods.cs
- documentsequencetextview.cs
- TextOutput.cs
- ComponentCommands.cs
- LineSegment.cs
- DbParameterHelper.cs
- _FtpDataStream.cs
- ToolStripProfessionalLowResolutionRenderer.cs
- ValueTable.cs
- ClipboardData.cs
- SqlUnionizer.cs
- EnumerableRowCollectionExtensions.cs
- Vector3DCollection.cs
- CfgRule.cs
- _KerberosClient.cs
- StackSpiller.Generated.cs
- KeyValuePairs.cs
- InfoCardProofToken.cs
- UpdatePanel.cs
- AddInBase.cs
- WebPartUserCapability.cs
- _NegoState.cs
- FigureParaClient.cs
- FillErrorEventArgs.cs
- CopyOnWriteList.cs
- Visual.cs
- CommandSet.cs
- MoveSizeWinEventHandler.cs
- XsltArgumentList.cs
- GridViewRowCollection.cs
- SspiNegotiationTokenAuthenticatorState.cs
- MediaPlayerState.cs
- StructuralType.cs
- IPAddress.cs
- HttpCachePolicyWrapper.cs
- TypeDescriptionProvider.cs
- ReflectionUtil.cs
- ExtendedPropertyInfo.cs
- QueryStringConverter.cs
- UxThemeWrapper.cs
- AudioFormatConverter.cs
- UpdatableWrapper.cs
- OSFeature.cs
- UserInitiatedNavigationPermission.cs
- ScrollBar.cs
- MetadataSource.cs
- precedingsibling.cs
- TextLineResult.cs
- JoinTreeNode.cs
- OracleInfoMessageEventArgs.cs
- ItemsControlAutomationPeer.cs
- TTSEvent.cs
- TTSEngineTypes.cs
- MILUtilities.cs
- documentsequencetextcontainer.cs