#region License
//
// The Open Toolkit Library License
//
// Copyright (c) 2006 - 2009 the Open Toolkit library.
//
// 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.
//
#endregion
using System;
using System.Collections.Generic;
using System.Text;
namespace OpenTK.Platform.X11
{
    /// \internal
    /// Describes an X11 window.
    sealed class X11WindowInfo : IWindowInfo
    {
        IntPtr handle, rootWindow, display;
        X11WindowInfo parent;
        int screen;
        XVisualInfo visualInfo;
        EventMask eventMask;
        #region --- Constructors ---
        #region X11WindowInfo()
        /// Constructs a new X11WindowInfo class.
        public X11WindowInfo() { }
        #endregion
        #region X11WindowInfo(IntPtr handle, X11WindowInfo parent)
        /// 
        /// Constructs a new X11WindowInfo class from the specified window handle and parent.
        /// 
        /// The handle of the window.
        /// The parent of the window.
        public X11WindowInfo(IntPtr handle, X11WindowInfo parent)
        {
            this.handle = handle;
            this.parent = parent;
            if (parent != null)
            {
                this.rootWindow = parent.rootWindow;
                this.display = parent.display;
                this.screen = parent.screen;
                this.visualInfo = parent.visualInfo;
            }
        }
        #endregion
        #endregion
        #region --- Public Methods ---
        /// Gets or sets the handle of the window.
        public IntPtr Handle { get { return handle; } set { handle = value; } }
        /// Gets or sets the parent of the window.
        public X11WindowInfo Parent { get { return parent; } set { parent = value; } }
        /// Gets or sets the X11 root window.
        public IntPtr RootWindow { get { return rootWindow; } set { rootWindow = value; } }
        /// Gets or sets the connection to the X11 display.
        public IntPtr Display { get { return display; } set { display = value; } }
        /// Gets or sets the X11 screen.
        public int Screen { get { return screen; } set { screen = value; } }
        /// Gets or sets the X11 VisualInfo.
        public XVisualInfo VisualInfo { get { return visualInfo; } set { visualInfo = value; } }
        /// Gets or sets the X11 EventMask.
        public EventMask EventMask { get { return eventMask; } set { eventMask = value; } }
        // For compatibility with whoever thought it would be
        // a good idea to access internal APIs through reflection
        // (e.g. MonoGame)
        public IntPtr WindowHandle { get { return Handle; } set { Handle = value; } }
        #endregion
        #region --- IDisposable Members ---
        /// 
        /// Disposes of this X11WindowInfo instance.
        /// 
        public void Dispose()
        {
        }
        #endregion
        #region --- Overrides ---
        #region public override string ToString()
        /// Returns a System.String that represents the current window.
        /// A System.String that represents the current window.
        public override string ToString()
        {
            return String.Format("X11.WindowInfo: Display {0}, Screen {1}, Handle {2}, Parent: ({3})",
                this.Display, this.Screen, this.Handle, this.Parent != null ? this.Parent.ToString() : "null");
        }
        #endregion
        /// Checks if this and obj reference the same win32 window.
        /// The object to check against.
        /// True if this and obj reference the same win32 window; false otherwise.
        public override bool Equals(object obj)
        {
            if (obj == null) return false;
            if (this.GetType() != obj.GetType()) return false;
            X11WindowInfo info = (X11WindowInfo)obj;
            if (info == null) return false;
            // TODO: Assumes windows will have unique handles per X11 display.
            return object.Equals(display, info.display) &&
                   handle.Equals(info.handle);
        }
        /// Returns the hash code for this instance.
        /// A hash code for the current X11WindowInfo.
        public override int GetHashCode()
        {
            return handle.GetHashCode() ^ display.GetHashCode();
        }
        #endregion
    }
}