// // HttpListenerPrefixCollection.cs // Copied from System.Net.HttpListenerPrefixCollection.cs // // Author: // Gonzalo Paniagua Javier (gonzalo@novell.com) // // Copyright (c) 2005 Novell, Inc. (http://www.novell.com) // Copyright (c) 2012-2013 sta.blockhead (sta.blockhead@gmail.com) // // Permission is hereby granted, free of charge, to any person obtaining // a copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to // permit persons to whom the Software is furnished to do so, subject to // the following conditions: // // The above copyright notice and this permission notice shall be // included in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. // using System; using System.Collections; using System.Collections.Generic; namespace WebSocketSharp.Net { /// /// Provides the collection used to store the URI prefixes for the . /// public class HttpListenerPrefixCollection : ICollection, IEnumerable, IEnumerable { #region Fields HttpListener listener; List prefixes; #endregion #region Private Constructor private HttpListenerPrefixCollection () { prefixes = new List (); } #endregion #region Internal Constructor internal HttpListenerPrefixCollection (HttpListener listener) : this () { this.listener = listener; } #endregion #region Properties /// /// Gets the number of prefixes contained in the . /// /// /// A that contains the number of prefixes. /// public int Count { get { return prefixes.Count; } } /// /// Gets a value indicating whether access to the is read-only. /// /// /// Always returns false. /// public bool IsReadOnly { get { return false; } } /// /// Gets a value indicating whether access to the is synchronized. /// /// /// Always returns false. /// public bool IsSynchronized { get { return false; } } #endregion #region Explicit Interface Implementation /// /// Gets an object that can be used to iterate through the . /// /// /// An object that implements the interface and provides access to /// the URI prefix strings in the . /// IEnumerator IEnumerable.GetEnumerator () { return prefixes.GetEnumerator (); } #endregion #region Public Methods /// /// Adds the specified to the . /// /// /// A that contains a URI prefix to add. /// /// /// is . /// /// /// The associated with this is closed. /// public void Add (string uriPrefix) { listener.CheckDisposed (); ListenerPrefix.CheckUri (uriPrefix); if (prefixes.Contains (uriPrefix)) return; prefixes.Add (uriPrefix); if (listener.IsListening) EndPointManager.AddPrefix (uriPrefix, listener); } /// /// Removes all URI prefixes from the . /// /// /// The associated with this is closed. /// public void Clear () { listener.CheckDisposed (); prefixes.Clear (); if (listener.IsListening) EndPointManager.RemoveListener (listener); } /// /// Returns a value indicating whether the contains /// the specified . /// /// /// true if the contains the specified ; /// otherwise, false. /// /// /// A that contains a URI prefix to test. /// /// /// is . /// /// /// The associated with this is closed. /// public bool Contains (string uriPrefix) { listener.CheckDisposed (); if (uriPrefix == null) throw new ArgumentNullException ("uriPrefix"); return prefixes.Contains (uriPrefix); } /// /// Copies the contents of the to the specified . /// /// /// An that receives the URI prefix strings in the . /// /// /// An that contains the zero-based index in at which copying begins. /// /// /// The associated with this is closed. /// public void CopyTo (Array array, int offset) { listener.CheckDisposed (); ((ICollection) prefixes).CopyTo (array, offset); } /// /// Copies the contents of the to the specified array of . /// /// /// An array of that receives the URI prefix strings in the . /// /// /// An that contains the zero-based index in at which copying begins. /// /// /// The associated with this is closed. /// public void CopyTo (string [] array, int offset) { listener.CheckDisposed (); prefixes.CopyTo (array, offset); } /// /// Gets an object that can be used to iterate through the . /// /// /// An object that implements the IEnumerator<string> interface and provides access to /// the URI prefix strings in the . /// public IEnumerator GetEnumerator () { return prefixes.GetEnumerator (); } /// /// Removes the specified from the list of prefixes in the . /// /// /// true if the was found in the /// and removed; otherwise, false. /// /// /// A that contains a URI prefix to remove. /// /// /// is . /// /// /// The associated with this is closed. /// public bool Remove (string uriPrefix) { listener.CheckDisposed (); if (uriPrefix == null) throw new ArgumentNullException ("uriPrefix"); bool result = prefixes.Remove (uriPrefix); if (result && listener.IsListening) EndPointManager.RemovePrefix (uriPrefix, listener); return result; } #endregion } }