diff --git a/CHANGELOG.md b/CHANGELOG.md index 4933a9eab..96fbed5f2 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,6 +8,7 @@ * Hide recent connections associated with unavailable adapters * Store network configuration in GSettings instead of /var/lib/blueman/network.state. * Replace custom MessageArea widget with regular Gtk.InfoBar +* Do not use pointless link quality value ### Bugs fixed diff --git a/blueman/gui/manager/ManagerDeviceList.py b/blueman/gui/manager/ManagerDeviceList.py index 177f28929..ab9918d99 100644 --- a/blueman/gui/manager/ManagerDeviceList.py +++ b/blueman/gui/manager/ManagerDeviceList.py @@ -48,9 +48,6 @@ def __init__(self, adapter: Optional[str] = None, inst: Optional["Blueman"] = No {"id": "rssi_pb", "type": GdkPixbuf.Pixbuf, "renderer": Gtk.CellRendererPixbuf(), "render_attrs": {}, "view_props": {"spacing": 0}, "celldata_func": (self._set_cell_data, "rssi")}, - {"id": "lq_pb", "type": GdkPixbuf.Pixbuf, "renderer": Gtk.CellRendererPixbuf(), - "render_attrs": {}, "view_props": {"spacing": 0}, - "celldata_func": (self._set_cell_data, "lq")}, {"id": "tpl_pb", "type": GdkPixbuf.Pixbuf, "renderer": Gtk.CellRendererPixbuf(), "render_attrs": {}, "view_props": {"spacing": 0}, "celldata_func": (self._set_cell_data, "tpl")}, @@ -61,7 +58,6 @@ def __init__(self, adapter: Optional[str] = None, inst: Optional["Blueman"] = No {"id": "objpush", "type": bool}, # used to set Send File button {"id": "battery", "type": float}, {"id": "rssi", "type": float}, - {"id": "lq", "type": float}, {"id": "tpl", "type": float}, {"id": "icon_info", "type": Gtk.IconInfo}, {"id": "cell_fader", "type": CellFade}, @@ -474,22 +470,18 @@ def _update_power_levels(self, tree_iter: Gtk.TreeIter, device: Device, cinfo: c # cinfo init may fail for bluetooth devices version 4 and up # FIXME Workaround is horrible and we should show something better if cinfo.failed: - bars.update({"rssi": 100.0, "tpl": 100.0, "lq": 100.0}) + bars.update({"rssi": 100.0, "tpl": 100.0}) else: try: bars["rssi"] = max(50 + float(cinfo.get_rssi()) / 127 * 50, 10) except ConnInfoReadError: bars["rssi"] = 50 - try: - bars["lq"] = max(float(cinfo.get_lq()) / 255 * 100, 10) - except ConnInfoReadError: - bars["lq"] = 10 try: bars["tpl"] = max(50 + float(cinfo.get_tpl()) / 127 * 50, 10) except ConnInfoReadError: bars["tpl"] = 50 - if row["battery"] == row["rssi"] == row["tpl"] == row["lq"] == 0: + if row["battery"] == row["rssi"] == row["tpl"] == 0: self._prepare_fader(row["cell_fader"]).animate(start=0.0, end=1.0, duration=400) w = 14 * self.get_scale_factor() @@ -502,12 +494,12 @@ def _update_power_levels(self, tree_iter: Gtk.TreeIter, device: Device, cinfo: c self.set(tree_iter, **{name: perc, f"{name}_pb": icon}) def _disable_power_levels(self, tree_iter: Gtk.TreeIter) -> None: - row = self.get(tree_iter, "cell_fader", "battery", "rssi", "lq", "tpl") - if row["battery"] == row["rssi"] == row["tpl"] == row["lq"] == 0: + row = self.get(tree_iter, "cell_fader", "battery", "rssi", "tpl") + if row["battery"] == row["rssi"] == row["tpl"] == 0: return - self.set(tree_iter, battery=0, rssi=0, lq=0, tpl=0) - self._prepare_fader(row["cell_fader"], lambda: self.set(tree_iter, battery_pb=None, rssi_pb=None, lq_pb=None, + self.set(tree_iter, battery=0, rssi=0, tpl=0) + self._prepare_fader(row["cell_fader"], lambda: self.set(tree_iter, battery_pb=None, rssi_pb=None, tpl_pb=None)).animate(start=1.0, end=0.0, duration=400) def _prepare_fader(self, fader: AnimBase, callback: Optional[Callable[[], None]] = None) -> AnimBase: @@ -559,7 +551,6 @@ def tooltip_query(self, _tw: Gtk.Widget, x: int, y: int, _kb: bool, tooltip: Gtk elif path[1] == self.columns["battery_pb"] \ or path[1] == self.columns["tpl_pb"] \ - or path[1] == self.columns["lq_pb"] \ or path[1] == self.columns["rssi_pb"]: tree_iter = self.get_iter(path[0]) assert tree_iter is not None @@ -572,7 +563,6 @@ def tooltip_query(self, _tw: Gtk.Widget, x: int, y: int, _kb: bool, tooltip: Gtk battery = self.get(tree_iter, "battery")["battery"] rssi = self.get(tree_iter, "rssi")["rssi"] - lq = self.get(tree_iter, "lq")["lq"] tpl = self.get(tree_iter, "tpl")["tpl"] if battery != 0: @@ -600,12 +590,6 @@ def tooltip_query(self, _tw: Gtk.Widget, x: int, y: int, _kb: bool, tooltip: Gtk lines.append(_("Received Signal Strength: %(rssi)u%% (%(rssi_state)s)") % {"rssi": rssi, "rssi_state": rssi_state}) - if lq != 0: - if path[1] == self.columns["lq_pb"]: - lines.append(_("Link Quality: %(lq)u%%") % {"lq": lq}) - else: - lines.append(_("Link Quality: %(lq)u%%") % {"lq": lq}) - if tpl != 0: if tpl < 30: tpl_state = _("Low") diff --git a/data/icons/pixmaps/Makefile.am b/data/icons/pixmaps/Makefile.am index 2536c1f64..2adbd512d 100644 --- a/data/icons/pixmaps/Makefile.am +++ b/data/icons/pixmaps/Makefile.am @@ -11,16 +11,6 @@ pixmaps_DATA = \ blueman-battery-80.png \ blueman-battery-90.png \ blueman-battery-100.png \ - blueman-lq-10.png \ - blueman-lq-20.png \ - blueman-lq-30.png \ - blueman-lq-40.png \ - blueman-lq-50.png \ - blueman-lq-60.png \ - blueman-lq-70.png \ - blueman-lq-80.png \ - blueman-lq-90.png \ - blueman-lq-100.png \ blueman-rssi-10.png \ blueman-rssi-20.png \ blueman-rssi-30.png \ diff --git a/data/icons/pixmaps/blueman-lq-10.png b/data/icons/pixmaps/blueman-lq-10.png deleted file mode 100644 index 71c2b2ed9..000000000 Binary files a/data/icons/pixmaps/blueman-lq-10.png and /dev/null differ diff --git a/data/icons/pixmaps/blueman-lq-100.png b/data/icons/pixmaps/blueman-lq-100.png deleted file mode 100644 index 99b4ffb85..000000000 Binary files a/data/icons/pixmaps/blueman-lq-100.png and /dev/null differ diff --git a/data/icons/pixmaps/blueman-lq-20.png b/data/icons/pixmaps/blueman-lq-20.png deleted file mode 100644 index a354ff059..000000000 Binary files a/data/icons/pixmaps/blueman-lq-20.png and /dev/null differ diff --git a/data/icons/pixmaps/blueman-lq-30.png b/data/icons/pixmaps/blueman-lq-30.png deleted file mode 100644 index cc496198b..000000000 Binary files a/data/icons/pixmaps/blueman-lq-30.png and /dev/null differ diff --git a/data/icons/pixmaps/blueman-lq-40.png b/data/icons/pixmaps/blueman-lq-40.png deleted file mode 100644 index 8fb5bb554..000000000 Binary files a/data/icons/pixmaps/blueman-lq-40.png and /dev/null differ diff --git a/data/icons/pixmaps/blueman-lq-50.png b/data/icons/pixmaps/blueman-lq-50.png deleted file mode 100644 index 5818da81e..000000000 Binary files a/data/icons/pixmaps/blueman-lq-50.png and /dev/null differ diff --git a/data/icons/pixmaps/blueman-lq-60.png b/data/icons/pixmaps/blueman-lq-60.png deleted file mode 100644 index 72846ae56..000000000 Binary files a/data/icons/pixmaps/blueman-lq-60.png and /dev/null differ diff --git a/data/icons/pixmaps/blueman-lq-70.png b/data/icons/pixmaps/blueman-lq-70.png deleted file mode 100644 index f7adc7df4..000000000 Binary files a/data/icons/pixmaps/blueman-lq-70.png and /dev/null differ diff --git a/data/icons/pixmaps/blueman-lq-80.png b/data/icons/pixmaps/blueman-lq-80.png deleted file mode 100644 index 892b74e77..000000000 Binary files a/data/icons/pixmaps/blueman-lq-80.png and /dev/null differ diff --git a/data/icons/pixmaps/blueman-lq-90.png b/data/icons/pixmaps/blueman-lq-90.png deleted file mode 100644 index 1d425e53d..000000000 Binary files a/data/icons/pixmaps/blueman-lq-90.png and /dev/null differ diff --git a/meson.build b/meson.build index ec59b7f8a..a552180d9 100644 --- a/meson.build +++ b/meson.build @@ -100,16 +100,6 @@ install_data( 'data/icons/pixmaps/blueman-battery-80.png', 'data/icons/pixmaps/blueman-battery-90.png', 'data/icons/pixmaps/blueman-battery-100.png', - 'data/icons/pixmaps/blueman-lq-10.png', - 'data/icons/pixmaps/blueman-lq-20.png', - 'data/icons/pixmaps/blueman-lq-30.png', - 'data/icons/pixmaps/blueman-lq-40.png', - 'data/icons/pixmaps/blueman-lq-50.png', - 'data/icons/pixmaps/blueman-lq-60.png', - 'data/icons/pixmaps/blueman-lq-70.png', - 'data/icons/pixmaps/blueman-lq-80.png', - 'data/icons/pixmaps/blueman-lq-90.png', - 'data/icons/pixmaps/blueman-lq-100.png', 'data/icons/pixmaps/blueman-rssi-10.png', 'data/icons/pixmaps/blueman-rssi-20.png', 'data/icons/pixmaps/blueman-rssi-30.png', diff --git a/module/_blueman.pyx b/module/_blueman.pyx index 428b75917..d646177da 100644 --- a/module/_blueman.pyx +++ b/module/_blueman.pyx @@ -79,7 +79,6 @@ cdef extern from "libblueman.h": cdef int connection_init(int dev_id, char *addr, conn_info_handles *ci) cdef int connection_get_rssi(conn_info_handles *ci, signed char *ret_rssi) - cdef int connection_get_lq(conn_info_handles *ci, unsigned char *ret_lq) cdef int connection_get_tpl(conn_info_handles *ci, signed char *ret_tpl, unsigned char type) cdef int connection_close(conn_info_handles *ci) cdef int c_get_rfcomm_channel "get_rfcomm_channel" (unsigned short service_class, char* btd_addr) @@ -100,7 +99,6 @@ ERR = { -4:"Get connection info failed", -5:"Read RSSI failed", -6:"Read transmit power level request failed", - -7:"Read Link quality failed", -8:"Getting rfcomm list failed", -9:"ERR_SOCKET_FAILED", -12: "Can't bind RFCOMM socket", @@ -248,14 +246,6 @@ cdef class conn_info: return rssi - def get_lq(self): - cdef unsigned char lq - res = connection_get_lq(&self.ci, &lq) - if res < 0: - raise ConnInfoReadError(ERR[res]) - - return lq - def get_tpl(self, tp=0): cdef signed char tpl res = connection_get_tpl(&self.ci, &tpl, tp) diff --git a/module/libblueman.c b/module/libblueman.c index 69c1fbfeb..03c94f74a 100644 --- a/module/libblueman.c +++ b/module/libblueman.c @@ -220,16 +220,6 @@ int connection_get_rssi(struct conn_info_handles *ci, int8_t *ret_rssi) } -int connection_get_lq(struct conn_info_handles *ci, uint8_t *ret_lq) -{ - uint8_t lq; - if (hci_read_link_quality(ci->dd, htobs(ci->handle), &lq, 1000) < 0) { - return ERR_READ_LQ_FAILED; - } - *ret_lq = lq; - return 1; -} - int connection_get_tpl(struct conn_info_handles *ci, int8_t *ret_tpl, uint8_t type) { int8_t level; diff --git a/module/libblueman.h b/module/libblueman.h index fd0f2f44b..3f1b56a21 100644 --- a/module/libblueman.h +++ b/module/libblueman.h @@ -5,7 +5,6 @@ #define ERR_GET_CONN_INFO_FAILED -4 #define ERR_READ_RSSI_FAILED -5 #define ERR_READ_TPL_FAILED -6 -#define ERR_READ_LQ_FAILED -7 #define ERR_GET_RFCOMM_LIST_FAILED -8 #define ERR_SOCKET_FAILED -9 #define ERR_BIND_FAILED -12 @@ -20,7 +19,6 @@ struct conn_info_handles { int connection_init(int dev_id, char *addr, struct conn_info_handles *ci); int connection_get_rssi(struct conn_info_handles *ci, int8_t *ret_rssi); -int connection_get_lq(struct conn_info_handles *ci, uint8_t *ret_lq); int connection_get_tpl(struct conn_info_handles *ci, int8_t *ret_tpl, uint8_t type); int connection_close(struct conn_info_handles *ci); int get_rfcomm_channel(uint16_t uuid, char* btd_addr); diff --git a/stubs/_blueman.pyi b/stubs/_blueman.pyi index 03a3ee711..59d93181d 100644 --- a/stubs/_blueman.pyi +++ b/stubs/_blueman.pyi @@ -43,7 +43,6 @@ class conn_info: failed: bool def __init__(self, addr: str, hci_name: str) -> None: ... def deinit(self) -> None: ... - def get_lq(self) -> int: ... def get_rssi(self) -> int: ... def get_tpl(self) -> int: ... def init(self) -> None: ...