Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / WinForms / Managed / System / WinForms / HtmlShimManager.cs / 1305376 / HtmlShimManager.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Windows.Forms { using System; using System.Collections.Generic; using System.Collections; using System.Diagnostics; ////// HtmlShimManager - this class manages the shims for HtmlWindows, HtmlDocuments, and HtmlElements. /// essentially we need a long-lasting object to call back on events from the web browser, and the /// manager is the one in charge of making sure this list stays around as long as needed. /// /// When a HtmlWindow unloads we prune our list of corresponding document, window, and element shims. /// /// internal sealed class HtmlShimManager :IDisposable { private DictionaryhtmlWindowShims; private Dictionary htmlElementShims; private Dictionary htmlDocumentShims; internal HtmlShimManager() { } /// AddDocumentShim - adds a HtmlDocumentShim to list of shims to manage /// Can create a WindowShim as a side effect so it knows when to self prune from the list. /// public void AddDocumentShim(HtmlDocument doc) { HtmlDocument.HtmlDocumentShim shim = null; if (htmlDocumentShims == null) { htmlDocumentShims = new Dictionary(); shim = new HtmlDocument.HtmlDocumentShim(doc); htmlDocumentShims[doc] = shim; } else if (!htmlDocumentShims.ContainsKey(doc)) { shim = new HtmlDocument.HtmlDocumentShim(doc); htmlDocumentShims[doc] = shim; } if (shim != null) { OnShimAdded(shim); } } /// AddWindowShim - adds a HtmlWindowShim to list of shims to manage /// public void AddWindowShim(HtmlWindow window) { HtmlWindow.HtmlWindowShim shim = null; if (htmlWindowShims == null) { htmlWindowShims = new Dictionary(); shim = new HtmlWindow.HtmlWindowShim(window); htmlWindowShims[window] = shim; } else if (!htmlWindowShims.ContainsKey(window)) { shim = new HtmlWindow.HtmlWindowShim(window); htmlWindowShims[window] = shim; } if (shim != null) { // strictly not necessary, but here for future use. OnShimAdded(shim); } } /// AddElementShim - adds a HtmlDocumentShim to list of shims to manage /// Can create a WindowShim as a side effect so it knows when to self prune from the list. /// public void AddElementShim(HtmlElement element) { HtmlElement.HtmlElementShim shim = null; if (htmlElementShims == null) { htmlElementShims = new Dictionary(); shim = new HtmlElement.HtmlElementShim(element); htmlElementShims[element] = shim; } else if (!htmlElementShims.ContainsKey(element)) { shim = new HtmlElement.HtmlElementShim(element); htmlElementShims[element] = shim; } if (shim != null) { OnShimAdded(shim); } } internal HtmlDocument.HtmlDocumentShim GetDocumentShim(HtmlDocument document) { if (htmlDocumentShims == null) { return null; } if (htmlDocumentShims.ContainsKey(document)) { return htmlDocumentShims[document]; } return null; } internal HtmlElement.HtmlElementShim GetElementShim(HtmlElement element) { if (htmlElementShims == null) { return null; } if (htmlElementShims.ContainsKey(element)) { return htmlElementShims[element]; } return null; } internal HtmlWindow.HtmlWindowShim GetWindowShim(HtmlWindow window) { if (htmlWindowShims == null) { return null; } if (htmlWindowShims.ContainsKey(window)) { return htmlWindowShims[window]; } return null; } private void OnShimAdded(HtmlShim addedShim) { Debug.Assert(addedShim != null, "Why are we calling this with a null shim?"); if (addedShim != null) { if (!(addedShim is HtmlWindow.HtmlWindowShim)) { // we need to add a window shim here for documents and elements // so we can [....] Window.Unload. The window shim itself will trap // the unload event and call back on us on OnWindowUnloaded. When // that happens we know we can free all our ptrs to COM. AddWindowShim(new HtmlWindow(this, addedShim.AssociatedWindow)); } } } /// /// HtmlWindowShim calls back on us when it has unloaded the page. At this point we need to /// walk through our lists and make sure we've cleaned up /// internal void OnWindowUnloaded(HtmlWindow unloadedWindow) { Debug.Assert(unloadedWindow != null, "Why are we calling this with a null window?"); if (unloadedWindow != null) { // // prune documents // if (htmlDocumentShims != null) { HtmlDocument.HtmlDocumentShim[] shims = new HtmlDocument.HtmlDocumentShim[htmlDocumentShims.Count]; htmlDocumentShims.Values.CopyTo(shims,0); foreach (HtmlDocument.HtmlDocumentShim shim in shims) { if (shim.AssociatedWindow == unloadedWindow.NativeHtmlWindow) { htmlDocumentShims.Remove(shim.Document); shim.Dispose(); } } } // // prune elements // if (htmlElementShims != null) { HtmlElement.HtmlElementShim[] shims = new HtmlElement.HtmlElementShim[htmlElementShims.Count]; htmlElementShims.Values.CopyTo(shims,0); foreach (HtmlElement.HtmlElementShim shim in shims) { if (shim.AssociatedWindow == unloadedWindow.NativeHtmlWindow) { htmlElementShims.Remove(shim.Element); shim.Dispose(); } } } // // prune the particular window from the list. // if (htmlWindowShims != null) { if (htmlWindowShims.ContainsKey(unloadedWindow)) { HtmlWindow.HtmlWindowShim shim = htmlWindowShims[unloadedWindow]; htmlWindowShims.Remove(unloadedWindow); shim.Dispose(); } } } } public void Dispose() { Dispose(true); } private void Dispose(bool disposing) { if (disposing) { if (htmlElementShims != null){ foreach (HtmlElement.HtmlElementShim shim in htmlElementShims.Values) { shim.Dispose(); } } if (htmlDocumentShims != null) { foreach (HtmlDocument.HtmlDocumentShim shim in htmlDocumentShims.Values) { shim.Dispose(); } } if (htmlWindowShims != null) { foreach (HtmlWindow.HtmlWindowShim shim in htmlWindowShims.Values) { shim.Dispose(); } } htmlWindowShims = null; htmlDocumentShims = null; htmlWindowShims = null; } } ~HtmlShimManager() { Dispose(false); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Windows.Forms { using System; using System.Collections.Generic; using System.Collections; using System.Diagnostics; ////// HtmlShimManager - this class manages the shims for HtmlWindows, HtmlDocuments, and HtmlElements. /// essentially we need a long-lasting object to call back on events from the web browser, and the /// manager is the one in charge of making sure this list stays around as long as needed. /// /// When a HtmlWindow unloads we prune our list of corresponding document, window, and element shims. /// /// internal sealed class HtmlShimManager :IDisposable { private DictionaryhtmlWindowShims; private Dictionary htmlElementShims; private Dictionary htmlDocumentShims; internal HtmlShimManager() { } /// AddDocumentShim - adds a HtmlDocumentShim to list of shims to manage /// Can create a WindowShim as a side effect so it knows when to self prune from the list. /// public void AddDocumentShim(HtmlDocument doc) { HtmlDocument.HtmlDocumentShim shim = null; if (htmlDocumentShims == null) { htmlDocumentShims = new Dictionary(); shim = new HtmlDocument.HtmlDocumentShim(doc); htmlDocumentShims[doc] = shim; } else if (!htmlDocumentShims.ContainsKey(doc)) { shim = new HtmlDocument.HtmlDocumentShim(doc); htmlDocumentShims[doc] = shim; } if (shim != null) { OnShimAdded(shim); } } /// AddWindowShim - adds a HtmlWindowShim to list of shims to manage /// public void AddWindowShim(HtmlWindow window) { HtmlWindow.HtmlWindowShim shim = null; if (htmlWindowShims == null) { htmlWindowShims = new Dictionary(); shim = new HtmlWindow.HtmlWindowShim(window); htmlWindowShims[window] = shim; } else if (!htmlWindowShims.ContainsKey(window)) { shim = new HtmlWindow.HtmlWindowShim(window); htmlWindowShims[window] = shim; } if (shim != null) { // strictly not necessary, but here for future use. OnShimAdded(shim); } } /// AddElementShim - adds a HtmlDocumentShim to list of shims to manage /// Can create a WindowShim as a side effect so it knows when to self prune from the list. /// public void AddElementShim(HtmlElement element) { HtmlElement.HtmlElementShim shim = null; if (htmlElementShims == null) { htmlElementShims = new Dictionary(); shim = new HtmlElement.HtmlElementShim(element); htmlElementShims[element] = shim; } else if (!htmlElementShims.ContainsKey(element)) { shim = new HtmlElement.HtmlElementShim(element); htmlElementShims[element] = shim; } if (shim != null) { OnShimAdded(shim); } } internal HtmlDocument.HtmlDocumentShim GetDocumentShim(HtmlDocument document) { if (htmlDocumentShims == null) { return null; } if (htmlDocumentShims.ContainsKey(document)) { return htmlDocumentShims[document]; } return null; } internal HtmlElement.HtmlElementShim GetElementShim(HtmlElement element) { if (htmlElementShims == null) { return null; } if (htmlElementShims.ContainsKey(element)) { return htmlElementShims[element]; } return null; } internal HtmlWindow.HtmlWindowShim GetWindowShim(HtmlWindow window) { if (htmlWindowShims == null) { return null; } if (htmlWindowShims.ContainsKey(window)) { return htmlWindowShims[window]; } return null; } private void OnShimAdded(HtmlShim addedShim) { Debug.Assert(addedShim != null, "Why are we calling this with a null shim?"); if (addedShim != null) { if (!(addedShim is HtmlWindow.HtmlWindowShim)) { // we need to add a window shim here for documents and elements // so we can [....] Window.Unload. The window shim itself will trap // the unload event and call back on us on OnWindowUnloaded. When // that happens we know we can free all our ptrs to COM. AddWindowShim(new HtmlWindow(this, addedShim.AssociatedWindow)); } } } /// /// HtmlWindowShim calls back on us when it has unloaded the page. At this point we need to /// walk through our lists and make sure we've cleaned up /// internal void OnWindowUnloaded(HtmlWindow unloadedWindow) { Debug.Assert(unloadedWindow != null, "Why are we calling this with a null window?"); if (unloadedWindow != null) { // // prune documents // if (htmlDocumentShims != null) { HtmlDocument.HtmlDocumentShim[] shims = new HtmlDocument.HtmlDocumentShim[htmlDocumentShims.Count]; htmlDocumentShims.Values.CopyTo(shims,0); foreach (HtmlDocument.HtmlDocumentShim shim in shims) { if (shim.AssociatedWindow == unloadedWindow.NativeHtmlWindow) { htmlDocumentShims.Remove(shim.Document); shim.Dispose(); } } } // // prune elements // if (htmlElementShims != null) { HtmlElement.HtmlElementShim[] shims = new HtmlElement.HtmlElementShim[htmlElementShims.Count]; htmlElementShims.Values.CopyTo(shims,0); foreach (HtmlElement.HtmlElementShim shim in shims) { if (shim.AssociatedWindow == unloadedWindow.NativeHtmlWindow) { htmlElementShims.Remove(shim.Element); shim.Dispose(); } } } // // prune the particular window from the list. // if (htmlWindowShims != null) { if (htmlWindowShims.ContainsKey(unloadedWindow)) { HtmlWindow.HtmlWindowShim shim = htmlWindowShims[unloadedWindow]; htmlWindowShims.Remove(unloadedWindow); shim.Dispose(); } } } } public void Dispose() { Dispose(true); } private void Dispose(bool disposing) { if (disposing) { if (htmlElementShims != null){ foreach (HtmlElement.HtmlElementShim shim in htmlElementShims.Values) { shim.Dispose(); } } if (htmlDocumentShims != null) { foreach (HtmlDocument.HtmlDocumentShim shim in htmlDocumentShims.Values) { shim.Dispose(); } } if (htmlWindowShims != null) { foreach (HtmlWindow.HtmlWindowShim shim in htmlWindowShims.Values) { shim.Dispose(); } } htmlWindowShims = null; htmlDocumentShims = null; htmlWindowShims = null; } } ~HtmlShimManager() { Dispose(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
- SiteIdentityPermission.cs
- AppModelKnownContentFactory.cs
- XmlConverter.cs
- ButtonColumn.cs
- ValuePattern.cs
- GuidConverter.cs
- SizeLimitedCache.cs
- AVElementHelper.cs
- ExtractorMetadata.cs
- AstNode.cs
- HtmlListAdapter.cs
- XmlBaseWriter.cs
- BamlRecordReader.cs
- Internal.cs
- CachedFontFamily.cs
- HostProtectionPermission.cs
- HandlerBase.cs
- RuntimeEnvironment.cs
- SchemaReference.cs
- FileReader.cs
- XslTransform.cs
- LayoutTableCell.cs
- Gdiplus.cs
- ActiveXContainer.cs
- DatePickerTextBox.cs
- FontEmbeddingManager.cs
- NativeObjectSecurity.cs
- OdbcInfoMessageEvent.cs
- SqlNamer.cs
- Polyline.cs
- HttpVersion.cs
- TraceListener.cs
- StrokeDescriptor.cs
- SafeNativeMethods.cs
- KeyboardEventArgs.cs
- ContentElement.cs
- regiisutil.cs
- SourceSwitch.cs
- SelectionHighlightInfo.cs
- XmlWrappingWriter.cs
- X509Extension.cs
- InnerItemCollectionView.cs
- OdbcException.cs
- JsonDeserializer.cs
- ConnectionString.cs
- dbenumerator.cs
- RSAPKCS1KeyExchangeDeformatter.cs
- BoundColumn.cs
- LastQueryOperator.cs
- FileDialogPermission.cs
- WebConfigurationManager.cs
- IDReferencePropertyAttribute.cs
- ProxyManager.cs
- SqlInfoMessageEvent.cs
- ColorAnimationBase.cs
- XmlSchemaInfo.cs
- ControlPaint.cs
- KeyGestureValueSerializer.cs
- webproxy.cs
- BitmapCodecInfoInternal.cs
- KeyInterop.cs
- ByteStream.cs
- errorpatternmatcher.cs
- InvalidEnumArgumentException.cs
- ObjectDataSourceSelectingEventArgs.cs
- EditCommandColumn.cs
- GCHandleCookieTable.cs
- Assert.cs
- Rectangle.cs
- EventLogPermission.cs
- ProgressPage.cs
- WmfPlaceableFileHeader.cs
- ExponentialEase.cs
- Rfc4050KeyFormatter.cs
- GeneralTransform.cs
- Clipboard.cs
- XmlParser.cs
- DataGridViewDataErrorEventArgs.cs
- Point.cs
- DataControlFieldsEditor.cs
- JulianCalendar.cs
- ImportContext.cs
- HostedController.cs
- RegexWriter.cs
- IconHelper.cs
- MessageQueueKey.cs
- BamlMapTable.cs
- LogSwitch.cs
- CodeTypeMemberCollection.cs
- CssTextWriter.cs
- SrgsRule.cs
- GridViewRowCollection.cs
- TraceHandler.cs
- CalloutQueueItem.cs
- EventToken.cs
- NativeMethodsOther.cs
- GifBitmapEncoder.cs
- MappingException.cs
- PrintPreviewDialog.cs
- KeyValueConfigurationCollection.cs