Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / 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
- GenericIdentity.cs
- QueryResponse.cs
- Trace.cs
- AuthorizationRule.cs
- Bits.cs
- PopupRootAutomationPeer.cs
- DictionaryTraceRecord.cs
- ExpressionPrefixAttribute.cs
- Validator.cs
- RoutedEventHandlerInfo.cs
- Site.cs
- EnlistmentState.cs
- BuildProvidersCompiler.cs
- oledbmetadatacollectionnames.cs
- ByteAnimationBase.cs
- BamlResourceContent.cs
- InstanceContextMode.cs
- LinqDataView.cs
- MouseGesture.cs
- ProcessInputEventArgs.cs
- CommandField.cs
- SelfIssuedTokenFactoryCredential.cs
- DayRenderEvent.cs
- Semaphore.cs
- DefaultSection.cs
- ControlDesigner.cs
- InteropBitmapSource.cs
- SqlReferenceCollection.cs
- RepeatButtonAutomationPeer.cs
- PartitionedStreamMerger.cs
- ExtensibleClassFactory.cs
- ContextStack.cs
- DataTransferEventArgs.cs
- GridViewColumn.cs
- CompositionTarget.cs
- KeyGesture.cs
- DesignerSerializationOptionsAttribute.cs
- QuaternionAnimationBase.cs
- PresentationSource.cs
- FrugalMap.cs
- WebPartManagerDesigner.cs
- ControlIdConverter.cs
- QilName.cs
- DocumentOrderQuery.cs
- PreservationFileWriter.cs
- EventLogPermissionHolder.cs
- PrivilegeNotHeldException.cs
- BasePropertyDescriptor.cs
- UITypeEditor.cs
- TableHeaderCell.cs
- ApplyTemplatesAction.cs
- Pkcs7Recipient.cs
- WebBrowser.cs
- DesignerActionGlyph.cs
- ApplicationFileParser.cs
- DateTimeFormatInfoScanner.cs
- MessageSecurityOverMsmqElement.cs
- SelectionItemPattern.cs
- WebPartZoneCollection.cs
- DocumentGridPage.cs
- XmlObjectSerializerWriteContext.cs
- AssemblyCollection.cs
- PropertyItemInternal.cs
- RadioButtonStandardAdapter.cs
- InternalDispatchObject.cs
- ExpressionVisitor.cs
- PerfService.cs
- EventRouteFactory.cs
- Scanner.cs
- Viewport2DVisual3D.cs
- DeviceContext.cs
- HwndHostAutomationPeer.cs
- ComponentResourceKey.cs
- DataGridViewBand.cs
- ArrayList.cs
- UseLicense.cs
- TableCell.cs
- ControlPaint.cs
- UnmanagedMarshal.cs
- HttpValueCollection.cs
- Splitter.cs
- HighlightVisual.cs
- DynamicRouteExpression.cs
- MultipartContentParser.cs
- ThrowHelper.cs
- TemplatedWizardStep.cs
- MenuAdapter.cs
- BooleanFunctions.cs
- WebPartEditorOkVerb.cs
- PropertyGridDesigner.cs
- PassportAuthenticationEventArgs.cs
- dataSvcMapFileLoader.cs
- BitmapEffectInputConnector.cs
- PersonalizationState.cs
- Popup.cs
- IntegerFacetDescriptionElement.cs
- SqlCacheDependencyDatabaseCollection.cs
- StrokeCollection2.cs
- SqlRecordBuffer.cs
- Vector3DKeyFrameCollection.cs