cli: allow enabling/disabling location signaling via DBus
Not making them '--location-enable|disable-signal' because that's the pattern used to enable/disable location sources. Instead, use the '--location-set-*' pattern, as that is what we're already using for the other location setup update.
This commit is contained in:
@@ -62,6 +62,8 @@ static gboolean disable_cdma_bs_flag;
|
|||||||
static gboolean get_cdma_bs_flag;
|
static gboolean get_cdma_bs_flag;
|
||||||
static gboolean enable_gps_unmanaged_flag;
|
static gboolean enable_gps_unmanaged_flag;
|
||||||
static gboolean disable_gps_unmanaged_flag;
|
static gboolean disable_gps_unmanaged_flag;
|
||||||
|
static gboolean set_enable_signal_flag;
|
||||||
|
static gboolean set_disable_signal_flag;
|
||||||
static gboolean get_all_flag;
|
static gboolean get_all_flag;
|
||||||
static gchar *set_supl_server_str;
|
static gchar *set_supl_server_str;
|
||||||
static gchar *set_gps_refresh_rate_str;
|
static gchar *set_gps_refresh_rate_str;
|
||||||
@@ -147,6 +149,14 @@ static GOptionEntry entries[] = {
|
|||||||
"Set GPS refresh rate in seconds, or 0 disable the explicit rate.",
|
"Set GPS refresh rate in seconds, or 0 disable the explicit rate.",
|
||||||
"[RATE]"
|
"[RATE]"
|
||||||
},
|
},
|
||||||
|
{ "location-set-enable-signal", 0, 0, G_OPTION_ARG_NONE, &set_enable_signal_flag,
|
||||||
|
"Enable location update signaling in DBus property.",
|
||||||
|
NULL
|
||||||
|
},
|
||||||
|
{ "location-set-disable-signal", 0, 0, G_OPTION_ARG_NONE, &set_disable_signal_flag,
|
||||||
|
"Disable location update signaling in DBus property.",
|
||||||
|
NULL
|
||||||
|
},
|
||||||
{ NULL }
|
{ NULL }
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -184,6 +194,11 @@ mmcli_modem_location_options_enabled (void)
|
|||||||
exit (EXIT_FAILURE);
|
exit (EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (set_enable_signal_flag && set_disable_signal_flag) {
|
||||||
|
g_printerr ("error: cannot enable and disable location signaling\n");
|
||||||
|
exit (EXIT_FAILURE);
|
||||||
|
}
|
||||||
|
|
||||||
if (get_all_flag) {
|
if (get_all_flag) {
|
||||||
get_3gpp_flag = TRUE;
|
get_3gpp_flag = TRUE;
|
||||||
get_gps_nmea_flag = TRUE;
|
get_gps_nmea_flag = TRUE;
|
||||||
@@ -203,7 +218,9 @@ mmcli_modem_location_options_enabled (void)
|
|||||||
enable_cdma_bs_flag +
|
enable_cdma_bs_flag +
|
||||||
disable_cdma_bs_flag +
|
disable_cdma_bs_flag +
|
||||||
enable_gps_unmanaged_flag +
|
enable_gps_unmanaged_flag +
|
||||||
disable_gps_unmanaged_flag) +
|
disable_gps_unmanaged_flag +
|
||||||
|
set_enable_signal_flag +
|
||||||
|
set_disable_signal_flag) +
|
||||||
!!(get_3gpp_flag +
|
!!(get_3gpp_flag +
|
||||||
get_gps_nmea_flag +
|
get_gps_nmea_flag +
|
||||||
get_gps_raw_flag +
|
get_gps_raw_flag +
|
||||||
@@ -425,6 +442,16 @@ build_sources_from_flags (void)
|
|||||||
return sources;
|
return sources;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
build_signals_location_from_flags (void)
|
||||||
|
{
|
||||||
|
if (set_enable_signal_flag)
|
||||||
|
return TRUE;
|
||||||
|
if (set_disable_signal_flag)
|
||||||
|
return FALSE;
|
||||||
|
return mm_modem_location_signals_location (ctx->modem_location);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
get_location_process_reply (MMLocation3gpp *location_3gpp,
|
get_location_process_reply (MMLocation3gpp *location_3gpp,
|
||||||
MMLocationGpsNmea *location_gps_nmea,
|
MMLocationGpsNmea *location_gps_nmea,
|
||||||
@@ -597,11 +624,13 @@ get_modem_ready (GObject *source,
|
|||||||
enable_cdma_bs_flag ||
|
enable_cdma_bs_flag ||
|
||||||
disable_cdma_bs_flag ||
|
disable_cdma_bs_flag ||
|
||||||
enable_gps_unmanaged_flag ||
|
enable_gps_unmanaged_flag ||
|
||||||
disable_gps_unmanaged_flag) {
|
disable_gps_unmanaged_flag ||
|
||||||
|
set_enable_signal_flag ||
|
||||||
|
set_disable_signal_flag) {
|
||||||
g_debug ("Asynchronously setting up location gathering...");
|
g_debug ("Asynchronously setting up location gathering...");
|
||||||
mm_modem_location_setup (ctx->modem_location,
|
mm_modem_location_setup (ctx->modem_location,
|
||||||
build_sources_from_flags (),
|
build_sources_from_flags (),
|
||||||
mm_modem_location_signals_location (ctx->modem_location),
|
build_signals_location_from_flags (),
|
||||||
ctx->cancellable,
|
ctx->cancellable,
|
||||||
(GAsyncReadyCallback)setup_ready,
|
(GAsyncReadyCallback)setup_ready,
|
||||||
NULL);
|
NULL);
|
||||||
@@ -707,13 +736,15 @@ mmcli_modem_location_run_synchronous (GDBusConnection *connection)
|
|||||||
enable_cdma_bs_flag ||
|
enable_cdma_bs_flag ||
|
||||||
disable_cdma_bs_flag ||
|
disable_cdma_bs_flag ||
|
||||||
enable_gps_unmanaged_flag ||
|
enable_gps_unmanaged_flag ||
|
||||||
disable_gps_unmanaged_flag) {
|
disable_gps_unmanaged_flag ||
|
||||||
|
set_enable_signal_flag ||
|
||||||
|
set_disable_signal_flag) {
|
||||||
gboolean result;
|
gboolean result;
|
||||||
|
|
||||||
g_debug ("Synchronously setting up location gathering...");
|
g_debug ("Synchronously setting up location gathering...");
|
||||||
result = mm_modem_location_setup_sync (ctx->modem_location,
|
result = mm_modem_location_setup_sync (ctx->modem_location,
|
||||||
build_sources_from_flags (),
|
build_sources_from_flags (),
|
||||||
mm_modem_location_signals_location (ctx->modem_location),
|
build_signals_location_from_flags (),
|
||||||
NULL,
|
NULL,
|
||||||
&error);
|
&error);
|
||||||
setup_process_reply (result, error);
|
setup_process_reply (result, error);
|
||||||
|
Reference in New Issue
Block a user