1
0
Fork 0
mirror of https://gitlab.gnome.org/GNOME/calls.git synced 2025-01-08 21:05:32 +00:00
Purism-Calls/src/util.c
Evangelos Ribeiro Tzaras abdb601afa util: Add API to query call icon names
This can later be used in the call history or in the call details
instead of always constructing the name repeatedly in private functions.
2021-12-07 11:05:12 +01:00

300 lines
6.4 KiB
C

/*
* Copyright (C) 2018, 2019 Purism SPC
*
* This file is part of Calls.
*
* Calls is free software: you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Calls is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Calls. If not, see <http://www.gnu.org/licenses/>.
*
* Author: Bob Ham <bob.ham@puri.sm>
*
* SPDX-License-Identifier: GPL-3.0-or-later
*
*/
#include "util.h"
void
calls_object_unref (gpointer object)
{
if (object)
{
g_object_unref (object);
}
}
typedef struct
{
gpointer needle;
guint needle_column;
GtkTreeIter *iter;
gboolean found;
} ListStoreFindData;
static gboolean
list_store_find_foreach_cb (GtkTreeModel *model,
GtkTreePath *path,
GtkTreeIter *iter,
gpointer data)
{
ListStoreFindData *find_data = data;
gpointer value;
gtk_tree_model_get (model, iter, find_data->needle_column,
&value, -1);
if (value == find_data->needle)
{
*find_data->iter = *iter;
return (find_data->found = TRUE);
}
return FALSE;
}
gboolean
calls_list_store_find (GtkListStore *store,
gpointer needle,
gint needle_column,
GtkTreeIter *iter)
{
ListStoreFindData find_data
= { needle, needle_column, iter, FALSE };
gtk_tree_model_foreach (GTK_TREE_MODEL (store),
list_store_find_foreach_cb,
&find_data);
return find_data.found;
}
void
calls_entry_append (GtkEntry *entry,
gchar character)
{
const gchar str[] = {character, '\0'};
GtkEntryBuffer *buf;
guint len;
g_return_if_fail (GTK_IS_ENTRY (entry));
buf = gtk_entry_get_buffer (entry);
len = gtk_entry_buffer_get_length (buf);
gtk_entry_buffer_insert_text (buf, len, str, 1);
}
gboolean
calls_date_time_is_same_day (GDateTime *a,
GDateTime *b)
{
#define eq(member) \
(g_date_time_get_##member (a) == \
g_date_time_get_##member (b))
return
eq (year)
&&
eq (month)
&&
eq (day_of_month);
#undef eq
}
gboolean
calls_date_time_is_yesterday (GDateTime *now,
GDateTime *t)
{
GDateTime *yesterday;
gboolean same_day;
yesterday = g_date_time_add_days (now, -1);
same_day = calls_date_time_is_same_day (yesterday, t);
g_date_time_unref (yesterday);
return same_day;
}
gboolean
calls_date_time_is_same_year (GDateTime *a,
GDateTime *b)
{
return
g_date_time_get_year (a) ==
g_date_time_get_year (b);
}
gboolean
calls_number_is_ussd (const char *number)
{
/* USSD numbers start with *, #, **, ## or *# and are finished by # */
if (!number ||
(*number != '*' && *number != '#'))
return FALSE;
number++;
if (*number == '#')
number++;
while (g_ascii_isdigit (*number) || *number == '*')
number++;
if (g_str_equal (number, "#"))
return TRUE;
return FALSE;
}
/**
* calls_find_in_store:
* @list: A #GListModel
* @item: The #gpointer to find
* @position: (out) (optional): The first position of @item, if it was found.
*
* Returns: Whether @list contains @item. This is mainly a convenience function
* until we no longer support older glib versions.
*/
gboolean
calls_find_in_store (GListModel *list,
gpointer item,
guint *position)
{
GListStore *store = (GListStore *) list;
guint count;
g_return_val_if_fail (G_IS_LIST_MODEL (list), FALSE);
if (G_IS_LIST_STORE (store))
return g_list_store_find (store,
item,
position);
count = g_list_model_get_n_items (list);
for (guint i = 0; i < count; i++) {
g_autoptr (GObject) object = NULL;
object = g_list_model_get_item (list, i);
if (object == item) {
if (position)
*position = i;
return TRUE;
}
}
return FALSE;
}
/**
* get_protocol_from_address:
* @target: The target address
*
* simply checks for the the scheme of an address without doing any validation
*
* Returns: The protocol used for address, or NULL if could not determine
*/
const char *
get_protocol_from_address (const char *target)
{
g_autofree char *lower = NULL;
g_return_val_if_fail (target, NULL);
lower = g_ascii_strdown (target, -1);
if (g_str_has_prefix (lower, "sips:"))
return "sips";
if (g_str_has_prefix (lower, "sip:"))
return "sip";
if (g_str_has_prefix (lower, "tel:"))
return "tel";
/* could not determine the protocol (which most probably means it's a telephone number) */
return NULL;
}
/**
* get_protocol_from_address_with_fallback:
* @target: The address to check
*
* simply checks for the the scheme of an address without doing any validation
*
* Returns: The protocol used for address, or "tel" as a fallback
*/
const char *
get_protocol_from_address_with_fallback (const char *target)
{
const char *protocol = get_protocol_from_address (target);
if (!protocol)
protocol = "tel";
return protocol;
}
/**
* dtmf_tone_is_valid:
* @key:
*
* Checks if @key is a valid DTMF keytone
*
* Returns: %TRUE if @key is 0-9, A-D, * or #, %FALSE otherwise
*/
gboolean
dtmf_tone_key_is_valid (gchar key)
{
return
(key >= '0' && key <= '9')
|| (key >= 'A' && key <= 'D')
|| key == '*'
|| key == '#';
}
static const char * const type_icon_name[] = {
"call-arrow-outgoing-symbolic",
"call-arrow-outgoing-missed-symbolic",
"call-arrow-incoming-symbolic",
"call-arrow-incoming-missed-symbolic",
};
/**
* get_call_icon_type_name:
* @inbound: Whether the call was inbound
* @missed: Whether the call was missed
*
* Returns: (transfer null): The icon symbolic name to use in the history, etc
*/
const char *
get_call_icon_symbolic_name (gboolean inbound,
gboolean missed)
{
guint index = 0;
index = ((inbound) << 1) + missed;
return type_icon_name[index];
}