X-Git-Url: http://git.bytex64.net/?a=blobdiff_plain;f=WebThing.cs;h=08cfb1bae7c1a346f83183ffef81f0445db317d3;hb=bf0210888b2c1a7eb26656fdcaec4e0559569772;hp=c1e180687d7e038427c2307ec4b1822f2334f749;hpb=6c50b11e5b8e72781db4195d8472bb7d542c1d3c;p=WebThing.git diff --git a/WebThing.cs b/WebThing.cs index c1e1806..08cfb1b 100644 --- a/WebThing.cs +++ b/WebThing.cs @@ -48,44 +48,68 @@ namespace bytex64.WebThing { [DllImport ("SoupSettings.dll")] private static extern void soup_settings(); + // Main setup public void Run() { Application.Init(); + soup_settings(); + Config.ParseCommandLine(); Config.Load(); //Config.DumpOptions(); - soup_settings(); - + // Initialize Window _Window = new Gtk.Window("WebThing"); - _Window.SetWmclass("webthing", "WebThing"); + // The GTK+ docs say not to use this, but the defaults are + // based on the executable name, which I don't like. + _Window.SetWmclass("webthing", "WebThing"); _Window.Role = "browser"; _Window.Destroyed += delegate { Quit(); }; + // Initialize WidgetGrid + // The WidgetGrid holds the Tabs (and thus WebKit) and + // AttachPoint.Interior in the center, and allows widgets to + // be added on the sides of the browser WidgetGrid = new Gtk.Table(3, 3, false); _Window.Add(WidgetGrid); + // Initialize Tabs + // Tabs are a core feature of WebThing, not a plugin. By + // default, they do nothing -- Tab manipulation is left to + // plugins to define. _Tabs = new Gtk.Notebook(); _Tabs.ShowBorder = false; _Tabs.Scrollable = true; _Tabs.SwitchPage += Tabs_SwitchPage; WidgetGrid.Attach(_Tabs, 1, 2, 1, 2); + // InteriorOverlay goes over top of the Tabs to contain + // widgets that hover over the content, like progress, or + // inline search. This is not a very solid idea ATM. InteriorOverlay = new Gtk.Alignment(1, 0, 0, 0); WidgetGrid.Attach(InteriorOverlay, 1, 2, 1, 2); _Window.ShowAll(); - WebThingView newview = NewWebThingView(); - + // Load Plugins Plugins = new PluginManager(this); Plugins.Load(); - Plugins.WebViewSetup(newview.WebView); - newview.WebView.GrabFocus(); + + // Create a new, default WebThingView if one has not already + // been created. + if (Tabs.NPages == 0) + OpenUriTab("http://dominionofawesome.com/"); + WebView.GrabFocus(); Application.Run(); } + public void Quit() { + Plugins.Deinit(); + Application.Quit(); + } + + // Widget attachment public void AttachWidget(Gtk.Widget widget, AttachPoint direction, AttachOptions xoptions, AttachOptions yoptions) { switch(direction) { case AttachPoint.N: @@ -110,10 +134,11 @@ namespace bytex64.WebThing { AttachWidget(widget, direction, 0, 0); } - public WebView NewTab() { + // Tab management + public WebThingView NewTab() { WebThingView newview = NewWebThingView(); Plugins.WebViewSetup(newview.WebView); - return newview.WebView; + return newview; } private WebThingView NewWebThingView() { @@ -139,10 +164,17 @@ namespace bytex64.WebThing { _Tabs.RemovePage(tab); view.Dispose(); } catch (ArgumentOutOfRangeException) { + Console.WriteLine("Attempted to close tab out of range: {0}", tab); } } } + private void Tabs_SwitchPage(object o, SwitchPageArgs e) { + Gtk.Widget page = _Tabs.GetNthPage((int)e.PageNum); + _Window.Title = _Tabs.GetTabLabelText(page) + " - WebThing"; + } + + // Uri loading public string FixUri(string Uri) { if (!Regex.IsMatch(Uri, @"://")) { return String.Format("http://{0}", Uri); @@ -155,18 +187,8 @@ namespace bytex64.WebThing { } public void OpenUriTab(string Uri) { - WebView view = NewTab(); - view.Open(FixUri(Uri)); - } - - public void Quit() { - // TODO: Create a way of shutting down plugins - Application.Quit(); - } - - private void Tabs_SwitchPage(object o, SwitchPageArgs e) { - Gtk.Widget page = _Tabs.GetNthPage((int)e.PageNum); - _Window.Title = _Tabs.GetTabLabelText(page) + " - WebThing"; + WebThingView wtv = NewTab(); + wtv.WebView.Open(FixUri(Uri)); } } }