From 664645986d11ec314047dcb58ea1a293d829eaca Mon Sep 17 00:00:00 2001 From: Michael Date: Sun, 16 Apr 2017 08:06:17 -0400 Subject: Document the Appearance Manager Also removed obsolete/unused code. --- ShiftOS_TheReturn/AppearanceManager.cs | 255 ++++++++++++++++++++++++--------- 1 file changed, 187 insertions(+), 68 deletions(-) (limited to 'ShiftOS_TheReturn') diff --git a/ShiftOS_TheReturn/AppearanceManager.cs b/ShiftOS_TheReturn/AppearanceManager.cs index dc88092..4c1754e 100644 --- a/ShiftOS_TheReturn/AppearanceManager.cs +++ b/ShiftOS_TheReturn/AppearanceManager.cs @@ -38,6 +38,9 @@ using static ShiftOS.Engine.SaveSystem; namespace ShiftOS.Engine { + /// + /// Provides functionality for managing windows within ShiftOS. + /// public static class AppearanceManager { [Obsolete("Please use Localization.GetAllLanguages().")] @@ -46,38 +49,16 @@ namespace ShiftOS.Engine return Localization.GetAllLanguages(); } - public static void AddFocusEvents(Control ctrl, Control child) - { - child.Enter += (o, a) => - { - ctrl.BringToFront(); - }; - child.MouseDown += (o, a) => - { - ctrl.BringToFront(); - }; - - foreach (Control c in child.Controls) - { - c.Enter += (o, a) => - { - ctrl.BringToFront(); - }; - c.MouseDown += (o, a) => - { - ctrl.BringToFront(); - }; - - try - { - AddFocusEvents(ctrl, c); - } - catch { } - } - } - + /// + /// Sets the title text of the specified window. + /// + /// The window to modify + /// The title text to use + /// Thrown if the window is null. public static void SetWindowTitle(IShiftOSWindow window, string title) { + if (window == null) + throw new ArgumentNullException("window", "The window cannot be null."); winmgr.SetTitle(window, title); } @@ -103,8 +84,16 @@ namespace ShiftOS.Engine return types; } + /// + /// Returns the default window title for a specified -inheriting type. + /// + /// The type to scan + /// The default title + /// Thrown if is null. public static string GetDefaultTitle(Type winType) { + if (winType == null) + throw new ArgumentNullException("winType"); foreach(var attrib in winType.GetCustomAttributes(false)) { if(attrib is DefaultTitleAttribute) @@ -115,78 +104,123 @@ namespace ShiftOS.Engine return winType.Name; } - public static string LastTerminalText { get; set; } + /// + /// Current cursor position of the console + /// public static int CurrentPosition { get; set; } + + /// + /// We don't know what this does. It may be gone if it does nothing. + /// public static int LastLength { get; set; } + /// + /// Minimize a window. + /// + /// The window border to minimize. + /// Thrown if is null. + /// Thrown if this part of the engine hasn't been enabled. public static void Minimize(IWindowBorder form) { + if (form == null) + throw new ArgumentNullException("form"); + if (winmgr == null) + throw new EngineModuleDisabledException(); winmgr.Minimize(form); } + /// + /// Maximizes a window. + /// + /// The window border to maximize. + /// Thrown if is null. + /// Thrown if this engine module hasn't been enabled. public static void Maximize(IWindowBorder form) { + if (form == null) + throw new ArgumentNullException("form"); + if (winmgr == null) + throw new EngineModuleDisabledException(); winmgr.Maximize(form); } - + /// + /// Provides a list of all open ShiftOS windows. + /// public static List OpenForms = new List(); - public static bool CanOpenWindow(IShiftOSWindow form) - { -#if !MUD_RAPIDDEV - if (ServerManager.IsSingleplayer) - { - foreach (var attr in form.GetType().GetCustomAttributes(false)) - { - if (attr is MultiplayerOnlyAttribute) - return false; - } - } -#endif - return true; - } - + /// + /// Decorates a window with a border, then shows the window. + /// + /// The window to decorate and show. + /// Thrown if is null. + /// Thrown if this engine module has not been initiated yet. public static void SetupWindow(IShiftOSWindow form) { + if (form == null) + throw new ArgumentNullException("form"); + if (winmgr == null) + throw new EngineModuleDisabledException(); winmgr.SetupWindow(form); Desktop.ResetPanelButtons(); } + /// + /// Closes the specified window. + /// + /// The window to close. + /// Thrown if is null. + /// Thrown if this engine module has not been initiated yet. public static void Close(IShiftOSWindow win) { + if (win == null) + throw new ArgumentNullException("win"); + if (winmgr == null) + throw new EngineModuleDisabledException(); winmgr.Close(win); Desktop.ResetPanelButtons(); } + /// + /// Decorates a window with a border, then shows the window, as a dialog box. + /// + /// The window to decorate and show. + /// Thrown if is null. + /// Thrown if this engine module has not been initiated yet. public static void SetupDialog(IShiftOSWindow form) { + if (form == null) + throw new ArgumentNullException("form"); + if (winmgr == null) + throw new EngineModuleDisabledException(); winmgr.SetupDialog(form); Desktop.ResetPanelButtons(); } + /// + /// The underlying window manager for this engine module + /// private static WindowManager winmgr = null; - public static double Measure(this string text, Font font) - { - return Graphics.FromImage(new Bitmap(1, 1)).MeasureString(text, font).Width; - } - + /// + /// Initiate this engine module, and perform mandatory configuration. + /// + /// A working, configured to use as a backend for this module public static void Initiate(WindowManager mgr) { winmgr = mgr; } - [Obsolete("This is a stub.")] - public static void DoWinformsSkinningMagicOnWpf(this UserControl ctrl) - { - //SetupControls(ctrl); - } - + /// + /// Raised when the engine is entering its shutdown phase. Save your work! + /// public static event EmptyEventHandler OnExit; + /// + /// Starts the engine's exit routine, firing the OnExit event. + /// internal static void Exit() { OnExit?.Invoke(); @@ -194,61 +228,133 @@ namespace ShiftOS.Engine ServerManager.Disconnect(); } - - internal static bool BordersHidden(Form frm) - { - string t = frm.Tag as string; - if (t == null) - return false; - - return t.Contains("hidden"); - } - + /// + /// The current terminal body control. + /// public static ITerminalWidget ConsoleOut { get; set; } + /// + /// Redirects the .NET to a new instance. + /// public static void StartConsoleOut() { Console.SetOut(new TerminalTextWriter()); } + /// + /// Invokes an action on the window management thread. + /// + /// The action to invoke public static void Invoke(Action act) { winmgr.InvokeAction(act); } } + /// + /// Provides the base functionality for a ShiftOS terminal. + /// public interface ITerminalWidget { + /// + /// Write text to this Terminal. + /// + /// Text to write void Write(string text); + /// + /// Write text to this Terminal, followed by a newline. + /// + /// Text to write. void WriteLine(string text); + /// + /// Clear the contents of this Terminal. + /// void Clear(); + /// + /// Move the cursor to the last character in the Terminal. + /// void SelectBottom(); } + /// + /// Provides the base functionality for a ShiftOS window manager. + /// public abstract class WindowManager { + /// + /// Minimizes a window + /// + /// The window border to minimize public abstract void Minimize(IWindowBorder border); + + /// + /// Maximizes a window + /// + /// The window border to maximize public abstract void Maximize(IWindowBorder border); + /// + /// Closes a window + /// + /// The window to close public abstract void Close(IShiftOSWindow win); + /// + /// Decorates a window with a window border, then shows it to the user. + /// + /// The window to decorate. public abstract void SetupWindow(IShiftOSWindow win); + + /// + /// Decorates a window with a border, then shows it to the user as a dialog box. + /// + /// The window to decorate public abstract void SetupDialog(IShiftOSWindow win); + /// + /// Invokes an action on the window management thread. + /// + /// The action to invoke. public abstract void InvokeAction(Action act); + /// + /// Sets the title text of a window. + /// + /// The window to modify. + /// The new title text. public abstract void SetTitle(IShiftOSWindow win, string title); } + /// + /// Provides the base functionality for a typical ShiftOS window border. + /// public interface IWindowBorder { + /// + /// Closes the border along with its window. Unload events should be invoked here. + /// void Close(); + + /// + /// Gets or sets the title text for the window border. + /// string Text { get; set; } + + /// + /// Gets or sets the underlying for this border. + /// IShiftOSWindow ParentWindow { get; set; } } + /// + /// Provides a way of setting default title text for classes. + /// public class DefaultTitleAttribute : Attribute { + /// + /// Creates a new instance of the . + /// + /// A default title to associate with this attribute. public DefaultTitleAttribute(string title) { Title = title; @@ -257,4 +363,17 @@ namespace ShiftOS.Engine public string Title { get; private set; } } + /// + /// An exception that is thrown when mandatory configuration to run a specific method or module hasn't been done yet. + /// + public class EngineModuleDisabledException : Exception + { + /// + /// Initializes a new instance of the . + /// + public EngineModuleDisabledException() : base("This engine module has not yet been enabled.") + { + + } + } } -- cgit v1.2.3