[baobab/wip/grid-layout: 3/8] Make LocationWidget a derived type from BaseLocationWidget



commit 4efbe3a7b5eb7a7de1b5ef5b17ba754117c20866
Author: Stefano Facchini <stefano facchini gmail com>
Date:   Wed Apr 11 15:13:52 2012 +0200

    Make LocationWidget a derived type from BaseLocationWidget

 src/baobab-location-widget.vala |   26 +++++++++++++++++---------
 1 files changed, 17 insertions(+), 9 deletions(-)
---
diff --git a/src/baobab-location-widget.vala b/src/baobab-location-widget.vala
index 727cbdd..fc527de 100644
--- a/src/baobab-location-widget.vala
+++ b/src/baobab-location-widget.vala
@@ -20,16 +20,17 @@
 
 namespace Baobab {
 
-    public class LocationWidget : Gtk.Grid {
-        private static Gtk.SizeGroup name_size_group = null;
-        private static Gtk.SizeGroup mount_point_size_group = null;
-        private static Gtk.SizeGroup size_size_group = null;
-        private static Gtk.SizeGroup used_size_group = null;
-        private static Gtk.SizeGroup button_size_group = null;
+    public abstract class BaseLocationWidget : Gtk.Grid {
 
-        public delegate void ActionOnClick (Location location);
+        protected static Gtk.SizeGroup name_size_group = null;
+        protected static Gtk.SizeGroup mount_point_size_group = null;
+        protected static Gtk.SizeGroup size_size_group = null;
+        protected static Gtk.SizeGroup used_size_group = null;
+        protected static Gtk.SizeGroup button_size_group = null;
 
-        void ensure_size_groups () {
+        public delegate void ActionOnClick (Location? location = null);
+
+        protected void ensure_size_groups () {
             if (name_size_group != null)
                 return;
 
@@ -40,10 +41,17 @@ namespace Baobab {
             button_size_group = new Gtk.SizeGroup (Gtk.SizeGroupMode.HORIZONTAL);
         }
 
-        public LocationWidget (Location location, ActionOnClick action) {
+        public BaseLocationWidget () {
             orientation = Gtk.Orientation.HORIZONTAL;
             column_spacing = 10;
             margin = 6;
+        }
+    }
+
+    public class LocationWidget : BaseLocationWidget {
+
+        public LocationWidget (Location location, BaseLocationWidget.ActionOnClick action) {
+            base ();
 
             ensure_size_groups ();
 



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]