plugin-base: apply post-probing filtering

Once probing is finished, the plugin will check whether the port is supported
or not based on the following filters:
 - Capabilities
 - Reported Vendor string
 - Reported Product string
This commit is contained in:
Aleksander Morgado
2011-09-15 22:57:13 +02:00
committed by Aleksander Morgado
parent f92fbcc906
commit 0646fc9d99

View File

@@ -287,8 +287,10 @@ apply_pre_probing_filters (MMPluginBase *self,
if (g_str_equal (subsys, priv->subsystems[i])) if (g_str_equal (subsys, priv->subsystems[i]))
break; break;
} }
/* If we didn't match any subsystem: unsupported */
if (!priv->subsystems[i]) if (!priv->subsystems[i])
return TRUE; /* Filtered by subsystem! */ return TRUE;
} }
/* The plugin may specify that only some drivers are supported. If that /* The plugin may specify that only some drivers are supported. If that
@@ -359,28 +361,106 @@ apply_pre_probing_filters (MMPluginBase *self,
return FALSE; return FALSE;
} }
/* Returns TRUE if the support check request was filtered out */
static gboolean
apply_post_probing_filters (MMPluginBase *self,
MMPortProbe *probe)
{
MMPluginBasePrivate *priv = MM_PLUGIN_BASE_GET_PRIVATE (self);
guint i;
/* The plugin may specify that only some capabilities are supported. If that
* is the case, filter by capabilities */
if (priv->capabilities &&
!(priv->capabilities & mm_port_probe_get_capabilities (probe)))
return TRUE;
/* The plugin may specify that only some vendor strings are supported. If
* that is the case, filter by vendor string. */
if (priv->vendor_strings) {
const gchar *vendor;
vendor = mm_port_probe_get_vendor (probe);
/* If we didn't get any vendor: unsupported */
if (!vendor)
return TRUE;
for (i = 0; priv->vendor_strings[i]; i++) {
gboolean found;
gchar *casefolded;
casefolded = g_utf8_casefold (priv->vendor_strings[i], -1);
found = !!strstr (vendor, casefolded);
g_free (casefolded);
if (found)
break;
}
/* If we didn't match any vendor: unsupported */
if (!priv->vendor_strings[i])
return TRUE;
/* The plugin may specify that only some product strings are supported.
* If that is the case, filter by product string */
if (priv->product_strings) {
const gchar *product;
product = mm_port_probe_get_product (probe);
/* If we didn't get any product: unsupported */
if (!product)
return TRUE;
for (i = 0; priv->product_strings[i]; i++) {
gboolean found;
gchar *casefolded;
casefolded = g_utf8_casefold (priv->product_strings[i], -1);
found = !!strstr (product, casefolded);
g_free (casefolded);
if (found)
break;
}
/* If we didn't match any product: unsupported */
if (!priv->product_strings[i])
return TRUE;
}
}
return FALSE;
}
/* Context for the asynchronous probing operation */
typedef struct {
GSimpleAsyncResult *result;
MMPluginBase *plugin;
} PortProbeRunContext;
static void static void
port_probe_run_ready (MMPortProbe *probe, port_probe_run_ready (MMPortProbe *probe,
GAsyncResult *probe_result, GAsyncResult *probe_result,
GSimpleAsyncResult *supports_port_result) PortProbeRunContext *ctx)
{ {
GError *error = NULL; GError *error = NULL;
if (!mm_port_probe_run_finish (probe, probe_result, &error)) { if (!mm_port_probe_run_finish (probe, probe_result, &error)) {
/* Probing failed */ /* Probing failed */
g_simple_async_result_take_error (supports_port_result, error); g_simple_async_result_take_error (ctx->result, error);
} else { } else {
/* Probing succeeded */ /* Probing succeeded */
guint32 capabilities; g_simple_async_result_set_op_res_gboolean (
ctx->result,
/* TODO: Let plugins decide which capabilities they support */ !apply_post_probing_filters (ctx->plugin, probe));
capabilities = mm_port_probe_get_capabilities (probe);
g_simple_async_result_set_op_res_gboolean (supports_port_result,
(capabilities > 0 ? TRUE : FALSE));
} }
/* Complete the async supports port request */ /* Complete the async supports port request */
g_simple_async_result_complete_in_idle (supports_port_result); g_simple_async_result_complete_in_idle (ctx->result);
g_object_unref (ctx->result);
g_object_unref (ctx->plugin);
g_free (ctx);
} }
static MMPluginSupportsResult static MMPluginSupportsResult
@@ -424,6 +504,8 @@ supports_port (MMPlugin *plugin,
gchar *key = NULL; gchar *key = NULL;
MMPortProbe *probe; MMPortProbe *probe;
GSimpleAsyncResult *async_result; GSimpleAsyncResult *async_result;
PortProbeRunContext *ctx;
guint32 probe_run_flags;
async_result = g_simple_async_result_new (G_OBJECT (self), async_result = g_simple_async_result_new (G_OBJECT (self),
callback, callback,
@@ -482,14 +564,32 @@ supports_port (MMPlugin *plugin,
probe = mm_port_probe_cache_get (port, physdev_path, driver); probe = mm_port_probe_cache_get (port, physdev_path, driver);
g_assert (probe); g_assert (probe);
/* Build flags depending on what probing needed */
probe_run_flags = 0;
if (priv->capabilities)
probe_run_flags |= MM_PORT_PROBE_AT_CAPABILITIES;
if (priv->vendor_strings)
probe_run_flags |= MM_PORT_PROBE_AT_VENDOR;
if (priv->product_strings)
probe_run_flags |= MM_PORT_PROBE_AT_PRODUCT;
if (priv->qcdm)
probe_run_flags |= MM_PORT_PROBE_QCDM;
g_assert (probe_run_flags != 0);
/* Setup async call context */
ctx = g_new (PortProbeRunContext, 1);
ctx->plugin = g_object_ref (self);
ctx->result = g_object_ref (async_result);
/* Launch the probe */ /* Launch the probe */
mm_dbg ("(%s) launching probe for (%s,%s)!", priv->name, subsys, name); mm_dbg ("(%s) launching probe for (%s,%s)!", priv->name, subsys, name);
mm_port_probe_run (probe, mm_port_probe_run (probe,
MM_PORT_PROBE_AT_CAPABILITIES, probe_run_flags,
priv->send_delay, priv->send_delay,
priv->custom_init, priv->custom_init,
(GAsyncReadyCallback)port_probe_run_ready, (GAsyncReadyCallback)port_probe_run_ready,
g_object_ref (async_result)); ctx);
/* Keep track of the probe */ /* Keep track of the probe */
g_hash_table_insert (priv->tasks, g_hash_table_insert (priv->tasks,