Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / fx / src / DataOracleClient / System / Data / OracleClient / OciEnlistContext.cs / 1 / OciEnlistContext.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //----------------------------------------------------------------------------- namespace System.Data.OracleClient { using System; using System.Data.Common; using System.Diagnostics; using System.Runtime.CompilerServices; using System.Runtime.InteropServices; using System.Threading; using SysTx = System.Transactions; using System.Runtime.ConstrainedExecution; sealed internal class OciEnlistContext : SafeHandle { private OciServiceContextHandle _serviceContextHandle; internal OciEnlistContext(byte[] userName, byte[] password, byte[] serverName, OciServiceContextHandle serviceContextHandle, OciErrorHandle errorHandle) : base(IntPtr.Zero, true) { RuntimeHelpers.PrepareConstrainedRegions(); try {} finally { _serviceContextHandle = serviceContextHandle; int rc = 0; try { rc = TracedNativeMethods.OraMTSEnlCtxGet(userName, password, serverName, _serviceContextHandle, errorHandle, out base.handle); } catch (DllNotFoundException e) { throw ADP.DistribTxRequiresOracleServicesForMTS(e); } if (0 != rc) { OracleException.Check(errorHandle, rc); } // Make sure the transaction context is disposed before the service // context is. serviceContextHandle.AddRef(); } } public override bool IsInvalid { get { return (IntPtr.Zero == base.handle); } } internal void Join(OracleInternalConnection internalConnection, SysTx.Transaction indigoTransaction) { SysTx.IDtcTransaction oleTxTransaction = ADP.GetOletxTransaction(indigoTransaction); int rc = TracedNativeMethods.OraMTSJoinTxn(this, oleTxTransaction); if (0 != rc) { OracleException.Check(rc, internalConnection); } } override protected bool ReleaseHandle() { // NOTE: The SafeHandle class guarantees this will be called exactly once. IntPtr ptr = base.handle; base.handle = IntPtr.Zero; if (IntPtr.Zero != ptr) { TracedNativeMethods.OraMTSEnlCtxRel(ptr); } // OK, now we can release the service context. if (null != _serviceContextHandle) { _serviceContextHandle.Release(); _serviceContextHandle = null; } return true; } internal static void SafeDispose(ref OciEnlistContext ociEnlistContext) { // Safely disposes of the handle (even if it is already null) and // then nulls it out. if (null != ociEnlistContext) { ociEnlistContext.Dispose(); } ociEnlistContext = null; } //--------------------------------------------------------------------- static internal IntPtr HandleValueToTrace (OciEnlistContext handle) { return handle.DangerousGetHandle(); // for tracing purposes, it's safe to just print this -- no handle recycling issues. } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //----------------------------------------------------------------------------- namespace System.Data.OracleClient { using System; using System.Data.Common; using System.Diagnostics; using System.Runtime.CompilerServices; using System.Runtime.InteropServices; using System.Threading; using SysTx = System.Transactions; using System.Runtime.ConstrainedExecution; sealed internal class OciEnlistContext : SafeHandle { private OciServiceContextHandle _serviceContextHandle; internal OciEnlistContext(byte[] userName, byte[] password, byte[] serverName, OciServiceContextHandle serviceContextHandle, OciErrorHandle errorHandle) : base(IntPtr.Zero, true) { RuntimeHelpers.PrepareConstrainedRegions(); try {} finally { _serviceContextHandle = serviceContextHandle; int rc = 0; try { rc = TracedNativeMethods.OraMTSEnlCtxGet(userName, password, serverName, _serviceContextHandle, errorHandle, out base.handle); } catch (DllNotFoundException e) { throw ADP.DistribTxRequiresOracleServicesForMTS(e); } if (0 != rc) { OracleException.Check(errorHandle, rc); } // Make sure the transaction context is disposed before the service // context is. serviceContextHandle.AddRef(); } } public override bool IsInvalid { get { return (IntPtr.Zero == base.handle); } } internal void Join(OracleInternalConnection internalConnection, SysTx.Transaction indigoTransaction) { SysTx.IDtcTransaction oleTxTransaction = ADP.GetOletxTransaction(indigoTransaction); int rc = TracedNativeMethods.OraMTSJoinTxn(this, oleTxTransaction); if (0 != rc) { OracleException.Check(rc, internalConnection); } } override protected bool ReleaseHandle() { // NOTE: The SafeHandle class guarantees this will be called exactly once. IntPtr ptr = base.handle; base.handle = IntPtr.Zero; if (IntPtr.Zero != ptr) { TracedNativeMethods.OraMTSEnlCtxRel(ptr); } // OK, now we can release the service context. if (null != _serviceContextHandle) { _serviceContextHandle.Release(); _serviceContextHandle = null; } return true; } internal static void SafeDispose(ref OciEnlistContext ociEnlistContext) { // Safely disposes of the handle (even if it is already null) and // then nulls it out. if (null != ociEnlistContext) { ociEnlistContext.Dispose(); } ociEnlistContext = null; } //--------------------------------------------------------------------- static internal IntPtr HandleValueToTrace (OciEnlistContext handle) { return handle.DangerousGetHandle(); // for tracing purposes, it's safe to just print this -- no handle recycling issues. } } } // 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
- ServiceObjectContainer.cs
- DataBindingCollectionEditor.cs
- CancellationHandler.cs
- OleAutBinder.cs
- UIElement.cs
- Zone.cs
- PropertyChangedEventArgs.cs
- VScrollBar.cs
- KnownTypes.cs
- XmlExpressionDumper.cs
- CurrencyManager.cs
- SimpleApplicationHost.cs
- ClosableStream.cs
- Cursors.cs
- TcpProcessProtocolHandler.cs
- RangeValueProviderWrapper.cs
- TreeNodeSelectionProcessor.cs
- WebAdminConfigurationHelper.cs
- LockedActivityGlyph.cs
- TraceLog.cs
- ToolStripDropDownMenu.cs
- PathData.cs
- ProfileGroupSettings.cs
- TimeSpanMinutesOrInfiniteConverter.cs
- ToolboxItem.cs
- XmlSchemaDocumentation.cs
- _Events.cs
- PartBasedPackageProperties.cs
- StructuralType.cs
- TableLayout.cs
- ArrayWithOffset.cs
- ValidationSummary.cs
- Odbc32.cs
- DayRenderEvent.cs
- Interlocked.cs
- ISAPIApplicationHost.cs
- BrowsableAttribute.cs
- ColumnResult.cs
- RegexInterpreter.cs
- PagesSection.cs
- XmlJsonReader.cs
- CapacityStreamGeometryContext.cs
- DocumentViewerBaseAutomationPeer.cs
- UshortList2.cs
- ContractListAdapter.cs
- HotSpotCollection.cs
- EdmItemError.cs
- CommandField.cs
- TextContainer.cs
- EndPoint.cs
- ProtectedConfiguration.cs
- CompoundFileStreamReference.cs
- RowUpdatedEventArgs.cs
- HwndSubclass.cs
- StorageMappingItemLoader.cs
- Bold.cs
- complextypematerializer.cs
- MetadataProperty.cs
- ColumnResizeUndoUnit.cs
- PropertyGridView.cs
- ipaddressinformationcollection.cs
- FileStream.cs
- CreateUserErrorEventArgs.cs
- DocumentPageViewAutomationPeer.cs
- SelectionProviderWrapper.cs
- Dump.cs
- WindowsPen.cs
- Aes.cs
- FullTextBreakpoint.cs
- DataSourceXmlSubItemAttribute.cs
- PointConverter.cs
- StringExpressionSet.cs
- ObjectFactoryCodeDomTreeGenerator.cs
- AxHostDesigner.cs
- Tag.cs
- DateTimeConverter.cs
- SafeEventLogWriteHandle.cs
- XmlSecureResolver.cs
- BaseServiceProvider.cs
- HandlerBase.cs
- TextRenderer.cs
- BrowserCapabilitiesFactory.cs
- MetadataArtifactLoaderXmlReaderWrapper.cs
- XmlCharCheckingReader.cs
- Vector3DAnimation.cs
- InfoCardRSAPKCS1SignatureFormatter.cs
- ObjectStateEntryBaseUpdatableDataRecord.cs
- ReceiveSecurityHeader.cs
- Stopwatch.cs
- SqlFunctionAttribute.cs
- CompilationUtil.cs
- _LoggingObject.cs
- ButtonField.cs
- DataServiceStreamProviderWrapper.cs
- InkCanvasInnerCanvas.cs
- Funcletizer.cs
- ServiceEndpointCollection.cs
- FixedTextSelectionProcessor.cs
- XComponentModel.cs
- DataGridViewTextBoxCell.cs