Add ServiceResponseTimeDialog.
[metze/wireshark/wip.git] / ui / qt / qt_ui_utils.cpp
index f551adfefad92f54239d700550b89bc78b6dd6dd..c1841c9f8014620ced1dc65d4d96d72ee68f0270 100644 (file)
@@ -1,6 +1,4 @@
 /* qt_ui_utils.cpp
- *
- * $Id$
  *
  * Wireshark - Network traffic analyzer
  * By Gerald Combs <gerald@wireshark.org>
  *
  * You should have received a copy of the GNU General Public License
  * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
  */
 
-#include <string.h>
+#include <stdio.h>
 #include <stdlib.h>
+#include <string.h>
 
 #include "qt_ui_utils.h"
 
-#include "ui/recent.h"
-#include "ui/ui_util.h"
+#include <epan/addr_resolv.h>
+#include <epan/range.h>
+#include <epan/to_str.h>
+#include <epan/value_string.h>
 
-// XXX - Copied from ui/gtk/gui_utils.c
+#include <ui/recent.h>
+#include <ui/ui_util.h>
 
-#define WINDOW_GEOM_KEY "window_geom"
+#include <wsutil/str_util.h>
 
-/* load the geometry values for a window from previously saved values */
-static gboolean window_geom_load(const gchar *name, window_geometry_t *geom);
+#include <QAction>
+#include <QFontDatabase>
 
