3
0
mirror of https://git.kernel.org/pub/scm/network/wireless/iwd.git synced 2025-01-03 02:02:33 +01:00

client: add AdHoc concept into device

This commit is contained in:
Tim Kourt 2018-07-29 15:33:00 -07:00 committed by Denis Kenzior
parent ece63270e7
commit 727a44aab4
2 changed files with 45 additions and 0 deletions

View File

@ -46,6 +46,7 @@ struct device {
const struct proxy_interface *connected_network; const struct proxy_interface *connected_network;
const struct proxy_interface *wsc; const struct proxy_interface *wsc;
const struct proxy_interface *ap; const struct proxy_interface *ap;
const struct proxy_interface *ad_hoc;
}; };
static struct proxy_interface *default_device; static struct proxy_interface *default_device;
@ -99,6 +100,7 @@ static void update_name(void *data, struct l_dbus_message_iter *variant)
} }
static const struct property_value_options device_mode_opts[] = { static const struct property_value_options device_mode_opts[] = {
{ "ad-hoc", (void *) "ad-hoc" },
{ "ap", (void *) "ap" }, { "ap", (void *) "ap" },
{ "station", (void *) "station" }, { "station", (void *) "station" },
{ } { }
@ -465,6 +467,12 @@ static bool device_bind_interface(const struct proxy_interface *proxy,
device->ap = dependency; device->ap = dependency;
return true;
} else if (!strcmp(interface, IWD_AD_HOC_INTERFACE)) {
struct device *device = proxy_interface_get_data(proxy);
device->ad_hoc = dependency;
return true; return true;
} }
@ -487,6 +495,12 @@ static bool device_unbind_interface(const struct proxy_interface *proxy,
device->ap = NULL; device->ap = NULL;
return true;
} else if (!strcmp(interface, IWD_AD_HOC_INTERFACE)) {
struct device *device = proxy_interface_get_data(proxy);
device->ad_hoc = NULL;
return true; return true;
} }
@ -564,6 +578,13 @@ static bool match_by_partial_name_and_ap(const void *a, const void *b)
return match_by_partial_name(a, b) && device->ap ? true : false; return match_by_partial_name(a, b) && device->ap ? true : false;
} }
static bool match_by_partial_name_and_ad_hoc(const void *a, const void *b)
{
const struct device *device = a;
return match_by_partial_name(a, b) && device->ad_hoc ? true : false;
}
static bool match_all(const void *a, const void *b) static bool match_all(const void *a, const void *b)
{ {
return true; return true;
@ -901,6 +922,27 @@ char *device_ap_family_arg_completion(const char *text, int state)
"Name", text, state); "Name", text, state);
} }
const struct proxy_interface *device_ad_hoc_get(const char *device_name)
{
const struct device *device;
const struct proxy_interface *proxy =
get_device_proxy_by_name(device_name);
if (!proxy)
return NULL;
device = proxy_interface_get_data(proxy);
return device->ad_hoc;
}
char *device_ad_hoc_family_arg_completion(const char *text, int state)
{
return proxy_property_str_completion(&device_interface_type,
match_by_partial_name_and_ad_hoc,
"Name", text, state);
}
static char *family_arg_completion(const char *text, int state) static char *family_arg_completion(const char *text, int state)
{ {
static bool first_pass; static bool first_pass;

View File

@ -26,3 +26,6 @@ char *device_wsc_family_arg_completion(const char *text, int state);
const struct proxy_interface *device_ap_get(const char *device_name); const struct proxy_interface *device_ap_get(const char *device_name);
char *device_ap_family_arg_completion(const char *text, int state); char *device_ap_family_arg_completion(const char *text, int state);
const struct proxy_interface *device_ad_hoc_get(const char *device_name);
char *device_ad_hoc_family_arg_completion(const char *text, int state);