-/* the geometry hashtable for all known window classes,
- * the window name is the key, and the geometry struct is the value */
-static GHashTable *window_geom_hash = NULL;
-
-/* save the window and it's current geometry into the geometry hashtable */
-static void
-window_geom_save(const gchar *name, window_geometry_t *geom)
-{
-    gchar *key;
-    window_geometry_t *work;
+/* Make the format_size_flags_e enum usable in C++ */
+format_size_flags_e operator|(format_size_flags_e lhs, format_size_flags_e rhs) {
+    return (format_size_flags_e) ((int)lhs| (int)rhs);
+}
 
-    /* init hashtable, if not already done */
-    if(!window_geom_hash) {
-        window_geom_hash = g_hash_table_new (g_str_hash, g_str_equal);
-    }
-    /* if we have an old one, remove and free it first */
-    work = (window_geometry_t *) g_hash_table_lookup(window_geom_hash, name);
-    if(work) {
-        g_hash_table_remove(window_geom_hash, name);
-        g_free(work->key);
-        g_free(work);
-    }
+/*
+ * We might want to create our own "wsstring" class with convenience
+ * methods for handling g_malloc()ed strings, GStrings, and a shortcut
+ * to .toUtf8().constData().
+ */
 
-    /* g_malloc and insert the new one */
-    work = (window_geometry_t *) g_malloc(sizeof(*geom));
-    *work = *geom;
-    key = g_strdup(name);
-    work->key = key;
-    g_hash_table_insert(window_geom_hash, key, work);
+gchar *qstring_strdup(QString q_string) {
+    return g_strdup(q_string.toUtf8().constData());
 }
 
+QString gchar_free_to_qstring(gchar *glib_string) {
+    QString qt_string(glib_string);
+    g_free(glib_string);
+    return qt_string;
+}
 
-/* load the desired geometry for this window from the geometry hashtable */
-static gboolean
-window_geom_load(const gchar *name, window_geometry_t *geom)
+QByteArray gstring_free_to_qbytearray(GString *glib_gstring)
 {
-    window_geometry_t *p;
+    QByteArray qt_ba(glib_gstring->str);
+    g_string_free(glib_gstring, TRUE);
+    return qt_ba;
+}
 
-    /* init hashtable, if not already done */
-    if(!window_geom_hash) {
-        window_geom_hash = g_hash_table_new (g_str_hash, g_str_equal);
+const QString address_to_qstring(const _address *address)
+{
+    QString address_qstr = QString();
+    if (address) {
+        gchar *address_gchar_p = address_to_str(NULL, address);
+        address_qstr = address_gchar_p;
+        wmem_free(NULL, address_gchar_p);
     }
+    return address_qstr;
+}
 
-    p = (window_geometry_t *) g_hash_table_lookup(window_geom_hash, name);
-    if(p) {
-        *geom = *p;
-        return TRUE;
-    } else {
-        return FALSE;
+const QString address_to_display_qstring(const _address *address)
+{
+    QString address_qstr = QString();
+    if (address) {
+        const gchar *address_gchar_p = address_to_display(NULL, address);
+        address_qstr = address_gchar_p;
+        wmem_free(NULL, (void *) address_gchar_p);
     }
+    return address_qstr;
 }
 
+const QString val_to_qstring(const guint32 val, const value_string *vs, const char *fmt)
+{
+    QString val_qstr = QString();
+    gchar* gchar_p = val_to_str_wmem(NULL, val, vs, fmt);
+    val_qstr = gchar_p;
+    wmem_free(NULL, gchar_p);
+
+    return val_qstr;
+}
 
-/* read in a single key value pair from the recent file into the geometry hashtable */
-extern "C" void
-window_geom_recent_read_pair(const char *name, const char *key, const char *value)
+const QString val_ext_to_qstring(const guint32 val, value_string_ext *vse, const char *fmt)
 {
-    window_geometry_t geom;
-
-
-    /* find window geometry maybe already in hashtable */
-    if(!window_geom_load(name, &geom)) {
-        /* not in table, init geom with "basic" values */
-        geom.key        = NULL;    /* Will be set in window_geom_save () */
-        geom.set_pos    = FALSE;
-        geom.x          = -1;
-        geom.y          = -1;
-        geom.set_size   = FALSE;
-        geom.width      = -1;
-        geom.height     = -1;
-
-        geom.set_maximized = FALSE;/* this is valid in GTK2 only */
-        geom.maximized  = FALSE;   /* this is valid in GTK2 only */
-    }
+    QString val_qstr = QString();
+    gchar* gchar_p = val_to_str_ext_wmem(NULL, val, vse, fmt);
+    val_qstr = gchar_p;
+    wmem_free(NULL, gchar_p);
 
-    if (strcmp(key, "x") == 0) {
-        geom.x = strtol(value, NULL, 10);
-        geom.set_pos = TRUE;
-    } else if (strcmp(key, "y") == 0) {
-        geom.y = strtol(value, NULL, 10);
-        geom.set_pos = TRUE;
-    } else if (strcmp(key, "width") == 0) {
-        geom.width = strtol(value, NULL, 10);
-        geom.set_size = TRUE;
-    } else if (strcmp(key, "height") == 0) {
-        geom.height = strtol(value, NULL, 10);
-        geom.set_size = TRUE;
-    } else if (strcmp(key, "maximized") == 0) {
-        if (g_ascii_strcasecmp(value, "true") == 0) {
-            geom.maximized = TRUE;
-        }
-        else {
-            geom.maximized = FALSE;
-        }
-        geom.set_maximized = TRUE;
-    } else {
-        /*
-         * Silently ignore the bogus key.  We shouldn't abort here,
-         * as this could be due to a corrupt recent file.
-         *
-         * XXX - should we print a message about this?
-         */
-        return;
+    return val_qstr;
+}
+
+const QString range_to_qstring(const epan_range *range)
+{
+    QString range_qstr = QString();
+    if (range) {
+        const gchar *range_gchar_p = range_convert_range(NULL, range);
+        range_qstr = range_gchar_p;
+        wmem_free(NULL, (void *) range_gchar_p);
     }
+    return range_qstr;
+}
 
-    /* save / replace geometry in hashtable */
-    window_geom_save(name, &geom);
+const QString bits_s_to_qstring(const double bits_s)
+{
+    return gchar_free_to_qstring(
+                format_size(bits_s, format_size_unit_none|format_size_prefix_si));
 }
 
-/* write all geometry values of all windows from the hashtable to the recent file */
-extern "C" void
-window_geom_recent_write_all(gpointer rf)
+const QString file_size_to_qstring(const gint64 size)
 {
-    /* init hashtable, if not already done */
-    if(!window_geom_hash) {
-        window_geom_hash = g_hash_table_new (g_str_hash, g_str_equal);
+    return gchar_free_to_qstring(
+                format_size(size, format_size_unit_bytes|format_size_prefix_si));
+}
+
+void smooth_font_size(QFont &font) {
+    QFontDatabase fdb;
+#if QT_VERSION < QT_VERSION_CHECK(4, 8, 0)
+    QList<int> size_list = fdb.smoothSizes(font.family(), "");
+#else
+    QList<int> size_list = fdb.smoothSizes(font.family(), font.styleName());
+#endif
+
+    if (size_list.size() < 2) return;
+
+    int last_size = size_list.takeFirst();
+    foreach (int cur_size, size_list) {
+        if (font.pointSize() > last_size && font.pointSize() <= cur_size) {
+            font.setPointSize(cur_size);
+            return;
+        }
+        last_size = cur_size;
     }
+}
 
-    g_hash_table_foreach(window_geom_hash, write_recent_geom, rf);
+bool qActionLessThan(const QAction * a1, const QAction * a2) {
+    return a1->text().compare(a2->text()) < 0;
 }
+
+/*
+ * Editor modelines
+ *
+ * Local Variables:
+ * c-basic-offset: 4
+ * tab-width: 8
+ * indent-tabs-mode: nil
+ * End:
+ *
+ * ex: set shiftwidth=4 tabstop=8 expandtab:
+ * :indentSize=4:tabSize=8:noTabs=true:
+ */