pax_global_header00006660000000000000000000000064143131072400014505gustar00rootroot0000000000000052 comment=1af0dbc9af130e254fd537c97e69f94c13781785 mate-hud-22.10.3/000077500000000000000000000000001431310724000133565ustar00rootroot00000000000000mate-hud-22.10.3/.github/000077500000000000000000000000001431310724000147165ustar00rootroot00000000000000mate-hud-22.10.3/.github/FUNDING.yml000066400000000000000000000007071431310724000165370ustar00rootroot00000000000000# These are supported funding model platforms github: # Replace with up to 4 GitHub Sponsors-enabled usernames e.g., [user1, user2] patreon: ubuntu_mate open_collective: # Replace with a single Open Collective username ko_fi: ubuntumate tidelift: # Replace with a single Tidelift platform-name/package-name e.g., npm/babel community_bridge: # Replace with a single Community Bridge project-name e.g., cloud-foundry custom: https://ubuntu-mate.org/donate mate-hud-22.10.3/.gitignore000066400000000000000000000000231431310724000153410ustar00rootroot00000000000000build/* __pycache__mate-hud-22.10.3/COPYING000066400000000000000000000432541431310724000144210ustar00rootroot00000000000000 GNU GENERAL PUBLIC LICENSE Version 2, June 1991 Copyright (C) 1989, 1991 Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. Preamble The licenses for most software are designed to take away your freedom to share and change it. By contrast, the GNU General Public License is intended to guarantee your freedom to share and change free software--to make sure the software is free for all its users. This General Public License applies to most of the Free Software Foundation's software and to any other program whose authors commit to using it. (Some other Free Software Foundation software is covered by the GNU Lesser General Public License instead.) You can apply it to your programs, too. When we speak of free software, we are referring to freedom, not price. Our General Public Licenses are designed to make sure that you have the freedom to distribute copies of free software (and charge for this service if you wish), that you receive source code or can get it if you want it, that you can change the software or use pieces of it in new free programs; and that you know you can do these things. To protect your rights, we need to make restrictions that forbid anyone to deny you these rights or to ask you to surrender the rights. These restrictions translate to certain responsibilities for you if you distribute copies of the software, or if you modify it. For example, if you distribute copies of such a program, whether gratis or for a fee, you must give the recipients all the rights that you have. You must make sure that they, too, receive or can get the source code. And you must show them these terms so they know their rights. We protect your rights with two steps: (1) copyright the software, and (2) offer you this license which gives you legal permission to copy, distribute and/or modify the software. Also, for each author's protection and ours, we want to make certain that everyone understands that there is no warranty for this free software. If the software is modified by someone else and passed on, we want its recipients to know that what they have is not the original, so that any problems introduced by others will not reflect on the original authors' reputations. Finally, any free program is threatened constantly by software patents. We wish to avoid the danger that redistributors of a free program will individually obtain patent licenses, in effect making the program proprietary. To prevent this, we have made it clear that any patent must be licensed for everyone's free use or not licensed at all. The precise terms and conditions for copying, distribution and modification follow. GNU GENERAL PUBLIC LICENSE TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION 0. This License applies to any program or other work which contains a notice placed by the copyright holder saying it may be distributed under the terms of this General Public License. The "Program", below, refers to any such program or work, and a "work based on the Program" means either the Program or any derivative work under copyright law: that is to say, a work containing the Program or a portion of it, either verbatim or with modifications and/or translated into another language. (Hereinafter, translation is included without limitation in the term "modification".) Each licensee is addressed as "you". Activities other than copying, distribution and modification are not covered by this License; they are outside its scope. The act of running the Program is not restricted, and the output from the Program is covered only if its contents constitute a work based on the Program (independent of having been made by running the Program). Whether that is true depends on what the Program does. 1. You may copy and distribute verbatim copies of the Program's source code as you receive it, in any medium, provided that you conspicuously and appropriately publish on each copy an appropriate copyright notice and disclaimer of warranty; keep intact all the notices that refer to this License and to the absence of any warranty; and give any other recipients of the Program a copy of this License along with the Program. You may charge a fee for the physical act of transferring a copy, and you may at your option offer warranty protection in exchange for a fee. 2. You may modify your copy or copies of the Program or any portion of it, thus forming a work based on the Program, and copy and distribute such modifications or work under the terms of Section 1 above, provided that you also meet all of these conditions: a) You must cause the modified files to carry prominent notices stating that you changed the files and the date of any change. b) You must cause any work that you distribute or publish, that in whole or in part contains or is derived from the Program or any part thereof, to be licensed as a whole at no charge to all third parties under the terms of this License. c) If the modified program normally reads commands interactively when run, you must cause it, when started running for such interactive use in the most ordinary way, to print or display an announcement including an appropriate copyright notice and a notice that there is no warranty (or else, saying that you provide a warranty) and that users may redistribute the program under these conditions, and telling the user how to view a copy of this License. (Exception: if the Program itself is interactive but does not normally print such an announcement, your work based on the Program is not required to print an announcement.) These requirements apply to the modified work as a whole. If identifiable sections of that work are not derived from the Program, and can be reasonably considered independent and separate works in themselves, then this License, and its terms, do not apply to those sections when you distribute them as separate works. But when you distribute the same sections as part of a whole which is a work based on the Program, the distribution of the whole must be on the terms of this License, whose permissions for other licensees extend to the entire whole, and thus to each and every part regardless of who wrote it. Thus, it is not the intent of this section to claim rights or contest your rights to work written entirely by you; rather, the intent is to exercise the right to control the distribution of derivative or collective works based on the Program. In addition, mere aggregation of another work not based on the Program with the Program (or with a work based on the Program) on a volume of a storage or distribution medium does not bring the other work under the scope of this License. 3. You may copy and distribute the Program (or a work based on it, under Section 2) in object code or executable form under the terms of Sections 1 and 2 above provided that you also do one of the following: a) Accompany it with the complete corresponding machine-readable source code, which must be distributed under the terms of Sections 1 and 2 above on a medium customarily used for software interchange; or, b) Accompany it with a written offer, valid for at least three years, to give any third party, for a charge no more than your cost of physically performing source distribution, a complete machine-readable copy of the corresponding source code, to be distributed under the terms of Sections 1 and 2 above on a medium customarily used for software interchange; or, c) Accompany it with the information you received as to the offer to distribute corresponding source code. (This alternative is allowed only for noncommercial distribution and only if you received the program in object code or executable form with such an offer, in accord with Subsection b above.) The source code for a work means the preferred form of the work for making modifications to it. For an executable work, complete source code means all the source code for all modules it contains, plus any associated interface definition files, plus the scripts used to control compilation and installation of the executable. However, as a special exception, the source code distributed need not include anything that is normally distributed (in either source or binary form) with the major components (compiler, kernel, and so on) of the operating system on which the executable runs, unless that component itself accompanies the executable. If distribution of executable or object code is made by offering access to copy from a designated place, then offering equivalent access to copy the source code from the same place counts as distribution of the source code, even though third parties are not compelled to copy the source along with the object code. 4. You may not copy, modify, sublicense, or distribute the Program except as expressly provided under this License. Any attempt otherwise to copy, modify, sublicense or distribute the Program is void, and will automatically terminate your rights under this License. However, parties who have received copies, or rights, from you under this License will not have their licenses terminated so long as such parties remain in full compliance. 5. You are not required to accept this License, since you have not signed it. However, nothing else grants you permission to modify or distribute the Program or its derivative works. These actions are prohibited by law if you do not accept this License. Therefore, by modifying or distributing the Program (or any work based on the Program), you indicate your acceptance of this License to do so, and all its terms and conditions for copying, distributing or modifying the Program or works based on it. 6. Each time you redistribute the Program (or any work based on the Program), the recipient automatically receives a license from the original licensor to copy, distribute or modify the Program subject to these terms and conditions. You may not impose any further restrictions on the recipients' exercise of the rights granted herein. You are not responsible for enforcing compliance by third parties to this License. 7. If, as a consequence of a court judgment or allegation of patent infringement or for any other reason (not limited to patent issues), conditions are imposed on you (whether by court order, agreement or otherwise) that contradict the conditions of this License, they do not excuse you from the conditions of this License. If you cannot distribute so as to satisfy simultaneously your obligations under this License and any other pertinent obligations, then as a consequence you may not distribute the Program at all. For example, if a patent license would not permit royalty-free redistribution of the Program by all those who receive copies directly or indirectly through you, then the only way you could satisfy both it and this License would be to refrain entirely from distribution of the Program. If any portion of this section is held invalid or unenforceable under any particular circumstance, the balance of the section is intended to apply and the section as a whole is intended to apply in other circumstances. It is not the purpose of this section to induce you to infringe any patents or other property right claims or to contest validity of any such claims; this section has the sole purpose of protecting the integrity of the free software distribution system, which is implemented by public license practices. Many people have made generous contributions to the wide range of software distributed through that system in reliance on consistent application of that system; it is up to the author/donor to decide if he or she is willing to distribute software through any other system and a licensee cannot impose that choice. This section is intended to make thoroughly clear what is believed to be a consequence of the rest of this License. 8. If the distribution and/or use of the Program is restricted in certain countries either by patents or by copyrighted interfaces, the original copyright holder who places the Program under this License may add an explicit geographical distribution limitation excluding those countries, so that distribution is permitted only in or among countries not thus excluded. In such case, this License incorporates the limitation as if written in the body of this License. 9. The Free Software Foundation may publish revised and/or new versions of the General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. Each version is given a distinguishing version number. If the Program specifies a version number of this License which applies to it and "any later version", you have the option of following the terms and conditions either of that version or of any later version published by the Free Software Foundation. If the Program does not specify a version number of this License, you may choose any version ever published by the Free Software Foundation. 10. If you wish to incorporate parts of the Program into other free programs whose distribution conditions are different, write to the author to ask for permission. For software which is copyrighted by the Free Software Foundation, write to the Free Software Foundation; we sometimes make exceptions for this. Our decision will be guided by the two goals of preserving the free status of all derivatives of our free software and of promoting the sharing and reuse of software generally. NO WARRANTY 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. END OF TERMS AND CONDITIONS How to Apply These Terms to Your New Programs If you develop a new program, and you want it to be of the greatest possible use to the public, the best way to achieve this is to make it free software which everyone can redistribute and change under these terms. To do so, attach the following notices to the program. It is safest to attach them to the start of each source file to most effectively convey the exclusion of warranty; and each file should have at least the "copyright" line and a pointer to where the full notice is found. Copyright (C) This program 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 2 of the License, or (at your option) any later version. This program 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 this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. Also add information on how to contact you by electronic and paper mail. If the program is interactive, make it output a short notice like this when it starts in an interactive mode: Gnomovision version 69, Copyright (C) year name of author Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. This is free software, and you are welcome to redistribute it under certain conditions; type `show c' for details. The hypothetical commands `show w' and `show c' should show the appropriate parts of the General Public License. Of course, the commands you use may be called something other than `show w' and `show c'; they could even be mouse-clicks or menu items--whatever suits your program. You should also get your employer (if you work as a programmer) or your school, if any, to sign a "copyright disclaimer" for the program, if necessary. Here is a sample; alter the names: Yoyodyne, Inc., hereby disclaims all copyright interest in the program `Gnomovision' (which makes passes at compilers) written by James Hacker. , 1 April 1989 Ty Coon, President of Vice This General Public License does not permit incorporating your program into proprietary programs. If your program is a subroutine library, you may consider it more useful to permit linking proprietary applications with the library. If this is what you want to do, use the GNU Lesser General Public License instead of this License. mate-hud-22.10.3/README.md000066400000000000000000000066421431310724000146450ustar00rootroot00000000000000# mate-hud Provides a way to run menubar commands through [rofi](https://github.com/davatorium/rofi), much like the Unity 7 Heads-Up Display (HUD). `mate-hud` was originally forked from `i3-hud-menu`: * https://jamcnaughton.com/2015/10/19/hud-for-xubuntu/ * https://github.com/jamcnaughton/i3-hud-menu * https://github.com/RafaelBocquet/i3-hud-menu It was subsequently improved by incorporating improvements from [snippins](https://gist.github.com/snippins) * [HUD.py](https://gist.github.com/snippins/ee943f2b25db555ef12107f7cee20241) ## What is a HUD and why should I care? A Heads-Up Display (HUD) allows you to search through an application's appmenu. So if you're trying to find that single filter in Gimp but can't remember which filter category it fits into or if you can't recall if preferences sits under File, Edit or Tools on your favourite browser, you can just search for it rather than hunting through the menus. ### Implementation [vala-panel-appmenu](https://github.com/rilian-la-te/vala-panel-appmenu) includes an implementation of the `com.canonical.AppMenu.Registrar` DBus service. Applications exporting their menu via `dbusmenu` need this service to run. `mate-hud.py` tries to get the menu of the currently focused window, lists possible actions and asks the user which one to run. `mate-hud.py`, binds itself to the `Alt_L` keyboard shortcut by default (can be changed in the settings GUI). ### Settings `mate-hud` includes a small GUI for configuring settings: `hud-settings.py` which should show up in your applications menu. `mate-hud.py` reads two gsettings keys: * `org.mate.hud`: `shortcut` (Default: `'Alt_L'`) * `org.mate.hud`: `rofi-theme` (Default: `mate-hud`) `mate-hud.py` will not execute until those gsettings keys are created, which the `mate-hud` Debian package will do, and the `enabled` key is set to *True* using something like `dconf-editor`. `mate-hud` can be enabled or disabled by MATE Tweak under `Panel > Panel Features > Enable HUD`. ### Themes `mate-hud.py` uses the `mate-hud-rounded` theme by default. The included `mate-hud` and `mate-hud-rounded` themes and their HiDPI variants try to use colors from your GTK theme and your system font. You can see the available themes and make changes with the included settings program. ### Manual Setup * The `vala-panel-appmenu` applet for MATE or XFCE should be added to a panel. * `mate-hud.py` should be started on session start-up. * The following should be added to the users `~/.profile` or `/etc/profile.d` or `/etc/X11/Xsession.d/`. ``` if [ -n "$GTK_MODULES" ]; then GTK_MODULES="$GTK_MODULES:unity-gtk-module" else GTK_MODULES="unity-gtk-module" fi export GTK_MODULES export UBUNTU_MENUPROXY=1 ``` ## Dependencies * `appmenu-qt` * `gir1.2-gtk-3.0` * `mate-desktop` * `python3` * `python3-dbus` * `python3-pyinotify` * `python3-setproctitle` * `python3-xlib` * `rofi` * `unity-gtk2-module` * `unity-gtk3-module` * `plotinus` (optional - additional menu backend for some GTK3 programs without a traditional menu) A reference package for Debian/Ubuntu is available from: * https://bitbucket.org/flexiondotorg/debian-packages ## Compatibility Compatibility may depend on your environment's compatability with the [rofi](https://github.com/davatorium/rofi/) package, which means environments using Wayland (e.g. Ubuntu 21.04) may not work (see [related rofi issue](https://github.com/davatorium/rofi/issues/446)). mate-hud-22.10.3/gen_icons.sh000077500000000000000000000022011431310724000156540ustar00rootroot00000000000000#!/usr/bin/env bash dir="$( dirname "$(readlink -f "$0")" )" if [ ! -f "${dir}"/usr/share/pixmaps/mate-hud.svg ] ; then echo "mate-hud.svg not found" >&2 exit 1 fi if ! which inkscape 2>/dev/null; then echo "inkscape required to convert svg to png" exit 1 fi rm -fr "${dir}"/usr/share/icons for d in 16 22 24 32 48 64 128 256 512 1024; do install -dm755 "${dir}"/usr/share/icons/hicolor/${d}x${d}/apps inkscape -w ${d} -h ${d} "${dir}"/usr/share/pixmaps/mate-hud.svg \ -o "${dir}"/usr/share/icons/hicolor/${d}x${d}/apps/mate-hud.png optipng -strip all -o7 "${dir}"/usr/share/icons/hicolor/${d}x${d}/apps/mate-hud.png done for d in 16 22 24 32 48 64 128 256; do d2=$(( $d * 2 )) install -dm755 "${dir}"/usr/share/icons/hicolor/${d}x${d}@2/apps inkscape -w ${d2} -h ${d2} "${dir}"/usr/share/pixmaps/mate-hud.svg \ -o "${dir}"/usr/share/icons/hicolor/${d}x${d}@2/apps/mate-hud.png optipng -strip all -o7 "${dir}"/usr/share/icons/hicolor/${d}x${d}@2/apps/mate-hud.png done install -Dm644 "${dir}"/usr/share/pixmaps/mate-hud.svg \ "${dir}"/usr/share/icons/hicolor/scalable/apps/mate-hud.svg mate-hud-22.10.3/setup.py000077500000000000000000000127031431310724000150760ustar00rootroot00000000000000#!/usr/bin/python3 # -*- coding: utf-8 -*- # Copyright (C) 2016 by Martin Wimpress # # This program 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 2 of the License, or # (at your option) any later version. # # This program 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 this program; if not, write to the # Free Software Foundation, Inc., # 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. import os import sys from glob import glob from setuptools import setup import DistUtilsExtra.command.build_extra import DistUtilsExtra.command.build_i18n import DistUtilsExtra.command.clean_i18n __VERSION__ = '22.10.3' def datafilelist(installbase, sourcebase): datafileList = [] for root, subFolders, files in os.walk(sourcebase): fileList = [] for f in files: fileList.append(os.path.join(root, f)) datafileList.append((root.replace(sourcebase, installbase), fileList)) return datafileList data_files = [ ('{prefix}/lib/mate-hud/'.format(prefix=sys.prefix), ['usr/lib/mate-hud/mate-hud']), ('{prefix}/lib/mate-hud/'.format(prefix=sys.prefix), ['usr/lib/mate-hud/common.py']), ('{prefix}/lib/mate-hud/'.format(prefix=sys.prefix), ['usr/lib/mate-hud/hud-settings.py']), ('{prefix}/lib/mate-hud/'.format(prefix=sys.prefix), ['usr/lib/mate-hud/i18n.py']), ('{prefix}/lib/mate-hud/'.format(prefix=sys.prefix), ['usr/lib/mate-hud/getkey_dialog.py']), ('{prefix}/lib/mate-hud/'.format(prefix=sys.prefix), ['usr/lib/mate-hud/getkey_dialog.ui']), ('{prefix}/share/applications/'.format(prefix=sys.prefix), ['usr/share/applications/hud-settings.desktop']), ('{prefix}/share/mate/autostart/'.format(prefix=sys.prefix), ['usr/share/mate/autostart/mate-hud.desktop']), ('{prefix}/share/glib-2.0/schemas/'.format(prefix=sys.prefix), ['usr/share/glib-2.0/schemas/org.mate.hud.gschema.xml']), ('{prefix}/share/pixmaps/'.format(prefix=sys.prefix), ['usr/share/pixmaps/mate-hud.svg']), ('{prefix}/share/icons/hicolor/16x16/apps'.format(prefix=sys.prefix), ['usr/share/icons/hicolor/16x16/apps/mate-hud.png']), ('{prefix}/share/icons/hicolor/22x22/apps'.format(prefix=sys.prefix), ['usr/share/icons/hicolor/22x22/apps/mate-hud.png']), ('{prefix}/share/icons/hicolor/24x24/apps'.format(prefix=sys.prefix), ['usr/share/icons/hicolor/24x24/apps/mate-hud.png']), ('{prefix}/share/icons/hicolor/32x32/apps'.format(prefix=sys.prefix), ['usr/share/icons/hicolor/32x32/apps/mate-hud.png']), ('{prefix}/share/icons/hicolor/48x48/apps'.format(prefix=sys.prefix), ['usr/share/icons/hicolor/48x48/apps/mate-hud.png']), ('{prefix}/share/icons/hicolor/64x64/apps'.format(prefix=sys.prefix), ['usr/share/icons/hicolor/64x64/apps/mate-hud.png']), ('{prefix}/share/icons/hicolor/128x128/apps'.format(prefix=sys.prefix), ['usr/share/icons/hicolor/128x128/apps/mate-hud.png']), ('{prefix}/share/icons/hicolor/256x256/apps'.format(prefix=sys.prefix), ['usr/share/icons/hicolor/256x256/apps/mate-hud.png']), ('{prefix}/share/icons/hicolor/512x512/apps'.format(prefix=sys.prefix), ['usr/share/icons/hicolor/512x512/apps/mate-hud.png']), ('{prefix}/share/icons/hicolor/16x16@2/apps'.format(prefix=sys.prefix), ['usr/share/icons/hicolor/16x16@2/apps/mate-hud.png']), ('{prefix}/share/icons/hicolor/22x22@2/apps'.format(prefix=sys.prefix), ['usr/share/icons/hicolor/22x22@2/apps/mate-hud.png']), ('{prefix}/share/icons/hicolor/24x24@2/apps'.format(prefix=sys.prefix), ['usr/share/icons/hicolor/24x24@2/apps/mate-hud.png']), ('{prefix}/share/icons/hicolor/32x32@2/apps'.format(prefix=sys.prefix), ['usr/share/icons/hicolor/32x32@2/apps/mate-hud.png']), ('{prefix}/share/icons/hicolor/48x48@2/apps'.format(prefix=sys.prefix), ['usr/share/icons/hicolor/48x48@2/apps/mate-hud.png']), ('{prefix}/share/icons/hicolor/64x64@2/apps'.format(prefix=sys.prefix), ['usr/share/icons/hicolor/64x64@2/apps/mate-hud.png']), ('{prefix}/share/icons/hicolor/128x128@2/apps'.format(prefix=sys.prefix), ['usr/share/icons/hicolor/128x128@2/apps/mate-hud.png']), ('{prefix}/share/icons/hicolor/scalable/apps'.format(prefix=sys.prefix), ['usr/share/icons/hicolor/scalable/apps/mate-hud.svg']), ('{prefix}/share/rofi/themes/'.format(prefix=sys.prefix), ['usr/share/rofi/themes/mate-hud.rasi']), ('{prefix}/share/rofi/themes/'.format(prefix=sys.prefix), ['usr/share/rofi/themes/mate-hud-hidpi.rasi']), ('{prefix}/share/rofi/themes/'.format(prefix=sys.prefix), ['usr/share/rofi/themes/mate-hud-rounded.rasi']), ('{prefix}/share/rofi/themes/'.format(prefix=sys.prefix), ['usr/share/rofi/themes/mate-hud-rounded-hidpi.rasi']), ] cmdclass = { "build" : DistUtilsExtra.command.build_extra.build_extra, "clean": DistUtilsExtra.command.clean_i18n.clean_i18n, } setup( name = "mate-hud", version = __VERSION__, description = "Run menubar commands, much like the Unity 7 HUD", license = 'GPLv2+', author = 'Martin Wimpress', url = 'https://github.com/ubuntu-mate/mate-hud/', #package_dir = {'': '.'}, data_files = data_files, install_requires = ['setuptools'], #scripts = [], cmdclass = cmdclass, ) mate-hud-22.10.3/usr/000077500000000000000000000000001431310724000141675ustar00rootroot00000000000000mate-hud-22.10.3/usr/lib/000077500000000000000000000000001431310724000147355ustar00rootroot00000000000000mate-hud-22.10.3/usr/lib/mate-hud/000077500000000000000000000000001431310724000164415ustar00rootroot00000000000000mate-hud-22.10.3/usr/lib/mate-hud/common.py000066400000000000000000000167711431310724000203170ustar00rootroot00000000000000#!/usr/bin/python3 import gi import logging import os import re gi.require_version('Gtk', '3.0') from gi.repository import Gio, Gtk import i18n _ = i18n.language.gettext def constant(f): def fset(self, value): raise TypeError def fget(self): return f() return property(fget, fset) class Defaults(object): @constant def THEME(): return 'mate-hud-rounded' @constant def LOCATION(): return 'north west' @constant def LOCATION_RTL(): return 'north east' @constant def MONITOR(): return 'window' @constant def VALID_LOCATIONS(): return [ 'default', 'north west', 'north', 'north east', 'east', 'south east', 'south', 'south west', 'west', 'center' ] @constant def VALID_MONITORS(): return [ 'window', 'monitor' ] @constant def VALID_SEPARATOR_PAIRS(): # unicode pair: left arrow (for RTL languages), 3 spaces (to make it easier to read), right arrow # If you add more valid pairs here, be sure to add them in the schema org.mate.hud.separator-pairs enum too. return [ u'\u25C2' + ' '*3 + u'\u25B8', # "◂ ▸" u'\u2190' + ' '*3 + u'\u2794', # "← ➔" # doesn't seem to be a left arrow to match the right, so close enough u'\u2190' + ' '*3 + u'\u279C', # "← ➜" # doesn't seem to be a left arrow to match the right, so close enough u'\u276E' + ' '*3 + u'\u276F', # "❮ ❯" u'\u00AB' + ' '*3 + u'\u00BB', # "« »" u'\u2039' + ' '*3 + u'\u203A' ] # "‹ ›" @constant def SEPARATOR(): return HUD_DEFAULTS.VALID_SEPARATOR_PAIRS[0] @constant def RECENTLY_USED_MAX(): return 10 @constant def RECENTLY_USED_UNLIMITED(): return -1 @constant def RECENTLY_USED_NONE(): return 0 @constant def CUSTOM_WIDTH(): return '0' @constant def PROMPT(): return _('HUD') @constant def RECENTLY_USED_DECORATION(): return u'\u2015' * 100 HUD_DEFAULTS = Defaults() def get_bool(schema, path, key): if path: settings = Gio.Settings.new_with_path(schema, path) else: settings = Gio.Settings.new(schema) return settings.get_boolean(key) def get_string(schema, path, key): if path: settings = Gio.Settings.new_with_path(schema, path) else: settings = Gio.Settings.new(schema) return settings.get_string(key) def get_number(schema, path, key): if path: settings = Gio.Settings.new_with_path(schema, path) else: settings = Gio.Settings.new(schema) return settings.get_int(key) def get_list(schema, path, key): if path: settings = Gio.Settings.new_with_path(schema, path) else: settings = Gio.Settings.new(schema) return settings.get_strv(key) def get_rofi_theme(): rofi_theme = 'mate-hud-rounded' try: rofi_theme = get_string('org.mate.hud', None, 'rofi-theme') except: logging.error(_('org.mate.hud gsettings not found. Defaulting to ') + rofi_theme) return rofi_theme def validate_custom_width(custom_width): custom_width = re.sub(r'\s', '', custom_width) if len(re.findall(r'^[0-9]+(px|em|ch|%)?$', custom_width)) == 1: w = re.sub(r'(px|em|ch|%)?$', '', custom_width) try: w = int(w) return True except: pass return False def get_custom_width(): custom_width = get_string('org.mate.hud', None, 'custom-width') if validate_custom_width(custom_width): custom_width = re.sub(r'\s', '', custom_width) w = re.sub(r'(px|em|ch|%)?$', '', custom_width) u = re.sub(r'^[0-9]+', '', custom_width) if u == '': u = 'px' return [ not ( w == '0' and u == 'px' ), w, u ] raise ValueError( _("Invalid custom width specified") ) def use_custom_width(): try: w = get_custom_width() if not ( w[0] == '0' and w[1] == 'px' ): return True except: pass return False def get_menu_separator_pair(): menu_separator = HUD_DEFAULTS.SEPARATOR try: menu_separator = get_string('org.mate.hud', None, 'menu-separator') except: pass return menu_separator def get_menu_separator(pair=None): if not pair: pair = get_menu_separator_pair() #pair stored as 'R L' R: RTL separator, L: LTR separator (spaces may be variable, currently 3) if isrtl(): return pair[0] else: return pair[-1] def monitor_rofi_argument(monitor): arguments = { 'window': '-2', 'monitor': '-1' } if monitor in HUD_DEFAULTS.VALID_MONITORS: return arguments[monitor] else: return arguments[HUD_DEFAULTS.MONITOR] def get_monitor(): monitor = HUD_DEFAULTS.MONITOR try: monitor = get_string('org.mate.hud', None, 'hud-monitor') except: logging.error(_('org.mate.hud gsettings not found. Defaulting to ') + HUD_DEFAULTS.MONITOR) if monitor in HUD_DEFAULTS.VALID_MONITORS: return monitor else: return HUD_DEFAULTS.MONITOR def get_location(): default_location = 'default' location = default_location try: location = get_string('org.mate.hud', None, 'location') except: logging.error(_('org.mate.hud gsettings not found. Defaulting to ') + default_location) if location not in HUD_DEFAULTS.VALID_LOCATIONS: location = default_location logging.error(_("Invalid location specified, defaulting to ") + default_location ) return location def get_recently_used_max(): recently_used_max = 0 try: recently_used_max = get_number('org.mate.hud', None, 'recently-used-max') except: logging.error(_('org.mate.hud gsettings not found. Defaulting to ') + recently_used_max) return recently_used_max def get_transparency(): transparency = 100 try: transparency = get_number('org.mate.hud', None, 'transparency') except: logging.error(_('org.mate.hud gsettings not found. Defaulting to ') + transparency) return transparency def isrtl(): window = Gtk.Window() style_context = window.get_style_context() state = style_context.get_state() return state & Gtk.StateFlags.DIR_RTL def get_theme_list(sort=False): def sort_themes(theme_name): return theme_name.lower() themes = [] theme_dirs = [ os.path.expanduser('~') + '/.local/share/rofi/themes/' , '/usr/share/rofi/themes/' ] for directory in theme_dirs: if os.path.isdir(directory): for filename in os.listdir(directory): f = os.path.join(directory, filename) # checking if it is a file if os.path.isfile(f) and filename[-5:] == '.rasi': theme = filename[:-5] if theme not in themes: themes.append( theme ) if sort: themes.sort(key=sort_themes) return themes def rgba_to_hex(color): """ Return hexadecimal string for :class:`Gdk.RGBA` `color`. """ return "#{0:02x}{1:02x}{2:02x}".format( int(color.red * 255), int(color.green * 255), int(color.blue * 255)) def get_color(style_context, preferred_color, fallback_color): color = rgba_to_hex(style_context.lookup_color(preferred_color)[1]) if color == '#000000': color = rgba_to_hex(style_context.lookup_color(fallback_color)[1]) return color mate-hud-22.10.3/usr/lib/mate-hud/getkey_dialog.py000066400000000000000000000115431431310724000216260ustar00rootroot00000000000000# Taken from kupfer https://github.com/kupferlauncher/kupfer from gi.repository import Gtk, Gdk import inspect, os.path class GetKeyDialogController(object): def __init__(self, check_callback=None, previous_key=None, screen=None, parent=None, show_clear=True): ''' check_callback: optional function to check is entered key is valid. previous_key - optional previous keybinding, press equal act like cancel screen: Screen to use parent: Parent toplevel window show_clear: Show the “clear” button ''' builder = Gtk.Builder() builder.set_translation_domain('mate-hud') filename = inspect.getframeinfo(inspect.currentframe()).filename path = os.path.dirname(os.path.abspath(filename)) ui_file = path + "/getkey_dialog.ui" builder.add_from_file(ui_file) builder.connect_signals(self) self.window = builder.get_object("dialoggetkey") self.labelkey = builder.get_object('labelkey') self.imagekeybindingaux = builder.get_object('imagekeybindingaux') self.labelkeybindingaux = builder.get_object('labelkeybindingaux') self.labelaccelerator = builder.get_object('labelaccelerator') buttonclear = builder.get_object('buttonclear') if not show_clear: buttonclear.hide() self.imagekeybindingaux.hide() self.labelkeybindingaux.hide() self._key = None self._check_callback = check_callback self._previous_key = previous_key self._press_time = None if screen: self.window.set_screen(screen) if parent: self.window.set_transient_for(parent) self.window.connect("focus-in-event", self.on_window_focus_in) self.window.connect("focus-out-event", self.on_window_focus_out) def run(self): ''' Run dialog, return key codes or None when user press cancel''' self.window.set_keep_above(True) self.window.run() self.window.destroy() return self._key def _return(self, key): " Finish dialog with @key as result" self._key = key self.window.hide() def on_buttoncancel_activate(self, _widget): self.return_cancel() return True def on_buttonclear_activate(self, _widget): self.return_clear() return True def return_cancel(self): self._return(None) def return_clear(self): self._return("") def translate_keyboard_event(self, widget, event): keymap = Gdk.Keymap.get_for_display(widget.get_display()) # translate keys properly _wasmapped, keyval, egroup, level, consumed = keymap.translate_keyboard_state( event.hardware_keycode, event.get_state(), event.group) modifiers = Gtk.accelerator_get_default_mod_mask() & ~consumed state = event.get_state() & modifiers return keyval, state def update_accelerator_label(self, keyval, state): accel_label = Gtk.accelerator_get_label(keyval, state) self.labelaccelerator.set_text(accel_label) def on_dialoggetkey_key_press_event(self, widget, event): self.imagekeybindingaux.hide() self.labelkeybindingaux.hide() self._press_time = event.time keyval, state = self.translate_keyboard_event(widget, event) state = Gdk.ModifierType(state) keyname = Gtk.accelerator_name(keyval, state) if keyname == 'Escape': self.return_cancel() elif keyname == 'BackSpace': self.return_clear() self.update_accelerator_label(keyval, state) def on_dialoggetkey_key_release_event(self, widget, event): if not self._press_time: return keyval, state = self.translate_keyboard_event(widget, event) self.update_accelerator_label(0, 0) state = Gdk.ModifierType(state) if Gtk.accelerator_valid(keyval, state): key = Gtk.accelerator_name(keyval, state) if (self._previous_key is not None and key == self._previous_key): self.return_cancel() return if self._check_callback is None or self._check_callback(key): self._return(key) else: self.imagekeybindingaux.show() self.labelkeybindingaux.show() def on_window_focus_in(self, window, _event): pass def on_window_focus_out(self, _window, _event): pass def ask_for_key(check_callback=None, previous_key=None, screen=None, parent=None, show_clear=True): dlg = GetKeyDialogController(check_callback, previous_key, screen=screen, parent=parent, show_clear=show_clear) result = dlg.run() return result mate-hud-22.10.3/usr/lib/mate-hud/getkey_dialog.ui000066400000000000000000000214161431310724000216130ustar00rootroot00000000000000 False 6 Set Keyboard Shortcut False True center normal True False vertical 12 True False end gtk-clear True False False True False False 0 gtk-cancel True False False True False False 1 False False end 0 True False 12 True False gtk-preferences 6 True True 0 True False 12 True False Set Keyboard Shortcut 0 0 True True 0 True False Please press desired key combination True 0 0 True True 1 True False 12 True False gtk-dialog-error True True 0 True False Keybinding could not be bound 0 True True 1 True True 2 True False 0 True True 3 True True 1 False True 1 buttoncancel mate-hud-22.10.3/usr/lib/mate-hud/hud-settings.py000077500000000000000000000607641431310724000214510ustar00rootroot00000000000000#!/usr/bin/python3 import gi import logging import os.path import re import setproctitle gi.require_version('Gtk', '3.0') gi.require_version('Gdk', '3.0') from gi.repository import Gdk, Gio, Gtk from common import * import getkey_dialog import i18n _ = i18n.language.gettext class HUDCurrentSettings(): @property def shortcut(self): return get_string( 'org.mate.hud', None, 'shortcut' ) @property def use_custom_width(self): return get_custom_width()[0] @property def custom_width(self): return int(get_custom_width()[1]) @property def custom_width_units(self): return get_custom_width()[2] @property def location(self): return get_string( 'org.mate.hud', None, 'location' ) @property def rofi_theme(self): return get_string( 'org.mate.hud', None, 'rofi-theme' ) @property def monitor(self): return get_string( 'org.mate.hud', None, 'hud-monitor' ) @property def recently_used_max(self): return get_number( 'org.mate.hud', None, 'recently-used-max' ) @property def menu_separator(self): return get_string( 'org.mate.hud', None, 'menu-separator' ) @property def use_prompt(self): return get_string( 'org.mate.hud', None, 'prompt' ) != '' @property def prompt(self): return get_string( 'org.mate.hud', None, 'prompt' ) @property def transparency(self): return get_number( 'org.mate.hud', None, 'transparency' ) # Add new properties here that return the current value of a gsettings key class HUDSettingsWindow(Gtk.Window): # Add 'widget-name': 'HUDCurrentSettings property name' when adding a new option widget_property_map = { 'shortcut': 'shortcut', 'custom-shortcut': 'shortcut', 'theme': 'rofi_theme', 'use-width': 'use_custom_width', 'width': 'custom_width', 'width-units': 'custom_width_units', 'monitor': 'monitor', 'location': 'location', 'separator': 'menu_separator', 'recently-used': 'recently_used_max', 'use-prompt': 'use_prompt', 'prompt': 'prompt', 'transparency': 'transparency' } widget_signal_map = { # widget: [ signal, function_name ] 'theme': [ "changed", 'selection_changed' ], 'use-width': [ "toggled", 'use_custom_width_toggled' ], 'width': [ "changed", 'selection_changed' ], 'width-units': [ "changed", 'selection_changed' ], 'monitor': [ "changed", 'selection_changed' ], 'location': [ "changed", 'selection_changed' ], 'separator': [ "changed", 'selection_changed' ], 'recently-used': [ "value-changed", 'selection_changed' ], 'use-prompt': [ "toggled", 'use_prompt_toggled' ], 'prompt': [ "changed", 'selection_changed' ], 'shortcut': [ "changed", 'shortcut_selector_changed' ], 'custom-shortcut': [ "clicked", 'on_shortcut_clicked' ], 'transparency': [ "value-changed", 'selection_changed' ], 'reset-recently-used': [ "clicked", 'reset_recently_used' ], 'reset-to-defaults': [ "clicked", 'reset_to_defaults' ], 'reset': [ "clicked", 'reset_view' ], 'apply-changes': [ "clicked", 'apply_changes' ] } # I guess if there are ever widgets that don't correespond to a property, we would # have to write this out, but for now this works fine widget_names = list( widget_property_map.keys() ) # Add new gsettings options here if we provide fields to change them # A changed listener will be set up with a callback to reload_view_on_change keys = [ 'shortcut', 'hud-monitor', 'location', 'rofi-theme', 'menu-separator', 'custom-width', 'recently-used-max', 'prompt' ] valid_units = [ 'px', 'em', 'ch', '%' ] single_modifier_keys = [ 'Alt_L', 'Alt_R', 'Ctrl_L', 'Ctrl_R', 'Super_L', 'Super_R' ] def __init__(self): super().__init__(title="HUD Settings") self.add_custom_css_classes() self.set_border_width(10) self.set_resizable(False) self.set_icon_name("mate-hud") box_outer = Gtk.Box(orientation=Gtk.Orientation.VERTICAL, spacing=50) self.add(box_outer) box_main = Gtk.Box(orientation=Gtk.Orientation.VERTICAL, spacing=10) hbox = Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=50) lbl_shortcut = Gtk.Label(label=_("Keyboard Shortcut: "), xalign=0, tooltip_text=_("Keyboard shortcut to activate the HUD")) hbox.pack_start(lbl_shortcut, True, True, 0) hbox_ = Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=10) cbx_shortcut = Gtk.ComboBoxText(name='shortcut') for u in range(len(self.single_modifier_keys)): cbx_shortcut.insert(u, str(u), self.single_modifier_keys[u]) cbx_shortcut.insert(len(self.single_modifier_keys), str(len(self.single_modifier_keys)), _("Custom: ")) hbox_.pack_start(cbx_shortcut, False, True, 0) btn_shortcut = Gtk.Button(name='custom-shortcut') hbox_.pack_start(btn_shortcut, False, True, 0) hbox.pack_start(hbox_, False, True, 0) box_main.pack_start(hbox, True, True, 0) hbox = Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=50) lbl_theme = Gtk.Label(label=_("HUD Theme: "), xalign=0, tooltip_text=_("HUD theme. Default is 'mate-hud-rounded'\n" + \ "The mate-hud* themes attempt to match the system font and colors from the GTK theme.")) hbox.pack_start(lbl_theme, True, True, 0) cbx_theme = Gtk.ComboBoxText(name='theme') hbox.pack_start(cbx_theme, False, True, 0) box_main.pack_start(hbox, True, True, 0) hbox = Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=50) lbl_prompt = Gtk.Label(label=_("HUD Prompt: "), xalign=0, tooltip_text=_("HUD prompt. Default is 'HUD' localized if possible.")) hbox.pack_start(lbl_prompt, True, True, 0) hbox_ = Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=10) ckb_prompt = Gtk.CheckButton(name='use-prompt') hbox_.pack_start(ckb_prompt, True, True, 0) entry_prompt = Gtk.Entry(name='prompt') entry_prompt.set_placeholder_text(HUD_DEFAULTS.PROMPT) hbox_.pack_start(entry_prompt, False, True, 0) hbox.pack_start(hbox_, False, True, 0) box_main.pack_start(hbox, True, True, 0) hbox = Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=50) lbl_width = Gtk.Label(label=_("Custom Width: "), xalign=0, tooltip_text=_("Override the width of the HUD specified in the theme")) hbox.pack_start(lbl_width, True, True, 0) hbox_ = Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=10) ckb_width = Gtk.CheckButton(name='use-width') hbox_.pack_start(ckb_width, True, True, 0) self.width_adjustments = { 'px': Gtk.Adjustment(lower=0, upper=7680, step_increment=10, page_increment=100, page_size=0, value=600), 'em': Gtk.Adjustment(lower=0, upper=200, step_increment=1, page_increment=5, page_size=0, value=40), 'ch': Gtk.Adjustment(lower=0, upper=200, step_increment=1, page_increment=5, page_size=0, value=40), '%': Gtk.Adjustment(lower=0, upper=100, step_increment=1, page_increment=5, page_size=0, value=40) } sb_width = Gtk.SpinButton(name='width') # set the adjustment when we load the value from gsettings hbox_.pack_start(sb_width, True, True, 0) cbx_units_width = Gtk.ComboBoxText(name='width-units') for u in range(len(self.valid_units)): cbx_units_width.insert(u, str(u), self.valid_units[u]) cbx_units_width.set_active(0) hbox_.pack_start(cbx_units_width, True, True, 0) hbox.pack_start(hbox_, False, True, 0) box_main.pack_start(hbox, True, True, 0) hbox = Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=50) lbl_monitor = Gtk.Label(label=_("Attach HUD to: "), xalign=0, tooltip_text=_("Where to attach the HUD.\nDefault is to the current window.\n" + "If set to monitor, the HUD will try to avoid overlapping any panels.")) hbox.pack_start(lbl_monitor, True, True, 0) cbx_monitor = Gtk.ComboBoxText(name='monitor') for u in range(len(HUD_DEFAULTS.VALID_MONITORS)): cbx_monitor.insert(u, str(u), HUD_DEFAULTS.VALID_MONITORS[u]) hbox.pack_start(cbx_monitor, False, True, 0) box_main.pack_start(hbox, True, True, 0) hbox = Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=50) lbl_location = Gtk.Label(label=_("HUD location: "), xalign=0, tooltip_text=_("How to position the HUD in relation to what is attached to (window or monitor).\n" + \ "'default' is north west for LTR languages and north east for RTL languages.")) hbox.pack_start(lbl_location, True, True, 0) cbx_location = Gtk.ComboBoxText(name='location') for u in range(len(HUD_DEFAULTS.VALID_LOCATIONS)): cbx_location.insert(u, str(u), HUD_DEFAULTS.VALID_LOCATIONS[u]) hbox.pack_start(cbx_location, False, True, 0) box_main.pack_start(hbox, True, True, 0) hbox = Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=50) lbl_separator = Gtk.Label(label=_("Menu Separator: "), xalign=0, tooltip_text=_("Character to separate the parts of the menu heirarchy in the HUD (RTL and LTR variants)")) hbox.pack_start(lbl_separator, True, True, 0) cbx_separator = Gtk.ComboBoxText(name='separator') for u in range(len(HUD_DEFAULTS.VALID_SEPARATOR_PAIRS)): cbx_separator.insert(u, str(u), HUD_DEFAULTS.VALID_SEPARATOR_PAIRS[u]) hbox.pack_start(cbx_separator, False, True, 0) box_main.pack_start(hbox, True, True, 0) hbox = Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=50) lbl_transparency = Gtk.Label(label=_("Transparency: "), xalign=0, tooltip_text=_("Transparency of the HUD window\n" + \ " 0: Completely transparent\n" + \ "100: Solid color")) hbox.pack_start(lbl_transparency, True, True, 0) adjustment = Gtk.Adjustment(lower=0, upper=100, step_increment=1, page_increment=5, page_size=0, value=0) sb_transparency = Gtk.SpinButton(xalign=1, name='transparency', adjustment=adjustment) hbox.pack_start(sb_transparency, False, True, 0) box_main.pack_start(hbox, True, True, 0) hbox = Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=50) lbl_recent_max = Gtk.Label(label=_("Max Recently Used Items: "), xalign=0, tooltip_text=_("Maximum number of recently used items to remember per application\n" + \ " 0: Don't save recently used items\n" + \ "-1: save unlimited recently used items")) hbox.pack_start(lbl_recent_max, True, True, 0) adjustment = Gtk.Adjustment(lower=-1, upper=100, step_increment=1, page_increment=10, page_size=0, value=0) sb_recent_max = Gtk.SpinButton(xalign=1, name='recently-used', adjustment=adjustment) hbox.pack_start(sb_recent_max, False, True, 0) box_main.pack_start(hbox, True, True, 0) hbox = Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=50) lbl_recent_reset = Gtk.Label(label=_("Recently Used Item List: "), xalign=0, tooltip_text=_("Reset the recently used item list")) hbox.pack_start(lbl_recent_reset, True, True, 0) btn_reset_recently_used = Gtk.Button(name='reset-recently-used', label=_("Reset")) hbox.pack_start(btn_reset_recently_used, False, True, 0) box_main.pack_start(hbox, True, True, 0) box_outer.pack_start(box_main, True, True, 0) box_buttons = Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=50) btn_reset_to_defaults = Gtk.Button(name='reset-to-defaults', label=_("Reset to defaults")) box_buttons.pack_start(btn_reset_to_defaults, True, True, 0) btn_reset = Gtk.Button(name='reset', label=_("Clear Changes")) box_buttons.pack_start(btn_reset, True, True, 0) btn_apply = Gtk.Button(name='apply-changes', label=_("Apply Changes")) box_buttons.pack_start(btn_apply, False, True, 0) box_outer.pack_start(box_buttons, True, True, 0) def show_all(self): super().show_all() self.reload_view() # Connect to the widget changed signals after we load the view # and establish the widget's initial values. Otherwise, the we'll # be responding to change signals as we load the initial state self.connect_to_signals() def add_custom_css_classes(self): screen = Gdk.Screen.get_default() provider = Gtk.CssProvider() style_context = Gtk.StyleContext() style_context.add_provider_for_screen( screen, provider, Gtk.STYLE_PROVIDER_PRIORITY_APPLICATION ) color = rgba_to_hex(style_context.lookup_color('theme_selected_bg_color')[1]) css = bytes(""" entry.changed, combobox.changed button.combo, comboboxtext.changed button.combo, button.changed, spinbutton.changed entry, checkbutton.changed check { border: solid #1fced2; border-width: 2px; } """.replace('#1fced2', color).encode('utf-8')) provider.load_from_data(css) def get_widget_by_name(self, name, root=None): if not root: root = self.get_toplevel() if root.get_name() == name: return root try: widgets = root.get_children() except: widgets = [] for w in widgets: if str(w.get_name()) == name: return w try: children = w.get_children() except: children = [] for y in children: z = self.get_widget_by_name( name, root=y ) if z: return z return None def use_custom_width_toggled(self, button): use_cw = button.get_active() self.get_widget_by_name('width').set_visible(use_cw) self.get_widget_by_name('width-units').set_visible(use_cw) self.selection_changed(button) self.selection_changed(self.get_widget_by_name('width')) self.selection_changed(self.get_widget_by_name('width-units')) def use_prompt_toggled(self, button): self.get_widget_by_name('prompt').set_visible(button.get_active()) self.selection_changed(button) self.selection_changed(self.get_widget_by_name('prompt')) def recent_max_update_tooltip(self): w = self.get_widget_by_name('recently-used') recent_max = w.get_value_as_int() if recent_max == HUD_DEFAULTS.RECENTLY_USED_UNLIMITED: w.set_tooltip_text(_('Unlimited')) elif recent_max == HUD_DEFAULTS.RECENTLY_USED_NONE: w.set_tooltip_text(_("Don't save or show recently used menu items")) else: w.set_has_tooltip(False) def on_shortcut_clicked(self, widget): keystr = getkey_dialog.ask_for_key( previous_key=get_string('org.mate.hud', None, 'shortcut'), screen=widget.get_screen(), parent=widget.get_toplevel() ) if not keystr: return w = self.get_widget_by_name('custom-shortcut') w.set_label(keystr) self.selection_changed(w) def reset_to_defaults(self, button): logging.info(_("Resetting all settings to default")) settings = Gio.Settings.new('org.mate.hud') for key in self.keys: settings.reset(key) def reset_recently_used(self, button): logging.info(_("Resetting recently used menu entry list")) Gio.Settings.new('org.mate.hud').reset('recently-used') def apply_changes(self, button): logging.info(_("Applying changes")) settings = Gio.Settings.new('org.mate.hud') settings.set_string( 'shortcut', self.get_widget_by_name('custom-shortcut').get_label()) settings.set_string( 'hud-monitor', self.get_widget_by_name('monitor').get_active_text()) settings.set_string( 'location', self.get_widget_by_name('location').get_active_text()) settings.set_string( 'rofi-theme', self.get_widget_by_name('theme').get_active_text()) settings.set_string( 'menu-separator', self.get_widget_by_name('separator').get_active_text()) settings.set_int( 'recently-used-max', self.get_widget_by_name('recently-used').get_value_as_int()) settings.set_int( 'transparency', self.get_widget_by_name('transparency').get_value_as_int()) if self.get_widget_by_name('use-prompt').get_active(): settings.set_string( 'prompt', self.get_widget_by_name('prompt').get_text()) else: settings.set_string( 'prompt', '') if self.get_widget_by_name('use-width').get_active(): settings.set_string('custom-width', \ str(self.get_widget_by_name('width').get_value_as_int()) + \ self.get_widget_by_name('width-units').get_active_text()) else: # Default is use the theme width (no custom width, so apply that if the checkbutton isn't checked settings.set_string('custom-width', HUD_DEFAULTS.CUSTOM_WIDTH) self.selection_changed_all() def selection_changed_all( self ): for name in self.widget_names: widget = self.get_widget_by_name( name ) if widget: self.selection_changed( widget ) def shortcut_selector_changed( self, widget ): use_custom = ( widget.get_active_text() == _('Custom') + ': ' ) custom_shortcut_btn = self.get_widget_by_name( 'custom-shortcut' ) if not use_custom: custom_shortcut_btn.set_label(widget.get_active_text()) self.selection_changed(custom_shortcut_btn) custom_shortcut_btn.set_visible( use_custom ) self.selection_changed(widget) def selection_changed( self, widget ): style_context = widget.get_style_context() if widget.get_name() == 'shortcut' and widget.get_active_text() == _('Custom') + ': ': widget = self.get_widget_by_name( 'custom-shortcut' ) widget_type = type(widget).__name__ current_value = getattr( HUDCurrentSettings(), self.widget_property_map.get( widget.get_name() ) ) displayed_value = current_value # assume not changed, til we get the value if widget_type == 'Button': displayed_value = widget.get_label() elif widget_type == 'SpinButton': displayed_value = widget.get_value_as_int() elif widget_type == 'ComboBoxText': displayed_value = widget.get_active_text() elif widget_type == 'Entry': displayed_value = widget.get_text() elif widget_type == 'CheckButton': displayed_value = widget.get_active() changed = ( current_value != displayed_value ) if changed: style_context.add_class('changed') widget.set_tooltip_text(_("Change not applied yet")) else: style_context.remove_class('changed') widget.set_has_tooltip(False) if widget.get_name() == 'recently-used': self.recent_max_update_tooltip() if widget.get_name() == 'width-units': # and changed: logging.info( 'Changing width adjustment' ) self.get_widget_by_name('width').set_adjustment( self.width_adjustments[ widget.get_active_text() ] ) def connect_to_signals(self): names = self.widget_signal_map.keys() for name in names: signal, function = self.widget_signal_map[name] self.get_widget_by_name(name).connect( signal, getattr( self, function ) ) def reload_view_on_change(self, schema, key): logging.info( _("Reloading view in response to key change.") ) self.reload_view(key=key) def reset_view(self, button): self.reload_view() def reload_view(self, key=None): logging.info(_("Reloading view") + ( " " + _('for') + " " + key if key else "" ) ) if not key or key == 'shortcut': shortcut = get_string( 'org.mate.hud', None, 'shortcut' ) if shortcut in self.single_modifier_keys: self.get_widget_by_name('shortcut').set_active(self.single_modifier_keys.index(shortcut)) self.get_widget_by_name('custom-shortcut').set_visible(False) else: # The shortcut combobox has all the single modifiers, then 'Custom: ' self.get_widget_by_name('shortcut').set_active(len(self.single_modifier_keys)) self.get_widget_by_name('custom-shortcut').set_visible(True) self.get_widget_by_name('custom-shortcut').set_label( get_string( 'org.mate.hud', None, 'shortcut' ) ) if not key or key == 'rofi-theme': themes = get_theme_list(sort=True) widget = self.get_widget_by_name('theme') widget.remove_all() for u in range(len(themes)): widget.insert(u, str(u), themes[u]) try: widget.set_active(themes.index(get_rofi_theme())) except: Gio.Settings.new('org.mate.hud').set_string('rofi-theme', HUD_DEFAULTS.THEME) widget.set_active(themes.index(HUD_DEFAULTS.THEME)) if not key or key == 'custom-width': try: use_width, width, units = get_custom_width() except: Gio.Settings.new('org.mate.hud').set_string('custom-width', HUD_DEFAULTS.CUSTOM_WIDTH) use_width, width, units = get_custom_width() widget_use = self.get_widget_by_name('use-width') widget_width = self.get_widget_by_name('width') widget_units = self.get_widget_by_name('width-units') widget_use.set_active(use_width) widget_width.set_visible(use_width) widget_units.set_visible(use_width) if use_width: if units == widget_units.get_active_text(): widget_width.set_value(int(width)) widget_units.set_active(self.valid_units.index(units)) widget_width.set_adjustment( self.width_adjustments[self.get_widget_by_name('width-units').get_active_text()] ) if not key or key == 'prompt': use_prompt = HUDCurrentSettings().use_prompt self.get_widget_by_name('use-prompt').set_active(use_prompt) self.get_widget_by_name('prompt').set_text( HUDCurrentSettings().prompt ) self.get_widget_by_name('prompt').set_visible( use_prompt ) if not key or key == 'hud-monitor': self.get_widget_by_name('monitor').set_active(HUD_DEFAULTS.VALID_MONITORS.index(get_monitor())) if not key or key == 'location': self.get_widget_by_name('location').set_active(HUD_DEFAULTS.VALID_LOCATIONS.index(get_location())) if not key or key == 'menu-separator': self.get_widget_by_name('separator').set_active(HUD_DEFAULTS.VALID_SEPARATOR_PAIRS.index(get_menu_separator_pair())) if not key or key == 'recently-used-max': self.get_widget_by_name('recently-used').set_value(get_recently_used_max()) self.recent_max_update_tooltip() if not key or key == 'transparency': self.get_widget_by_name('transparency').set_value(get_transparency()) if __name__ == "__main__": setproctitle.setproctitle('hud-settings') logging.basicConfig(level=logging.INFO) win = HUDSettingsWindow() win.connect("destroy", Gtk.main_quit) settings = Gio.Settings.new("org.mate.hud") for k in win.keys: settings.connect("changed::" + k, win.reload_view_on_change) win.show_all() Gtk.main() mate-hud-22.10.3/usr/lib/mate-hud/i18n.py000066400000000000000000000004721431310724000175750ustar00rootroot00000000000000#!/usr/bin/python3 import os, sys import locale import gettext APP_NAME = "mate-hud" LOCALE_DIR = os.path.join(sys.prefix, "share", "locale") gettext.install (True) gettext.bindtextdomain (APP_NAME, LOCALE_DIR) gettext.textdomain (APP_NAME) language = gettext.translation (APP_NAME, LOCALE_DIR, fallback = True) mate-hud-22.10.3/usr/lib/mate-hud/mate-hud000077500000000000000000001753051431310724000201060ustar00rootroot00000000000000#!/usr/bin/python3 import gi gi.require_version('Gdk', '3.0') gi.require_version("Gtk", "3.0") import configparser import dbus import json import logging import os import psutil import pyinotify import re import setproctitle import subprocess import time import threading from dbus.mainloop.glib import DBusGMainLoop from gi.repository import Gio, GLib, Gtk, Gdk, GObject from Xlib import display, protocol, X, Xatom, error from common import * class Store(object): def __new__(cls): if not hasattr(cls, 'instance'): cls.instance = super(Store, cls).__new__(cls) # Set up the default store variables cls.instance.margin = [ -1, -1 ] cls.instance.last_gtk_theme = '' cls.instance.gtk_theme = '' cls.instance.last_font_name = '' cls.instance.font_name = '' cls.instance.dpi = 0 cls.instance.rofi_theme = HUD_DEFAULTS.THEME cls.instance.rofi_theme_overrides = None cls.instance.mate_hud_themes = [ 'mate-hud', 'mate-hud-hidpi', 'mate-hud-rounded', 'mate-hud-rounded-hidpi' ] cls.instance.themes_hidpi_versions = { 'mate-hud': 'mate-hud-hidpi', 'mate-hud-rounded': 'mate-hud-rounded-hidpi' } cls.instance.monitor = HUD_DEFAULTS.MONITOR cls.instance.location = HUD_DEFAULTS.LOCATION if not isrtl() else HUD_DEFAULTS.LOCATION_RTL cls.instance.custom_width = HUD_DEFAULTS.CUSTOM_WIDTH cls.instance.menu_separator_pair = get_menu_separator_pair() cls.instance.menu_separator = get_menu_separator() cls.instance.recently_used = None cls.instance.recently_used_max = get_number( 'org.mate.hud', None, 'recently-used-max' ) cls.instance.plotinus_enabled = False cls.instance.plotinus_schema = None cls.instance.plotinus_path = None cls.instance.plotinus_bus_name = None cls.instance.plotinus_bus_path = None cls.instance.panels = [] cls.instance.prompt = '' cls.instance.rofi_process = None return cls.instance STORE = Store() class EWMH: """This class provides the ability to get and set properties defined by the EWMH spec. It was blanty ripped out of pyewmh * https://github.com/parkouss/pyewmh """ def __init__(self, _display=None, root = None): self.display = _display or display.Display() self.root = root or self.display.screen().root def getActiveWindow(self): """Get the current active (toplevel) window or None (property _NET_ACTIVE_WINDOW) :return: Window object or None""" active_window = self._getProperty('_NET_ACTIVE_WINDOW') if active_window == None: return None return self._createWindow(active_window[0]) def _getProperty(self, _type, win=None): if not win: win = self.root atom = win.get_full_property(self.display.get_atom(_type), X.AnyPropertyType) if atom: return atom.value def _setProperty(self, _type, data, win=None, mask=None): """Send a ClientMessage event to the root window""" if not win: win = self.root if type(data) is str: dataSize = 8 else: data = (data+[0]*(5-len(data)))[:5] dataSize = 32 ev = protocol.event.ClientMessage(window=win, client_type=self.display.get_atom(_type), data=(dataSize, data)) if not mask: mask = (X.SubstructureRedirectMask|X.SubstructureNotifyMask) self.root.send_event(ev, event_mask=mask) def _createWindow(self, wId): if not wId: return None return self.display.create_resource_object('window', wId) def format_path(path): #logging.debug('Path:%s', path) result = path.replace('>', '', 1) result = result.replace('Root > ', '') result = result.replace('Label Empty > ', '') result = result.replace('_', '') return result.replace('>', u'\u0020\u0020' + STORE.menu_separator + u'\u0020\u0020').lstrip() def process_running(name): uid = os.getuid() for process in psutil.process_iter(): try: proc = process.as_dict(attrs=['name', 'uids']) except psutil.NoSuchProcess: pass else: if name == proc['name'] and uid == proc['uids'].real: return True return False def process_get_cmdline(name): uid = os.getuid() for process in psutil.process_iter(): try: proc = process.as_dict(attrs=['name', 'uids']) except psutil.NoSuchProcess: pass else: if name == proc['name'] and uid == proc['uids'].real: return process.as_dict(attrs=['cmdline'])['cmdline'] return [] def kill_process(name): uid = os.getuid() for process in psutil.process_iter(): try: proc = process.as_dict(attrs=['name', 'pid', 'uids']) except psutil.NoSuchProcess: pass else: if name == proc['name'] and uid == proc['uids'].real: try: target = psutil.Process(proc['pid']) target.kill() except psutil.NoSuchProcess: pass def terminate_appmenu_registrar(): # TODO: # - Use Dbus Quit method. appmenu_loaded = False if process_running('mate-panel'): applets = get_list( 'org.mate.panel', '/org/mate/panel/general/', 'object-id-list') for a in applets: if get_string( 'org.mate.panel.object', '/org/mate/panel/objects/' + a + '/', 'applet-iid' ) == 'AppmenuAppletFactory::AppmenuApplet': appmenu_loaded = True break if not appmenu_loaded and process_running('xfce4-panel'): bus = dbus.SessionBus() try: object = bus.get_object("org.xfce.Xfconf", "/org/xfce/Xfconf") interface = dbus.Interface(object, dbus_interface="org.xfce.Xfconf") panels = list(interface.GetProperty( 'xfce4-panel', '/panels' )) plugin_ids = [] for panel in panels: plugin_ids += list(interface.GetProperty('xfce4-panel', "/panels/panel-" + str(panel) + "/plugin-ids")) for plugid in plugin_ids: if ( str(interface.GetProperty('xfce4-panel', "/plugins/plugin-" + str(plugid))) == 'appmenu' ): appmenu_loaded = True break except dbus.exceptions.DBusException: logging.info('Failed to get xfce4-panel information over dbus.') cmdline = process_get_cmdline( 'vala-panel' ) if not appmenu_loaded and cmdline: profile = 'default' try: profile = cmdline[cmdline.index('-p') + 1] except: pass #if not specified, default profile is used config = configparser.ConfigParser() confdir = GLib.get_user_config_dir() if os.path.isfile( confdir + '/vala-panel/' + profile ): config.read( confdir + '/vala-panel/' + profile ) # List of the plugins in the loaded config (each item will be single-quoted plugins = config.get('core-version-1', 'units').strip("][").split(', ') for p in plugins: try: if config[p[1:-1]]['plugin-type'] == "'org.valapanel.appmenu'": appmenu_loaded = True break except: pass if not appmenu_loaded and process_running('budgie-panel'): panels = get_list( 'com.solus-project.budgie-panel', None, 'panels' ) applets = [] for p in panels: applets.append( get_list('com.solus-project.budgie-panel.panel', '/com/solus-project/budgie-panel/panels/{' + p + '}/', 'applets') ) for a in applets: name = get_string('com.solus-project.budgie-panel.applet', '/com/solus-project/budgie-panel/applets/{' + p + '}/', 'name') if name == 'Global Menu': appmenu_loaded = True break if process_running('appmenu-registrar') and not appmenu_loaded: kill_process('appmenu-registrar') def get_running_panels(): panels = [] for p in [ 'xfce4-panel', 'mate-panel', 'budgie-panel', 'plank', 'dockx' 'vala-panel' ]: if process_running(p): panels.append(p) return panels def thr_panel_updater(): while True: time.sleep(60) panels = get_running_panels() if panels != STORE.panels: logging.info("Running panels have changed, updating margin") STORE.panels = panels update_panel_margin() def get_panel_margin(): logging.info( 'Getting panel margin' ) margin = [ -1, -1 ] location = STORE.location if 'xfce4-panel' in STORE.panels: pos_nm = { 'left': [ 5, 6, 8 ], 'top': [ 2, 6, 11 ], 'right': [ 1, 2, 4 ], 'bottom': [ 4, 8, 12 ] } orientation = { 'horizontal': [ 0 ], 'vertical': [ 1, 2 ] } bus = dbus.SessionBus() try: object = bus.get_object("org.xfce.Xfconf", "/org/xfce/Xfconf") interface = dbus.Interface(object, dbus_interface="org.xfce.Xfconf") panels = list(interface.GetProperty( 'xfce4-panel', '/panels' )) for panel in panels: _pos = interface.GetProperty('xfce4-panel', "/panels/panel-" + str(panel) + "/position") #.split(';=') pos = re.split(r'[;=]', _pos ) # [ 'p', p, 'x', x, 'y', y ] edge = int( pos[1] ) mode = 0 # Default panel mode, key doesn't always exist if default if interface.PropertyExists('xfce4-panel', "/panels/panel-" + str(panel) + "/mode"): mode = interface.GetProperty('xfce4-panel', "/panels/panel-" + str(panel) + "/mode") ah = 0 # Default autohide value, key doesn't always exist if default if interface.PropertyExists('xfce4-panel', "/panels/panel-" + str(panel) + "/autohide-behavior"): ah = interface.GetProperty('xfce4-panel', "/panels/panel-" + str(panel) + "/autohide-behavior") is_panel = ( ah == 0 ) if is_panel and mode in orientation.get('vertical') and \ ( ( edge in pos_nm.get('left') and 'west' in location ) or \ ( edge in pos_nm.get('right') and 'east' in location ) ): x = int(interface.GetProperty('xfce4-panel', "/panels/panel-" + str(panel) + "/size")) if x > margin[0]: margin[0] = x if is_panel and mode in orientation.get('horizontal') and \ ( ( edge in pos_nm.get('top') and 'north' in location ) or \ ( edge in pos_nm.get('bottom') and 'south' in location ) ): y = int(interface.GetProperty('xfce4-panel', "/panels/panel-" + str(panel) + "/size")) if y > margin[1]: margin[1] = y except dbus.exceptions.DBusException: logging.info('Failed to get xfce4-panel information over dbus.') if 'mate-panel' in STORE.panels: panels = get_list( 'org.mate.panel', None, 'toplevel-id-list' ) for p in panels: size = get_number( 'org.mate.panel.toplevel', '/org/mate/panel/toplevels/' + p + '/', 'size' ) orientation = get_string( 'org.mate.panel.toplevel', '/org/mate/panel/toplevels/' + p + '/', 'orientation' ) if ( ( orientation == 'left' and 'west' in location ) or \ ( orientation == 'right' and 'east' in location ) ) and \ size > margin[0]: margin[0] = size if ( ( orientation == 'top' and 'north' in location ) or \ ( orientation == 'bottom' and 'south' in location ) ) and \ size > margin[1]: margin[1] = size if 'budgie-panel' in STORE.panels: panels = get_list( 'com.solus-project.budgie-panel', None, 'panels' ) for p in panels: size = get_number( 'com.solus-project.budgie-panel.panel', '/com/solus-project/budgie-panel/panels/{' + p + '}/', 'size' ) orientation = get_string( 'com.solus-project.budgie-panel.panel', '/com/solus-project/budgie-panel/panels/{' + p + '}/', 'location' ) if ( ( orientation == 'left' and 'west' in location ) or \ ( orientation == 'right' and 'east' in location ) ) and \ size > margin[0]: margin[0] = size if ( ( orientation == 'top' and 'north' in location ) or \ ( orientation == 'bottom' and 'south' in location ) ) and \ size > margin[1]: margin[1] = size if 'plank' in STORE.panels: cmdline = process_get_cmdline( 'plank' ) dock = 'dock1' # default try: idx = -1 if '--name' in cmdline: idx = cmdline.index('--name') elif '-n' in cmdline: idx = cmdline.index('-n') if idx > 0: dock = cmdline[idx + 1] except: pass position = get_string('net.launchpad.plank.dock.settings', '/net/launchpad/plank/docks/' + dock + '/', 'position') size = get_number('net.launchpad.plank.dock.settings', '/net/launchpad/plank/docks/' + dock + '/', 'icon-size') theme = get_string('net.launchpad.plank.dock.settings', '/net/launchpad/plank/docks/' + dock + '/', 'theme') config = configparser.ConfigParser() cfg_file = '/usr/share/plank/themes/' + theme + '/dock.theme' if os.path.isfile( cfg_file ): config.read( cfg_file ) pad = 0 try: pad = float(config['PlankDockTheme']['BottomPadding']) except: pass size = round( size * ( 1 + pad / 10 ) ) plank_is_panel = False if get_string( 'net.launchpad.plank.dock.settings', '/net/launchpad/plank/docks/' + dock + '/', 'hide-mode') == 'none': plank_is_panel = True if plank_is_panel and size > margin[0] and \ ( ( position == 'left' and 'west' in location ) or \ ( position == 'right' and 'east' in location ) ): margin[0] = size if plank_is_panel and size > margin[1] and \ ( ( position == 'top' and 'north' in location ) or \ ( position == 'bottom' and 'south' in location ) ): margin[1] = size if 'dockx' in STORE.panels: dockx_is_panel = False if get_string( 'org.dockbarx.dockx', None, 'behaviour') == 'standard': dockx_is_panel = True position = get_string( 'org.dockbarx.dockx', None, 'position') size = get_number( 'org.dockbarx.dockx', None, 'size' ) if dockx_is_panel and size > margin[0] and \ ( ( position == 'left' and 'west' in location ) or \ ( position == 'right' and 'east' in location ) ): margin[0] = size if dockx_is_panel and size > margin[1] and \ ( ( position == 'top' and 'north' in location ) or \ ( position == 'bottom' and 'south' in location ) ): margin[1] = size if 'vala-panel' in STORE.panels: cmdline = process_get_cmdline( 'vala-panel' ) if cmdline: profile = 'default' try: profile = cmdline[cmdline.index('-p') + 1] except: pass #if not specified, default profile is used config = configparser.ConfigParser() confdir = GLib.get_user_config_dir() if os.path.isfile( confdir + '/vala-panel/' + profile ): config.read( confdir + '/vala-panel/' + profile ) # List of the 'units' in the loaded config (toplevels, applets, other objects?) # (each item will be single-quoted). We only care about the toplevels (panels) now units = [] try: units = config.get('core-version-1', 'units').strip("][").split(', ') except: pass for u in units: try: if config[u[1:-1]]['object-type'] == "'toplevel'": size = int(config[u[1:-1]]['height']) # comes back as 'north-left', 'west-down', etc position = config[u[1:-1]]['panel-gravity'].strip("'").split('-')[0] # was auto-hide in one place and autohide in another? #ah = config[u[1:-1]]['auto-hide'] if size > margin[0] and \ ( ( position == 'west' and 'west' in location ) or \ ( position == 'east' and 'east' in location ) ): margin[0] = size if size > margin[1] and \ ( ( position == 'north' and 'north' in location ) or \ ( position == 'south' and 'south' in location ) ): margin[1] = size except: pass if margin[0] > 0 and margin[1] < 0: margin[1] = 0 if margin[1] > 0 and margin[0] < 0: margin[0] = 0 logging.info( 'New margin:' + str(margin) ) return margin def update_panel_margin(): STORE.margin = get_panel_margin() def update_theme_overrides_if_needed(): gtk_settings = Gtk.Settings.get_default() STORE.gtk_theme = gtk_settings.get_property( 'gtk-theme-name' ) STORE.font_name = gtk_settings.get_property( 'gtk-font-name' ) if not STORE.rofi_theme_overrides or STORE.gtk_theme != STORE.last_gtk_theme or STORE.font_name != STORE.last_font_name: STORE.rofi_theme_overrides = get_theme_overrides() STORE.last_gtk_theme = STORE.gtk_theme STORE.last_font_name = STORE.font_name def get_theme_overrides(): logging.info( 'Getting rofi theme overrides' ) # Get the currently active font. theme_options = '' font_name = Gtk.Settings.get_default().get_property( 'gtk-font-name' ) if font_name: theme_options += ' * { font: "' + font_name + '"; } ' window = Gtk.Window() style_context = window.get_style_context() bg_color = get_color(style_context, 'dark_bg_color', 'theme_bg_color') fg_color = get_color(style_context, 'dark_fg_color', 'theme_fg_color') #borders = get_color(style_context, 'borders', 'border_color') logging.debug('bg_color: %s', str(bg_color)) logging.debug('fg_color: %s', str(fg_color)) #logging.debug('borders: %s', str(borders)) selected_bg_color = rgba_to_hex(style_context.lookup_color('theme_selected_bg_color')[1]) selected_fg_color = rgba_to_hex(style_context.lookup_color('theme_selected_fg_color')[1]) alpha = get_transparency() * 255 // 100 # Overwrite some of the theme options theme_options += 'listview { background-color: ' + bg_color + f'{alpha:x}' + '; ' + \ ' border-color: ' + selected_bg_color + '; } ' + \ 'element { text-color: ' + fg_color + '; } ' + \ 'element selected.normal { background-color: ' + selected_bg_color + '; ' + \ ' text-color: ' + selected_fg_color + '; } ' + \ 'inputbar { background-color: ' + bg_color + '; ' + \ ' border-color: ' + selected_bg_color + '; ' + \ ' text-color: ' + fg_color + '; } ' return theme_options def get_display_dpi(): logging.info( 'Getting DPI' ) # Calculate display DPI value window = Gtk.Window() screen = window.get_screen() scale = window.get_scale_factor() def get_dpi(pixels, mm): if mm >= 1: return scale * pixels / (mm / 25.4) else: return 0 dpi = screen.get_resolution() # https://docs.gtk.org/gdk3/method.Screen.get_resolution.html # gdk_screen_get_resolution() returns -1 if no resolution is set if dpi == -1: width_dpi = get_dpi(screen.width(), screen.width_mm()) height_dpi = get_dpi(screen.height(), screen.height_mm()) dpi = (width_dpi + height_dpi) / 2 return round( dpi * scale ) def init_rofi(): STORE.recently_used_current_window = [] if STORE.current_win_name in STORE.recently_used.keys(): STORE.recently_used_current_window = STORE.recently_used.get(STORE.current_win_name) # update each time in case interface direction has changed (unlikely, but shouldn't cost use much STORE.menu_separator = get_menu_separator(pair=STORE.menu_separator_pair) # Allow closing the HUD with the same modifier key that opens it shortcut = get_shortcut() keyval, modifiers = Gtk.accelerator_parse(shortcut) shortcut = '' if modifiers else ',' + shortcut prompt = STORE.prompt or HUD_DEFAULTS.PROMPT cmd = ['rofi', '-dmenu', '-i', '-p', prompt, '-lines', '10', '-dpi', str(STORE.dpi), '-separator-style', 'none', '-hide-scrollbar', '-click-to-exit', '-line-padding', '2', '-kb-cancel', 'Escape' + shortcut, '-monitor', monitor_rofi_argument(STORE.monitor), # show in the current application or current window '-theme', STORE.rofi_theme, '-theme-str', 'window { location: ' + STORE.location + '; ' + \ ' anchor: ' + STORE.location + '; }' ] # Override the window location if STORE.monitor == 'monitor': margin = STORE.margin if margin[0] >= 0 or margin[1] >= 0: cmd += [ '-theme-str', 'window { margin: ' + str(margin[1]) + 'px ' + str(margin[0]) + 'px; } ' ] # If we use the default adaptive theme, we need to pull in some # color information from the GTK theme if STORE.rofi_theme in STORE.mate_hud_themes: update_theme_overrides_if_needed() cmd += [ '-theme-str', STORE.rofi_theme_overrides ] if STORE.custom_width != HUD_DEFAULTS.CUSTOM_WIDTH: cmd += [ '-theme-str', ' window { width: ' + STORE.custom_width + STORE.custom_width_units + '; } ' ] STORE.rofi_process = subprocess.Popen(cmd, stdout=subprocess.PIPE, stdin=subprocess.PIPE) if STORE.recently_used_current_window: STORE.rofi_process.stdin.write(('Recently Used ' + HUD_DEFAULTS.RECENTLY_USED_DECORATION + '\n ' + '\n '.join(STORE.recently_used_current_window).replace('>',STORE.menu_separator) + '\n' + HUD_DEFAULTS.RECENTLY_USED_DECORATION + '\n').encode('utf-8')) STORE.rofi_process.stdin.flush() def write_menuitem(menu_item): menu_string = menu_item + '\n' if STORE.recently_used_current_window and menu_item in STORE.recently_used_current_window: return try: STORE.rofi_process.stdin.write((' ' + menu_string).encode('utf-8')) STORE.rofi_process.stdin.flush() except BrokenPipeError: # Rofi process terminated either we selected an option, or used the # shortcut to close before everything was piped to rofi pass def get_menu(): """ Generate menu of available menu items. """ if not STORE.rofi_process and STORE.rofi_process.poll() is not None: logging.debug("get_menu() rofi_process was terminated before asking for menu_result") return '' menu_result = STORE.rofi_process.communicate()[0].decode('utf8').strip() STORE.rofi_process.stdin.close() STORE.rofi_process = None STORE.recently_used_current_window = None # Add the menu result to the list of recently used commands for the application if STORE.recently_used_max != HUD_DEFAULTS.RECENTLY_USED_NONE and menu_result and not HUD_DEFAULTS.RECENTLY_USED_DECORATION in menu_result: result_fmt = menu_result.replace(STORE.menu_separator, '>').lstrip() if STORE.current_win_name not in STORE.recently_used.keys(): STORE.recently_used.update({ STORE.current_win_name: [] }) if result_fmt in STORE.recently_used.get(STORE.current_win_name): STORE.recently_used.get(STORE.current_win_name).remove(result_fmt) # we're moving it to the front STORE.recently_used.get(STORE.current_win_name).insert(0, result_fmt) if STORE.recently_used_max != HUD_DEFAULTS.RECENTLY_USED_UNLIMITED: STORE.recently_used[STORE.current_win_name] = STORE.recently_used.get(STORE.current_win_name)[:STORE.recently_used_max] Gio.Settings.new('org.mate.hud').set_string('recently-used', json.dumps(STORE.recently_used)) return menu_result """ try_appmenu_interface """ def try_appmenu_interface(window_id): # --- Get Appmenu Registrar DBus interface registrar_running = process_running("appmenu-registrar") session_bus = dbus.SessionBus() try: appmenu_registrar_object = session_bus.get_object('com.canonical.AppMenu.Registrar', '/com/canonical/AppMenu/Registrar') appmenu_registrar_object_iface = dbus.Interface(appmenu_registrar_object, 'com.canonical.AppMenu.Registrar') except dbus.exceptions.DBusException: logging.debug('Unable to register with com.canonical.AppMenu.Registrar.') return False # --- Get dbusmenu object path try: dbusmenu_bus, dbusmenu_object_path = appmenu_registrar_object_iface.GetMenuForWindow(window_id) if not registrar_running: terminate_appmenu_registrar() except dbus.exceptions.DBusException: logging.debug('Unable to get dbusmenu object path.') return False # --- Access dbusmenu items try: dbusmenu_object = session_bus.get_object(dbusmenu_bus, dbusmenu_object_path) dbusmenu_object_iface = dbus.Interface(dbusmenu_object, 'com.canonical.dbusmenu') except ValueError: logging.debug('Unable to access dbusmenu items.') return False # --- Valid menu, so init rofi process to capture keypresses. init_rofi() dbusmenu_root_item = dbusmenu_object_iface.GetLayout(0, 0, ["label", "children-display"]) dbusmenu_item_dict = dict() #For excluding items which have no action blacklist = [] """ expanse_all_menu_with_dbus """ def expanse_all_menu_with_dbus(item, root, path): item_id = item[0] item_props = item[1] # expand if necessary if 'children-display' in item_props: dbusmenu_object_iface.AboutToShow(item_id) dbusmenu_object_iface.Event(item_id, "opened", "not used", dbus.UInt32(time.time())) #fix firefox try: item = dbusmenu_object_iface.GetLayout(item_id, 1, ["label", "children-display"])[1] except: return item_children = item[2] if 'label' in item_props: new_path = path + " > " + item_props['label'] else: new_path = path if len(item_children) == 0: if new_path not in blacklist: menu_item = format_path(new_path) dbusmenu_item_dict[menu_item] = item_id write_menuitem(menu_item) else: blacklist.append(new_path) for child in item_children: expanse_all_menu_with_dbus(child, False, new_path) expanse_all_menu_with_dbus(dbusmenu_root_item[1], True, "") menu_result = get_menu() # --- Use dmenu result if menu_result in dbusmenu_item_dict: action = dbusmenu_item_dict[menu_result] logging.debug('AppMenu Action : %s', str(action)) dbusmenu_object_iface.Event(action, 'clicked', 0, 0) # Firefox: # Send closed events to level 1 items to make sure nothing weird happens # Firefox will close the submenu items (luckily!) # VimFx extension wont work without this dbusmenu_level1_items = dbusmenu_object_iface.GetLayout(0, 1, ["label"])[1] for item in dbusmenu_level1_items[2]: item_id = item[0] dbusmenu_object_iface.Event(item_id, "closed", "not used", dbus.UInt32(time.time())) return True """ try_gtk_interface """ def try_gtk_interface(gtk_bus_name, gtk_menu_object_path, gtk_actions_paths_list): registrar_running = process_running("appmenu-registrar") session_bus = dbus.SessionBus() # --- Ask for menus over DBus --- Credit @1931186 try: gtk_menu_object = session_bus.get_object(gtk_bus_name, gtk_menu_object_path) gtk_menu_menus_iface = dbus.Interface(gtk_menu_object, dbus_interface='org.gtk.Menus') if not registrar_running: terminate_appmenu_registrar() except dbus.exceptions.DBusException: logging.info('Unable to connect with com.gtk.Menus.') return False # Here's the deal: The idea is to reduce the number of calls to the proxy and keep it as low as possible # because the proxy is a potential bottleneck # This means we ignore GMenus standard building model and just iterate over all the information one Start() provides at once # Start() does these calls, returns the result and keeps track of all parents (the IDs used by org.gtk.Menus.Start()) we called # queue() adds a parent to a potential_new_layers list; we'll use this later to avoid starting() some layers twice # explore is for iterating over the information a Start() call provides gtk_menubar_action_dict = dict() gtk_menubar_action_target_dict = dict() usedLayers = [] def Start(i): usedLayers.append(i) return gtk_menu_menus_iface.Start([i]) # --- Construct menu list --- potential_new_layers = [] def queue(potLayer, label, path, idx = None): # collects potentially new layers to check them against usedLayers # potLayer: ID of potential layer, label: None if nondescript, path if idx == None: potential_new_layers.append([potLayer, label, path]) else: potential_new_layers.insert(idx, [potLayer, label, path]) def explore(parent, path): for node in parent: content = node[2] # node[0] = ID of parent # node[1] = ID of node under parent # node[2] = actuall content of a node; this is split up into several elements/ menu entries for element in content: # We distinguish between labeled entries and unlabeled ones # Unlabeled sections/ submenus get added under to parent ({parent: {content}}), labeled under a key in parent (parent: {label: {content}}) if 'label' in element: if ':section' in element or ':submenu' in element: # If there's a section we don't care about the action # There theoretically could be a section that is also a submenu, so we have to handel this via queue # submenus are more important than sections if ':submenu' in element: idx = 0 if node[0] == 0 else None queue(element[':submenu'][0], None, path + " > " + element['label'], idx) # We ignore whether or not a submenu points to a specific index, shouldn't matter because of the way the menu got exportet # Worst that can happen are some duplicates # Also we don't Start() directly which could mean we get nothing under this label but this shouldn't really happen because there shouldn't be two submenus # that point to the same parent. Even if this happens it's not that big of a deal. if ':section' in element: if element[':section'][0] != node[0]: queue(element['section'][0], element['label'], path) # section points to other parent, we only want to add the elements if their parent isn't referenced anywhere else # We do this because: # a) It shouldn't happen anyways # b) The worst that could happen is we fuck up the menu structure a bit and avoid double entries elif 'action' in element: # This is pretty straightforward: menu_action = str(element['action']).split(".",1)[1] action_path = format_path(path + " > " + element['label']) gtk_menubar_action_dict[action_path] = menu_action # If rofi isn't running already this is when we know we have a menu finally, so start it up if not STORE.rofi_process: init_rofi() write_menuitem(action_path) if 'target' in element: gtk_menubar_action_target_dict[action_path] = element['target'] else: if ':submenu' in element or ':section' in element: if ':section' in element: if element[':section'][0] != node[0] and element['section'][0] not in usedLayers: queue(element[':section'][0], None, path) # We will only queue a nondescript section if it points to a (potentially) new parent if ':submenu' in element: queue(element[':submenu'][0], None, path) # We queue the submenu under the parent without a label queue(0, None, "") # We queue the first parent, [0] # This means 0 gets added to potential_new_layers with a path of "" (it's the root node) while len(potential_new_layers) > 0: layer = potential_new_layers.pop() # usedLayers keeps track of all the parents Start() already called if layer[0] not in usedLayers: explore(Start(layer[0]), layer[2]) gtk_menu_menus_iface.End(usedLayers) menuKeys = gtk_menubar_action_dict.keys() if len(menuKeys) == 0: return False menu_result = get_menu() # --- Use menu result if menu_result in gtk_menubar_action_dict: action = gtk_menubar_action_dict[menu_result] target = [] try: target = gtk_menubar_action_target_dict[menu_result] if (not isinstance(target, list)): target = [target] except: pass for action_path in gtk_actions_paths_list: try: action_object = session_bus.get_object(gtk_bus_name, action_path) action_iface = dbus.Interface(action_object, dbus_interface='org.gtk.Actions') not_use_platform_data = dict() not_use_platform_data["not used"] = "not used" logging.debug('GTK Action : %s', str(action)) action_iface.Activate(action, target, not_use_platform_data) except Exception as e: logging.debug('action_path: %s', str(action_path)) return True # DbusPlotinusMenuItem and DbusPlotinusMenu classes taken and slightly # modified from gnome-hud https://github.com/hardpixel/gnome-hud class DbusPlotinusMenuItem(object): def __init__(self, item): self.path = list(item['Path'])[1:] self.action = int(item['Id']) self.accel = list(item['Accelerators']) self.label = item['Label'] self.text = format_path('>' + '>'.join(self.path + [self.label])) class DbusPlotinusMenu(object): def __init__(self, session, window_object_path): self.actions = {} self.session = session self.win_path = window_object_path self.interface = self.get_interface() def activate(self, selection): self.actions[selection].Execute() def get_interface(self): bus_name = STORE.plotinus_bus_name bus_path = STORE.plotinus_bus_path try: object = self.session.get_object(bus_name, bus_path) interface = dbus.Interface(object, dbus_interface=bus_name) return interface except dbus.exceptions.DBusException: logging.info('Unable to get plotinus D-Bus interface') return None def get_results(self): self.actions = {} if self.interface and self.win_path: name, paths = self.interface.GetCommands(self.win_path) commands = [self.session.get_object(name, path) for path in paths] if commands: init_rofi() else: return False for command in commands: self.collect_entries(command) return True def collect_entries(self, command): interface = dbus.Interface(command, dbus_interface='org.freedesktop.DBus.Properties') command = dbus.Interface(command, dbus_interface=(STORE.plotinus_bus_name + '.Command')) properties = interface.GetAll(STORE.plotinus_bus_name + '.Command') menu_item = DbusPlotinusMenuItem(properties) self.actions[menu_item.text] = command write_menuitem(menu_item.text) def try_plotinus_interface(gtk_win_object_path): plotinus = DbusPlotinusMenu(dbus.SessionBus(), gtk_win_object_path) plotinus_success = plotinus.get_results() if not plotinus_success: return False menu_result = get_menu() if menu_result: plotinus.activate(menu_result) return True def hud(widget, keystr, user_data): logging.debug("Handling %s", str(user_data)) # Get Window properties and GTK MenuModel Bus name ewmh = EWMH() win = ewmh.getActiveWindow() if win is None: logging.debug('ewmh.getActiveWindow returned None, giving up') return window_id = hex(ewmh._getProperty('_NET_ACTIVE_WINDOW')[0]) win_name = ewmh._getProperty('WM_CLASS', win) # comes back in the format b'name\x00Name\x00' and we just want to keep name (\x00 is Null character) win_name = bytes(bytearray(win_name)[:bytearray(win_name).index(0)]).decode('utf-8') STORE.current_win_name = win_name gtk_bus_name = ewmh._getProperty('_GTK_UNIQUE_BUS_NAME', win) gtk_menubar_object_path = ewmh._getProperty('_GTK_MENUBAR_OBJECT_PATH', win) gtk_app_object_path = ewmh._getProperty('_GTK_APPLICATION_OBJECT_PATH', win) gtk_win_object_path = ewmh._getProperty('_GTK_WINDOW_OBJECT_PATH', win) gtk_unity_object_path = ewmh._getProperty('_UNITY_OBJECT_PATH', win) gtk_bus_name, gtk_menubar_object_path, gtk_app_object_path, gtk_win_object_path, gtk_unity_object_path = \ [i.decode('utf8') if isinstance(i, bytes) \ else i for i in [gtk_bus_name, gtk_menubar_object_path, gtk_app_object_path, gtk_win_object_path, gtk_unity_object_path]] logging.debug('Window id: %s', window_id) logging.debug('Window name: %s', win_name) logging.debug('_GTK_UNIQUE_BUS_NAME: %s', gtk_bus_name) logging.debug('_GTK_MENUBAR_OBJECT_PATH: %s', gtk_menubar_object_path) logging.debug('_GTK_APPLICATION_OBJECT_PATH: %s', gtk_app_object_path) logging.debug('_GTK_WINDOW_OBJECT_PATH: %s', gtk_win_object_path) logging.debug('_UNITY_OBJECT_PATH: %s', gtk_unity_object_path) logging.debug('Trying AppMenu') registrar_running = process_running("appmenu-registrar") appmenu_success = try_appmenu_interface(int(window_id, 16)) if not registrar_running: terminate_appmenu_registrar() if appmenu_success: return gtkmenubar_success = False if gtk_menubar_object_path: logging.debug('Appmenu found nothing.') # Many apps do not respect menu action groups, such as # LibreOffice and gnome-mpv, so we have to include all action # groups. Many other apps have these properties point to the # same path, so we need to remove them. logging.debug('Trying GTK interface') gtk_actions_paths_list = list(set([gtk_win_object_path, gtk_menubar_object_path, gtk_app_object_path, gtk_unity_object_path])) gtkmenubar_success = try_gtk_interface(gtk_bus_name, gtk_menubar_object_path, gtk_actions_paths_list) else: logging.debug('_GTK_MENUBAR_OBJECT_PATH in None. Unable to use the menubar interface.') if gtkmenubar_success: return else: logging.debug('GTK menubar found nothing.') if STORE.plotinus_enabled: logging.debug('Trying Plotinus interface') if gtk_win_object_path: success = try_plotinus_interface(gtk_win_object_path) if not success: logging.debug('Plotinus found nothing. Giving up.') else: logging.debug('_GTK_WINDOW_OBJECT_PATH in None. Unable to use plotinus interface') else: logging.debug('Plotinus is not enabled') class GlobalKeyBinding(GObject.GObject, threading.Thread): __gsignals__ = { 'activate': (GObject.SignalFlags.RUN_LAST, None, ()), } def __init__(self): GObject.GObject.__init__(self) threading.Thread.__init__(self) self.daemon = True self.display = display.Display() self.screen = self.display.screen() self.window = self.screen.root self.keymap = Gdk.Keymap().get_for_display(Gdk.Display().get_default()) self.keycodes = self.get_keycodes() self.ignored_masks = self.get_mask_combinations(X.LockMask | X.Mod2Mask | X.Mod5Mask) self.map_modifiers() self.tap_timeout = get_number('org.mate.hud', None, 'tap-timeout') def get_mask_combinations(self, mask): return [x for x in range(mask+1) if not (x & ~mask)] # Determine valid keycodes that can operate bindings within a window def get_keycodes(self): keycodes = [] # White-list shortcuts used by other MATE programs # Return opens up file properties # Up|Left|Right|Home are navigation shortcuts in Caja # BackSpace is a common shortcut in text editors whitelist = ['Return', 'Up', 'Down', 'Left', 'Right', 'Home', 'BackSpace'] for key in whitelist: sym = Gtk.accelerator_parse(key).accelerator_key code = self.display.keysym_to_keycode(sym) keycodes.append(code) # Allow replaying supported keycodes for sym, codes in self.display._keymap_syms.items(): keycode = self.display.keysym_to_keycode(sym) # Valid codes have keysyms from 8 to 255, inclusive if sym >= 8 and sym <= 255 and keycode not in keycodes: keycodes.append(keycode) keycodes.sort() return keycodes def map_modifiers(self): gdk_modifiers = (Gdk.ModifierType.CONTROL_MASK, Gdk.ModifierType.SHIFT_MASK, Gdk.ModifierType.MOD1_MASK, Gdk.ModifierType.MOD2_MASK, Gdk.ModifierType.MOD3_MASK, Gdk.ModifierType.MOD4_MASK, Gdk.ModifierType.MOD5_MASK, Gdk.ModifierType.SUPER_MASK, Gdk.ModifierType.HYPER_MASK) self.known_modifiers_mask = 0 for modifier in gdk_modifiers: if "Mod" not in Gtk.accelerator_name(0, modifier) or "Mod4" in Gtk.accelerator_name(0, modifier): self.known_modifiers_mask |= modifier def idle(self): self.emit("activate") return False def activate(self): GLib.idle_add(self.run) def grab(self, shortcut): accelerator = shortcut.replace("", "") keyval, modifiers = Gtk.accelerator_parse(accelerator) if not accelerator or (not keyval and not modifiers): self.keycode = None self.modifiers = None return False self.keycode = self.keymap.get_entries_for_keyval(keyval).keys[0].keycode self.modifiers = int(modifiers) # Request to receive key press/release reports from other windows that may not be using modifiers catch = error.CatchError(error.BadWindow) if self.modifiers: self.window.change_attributes(onerror=catch, event_mask=X.KeyPressMask|X.KeyReleaseMask) else: self.window.change_attributes(onerror=catch, event_mask=X.NoEventMask) if catch.get_error(): return False catch = error.CatchError(error.BadAccess) for ignored_mask in self.ignored_masks: mod = self.modifiers | ignored_mask self.window.grab_key(self.keycode, mod, True, X.GrabModeAsync, X.GrabModeSync, onerror=catch) self.display.flush() if catch.get_error(): return False catch = error.CatchError(error.BadCursor) if not self.modifiers: # We grab Alt+click so that we can forward it to the window manager and allow Alt+click bindings (window move, resize, etc.) self.window.grab_button(X.AnyButton, X.Mod1Mask, True, X.ButtonPressMask, X.GrabModeSync, X.GrabModeAsync, X.NONE, X.NONE) self.display.flush() if catch.get_error(): return False return True # Get which window manager we're currently using (Marco, Compiz, Metacity, etc...) def get_wm(self): name = '' wm_check = self.display.get_atom('_NET_SUPPORTING_WM_CHECK') win_id = self.window.get_full_property(wm_check, X.AnyPropertyType) if win_id: w = self.display.create_resource_object("window", win_id.value[0]) wm_name = self.display.get_atom('_NET_WM_NAME') prop = w.get_full_property(wm_name, X.AnyPropertyType) if prop: name = prop.value return name.lower() def run(self): self.running = True possible_tap = False tap_start = 0 while self.running: event = self.display.next_event() if self.modifiers: # Use simpler logic when using traditional combined keybindings modifiers = event.state & self.known_modifiers_mask if event.type == X.KeyPress and event.detail == self.keycode and modifiers == self.modifiers: GLib.idle_add(self.idle) self.display.allow_events(X.SyncKeyboard, X.CurrentTime) else: try: # Cancel waiting for the key release if it's not a tap if self.tap_timeout and event.time - tap_start > self.tap_timeout: possible_tap = False # KeyPress, determine if it's the begining of the tap if event.type == X.KeyPress and event.detail == self.keycode and not possible_tap: tap_start = event.time modifiers = event.state & self.known_modifiers_mask if modifiers == self.modifiers: possible_tap = True self.display.allow_events(X.SyncKeyboard, X.CurrentTime) # KeyRelease - determine if it's the end of the tap and activate the HUD elif event.type == X.KeyRelease and event.detail == self.keycode and possible_tap: GLib.idle_add(self.idle) possible_tap = False self.display.allow_events(X.AsyncKeyboard, X.CurrentTime) # Modifiers are often used with mouse events - don't let the system swallow those elif event.type == X.ButtonPress: self.display.allow_events(X.ReplayPointer, X.CurrentTime) # Compiz would rather not have the event sent to it and just read it from the replayed queue wm = self.get_wm() if wm != b'compiz': self.display.ungrab_keyboard(X.CurrentTime) self.display.ungrab_pointer(X.CurrentTime) query_pointer = self.window.query_pointer() self.display.send_event(query_pointer.child, event, X.ButtonPressMask, True) possible_tap = False # If the user presses another key in between the KeyPress and the KeyRelease, they # meant to use a different shortcut - determine what to do based on the keycode else: # Replay event if the display supports it as a window-based binding # otherwise send it asynchronously to let the top-level window grab it if event.detail in self.keycodes: self.display.allow_events(X.ReplayKeyboard, X.CurrentTime) else: self.display.allow_events(X.AsyncKeyboard, X.CurrentTime) self.display.ungrab_keyboard(X.CurrentTime) self.display.send_event(event.window, event, X.KeyPressMask | X.KeyReleaseMask, True) possible_tap = False except Exception as e: logging.error('Error processing keybinding: %s' % e) # Allow keybinding to go through and reset tap state self.display.allow_events(X.AsyncKeyboard, X.CurrentTime) possible_tap = False continue def stop(self): self.running = False self.ungrab() self.display.close() def ungrab(self): if self.keycode: self.window.ungrab_key(self.keycode, X.AnyModifier, self.window) def rebind(self, shortcut): self.ungrab() if shortcut != "": self.grab(shortcut) def get_shortcut(): shortcut = 'Alt_L' try: shortcut = get_string('org.mate.hud', None, 'shortcut') except: logging.error('org.mate.hud gsettings not found. Defaulting to %s.' % shortcut) return shortcut def remove_autostart(filename): config_dir = GLib.get_user_config_dir() autostart_file = os.path.join(config_dir, 'autostart', filename) if os.path.exists(autostart_file): os.remove(autostart_file) if __name__ == "__main__": setproctitle.setproctitle('mate-hud') logging.basicConfig(level=logging.DEBUG) # Remove old-style autostart .desktop file for mate-hud remove_autostart('mate-hud.desktop') def change_shortcut(schema, key): shortcut = settings.get_string("shortcut") keybinder.rebind(shortcut) def change_tap_timeout(schema, key): tap_timeout = settings.get_int("tap-timeout") keybinder.tap_timeout = tap_timeout; def change_rofi_theme(schema, key): default_theme = HUD_DEFAULTS.THEME rofi_theme = settings.get_string("rofi-theme") themes = get_theme_list() if not rofi_theme in themes: logging.info( '%s not found as a valid rofi theme, defaulting to %s' % ( rofi_theme, default_theme ) ) settings.set_string('rofi-theme', default_theme ) return if rofi_theme in STORE.mate_hud_themes: if Gtk.Window().get_scale_factor() > 1 and rofi_theme in STORE.themes_hidpi_versions.keys(): rofi_theme = STORE.themes_hidpi_versions[rofi_theme] STORE.rofi_theme = rofi_theme if STORE.rofi_theme in STORE.mate_hud_themes: update_theme_overrides_if_needed() def change_monitor(schema, key): STORE.monitor = get_monitor() change_location(None, None) def change_location(schema, key): location = get_location() if location == 'default': location = HUD_DEFAULTS.LOCATION if not isrtl() else HUD_DEFAULTS.LOCATION_RTL logging.info( "Using default location: %s" % location ) else: logging.info( "Updated location to: %s" % location ) STORE.location = location change_panel_margin(None, None) def change_panel_margin(schema, key): if STORE.location == 'center': logging.info( 'Updating panel margin to 0 for HUD in the center' ) STORE.margin = [ 0, 0 ] elif STORE.monitor == 'window': STORE.margin = [ -1, -1 ] else: STORE.margin = get_panel_margin() def change_custom_width(schema, key): try: STORE.use_custom_width, STORE.custom_width, STORE.custom_width_units = get_custom_width() except: logging.error( "Invalid custom width specified. Resetting to default." ) settings.set_string('custom-width', HUD_DEFAULTS.CUSTOM_WIDTH) return # since we changed the setting, it will call this function again if STORE.use_custom_width: logging.info('Using custom width ' + STORE.custom_width + STORE.custom_width_units) else: logging.info('Using width specified by theme.') def change_menu_separator_pair(schema, key): STORE.menu_separator_pair = get_menu_separator_pair() logging.info('Menu separator pair set as %s' % STORE.menu_separator_pair) STORE.menu_separator = get_menu_separator(pair=STORE.menu_separator_pair) def change_recently_used_max(schema, key): STORE.recently_used_max = get_number('org.mate.hud', None, 'recently-used-max') logging.info( 'Updated recently used max number entries to %d' % STORE.recently_used_max ) if STORE.recently_used_max > 0: for key in STORE.recently_used.keys(): STORE.recently_used[key] = STORE.recently_used.get(key)[:STORE.recently_used_max] settings.set_string('recently-used', json.dumps(STORE.recently_used)) elif STORE.recently_used_max == 0: settings.set_string('recently-used', '{}') # 0 means don't save recently used, so clear it out. def change_recently_used(schema, key): recently_used = get_string('org.mate.hud', None, 'recently-used') try: STORE.recently_used = json.loads(recently_used) except: logging.info( 'Reset recently used list to empty.' ) settings.set_string('recently-used', '{}') def change_prompt(schema, key): STORE.prompt = get_string( 'org.mate.hud', None, 'prompt' ) def start_plotinus(): # Enable plotinus D-bus service in gsettings ss = Gio.SettingsSchemaSource.get_default() schema = ss.lookup('com.worldwidemann.plotinus', True) if schema: STORE.plotinus_schema = 'com.worldwidemann.plotinus' STORE.plotinus_path = '/com/worldwidemann/plotinus/' STORE.plotinus_bus_name = 'com.worldwidemann.plotinus' STORE.plotinus_bus_path = '/com/worldwidemann/plotinus' else: schema = ss.lookup('org.unityx.plotinus', True) if schema: STORE.plotinus_schema = 'org.unityx.plotinus' STORE.plotinus_path = '/org/unityx/plotinus/' STORE.plotinus_bus_name = 'org.unityx.plotinus' STORE.plotinus_bus_path = '/com/worldwidemann/plotinus' if schema: # The last tagged release of plotinus 0.2.0 doesn't include the dbus service # so we need to make sure this key exists that we're using a compatible version if schema.has_key('dbus-enabled'): plotinus_settings = Gio.Settings.new_with_path(STORE.plotinus_schema, STORE.plotinus_path + 'default/') plotinus_settings.set_boolean('dbus-enabled', True) else: logging.info('Unable to enable plotinus D-bus service') return else: logging.info('Plotinus schema not installed') return # Start the D-bus service executable if not process_running('plotinus'): try: subprocess.Popen(['plotinus']) logging.info('Launching plotinus D-Bus service') except: logging.info('Unable to launch plotinus D-Bus executable') return else: logging.info('plotinus D-Bus service is already running') STORE.plotinus_enabled = True def xfce_panel_change_handler(channel, prop, value): watched_props = [ 'autohide-behavior', 'mode', 'position', 'size', 'panels' ] prop = prop.split('/')[-1] if channel == 'xfce4-panel' and prop.split('/')[-1] in watched_props: # If we got a new panel or removed one, update our listeners if prop in 'panels': setup_panel_change_handlers() panel_change_handler(None, None) def panel_new_or_removed_handler(schema, key): panel_listeners = setup_panel_change_handlers() panel_change_handler(None, None) def panel_change_handler(schema, key): if schema and key: logging.debug('Called panel_change_handler. schema: ' + \ schema.get_property('schema-id') + \ ', path: ' + schema.get_property('path') + \ ', key: ' + key ) else: logging.debug('Called panel_change_handler manually.') update_panel_margin() def vala_panel_change_handler(e): update_panel_margin() def setup_panel_change_handlers(): #xfce4-panel bus = dbus.SessionBus() try: object = bus.get_object("org.xfce.Xfconf","/org/xfce/Xfconf") # Listens to every change on xfconf, so we'll have to filter out what we care about object.connect_to_signal("PropertyChanged", xfce_panel_change_handler, dbus_interface="org.xfce.Xfconf") except dbus.DBusException: logging.debug( 'Unable to set D-Bus listener for xfce panel changes.' ) ss = Gio.SettingsSchemaSource.get_default() settings_objects = [] #mate-panel if ss.lookup('org.mate.panel', True): settings_objects.append(Gio.Settings.new('org.mate.panel')) settings_objects[-1].connect("changed::toplevel-id-list", panel_new_or_removed_handler) panels = get_list("org.mate.panel", None, 'toplevel-id-list') for p in panels: settings_objects.append(Gio.Settings.new_with_path( 'org.mate.panel.toplevel', '/org/mate/panel/toplevels/' + p + '/' )) settings_objects[-1].connect("changed::size", panel_change_handler) settings_objects[-1].connect("changed::orientation", panel_change_handler) else: logging.debug( 'mate-panel schema not found' ) #budgie-panel if ss.lookup('com.solus-project.budgie-panel', True): settings_objects.append(Gio.Settings.new('com.solus-project.budgie-panel')) settings_objects[-1].connect("changed::panels", panel_new_or_removed_handler) panels = get_list('com.solus-project.budgie-panel', None, 'panels') for p in panels: settings_objects.append(Gio.Settings.new_with_path( 'com.solus-project.budgie-panel.panel', '/com/solus-project/budgie-panel/panels/{' + p + '}/' )) settings_objects[-1].connect("changed::size", panel_change_handler) settings_objects[-1].connect("changed::location", panel_change_handler) else: logging.debug( 'budgie panel schema not found' ) #plank if ss.lookup('net.launchpad.plank', True): settings_objects.append(Gio.Settings.new('net.launchpad.plank')) settings_objects[-1].connect("changed::enabled-docks", panel_new_or_removed_handler) docks = get_list('net.launchpad.plank', None, 'enabled-docks' ) for dock in docks: settings_objects.append(Gio.Settings.new_with_path('net.launchpad.plank.dock.settings', '/net/launchpad/plank/docks/' + dock + '/')) settings_objects[-1].connect("changed::position", panel_change_handler) settings_objects[-1].connect("changed::icon-size", panel_change_handler) settings_objects[-1].connect("changed::theme", panel_change_handler) settings_objects[-1].connect("changed::hide-mode", panel_change_handler) else: logging.debug( 'plank schema not found' ) #dockx if ss.lookup('org.dockbarx.dockx', True): settings_objects.append(Gio.Settings.new('org.dockbarx.dockx')) settings_objects[-1].connect("changed::position", panel_change_handler) settings_objects[-1].connect("changed::behavior", panel_change_handler) settings_objects[-1].connect("changed::size", panel_change_handler) else: logging.debug( 'dockx schema not found' ) return settings_objects enabled = False enabled = get_bool('org.mate.hud', None, 'enabled') if enabled: shortcut = get_shortcut() DBusGMainLoop(set_as_default=True) keybinder = GlobalKeyBinding() keybinder.grab(shortcut) keybinder.connect("activate", hud, shortcut, "keystring %s (user data)" % shortcut) keybinder.start() logging.info("Press %s to handle keybinding", shortcut) settings = Gio.Settings.new("org.mate.hud") settings.connect("changed::shortcut", change_shortcut) settings.connect("changed::tap-timeout", change_tap_timeout) settings.connect("changed::rofi-theme", change_rofi_theme) settings.connect("changed::hud-monitor", change_monitor) settings.connect("changed::location", change_location) settings.connect("changed::custom-width", change_custom_width) settings.connect("changed::menu-separator", change_menu_separator_pair) settings.connect("changed::recently-used-max", change_recently_used_max) settings.connect("changed::recently-used", change_recently_used) settings.connect("changed::prompt", change_prompt) # watches what panels are running STORE.panels = get_running_panels() panel_updater_thread = threading.Thread(target=thr_panel_updater, daemon=True).start() # If we don't preserve the gsettings objects in this context, # the listeners don't work panel_listeners = setup_panel_change_handlers() vala_panel_config_dir = GLib.get_user_config_dir() + '/vala-panel/' watch = True if not os.path.isdir(vala_panel_config_dir): try: os.mkdir(vala_panel_config_dir) except: watch = False if watch: wm = pyinotify.WatchManager() notifier = pyinotify.ThreadedNotifier(wm, default_proc_fun=vala_panel_change_handler) notifier.start() wm.add_watch(GLib.get_user_config_dir() + '/vala-panel/', pyinotify.IN_MODIFY, rec=True, auto_add=True) else: notifier = None # Do some initial setup, so we don't have to do it when the HUD is called change_rofi_theme(None, None) change_monitor(None, None) # This calls change_location too STORE.dpi = get_display_dpi() change_custom_width(None, None) change_menu_separator_pair(None, None) change_recently_used(None, None) change_recently_used_max(None, None) change_prompt(None, None) start_plotinus() try: GLib.MainLoop().run() except KeyboardInterrupt: if notifier: notifier.stop() terminate_appmenu_registrar() kill_process('plotinus') GLib.MainLoop().quit() else: logging.info("The HUD is disabled via org.mate.hud in gsettings.") mate-hud-22.10.3/usr/share/000077500000000000000000000000001431310724000152715ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/applications/000077500000000000000000000000001431310724000177575ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/applications/hud-settings.desktop000066400000000000000000000003111431310724000237630ustar00rootroot00000000000000[Desktop Entry] Type=Application Name=HUD Settings Exec=/usr/lib/mate-hud/hud-settings.py Icon=mate-hud StartupNotify=false Terminal=false Categories=GTK;Settings;DesktopSettings; X-XfcePluggable=true mate-hud-22.10.3/usr/share/glib-2.0/000077500000000000000000000000001431310724000165035ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/glib-2.0/schemas/000077500000000000000000000000001431310724000201265ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/glib-2.0/schemas/org.mate.hud.gschema.xml000066400000000000000000000123371431310724000245570ustar00rootroot00000000000000 true Enable MATE HUD. If true, MATE HUD will run when invoked. 'Alt_L' The keyboard shortcut used to pop-up the MATE HUD The format looks like "a]]>" or "F1]]>". The parser is fairly liberal and allows lower or upper case, and also abbreviations such as "]]>" and "]]>". 'mate-hud-rounded' The rofi theme to use for the HUD MATE HUD uses rofi to display the HUD. Specify the rofi theme to use here. 'mate-hud' and 'mate-hud-rounded' try to pull colors from the GTK theme. Find available themes in /usr/share/rofi/themes or put your own in ~/.local/share/rofi/themes 'window' Whether to pin the HUD to the monitor or to the current window Whether to pin the HUD to the monitor or to the current window "default" Where to position the HUD on the window (or monitor) Where to position the HUD on the window (or monitor) '' The prompt to use for the HUD Prompt to use for the HUD Default: '' -> displayed as HUD localized if available '0' A custom width for the HUD (or 0 for default) Custom width for the HUD. 0: Use theme defined width 'NUM' or 'NUM px': NUM screen pixels 'NUM em': Relative to text height. 'NUM ch': Relative to width of a single number. 'NUM %': Num percent of the monitor* width * monitor to rofi means whatever it is attached to (window or monitor) "◂ ▸" Character to separate the parts of the menu heirarchy in the HUD (RTL and LTR variants) Character to separate the parts of the menu heirarchy in the HUD (RTL and LTR variants) "{}" JSON dictionary of recently selected menu items per application JSON dictionary of recently selected menu items per application 10 The maximum number of recently used menu entries to save per application The maximum number of recently used menu entries to save per application -1 is interpreted as unlimited entries. 0 is interpreted as don't show/save recently used items 250 The timeout between key press and release to determine if the user meant to open MATE HUD This only applies to single key shortcuts (e.g. `Alt_L`). It prevents the HUD from showing up if the user keeps the shortcut pressed for longer than the timeout. Set to 0 to disable the timeout. 100 The transparency of the HUD window background The transparency of the HUD window background 0 completely transparent 100 solid color mate-hud-22.10.3/usr/share/icons/000077500000000000000000000000001431310724000164045ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/000077500000000000000000000000001431310724000200435ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/1024x1024/000077500000000000000000000000001431310724000211305ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/1024x1024/apps/000077500000000000000000000000001431310724000220735ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/1024x1024/apps/mate-hud.png000066400000000000000000001216041431310724000243110ustar00rootroot00000000000000PNG  IHDR+KIDATxi\} WUB6B KDR-cĉ[JIrb;9:əLr!39'ۇY{>·(3^hDZ,"M$$bR^߫fMt R8PMM $l8F+( 1(Hk e BH€d( D)H( A L@b}#z i^+X ^Xҭ Ӿ $+H k1u N(HgIj&M!aՆՎc$ J]ͱ$qj5m>6Xic JY߬p{)h.tq}m!>}j7O6E RZbX֘+HJW7׋ +-jk a9kPڀ^sqJ} (?Z1@9"f~W3S-UPl դ|Яzs/B@IUZ-J 7kFo'_H-Ig\YTk$ڕ}>93"@JP >rRP7swO <Z6$7T B罗/#eN`) gc)TPHU PsP$=ךE#P"@UA'=wa`;j <^j3_gn}ۨmݺutbbblÆ jښMc6͍zX_6^׶]\ta[ʹ֤})y?{?;.|ONOO_hI]pD[?wԩǏ?wȑ =$y%½:}PY~tjZAϠNugv1JYnՍFcSkϛZ^ؐ^fy9 Nsim3gμs;utAIzgWXLJA$^ c'߽{m~[+&|n%֏lk}lnc8EHDξZi6GGﯷ>MMM~_|Ë4X.o("^EHVYXkWm[6MLL^f͞Vb;|ַwf?ZOEKs[/:uꥧ~&$\0B@E*bIVJkJ8mƍw h4nn%7>1.@rZ>>9wcOf٧[OMM'|78-}9@˄]y*R;'[;9™Vo^?0l6~ojj{a>L 3_}*Q(k z?/u];[ G[h}mxٛߙƩS}lͬy;_JW(c mٳg޽{_0yiff_~?쳧H-i!@A&l]o}ZIo2%l6u…СCD1`v?*$T(:5۷۷k֬V:;?;;ŋ //sһw@ MVsֿĿo5_ku333q?{ᇿH&zIKQ(K G-oǎ#rjڝ 1O\x?=rl+ 'U(C 3v۷vxx?n}>$̟kcԥ>F0"@ E$_4{LLL|hۙ\17^vĉ;z "@`n;199VGukeM_GG?_Lw{Y"@ L{mϞ=kzw;禦g}{K b-ĖWJ_~7GGG5l6OMM~rAT!`V[n'uS\ _;vyj}L ʯG}V[k|_K_>bO/[I^P/+O~7wWB22[{xݚ'w]䜝E =&okݿo߾}?"k7[={_>}zv\ףK"kطo{?m`>99ywV/wZ$+Mڭy&'wցuV{bbk֬7xEz/vÿ+۷E뀺Euƍشi_czi.t='hۿ:nҝ/L[W_?SP_K\vmݶk֟F)lddǎ;c\YR={p _l8w>+\iӦ.^'NL-O6s(s;/O[/6-u-Qv; {9wbP;<>(>OCCCOw(}=̓~{'Ps K]cؿ9::_ѸoΝ?}[$?lozhsA_{ 6ߵZm.Pnڴ_');@~  ',wmrrr͛o7*g-[֭[GY;W~t; jj|;"yb˜+GZ/(u>ལkXMhܵ}_zY7n@?"T-Lwڵnڵ<܍蟡e˖K;Lm^j*+}Zm>4<WY?FGGsbsj^gOi|+8YMgp:,yGء ЯdfDtg$l],q o 0-\/& ֭[t Ÿ]M΋% KM1%2Ŀ(%Nc?;Cń};s ϟW!;1W\?_7_j-\?k m9y~3k{#?}]QZ1;ȑ?|R={ss^">;Yϝ=0Aޯ-~&0_;\s$g=&ua2< sbΤ}Y 3a Rg%= bw8_uTX,@}!"\N(;ӧSN'Nەчfrrl.%y wknw1*ׯ8yd`!);$=⾜PB!СC#sjΜ9}.f (c`/(#Nxc]ve>T } _~쥗^ʞ|1ݏ:@ReW0@qك>޽`! =>p'O~e# `R |㗳2"/ {?zEѸLG^WW|3ٖ-["9->͝R=<X"CG _B}_迟rgb6e{6l؋ w?o62XMv>OZu쩧N>qc||^;o_ɛ_=??x? A$nݺϫ:n͟}y'm7,]j=7099>] @ܑϧ"?ccާ}ddSel n7k;swk-FߗHw$ 혏w˙>n9o^^|7o7mڔ}} $qG>Oac~)r˖-z_U/-SHzJ$HwqoowĨS~:{M;K{o(\qko뀺%O:۳g^ @ .$?ևǡ3QKԖ=K)@Տ^gW]uGcl[o5~}^y]vew_/䖫e εs/k=]K1?,{bb"g?kw>OFTKJg{i Ic*]Hxu õ-k֬1?yy}V}=5˝k|JLUoؿ֧15p5er @>>>5\t{KiDUYc:Z,~~ͨXb!>>>xtu||?Vˋn1jz#1,Ї͛7! A,Wpwf7n= }x32tX.eƮ޽{}Ѹ#% %=9^߳}uٕe7@,7\w֧X^wIh,DGG?ltt4馛4/1ϻPU[0k֬;G>b,DGGڵk{7v=]yy?v<.ЍFݻwg;v0Xϣϣw)즎I+ܿ /ͫ{_@_x^D>>O][FzZ杗r? ;Vl[n֧t?*B Ayy^u]1M׳?J(~X6l`d,DGGсzׯ3>-mؑh 3XϣϣϯD'3::<XU\ zMo4Xϣϣϯ-ks+-*Q/}D;vi3>>|{YnME涱9Am/yxx8mیF 9022rcj9qnEA=w5hш{\s ȂqGwľktﹹy9j\'V9yf#зŀ3@i}}}>6l&Ϫ7-f+|={V ֯_o,DGGў={bϮ۷e~`i@7Ih54vC Xb!>>>_@KcΝ㖵zLOؾ} Xb!>>>_' "7^^LͿ644Tn1#=ΕV+˦ZpυNAMnܱc jA`Qn^GGgiF# ݰ g-.\C]t[Ꙁ \$uFg_T>8 lttT:^ =ӹN^7/vܔ1{ͭε.ŀi}}}ru+ݻ\7@WoxӦM շm۶h^u]$E~bk\Xb!(bϣS75kI}}r?x+pGq[.q˖-z$`1`!1yyy R׳(^˼\tOhˁXb!>>>_U7ou4> `l}p^ 6mHtA#;bOz,ՓQ(<#qGwKh-L y-g)#=ŻꪫxzڢǬG'p 3p_ڱGGG'.ׯ奬RZA'&&&c|,סXϣϣWYx`,z;}rk### A,)ކ y-㓗z\@r3<<E "v /<}m͚5-K> 0ϓ-,khh(@@`! <<<}0>>˱6Y*iǎj=J @{.4 G^c `1؋=Nr 7~Ej5oӦMz X ='k׮u;)]ē +&İ}@wqbuLn%S,4vs @{"`r9k| @Qo(l۶m)}vvIX,/eb9k9s@m7kE_*+lzz:pBLvŸGl6/ז9SSSW}_J=g͹ @­5%?<>~sX߮_/ ğU$1#d2,ޡ֠Mbƿ폹d?|:ujm@z®K&CCBGXK_e/{9+&t(9TIµ'Nh[!g2B5W?}c*\U+c[K P(R8{رѣdz7x*6{W_ 7oζlْmݺ5mTKdaEj{(v O0?l]1NXzp,mۖرs%FcSv Ql Dk>Ps$z/oߞܹʹ9NNײ=1^@i-/rȑ#9@ g}pݻ]vEuF.s^NN):m*9wnHB CgR^v2{18Ev `$1,'ܱ?$!hELR|'kŀprO ]]qA:ьJԻZ^%,&O?uR8a2wdx_۷Ϻ+Dm)RXWE@ĜP[{9[rN<ٓO>پD}o{w@ ;Qj:Hأ%]j} ~8&&K6nܘz Ɂ / ub_611=/;ztIډ~ON<=ُ}{_vM7Y'(<BqhZcugΜw{͛7Gڵz_ @+ʾwa*)&&&ֶl]֭nJB:Bugi'ϟ ½oti@"}")Å"lO(H^^p~ ;3# {7( bf͚ejR\@_>}:w.z+򗿜ݻ7CbQ 722RÕIuC8\&mEt^yPhBIAV0βַǏk xbÇgS(LP;qZM{":=z4;wjٕH^8Q\_X:o~}zSĀKKAuƍ"Dbz z  %6221H5L;BnG^xK_ !ofّ#G4FŴVj{xڂ4@ym_O R-^ eQ vŲN;vLPJofv Q2&$sy @ X)ר %JWãB@Ph~Sd@K"OWaS4*v#*B#<*@UZh~\2;;+/ c$22ݰ4/LUT9/k;wNcP am{ Q{ )U<ۿC_~Y#TP{ g^}U#b[? $[K*jL+v~_ɓ;@'\Y/d]2=%&*:|F??)8зlVQzHcH T]i@ww&.)Mxo!@T1/DZqc<ۿPx4ԔQ JΎ=!Mcʹڨe)ĞgKUi1٭>T1%ed?Ug@aL;]s$ e:ۿX{?~@PK*ܨt2\߉p'NhwG `#Ŀ*;f .Od(M^]{tcPg^_TGLr^kM2W ev'K⊼ *w… ٩SP$ɓŋ5Dl]*P@*I|@k|t/]PF4A & Od1d%k@QnvH ~` s"[!,ЃNn8w;$kUrR_7T>F@tI\@ [`P~A;}F IFXm"[*PgΜX ;0@PP SSS$*Y(P*X[+(Hٳg5*@Pؚx5<7C~S uvŮ.w ;&h?Kzҹk9@… 4BI/? `M\ ŋ5 Ul:lB_fSSS5q\d.Z'Hom8+ ^@@1k{R v@5Cp;t6jB +s @ c60~J!{upcGGGq}RXVN>]xay7v(T``î]OwJi d/BC(ƚQJ4} D%;K+͹1w*8&G{&2CRԹ@BRN6w[h4 *l-7r'Փqn_k@ *g & y@ /> ~M h7TXm{I?uN6%2.HK$D1و>P(\'HҜl]1 yv(Hd#<v`=ࠣ/;ˬhl% `A)$2NXY) T2X) &MJN٤Xa-)tf`M @\ q_d#(O08Yw ,3b!L2bkxD9 &C;K^@ G^Ow{bfksL ֱ 2#>G4+KNAbH^G}j!B0>I@ r I!E{[MMMi`R{@G &*:><`R=v(8K@yo(l5,=ϣ L&D;А[">(@չBy &FH겅 bX:ː?#>5T겉y@d}qy2bDwk4}ȝIqy⋽5Z}8 A/h< ;e{}#wח釈=]y wvw@'[(Iy޸`r0&} qy⋽4< `R@}>M< ^+I v(81K=ϓ@ܝQIqy4< L.< I} b< ->oQpi¨.#=ϋ{|qFQpkܩ.;{mboR@G+=>`w]QAKlRw@Gcl hb}إNUԮ-w}fffWG#>O՟֤ϣA@w@wk5 =]w^@Q NepH1 {դ(@7*G$Ge*{5|3{i *g!j5WCYb_-? !>O#㵇-d^{yxU@Q`R{#%-; ,bxT (qwX |v 2wdYU{c {]&wUYyhS]Lc"/tT]X@B6IE!QsB@܍Q;n0ޣ %l6M &qG!"n &2>qAT4X & T^xX@& ?z] .&qB=p (I A  MoݯIG׮}q';9 tm;@G7ji% L*b;1}Q}i@GI N֤{; ڤ'ϋ;b﵊; Oqyq ;y00Pw}xwVIo{yĞN>⽮n2q<+{\P >ؓ`鵋yĝch4\G@g28(;{`20^b/TܤϣL&)qom(`B@Q`2w0#p= :A@\#h&(1w@Gw{($sҝL$;bO Gܩx@{g@%;A!D#hOPH``19;c{ĝ@P0)PDx#hc:*;{ĝl` 7)<+0 v(b@7)9;/{L T8vb G,@@D 4 qyq`bw0> = oRHw2{0 ;bE@Mq?b^.D@Zx#($2\v9XD";0OPqq윴0c*M ,(pqfL$9Lj;b(& ;5> 1}qGI }X5d@w}@ML8(1qGw0>#T1Nڤw; w& =ݚMG F!;b EAC{w;ҋKLPdWq';ҋL@C{cKG Z_!; ޮM}3bؓ@o< jVM5=Nw}qGI0Nڤ{ /=Nwov62 @e߱Ƴf Y + {w y޺%v@CRN&`f{00(=` : ػ@DA@28^+;00;l4PDx@30۞b$JK z.dwTWP &kN*f;`2{Gw M Nbh[ \Y;X BPz6;Q=@k+tc$נ`P"2y^ ڠ`0q(ڍrq @Tq(T89; +HҊPxH&qPI?X(NU1ID *N']&ً4@ilͬ1vPس#w' BEݩ)<=ec 6TXI(j}ǸSUíxjcf4NŹ@BTSط_}]Ğn>`CAEܩ|kuH1voQ 览=co\0֣DADI-d܍i=,<o'{c"+('苈;b5qx@CI,v{GZq@qG37L3= X5Ğb1ݘbG V!IV]&#}VK qX֮;bOjqw @7Qp`#GI-5wc6GM"=cӌ1H;gz]M =N)co@q7i_{^;bObqw4co\Ҧ(`p@{ĝb1iʹb1 : #Y)XP}jq'#(޻wĞSҌ+r =*L9/ubd܍e {F{iM(`p@{]YH16Nd`6b#@wPС ;w>l&W G/셧8`>_ZOe<l9O~g/(lk}׾Ǭ1ıωhM}}}^ZW4FY@Cm)t{Bv<+y^ۉ}Q\``m-`x@qGID 1Rhk +( P31x< XT,&bq@I&X_Hq@( Xk3@.P0!^c(߈ SA`CE*  ,-(@ Hv @ ` 0 .P\"XAU `T@⏸+AӬݬQH$~@`MFbl _ ͸/ &-̹-.6h>$ȴn"be]dcFG۶md{{T#=#(`pNb#;b@ͦqG{Gܵ:{qGܵ-!wGw SwqG쵓kU{qGw*f@Db 䆸#;b;wqz(N7b/AwT1#;ږty.qGwP("L&4'jqw|!=#;b(`R'qGwq}N(b/.;bXN7;bG{G|@ f+Π$"G}S /AE=#f@G{@@b-qGGPHFHl1X@ =⎘" `PA{P";BqGwVHJL=((;b#IqDwqz]#(=qGw⌽!XTF{'Ѹ;.Ҋ sh+G{]@0) ;bπXI+ =ؓ@+ `R@wĞDQȕG{wǏ`R@wĞDQȕ)7#{WZqo¹{G{ \h[G~@w̥wVL =#= qGw^] ؋#;b8T;m#;剽c3vo¹ `ZР{*((``{wqGw ޣ6!WϟQvͧ4W?OVCP1[*(d& lxo5v`vw_@}{y^@QP00h0{oC R";>ͣӈ΃ 6COmSwUU033#/ :J$`RuF#w :HwrNAewzlR{C Qe`pH k>@ :@$sg:5@zf@굝w.է=(Q,00[t372]@} !C-0ә] xOL Bc= M W=L B=[QLC{ D% ˳dRHw{ A(:.P(\0)C׏ zȏKL 9qx@P(\;L 嵚n! dI"bo!}<]Xg@0)TJ {ʷC@@XqXOp(`r`Yb`\T(\Oܓ z%@pL u,#3Φ>-P@T7뱆c <@[>&̎kޟէ $  erˤNT0 AN)Gܩfc@2\P80y`!#=.t89@nL;bS[(F L =o< !=Nw|(ƍ& 4b#w'y#; 1ϣ0 .=o;^ gKA;|3 oHʒ%IHOv "?V눷XyCW]I}m(H "A8c 0gW>Ȭ~"*'*̢>@; ` ;$PA6$;RP|h 8(;H uw;{P0M%mDo!:F4&P`gM݃zu>a}c< A;{PЪMm@1,I;9ꚃ{Pa^s6P419(zu=Sh @P΁5 {@ TPt1p:A݃zu&N\yPntt@݃zu}c< c0i211AEsPNS;{ÌQ޴yFG4s0i(_x =uON eO'Ysr&<8(zuGL:LYѠLJu;R:A݃z'Q0a8uoeI(#1đW.C=wP1ig};4$4o<&%0&APA' SSHм0%wPA݇ɤ8AXL :YmXPA݃z{O 2 QA>\C r @Faee3i;CP;{Pi622&&& jSG4Qg@m1i@100`Na:~}yA>1m L;nAA6<>bɛJ @PY/}}Z[[I;{ӧSa_vrAӦx}c>\@I16@:AG2?m梞/i#@ Yfy {li$p/dimmmF}ޮ.vFA݃zu> bl6f`L@B6Beg6qR-;{Pw'u˸0i" $wg'4zOOw݃6ikb~A /RqtAC>s{{;Un[R2n޼y}SNQqtAmJe \m3 ;=w uOAGRM۶܌HV ЩPI4N˟ȑ#TA6<խEu:YN`Q@0_yS\ aL\PT6({- VmPO<Iˉ}^ c.$ 6`~uuM7QRv9 Vs#z}iOiz5\L΢E>k.F4Ӧ3׳8D Ԥ.\HO`EkWNV 677 ? -?}=L d迌4y,m>|ƪZ #g@X=؝CvܩFGG;Hv' 0K&K<#ieEFsXj[.So&Sp>m^̤0vzjW߿:wdO't"NNN AA0re_|1 ~X^xpҿKf@NzxL~f^W5CرcnڵE|ܘ:eU9siI :|N:ݛ4di;CNjuO$Ξ=k5 ;ݎw3ϟOLY_wu Opp*$ $ :onltkG&oI=EӑB6U_}sj߾};?~7Tuֹ}45"H^}Uk.$77={o:Sݷ F$VMj@'IY@êUq5br _]z' AI;wjO Պ+RݷOK@ivD$ @: L*D~Wbߴ^Rof"DFJ6}#UpLHA!RQyw~3RQ;? M.]A$8Nܶm} 555O~#O됄p6cV7fYtuvvڷ~H~Пrw!d?ҷ&0Vz:Xf @! nuСTriIo>Os@HoG4'Np4뮻8GD5&'''!4fȈ6 9K+٦kv ,PVR֭[{ァ>@G$~{_>NիW rOQ@B'V5̌I 2KD1G=;{'U mѢE{uCp#`3رÝޘVo8/+h:Z$gޤn.;@ ѐ WiY9NZ'Ν;U&Qsu ,_͛ }}C䌾7d. -V\q> &QZ Fw~j#՟D 2ŋ]5A(I ̟?$)ź{^ʙ}9?66F#p& ̴h@­w;HVWǎ0|9y2O^{{\eaΜ9c^Ѷiͳ, VZ[ҿ3 ~ztR  ,< e#dVO<г:ԁK.ǯzM_`})\TX ɮar|I`_x_`)QdtQSmTpFj(\mZ~P:`Rw0Bd؟ln3gt7IޗMFx[$SAMw^|9/V~łyNDvք:!/￷mmWˠ߯9Pjd4A ɀ3f\hw&?˂tA݃zG^J侷2uO6/З{{/:ua0%*6@ /l6~7S04&g#_/ <=ݗV^+ ;ިy^ڪ$!>}Lחcw\ryy\]ne]J'{ ^˭~>< ,Hڕ&^X ,mt:pǚ5kVd$E:Uɰv oBaRU#Pn{Q #,q Fuw/XsxDžR`xU_)u7UVQ1￈QN #䚴2 "@!s7~ 32` Փ%gL}Q ڰaWHҀ.'nQgJT )DBHzj UZ. kdatF3ZhP-^X=&d!N0 ̬SPDo{.4J?W @XRݹX@ 7nTgϦ04F3GB#n:Pԃ>: B3MAY K.#P}ݧnF ԽKAdDM ]O m{4Y_Բe( 4dsЏFj%cX=l[2$l6򕯨 R՗%o MC FLŦ9ʹEGt,LЋdfM/Y͚5@Mկ~URa$tQp 2`llVQ_jo|ZPS]Q2A]vM`rrVs_m>8|_KLC:TnF] YsqL@_0H#%602A3^>)~ Y}Uv;€Ƽyܩf3Hl:::7H0m@m`4PfΜfu.]J%}C -j!-L)arH~ֵVe%Wp7R)w 7'XL0tNERLHp&qFS)uwRl0ĄZ|˗/Wauc7OFHaZqq{ǝuV.---jÆ K.Uٜt… &] Zy72<@-a#A6>ϩO|^PT@̘1uQ$7];%ulFu=_ի瀞o0'?I$4ũq^y-Nϲുe`}Qu-_|QR)ժU(%6lZm\ @rR/_طoڵkS>4'+w}ꮻr/!.C S\.PرC;$J8%i%'?|r ad{ڻw:pH{~zusR )rr'%mR-, M F0{l~V}jϞ=we1H(nA=|CGHE$Xw v~{u-$1@_٬Y$vN rͺCe@ NS#z cKf,X jeee@$=}N=Cjŋ @,ӧO@ # rJAPuڌHY_(n=0uttS;Ƃ Q2~wyZv-}V\!WsH_||G@zA%j"P굕t.#L؉SWv7p!-(@+mmm7`ubcf?%B+ z۵p 菎LK&=}%M_߲eˆ X"vu.?Sp;;;V\բU+̟?]V.Q|Ց#G|)Jruuֹ[d Pm{ԩS @}MȸSؒiנ QSHV[6Չ'ܵH*Y~.pBKOOOA@g;k53LHǀ9d*,(|Μ9NN9PO*Aʕ+E$F)S鸇 or|>6@.#G0 9 Y݄\bK;wN={֝:jU.]/vO6Aົc 2ܶEjI &l)l#S{2|ϻÞu@dѾ gVϙ3A$t \Nt8HbQ(.]r7 !S@@_{$69EptX~F&$ۢC !immuVSKH2@F ^2P3g6wU~Y 1ۯ!|$gԌ`K_Y;#$ V$xu d>}{;c q %_^F)jaML_-N ҩC˙U~Z^xZA$FGGؘ;/ddVxEc^cZK$;٬;DI/|B~Vŗqc ߕ^/,a/v%ohG9Z0з 2BrO u&`ɐA$7$qQ$6Alji@ 3sAGKJ\ B_~1^U@.\8;w\_nnAڰFL 4=zhȢq:d?\5CPo1gCqO˲5rPumy… ${{{ äCm_; k8(!AAm gl$Mrr EEi h̓61X\1 )sW(%@tAmy+@52;(S#Ψʐ% # h̓6 X]]]:$aj9fMNJV ˸ę`wPAu +FGGOz' g]̓6}:ޠՉ5.?ʉA'~U6x9]-q*= ѣꔠ#:̓6<`kɋ5o?mBȑ#P:#$AT ;Va= z-Z(Amyߏ3x +q H>j[X)qڽ{:#_]}bRwx A]touAmy4_3\:0ccmQW2/NKL ψ  h̓6gϞUN3HldbΐbȂX/Xta_|KGtAmz+g(a׷[`kqMwq%ɓZ:#r+AXW@X5k!@۶OUmKG uOmyIT{饗bqsvUt]l###Wa~3C@GyAl٢.QSr7 Cz-f@fX:ùLxWUgg'Amy ~_iYҶÇ>>Wצ3bQG3x7`\ihO?MGtAmyٶx\%l0b 'bOLL4cǎد_IGtAmy:yGƒĠg,fF-NP߾R/T,r :#)%_R z @1v#\ ̻{йo'O 6ĎՂV&2:vwwVRÇGtAGyAjvR?L;z'ۉUQ"`GU[@w9Yi_T Amy[oZ5JŎNLVGGGv>?8:@e]J%rz/! ۿ[u!:#>\Hm$ EuZv-AmyFƁ6 y?﨣Gjx822qmgΜ?/_<]DV3=P5TXn:UY/ݾ}TwwktyyЅ|}}wԳѴ߫W+lF2' ~,Y2f7~uEo߮.]N:#z'@04%okk3-Z>O],0ɰ#{@F ^xAmݺսo!511qo#~SO*gdB` A% +u4=? t\Џ3gnAZϟ̙͛,{#:Aݓ gϞUݡdll>99X}<D~3_poYf%@,#$b |+M6APIPPWoC{=c>00p<Q4j pk*Hx~gĔI QEdM2\O&sr5]oWԵg@PIiFGڞ,&Oh# k ,[̽M.?pBwK& {$IP__ԑ#GԩSF/w+PK~;*$JyTs'轿 - ޵s^I ,^M ȭN!m@rfǝn;{>w+,Nj8eۿ%?J]= 8 p뭷(~?Y8Oփ2u@2ŠV$AZ;Dt @^2^2^vY^nGGGMV3r+nd[~e#WJntmۭJ/W;_%ʽ&Kq&LMd/ Vٳg 0ʭ$ ~R"#H 9$3^`}5eouy 8Klr_wIk/9R)o{q/J k!&*O׸ x>/_ XӺ@dvEwFDl^R@f>&5L>}\neᲇt @P{@&}EXz9/X^,^Y¿}y^u 7W|wԵSϨ0d:p?C?d2:Y$q /9 2CFsȭ<&,wyL^[AP&cm%H}/-d;\;\=-rgg* OR7}T;uOرߨ:_0R^ vE+Vx.KH d$$[!o$ ^@/זP*Pwj%XoYЁANJ2/nRWH#ºzF yz(yI)Չ5!+쐗S]kt WB.1UN3/ASQyYKӕ $\R~ Cڽ/˴GN:uD?Yǵ_h 0O1 =K /8( O<ٽxtEFO'/S(dTccc T3J]}Zoć6 ~!dGJj}wy:_K0 &vbJ_jX= qՆWK*\U###/^7JEr\['.Uģkoĵ@V˗79>] $sd/@ҙ1::?ʯPJ%2;s̮+W}dj繝k*/K ΍* (Wn:u@J`H/Z߉Ϟ=]">T*ܳZh= @xGϟ˖eMH$\ msw~ȑê.7z_uO Ÿϟ?߱lٲ~'\/L(uw@rU366 urCK]E]Qʎr@DUwd=LJR!&`]7_NVlsnWxT $j pU%KܞdV1% 6mۯٳ'&&&յKmJ`k0`ԑkԣ*]0S1[hуe-%/  x2;pԵ >oRO̿];Ν'_TK`ll 9W/?~wzzz'UkT ̍;kO_KBTk~zYS$$_ˉV$?v7ϟ?߯6 ZvI8NW5 8_qgۼ`Lpkض/ DwFFF.W<|50xO4% ȳ& tM{ߡ~^$%ŋf2kJ"@$r$A~+499y__HQ_gWw I0FT_1YϯX=YCiL %/;Ͽ0;DxѿRF~c# *$ӧOo[pl6+{#d bJOV~뭷gAp_jRk(m3 k*Erwܹ#>u|Q/ln0=@ x'El7JwymUR#ǒ$05P-.8_ڟ̛7oq&^2`ttԽ2=dlܯeq8]c1sAxJ\5n?O}eƌ Q W607޳g/U+4 8{lɃ'yW)VQ<矜5kֲL&^5Ta0Hdd,!1FYa#C~CcN>W&vn 7egk*w[j$ȨkYF|~ƌ ]HfW6 qbpp?߿[~ @5olguI(xkkkw/ gU`x$V6./ ,e$}wNs*=ϟ? ^ொK%2K,i_fͿnnnge .-X`Z`j9oSGGǟ9s*?ǿTvO Ik}U~@իW/Z|;WP))nI }9_x?`s;)'k'+E@I8WE ٳgO_~7Z[[ ZSIn8S ^z// K8;>>#Gex?gU$N? ?Us&$5*}yw}iӦ߯aL zxHmA~qiR`.={ ⫝/7_/Wk5\I@(.&^bL"@vmΚ5N` )L'*m6/6[{RMh4 P5&@D߹3gם`z(I0P|c~כ` 1@+j ra ޽{_W K%*?_aIʯ PO"Ԁ ֯_N`z`۶/9A\./kW uuN٬ b@ZUQ*nֹs>d,vg˲[I/񉉉._ĉ{L^ ~crm E(I~k/^ܾbŊlmmeYw9Jgc~v9gΜy… JsK%*_ieVOl{$3X߽qI,];>dd!g;8w܎΋%{U&`tijg.GI rA|3%FQ׼M7ݴ3CkT Z ˹=opppCK-'/|~A Oę|lZ˲2HQng;999y ~j(㥂JAieHO Iz2U&!`ITZ޲`%Kf̘&ͮ,kU&Y.  йt2_߹pήCeJϫWL'0W_Ց(WJTz2/9siӦ-f %)4߹oYgܟdW e.NNN^tn;~O.9?000#8tRիՂZRCKUoZ $@-ɁZ+0s&R\B@mmmm7oYffs[ZZd2Ζ Mng9/oqYfUg\p<<. %m;?;sέtun vbb_w7'{itttJAv >nI&%TDU|~Ŋͭ& ˹N皚ffٖ,禩%d33L4i[ 7'hx9$q ;5o^~NQ+'8s~zMFgϞ`h|ޮ1eܮ ȗyTiI29Po2RB{\LhE&|;wާ( C@c|_?ԟ6*+)]&H<|>n Dx߫s- ;Zrg5XI ,˲k\̈́A^>`4Z ZMM6כ(|X%^'1P)]|P;Q O)ƴIJ2AP ~AQa$*=_(ze>*[>^[.AP-ZɍZSSSm.qmB3?>ߧ֩~Lm| # "J 2 Ϊ,(ޫgm?FA |sɀ  ɮwTA=" *Hs1TIJ4sf{כ(]+%ʝSF6z[4H+L$Hb &v3$j}m D[ lVHU&&%JoX!i8=P,H)c R\0̠>? (~zzzM 7:&9555% $(ȷ#nkQۧf8n5$ M~$ +i:Ph 07A|H{P*? F~3~ފY 6v:VHc)mծS ߎ*mJ~F7D@#A~=Y~魀wB8F;r99@@aEZ!nXA~~Ap+,<Xohc(QvL#'hoPYȁ $~!qv@ Iza%j ƃZyaT-0nMqc"|(ag1vc2aMy *B~}hQXp@J{:& /H4L"otc>o ׼y;ƲJ}4K+* ^T D(ښm'Fn^&}MO#t8Pd% H_{tI>$*~95郺}\C94@ `ي=5+2 !P3:/33qektq n1oHe" ݊A-&$BbY|aÜoEXV"ws?MYHJcj|g-Mm@eq:O$j^B} Ih d`צ,H D@`iT"t/$k(& J@YԼbf3iLw#diܐ8H /I I ɀz%`jhiO bI I CPN _   4>A }Hy&9 AHF  $@,ˢ]U+ E @$ @$ HE&L),RͶ6J0"0R4X@) ) @##$"h{[u+%x'fP ͜9sm-`摑fe}Rh'(@)_ qΤ4c_~"E(@ID5!(kmϥ4:wu>u^JPk 9?`&qPb\ _-$|~/\cƍ| Q<˺f{RG] S_ pmذF'XxQ@,|4Qn>pn~K( f9֭;~ҋ5 6lps_JH7xߤ( AJ'dYַ) @~l_zJHHG}t^KK[mviL8O9kMHqA˲Fms"IQgpvpll[R, )})}չM~1lٶm6A$$ЦMs͹IJ;lnS qil/lm۶`y8w4@$M/.R ڸql6sJTN>>GQɔdq$>nYOe`H&7Pmmmę|sMLLL=zUJH`y'nvn9[ j4?(da LNԒdC1 a,AIFd2O?3)$kH'#J4jrr) aE$ǦMfٶm4@Z[[?eHF  @@Zr)=}"Am@,˺R-4sG) }Rm{@Ɩ,YqJ4ÉS @4Q@ݻ7~nW) P۶OIbQ@2=X5zy_P,, $S6L_:7g) P m?@A~_^d22 `> ;}lٲ ygvMM *m{wAQ@ <[sw5v _/ɢ@1H-[zsosGl'n#ҁ@lڴn۶ĹRѤmqgͻ)'ٶ-I:ۭζR2$Nwwc,eAIENDB`mate-hud-22.10.3/usr/share/icons/hicolor/128x128/000077500000000000000000000000001431310724000210005ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/128x128/apps/000077500000000000000000000000001431310724000217435ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/128x128/apps/mate-hud.png000066400000000000000000000102701431310724000241550ustar00rootroot00000000000000PNG  IHDR>aIDATx][L>5m84LHlJ-R$RݪiD}"U}i*SۧnU%RHy*nڭ#Ɩ[ ũ/8@;s[? Ù33g./=ssfҚćN P=M@} }z> d@l555ׯߴnݺ"A @8j<.v/?봼< 'oF;::;XE766>   |!KNF?>k2@233O޵_\x,|A+_\\yС?goP,S{{@T@ jhh8"vww_P~4.?_U `H$qVVm:C!q` $pH&b<5CS)L"/ZZZ"Qym&`CG&&&8Zs}@5 @A1;;<󤶶V^!=i0F'+Cv&|^RZ6//R믓-<~:u ҥK0b&YzW<-|doZ^zi;,[*o?+Y]]M=-x7{tR o߾@U/t@p;v!m~eP,ӷDd.DJ宼zL/)U9)U U/4| `ގW#y/wslL1h8222J Wﹹ܄E [ S1(EOA bA drmذH(`zzZv,+̇B~駤[@ +zjʶsNg(f &L=_E(T3Z}ҷ͛æ/y=ahu kU׮]#]]]TMZ͖]bhL^p o1c_ ݽ{WU 2 ]@ЊZ;w|q۷opiG_8HfDqAS bցO=x@N_$iqҳ@YeeݻwX7hA3 œP2[Jnt% WSǣG|IDX9*"mJ?IP5ºO.bQVVx|r+@KYb9U,aUZKP65lB;LNϿgLgqmȞq4Xϗ *!3B k"Sk̡`5Vr9F%]Y0t|f-uTB2#'^L(j窭F,c.e ɘZNvxn.U:hFO2a[j#` 2NBswRb% Lm|tJnNo5uT:tvZ.@Q 7d0nax0j E22x;un NVN`*TD^ G7kaUilf'MLjUI,'f Z.'Ó=%HV7Z=0ƃA*Ƒ,lDv}J. 3j{B8kj@nn. KeP;Stv`B!G= ֵ؄zcet_c;҂JRwA+}I4,d.C"MGwbxMlRZ$ֹkޮdx !(lI`U(_`&[NN(W!bM8Roߞ|\kk#.\PfPK?`fv #G|{\b~۶mbL,B8VLizęunmNƳ(g$Y@iUk,l AV/>;~*I~Xʓb[1V#Ipji|4p LIf53386/bPL@@p/>ĠLJI4>88Iii0#i'wI*AY[[۟1 P>(c)صk׶ @z RH>IߥOxl= 8 Y{{{d_V$#w':挂HUUQG@@Y'>9 4|@wApLBK2S_ B$jB 1џ?vXyQcGef=hO>!ڷۂT%L (I@l4к[n]tk4-3*–SMuB+ SVD(Q#1+t h$CPj;q!.qf   FO,C8 5N {,,C(樓,'V xx-0.)` CıS E"ݐSզ@נti 퐂>?1΅ủOp%hHzPx>M7_"!Nc ՗}2>b>`,  _IH;8p64</\g3~IENDB`mate-hud-22.10.3/usr/share/icons/hicolor/128x128@2/000077500000000000000000000000001431310724000211625ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/128x128@2/apps/000077500000000000000000000000001431310724000221255ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/128x128@2/apps/mate-hud.png000066400000000000000000000207001431310724000243360ustar00rootroot00000000000000PNG  IHDR\rf!IDATx]i}=^,an0,k$@qB\m,bTC9*'T!/*_bJRER˨%H r{vv:^=ݯg^{=UulO~~c  HKĉf@ͨQFZ8@%)/B!?/`[D|'Ar M'aF|;S@Lށ'Rv.<<05J2 cr"ϓ&s3?j::~ntx$?ƀlw=拾/6?n[tn _y#G\/X8 QpQ9QH~xammtz /6~ߏ91'\ra8վ}>.` RO_L&u޲? ? U.{߳g0 S(K %~KK˸  oIߊ*4~v̙}=EBPɟؼyW9{sέ# E @I/\ uuȑ|rx @.w}͛O:Qε7o#1cFc[[۫Vz 9q5===[*W§_e˞_jPE`5޿4 vZP__rT R!ϙLf5ODe]]]Ν;+Wclhh v{(jAa߰aW9~p/_VZ,X`'e ċJ1qevQc{s{Z x]җ<ɦM @k (طo۾}F6kCy+%^[7-[#hKO~>1lܻw"/ _Do/~PdxٳggyF(]/x"!o=$.^v-{G~\S؃>y}:=Wy8fߪUZkvqƱEkёM6y}]wm+W\JOwD2Cy%蔟 &+rn>>/ •h@kё_$ X^>1 }p,vCt$罵Q^w1\p`7Z{S@KK;{LlEnOu^z:Z{Ny3gWz kt%^}"xȻg͚yMmm?!Ȳࣝ | 'Nf_CfB@<]M͞$əlr `#LaMMM =aYCCCn5Cf`JǏŸyWZ7M0ÁfP\OCu~4>h:h%]t}/6;5tZ_dEdVF~Ԩѳ`J=Ti6hvv-kZE2X,5oݏ;i$6yd6sLo൐GK o ^Z~$YU=C=6m3 *8w@ *riW^E/Dy(+h!J[b>YZBE[WY9B0Ĵt_kQJׄ DAخHGv9 @%4Ќ?@g-Yyd(?h?@hyC_ Iv@ؠF,6 {2 (CuZaA@!ۆe{)؎?@l@,N|j+t R@3WX - jâ`RkU nȖ1WUu=<=JBe@pt= ceb ބN[&2a+Wdmmmҗ+p>,(xYDM:G[8u;p/i{ &]ZusFW6ㅵX=[' !l$Ax@(wgR)@Wr@x=F8 M@x_ˌM@9U9A~\nHYNm@*U{U @T&}hi`WeVT9` /ТRd|~*'ċ3ej-"c4>Ak>^r p{GCtWG톦Z֪HUT |&UOR- Dګ6{Z*_*hUy"Gj@_ihU<j|) ?`Vw۹FE5l%Z۝-Tl*ʤ/-SE_G, \3{zKZ۝-F.!p0ޯ2Ky >H/*'EF6@zZ2ҫ6 Ay #@=K@L=Joք,7ܯU݂=h0ܬѫـ*_1Up ŲN+I?rJG`c:0\OiiZOb?^dϩ*x*'H_YNZ*+G뵃H?ʍMd=+_@ ^r2P # zw =d ӆT7@AT[j2B/>i@1UD1GL? :-v@Xy*2w{fj=\.W}}}=_ytHJ*ҭ$R|K/3 zgտvμ읉P^=̨ 6EC}UgUP~X+P9nvTL+Zᗂ[G _xGl&$w@:v >P m$Cʨtg|-Hn˂ʭCe: Qv0k^$kYpI@i?,:bgkZ Tw>lcff $):d nݎڻo(j-@(W~P@'Euc/yأ -N<6ǰexj2aYﳡ4C/sMs8q]YGBTX,&gJ Ө2{^@4ɇ@60@XTv*) @" LT' Ϊq UiEAD!-m==V.j=!;<~dKA>_yP= QԺ@<=|( u1NRG!1 @e ?^īmR|GTj* qQTw@>j4X1 /yW H^.<>Dgay[ !>ʻ@jPPH¶\n -?d-<cUzǹ.j־R&)/G8QdsÑT dBw +}o B&`y-&#<-F>eBö2B=EU1*# }2ۂ׀^hHMOvycutT > Qz 3rދFEx@<.HR@{R` >tA.@Y}*P@<,KRRӗ jP\-lyPw[Oz T2^DYHO E>_ە=HM</JhB__ DOcêg/ \W^ڞ״\W[߹s'V@F766 _{M>D/߸q#@QϫWF ]ɧit@MMC.]T>DX{{ƍ:ϡɓ' _K G$\pʔ)r + Ɣ.\<-{ĉ}ͺ:~8b{N8qB7dda?%` B BןR3gKӾ\_uuuE& o߶lfgϞ-  {R"ģsu_~_[n*|`FDolTv% ih7sf/fmBkz~!{饗J3k2N_8 8XTyf_nyak&"%~]&*fgggAyOƍVP 6)q9 hJC5!^j^7xH-:R^՜Lq!_% ַ8`M/\5kXÆׂ^gZ=AOT/@kM/@@hL;Qg&dwJȎVXaUٳgٹswqb{!4Ϊ|nJ~`wV*atPEZ[Z4IC?*6Ci8 m8 9[7< \Wt{Er-3fXG! g`Ai NFؔT5t (}43ACi8U׀WYfE}nl="=Z%ܵ%*u5v#{ Ig{XDNd$(x yխŠVPؑ(neO~ū#cn|dK \a< ez s:qUӧOxhni?۷oy&0`݌?@nY7Ck^.\~/"lֵAlхkOB.g Z~D tGno>=Z{50x7v\0'rΝ;+Zn =>qk$?)>R x=+⡵Gk/=`se>:hṕl6{k]]v AغuD\&n!<᷼&\ !Ο^xAȓY-C*RTp.l>~gj8*&߿ߊOh6Fk|l%>$ g}R^xx@y΁&1CP<Z:ve2o(" /Z͜9ӚiE+ЙPTB\MD,΢u/o;pߐ30"ljZ[[qPS4+:ӔLڭfhv`p|ėvW+noLBg"H me먓^Sm`K՜9su=ٹgUy$40f͚MR_RJ*4UD֚Gg:HmwAR6xJ(2|Q(Lwb3@dO+EReBĵ7)GgG簧UK<=6Uֿ\f͚58)|J~>oR3 3>wݗ$䵌xC<}?_%R^(xquʔ)<E A- &ty{キc9JR(uSkӦM;[\@|P?WP7wy̽_SB_7ĀV?ܼNzvg [{-!97n|ѣ[\ߓt Hq,]2̷c^Sti!Gc+O$0&~ʉo]4[=Z pDds!CNyv{VCp:w= V³a8]5%x?Ϝ9o9 "Gb…&-aBp} RًE~ "A_[[۬t(09s#kN۝}r[g狾/S 8 BHB!pu4553R__?T-jH"i. itMd?b~<pΏc~~"rtX۟9!~M?o}}}]98٧;QԚZ_ J+>0ZaʕOf2 |[̓g=N$A5y-5&9UfFfP"!(@oqE=:2Ћ"i}OHHUa(Qݽ ş<Gt:7\3+[YE5vfr.+8qij>?MJn d.HZ8 Yߡ 7|x%,4r$&_(HmSdpyP#NDè6H -^ođŤ{U$@# ^U* *2A a(T3@*1y'VkLsR\C q0kc$vkQݚ1@=6n[cX 7|c>]Ncp qo`;C@{Pkks,?X'?ڱcGw ˚ZIx[IENDB`mate-hud-22.10.3/usr/share/icons/hicolor/16x16/000077500000000000000000000000001431310724000206305ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/16x16/apps/000077500000000000000000000000001431310724000215735ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/16x16/apps/mate-hud.png000066400000000000000000000011621431310724000240050ustar00rootroot00000000000000PNG  IHDRa9IDAT8K[Aļ^C!Tk1t"(҅KW;BJ-lЊU*`&vy33|cC6wp*"kkku;??T*bܬTJQJ1nvm,{\.j4Dt:ifffHzX,.j?/BkM"ZZӸKoyAL&>LNw$~zjD䄽'PJaAk3![ FHjqx; > ZR qJPj9(8z@D>_7QJE#%t.Yk}0h )d"VƘhoE+"r9666}`/G4US) f+"vRy4 O##RVclDU>/RJ)sV;88P,-..~ pRŸ ρ]YY9hBYIENDB`mate-hud-22.10.3/usr/share/icons/hicolor/16x16@2/000077500000000000000000000000001431310724000210125ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/16x16@2/apps/000077500000000000000000000000001431310724000217555ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/16x16@2/apps/mate-hud.png000066400000000000000000000022531431310724000241710ustar00rootroot00000000000000PNG  IHDR DCPLTE999666@@@===777444MMM333777NNNEEEGGGGGGFFFAAABBBHHHGGGHHHGGGHHHHHHGGGHHHHHH???IIIHHHHHHIIIDDDHHHFFFCCCEEEMMMNNNMMMEEELLLKKKDDDJJJJJJKKKMMMEEEKKKMMMdddfffnnnvvvzzz}}}~~~3GJKRXWa_`hivvwxy~}~ʳʷ̴̹gt0z3tRNS%'8<`3.~x>(|\^h6'lTpwO gÒl ŵ|u[)`\?CZo}XEL h#=;0,^v:ULr^IENDB`mate-hud-22.10.3/usr/share/icons/hicolor/22x22/000077500000000000000000000000001431310724000206225ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/22x22/apps/000077500000000000000000000000001431310724000215655ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/22x22/apps/mate-hud.png000066400000000000000000000014251431310724000240010ustar00rootroot00000000000000PNG  IHDRj PLTE@@@333IIIKKKGGGCCC@@@)))''';;;NNNMMM444333OOOFFFFFF???@@@???MMMMMMJJJVVVVVV```bbbdddcccWWWVVVzzzAAAHHHMMMfffggglllmmmnnnssswwwyyyzzz|||}}}~~~FFMMSTU[\[]^4!$tRNS'(,2Dfiy{({@IDATNTQπ0 KL|^w[,MB%9gVeз8?lrp1@1}:CNduZVlU3E+D1{!"QD_ Qz8 ;-ek~̰I"yN$JO="iҔ0$W?DY6BMs7tޞ<_fj_vmZ<ͼ|'.ղS=_EbkmKC0x j;]O9pIENDB`mate-hud-22.10.3/usr/share/icons/hicolor/22x22@2/000077500000000000000000000000001431310724000210045ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/22x22@2/apps/000077500000000000000000000000001431310724000217475ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/22x22@2/apps/mate-hud.png000066400000000000000000000030001431310724000241520ustar00rootroot00000000000000PNG  IHDR,,)Z3PLTE333000PPP---333...777333IIIDDD;;;AAA888>>>:::>>>===:::<<<@@@???222111DDDEEEDDD000000111LLLNNN:::;;;888777LLLMMMNNNJJJIIIJJJJJJKKKFFFFFFDDDLLLMMMLLLKKKLLLMMMMMM???EEEGGGIIIJJJKKKMMMRRRTTTWWW\\\```aaapppuuuwww82,9@mnov}w~xyz}£ĥħʻ˹̼μ6'J@tRNS'')),-.0345=?DFGJKT[\`crsuw?IDATMe~|Ό XH_ Ak'ѲU -ADE$hasqyy+ d4Cm݅)JU.잜Qkhr8U\le@ pfL_@I YߞFtfa.fLadYy NU ݼb7F)qr( sP1ޙO!pj*@Ax 2FE s! "?˄HQAxXJ@ );W!=BTtA @@@At!#ub0+o,RXBDEU"T P} g! *"x]Ah ޹" tHA@8RjcÝ`܁WaP o w`}ͷb0Vїog|)M81-̡zmIENDB`mate-hud-22.10.3/usr/share/icons/hicolor/24x24/000077500000000000000000000000001431310724000206265ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/24x24/apps/000077500000000000000000000000001431310724000215715ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/24x24/apps/mate-hud.png000066400000000000000000000017151431310724000240070ustar00rootroot00000000000000PNG  IHDRשPLTENNNIII444999CCCBBBMMMNNNOOODDDHHHGGGFFFKKKJJJMMMKKKEEEGGGFFFLLL]]]HHH]]]^^^\\\LLLTTTiiieeegggGGGiiihhhpppMMMggglllEEEGGGHHHMMMNNNWWWXXXiiijjjlllmmmnnnooopppqqq6789STwk^xl_ijyzäçĥĭŦƧƯǰ˲ʹʹ̻ͷtU)tRNS ,-56_W~)*d3ԒJ[T*)5bwWB_SKLU שּׁΨ(+=.P )%^*tS$1/<"TcVȵ۱(6jP9ɉj =/ۙ4?vmˀ}Ru7>Wc/d2M>9[\_g2P'[Bl{`wr:IENDB`mate-hud-22.10.3/usr/share/icons/hicolor/24x24@2/000077500000000000000000000000001431310724000210105ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/24x24@2/apps/000077500000000000000000000000001431310724000217535ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/24x24@2/apps/mate-hud.png000066400000000000000000000031211431310724000241620ustar00rootroot00000000000000PNG  IHDR00` PLTE$$$ ///LLL...OOO888666NNNEEEFFFFFF777999FFFCCCLLLMMM<<>>===JJJLLL???JJJ>>>MMMKKKHHHIIIKKKKKK@@@LLLJJJKKKLLLLLLMMMLLLMMMLLLMMMMMMLLLMMMHHHKKKMMMKKKMMMAAADDDEEEKKKLLLMMMNNNQQQVVVWWWXXXZZZ[[[^^^```bbbhhhjjjlllmmmyyyzzz{{{|||~~~45,9CHBQQ[ehijsrtry||{ɲʳ˴̵ϾyDtRNS6677NP_`bc5JIDATϊu;L XR E ?mBE- I"Sp3s缿' C Sq8:>J\fV`ڌKv}zqŠ9F4R(<8AAxPh`gaAv!  @ -0@@3( _`[b,0 ~K 03G90 PH1! (4la֌FB ?w) B $HKDP ܿ`Hkq@ xBHV"%B@\] "P0a0"P`  : = 8v.@ݛ!|{"`dAo OG4L Ÿ!ܿ?kp[WHZ^8 `g"`<:~֕~4}vk 4#iŢ?uyEխ<8\Ъvu ?'m\-x$.x @קS zt(``_,kZPy `ep`'[A;IENDB`mate-hud-22.10.3/usr/share/icons/hicolor/256x256/000077500000000000000000000000001431310724000210045ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/256x256/apps/000077500000000000000000000000001431310724000217475ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/256x256/apps/mate-hud.png000066400000000000000000000207001431310724000241600ustar00rootroot00000000000000PNG  IHDR\rf!IDATx]i}=^,an0,k$@qB\m,bTC9*'T!/*_bJRER˨%H r{vv:^=ݯg^{=UulO~~c  HKĉf@ͨQFZ8@%)/B!?/`[D|'Ar M'aF|;S@Lށ'Rv.<<05J2 cr"ϓ&s3?j::~ntx$?ƀlw=拾/6?n[tn _y#G\/X8 QpQ9QH~xammtz /6~ߏ91'\ra8վ}>.` RO_L&u޲? ? U.{߳g0 S(K %~KK˸  oIߊ*4~v̙}=EBPɟؼyW9{sέ# E @I/\ uuȑ|rx @.w}͛O:Qε7o#1cFc[[۫Vz 9q5===[*W§_e˞_jPE`5޿4 vZP__rT R!ϙLf5ODe]]]Ν;+Wclhh v{(jAa߰aW9~p/_VZ,X`'e ċJ1qevQc{s{Z x]җ<ɦM @k (طo۾}F6kCy+%^[7-[#hKO~>1lܻw"/ _Do/~PdxٳggyF(]/x"!o=$.^v-{G~\S؃>y}:=Wy8fߪUZkvqƱEkёM6y}]wm+W\JOwD2Cy%蔟 &+rn>>/ •h@kё_$ X^>1 }p,vCt$罵Q^w1\p`7Z{S@KK;{LlEnOu^z:Z{Ny3gWz kt%^}"xȻg͚yMmm?!Ȳࣝ | 'Nf_CfB@<]M͞$əlr `#LaMMM =aYCCCn5Cf`JǏŸyWZ7M0ÁfP\OCu~4>h:h%]t}/6;5tZ_dEdVF~Ԩѳ`J=Ti6hvv-kZE2X,5oݏ;i$6yd6sLo൐GK o ^Z~$YU=C=6m3 *8w@ *riW^E/Dy(+h!J[b>YZBE[WY9B0Ĵt_kQJׄ DAخHGv9 @%4Ќ?@g-Yyd(?h?@hyC_ Iv@ؠF,6 {2 (CuZaA@!ۆe{)؎?@l@,N|j+t R@3WX - jâ`RkU nȖ1WUu=<=JBe@pt= ceb ބN[&2a+Wdmmmҗ+p>,(xYDM:G[8u;p/i{ &]ZusFW6ㅵX=[' !l$Ax@(wgR)@Wr@x=F8 M@x_ˌM@9U9A~\nHYNm@*U{U @T&}hi`WeVT9` /ТRd|~*'ċ3ej-"c4>Ak>^r p{GCtWG톦Z֪HUT |&UOR- Dګ6{Z*_*hUy"Gj@_ihU<j|) ?`Vw۹FE5l%Z۝-Tl*ʤ/-SE_G, \3{zKZ۝-F.!p0ޯ2Ky >H/*'EF6@zZ2ҫ6 Ay #@=K@L=Joք,7ܯU݂=h0ܬѫـ*_1Up ŲN+I?rJG`c:0\OiiZOb?^dϩ*x*'H_YNZ*+G뵃H?ʍMd=+_@ ^r2P # zw =d ӆT7@AT[j2B/>i@1UD1GL? :-v@Xy*2w{fj=\.W}}}=_ytHJ*ҭ$R|K/3 zgտvμ읉P^=̨ 6EC}UgUP~X+P9nvTL+Zᗂ[G _xGl&$w@:v >P m$Cʨtg|-Hn˂ʭCe: Qv0k^$kYpI@i?,:bgkZ Tw>lcff $):d nݎڻo(j-@(W~P@'Euc/yأ -N<6ǰexj2aYﳡ4C/sMs8q]YGBTX,&gJ Ө2{^@4ɇ@60@XTv*) @" LT' Ϊq UiEAD!-m==V.j=!;<~dKA>_yP= QԺ@<=|( u1NRG!1 @e ?^īmR|GTj* qQTw@>j4X1 /yW H^.<>Dgay[ !>ʻ@jPPH¶\n -?d-<cUzǹ.j־R&)/G8QdsÑT dBw +}o B&`y-&#<-F>eBö2B=EU1*# }2ۂ׀^hHMOvycutT > Qz 3rދFEx@<.HR@{R` >tA.@Y}*P@<,KRRӗ jP\-lyPw[Oz T2^DYHO E>_ە=HM</JhB__ DOcêg/ \W^ڞ״\W[߹s'V@F766 _{M>D/߸q#@QϫWF ]ɧit@MMC.]T>DX{{ƍ:ϡɓ' _K G$\pʔ)r + Ɣ.\<-{ĉ}ͺ:~8b{N8qB7dda?%` B BןR3gKӾ\_uuuE& o߶lfgϞ-  {R"ģsu_~_[n*|`FDolTv% ih7sf/fmBkz~!{饗J3k2N_8 8XTyf_nyak&"%~]&*fgggAyOƍVP 6)q9 hJC5!^j^7xH-:R^՜Lq!_% ַ8`M/\5kXÆׂ^gZ=AOT/@kM/@@hL;Qg&dwJȎVXaUٳgٹswqb{!4Ϊ|nJ~`wV*atPEZ[Z4IC?*6Ci8 m8 9[7< \Wt{Er-3fXG! g`Ai NFؔT5t (}43ACi8U׀WYfE}nl="=Z%ܵ%*u5v#{ Ig{XDNd$(x yխŠVPؑ(neO~ū#cn|dK \a< ez s:qUӧOxhni?۷oy&0`݌?@nY7Ck^.\~/"lֵAlхkOB.g Z~D tGno>=Z{50x7v\0'rΝ;+Zn =>qk$?)>R x=+⡵Gk/=`se>:hṕl6{k]]v AغuD\&n!<᷼&\ !Ο^xAȓY-C*RTp.l>~gj8*&߿ߊOh6Fk|l%>$ g}R^xx@y΁&1CP<Z:ve2o(" /Z͜9ӚiE+ЙPTB\MD,΢u/o;pߐ30"ljZ[[qPS4+:ӔLڭfhv`p|ėvW+noLBg"H me먓^Sm`K՜9su=ٹgUy$40f͚MR_RJ*4UD֚Gg:HmwAR6xJ(2|Q(Lwb3@dO+EReBĵ7)GgG簧UK<=6Uֿ\f͚58)|J~>oR3 3>wݗ$䵌xC<}?_%R^(xquʔ)<E A- &ty{キc9JR(uSkӦM;[\@|P?WP7wy̽_SB_7ĀV?ܼNzvg [{-!97n|ѣ[\ߓt Hq,]2̷c^Sti!Gc+O$0&~ʉo]4[=Z pDds!CNyv{VCp:w= V³a8]5%x?Ϝ9o9 "Gb…&-aBp} RًE~ "A_[[۬t(09s#kN۝}r[g狾/S 8 BHB!pu4553R__?T-jH"i. itMd?b~<pΏc~~"rtX۟9!~M?o}}}]98٧;QԚZ_ J+>0ZaʕOf2 |[̓g=N$A5y-5&9UfFfP"!(@oqE=:2Ћ"i}OHHUa(Qݽ ş<Gt:7\3+[YE5vfr.+8qij>?MJn d.HZ8 Yߡ 7|x%,4r$&_(HmSdpyP#NDè6H -^ođŤ{U$@# ^U* *2A a(T3@*1y'VkLsR\C q0kc$vkQݚ1@=6n[cX 7|c>]Ncp qo`;C@{Pkks,?X'?ڱcGw ˚ZIx[IENDB`mate-hud-22.10.3/usr/share/icons/hicolor/256x256@2/000077500000000000000000000000001431310724000211665ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/256x256@2/apps/000077500000000000000000000000001431310724000221315ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/256x256@2/apps/mate-hud.png000066400000000000000000000444501431310724000243520ustar00rootroot00000000000000PNG  IHDRxHIDATx{ǝߙ=/`0 b"HHIH.)iE:ݰn%[6|gaG7.vm^:–bmzW KVCDi)H$"00<tל~TweVgU~>b 뗕}YJ@P1D@N@x ($Xf(34b`,H1z3;wב1Iuf<*#06~ ߓHW?pB IY@{{A 031B Y>SLA[ #\tQz &zC utX8!ЮJDX. j~`J4I!`*g)oM=o2XRkd{`9WТ8^?;#\D(W{VTyƍ˗/Xp኎l6;_u׽AtsPe2}9s>/}.AfAp^4>Os^kW[Y}|>?8=5559s&t [@2-LpwCCC֭k .J]x˪opZ\83cXsssG.^xGFFF. A6-f8@L쫝.]馛6ު{u߬ؠHxxP(Ǟ7v޽wll,_%W; fJ/.ۯZj7QݳҁvuB0Z2;;7><<|qw"Y!v`SD UA֭?#mZ ̙3Oܹ*b pF0 zիWg{Ts3E&!B|o׮]fA"0k|^sR n b;q۶mʄ@ hhKU:?:?Bo\ ߩ" D_M֭[WZ_dYwPAdmzر?~7F-d LQ/%'?_P ~<_$M 3IШ- ̖-[[tK4 w8Ow~>h*@")ey?|{&*IE:sپ}!ߊc׻<޿UR鉉{_rIb w__ RϯYÇ+ a7BT%yoŋ_SW etvuu=E Z,AX&:%mړ-w}e˖=KҊqZEBP|>fffQmԥKR'J-ϋ/F獵C[5QC^{ -rrCޓ!?&Nʕ+?222rYΠ@elٲJq]ŋբE.WRp+ʊ_* Z;9ࢅQ?1+~f剉199Y<]>N>]<;V7vmdz>}#b c?|ƍүbLkF}PׯWk֬Q]>l7d@D:uJ Ϻ?.\{5;۷z߀m'ya ]0e@fݺug_M7ݤu-4LAk|DzeˊǍ7x08{:zhAp15555 #-rCB~,@߷K^`@}ݧ>򑏨~d DܹS[ڋ Se޽gDf͚/ 2!7~7ԃ>X| vVYtiزeK1Pm۶8apynذj13h_"9=׵L(I^1t7@$sI9&) _|ŭYjz̀k%_~>}& M&}sS?xG\r*v{lO>2}H8qB,%;>|"7y]ئ(ft7B_W<}:p؎xǸ\1yUTjPSߤ*֯_0}TAnf" у"볈Xv1˗/i-V^ 7I`}_V]wb;ہd/][Dnߨ0Jf]]]1u?0=b;^W^}Qcc壪acoN3 .$j~:vD;Q?UVԕ;f¨}cB4QYp؎vg$Yw}fn M #~A .D~jƍD!b;۝z,@$ȱ @/Qr+ #zݵz/Tr+i64jGV֨"; lwoݺZlU caB;ܤ viۈLvD;[e  0pm[lF9`Cfɒ%[M|l vD\ey lU&<[Xu\.w{ԋ5M}?۩6F6U j6`厀]KXp؎v}OOڴiSѝf&F dL #z= ބrO|!b;}Ԛ{\vdB]FJdp؎{@[ru*O+`M&n0p؎%KŋGL L?WO0lz˖-+Nb;ۓbl\kԕ{T2\nC\f p؎' Clю.0Z 򡄀f# w؏؎IBf7l b 3Tvl~lO2|mPXSݥOЬ ݉{lO:K.5Q6+{{{su:mYu]v b 8 S7mڴi,T__ʨ,)xp8@lc{6&>D ĿY$ zIDJOOJU}SKg[ǵ6~gggdGz ݙ^QE4_wXgOvl~lGF6]nu >A/5;;.]t(ynnN⿑Y/_7dv5Y]]]Pϓ,ϕzOЏUl=ZLUM`#7C) jrrR?^]pt. Rϵ'M _ԢEToo{( XjLO 3gԩS籱1uܹH@ZA|<&#Ʋ> YY\, 'NP:}4=@T 9:T|/˩˗h]ZE+$3[J @Iuauȑ&px׊) 6!zjĀ @7jFD4۷ħ)h;_edb/ˆ $#{Zn |"K-47\Elva+-uf䑚;v^x^ :ӾHI{tU+فRoO{@Rd 7iQCߛڥl|le~-Ld9z)?x nL*,,9V dZoD'gS'JHiL Ic[2d^~d*B=P+ ճ>k}O$"Q|ʴ`j`Yб.J ?f ijȘisZ&''i _EI `W [fY]VFM:hX/6 C###ꭷޢ54ɛoN80ԩ6)D}@V}Ӑh۶mK*1fZ1~Ӻ@LMM;w"~-ƭDY{z@e. {MiKP,< WҾ@0jR'| Q#nRN>>L0 x Z+avڕ6љJM& X;v `y$0;TKcvطo_<u ~<;B,qĭ `"!f*~9Ge__i D~5:D̻KAp9Bf %dk6<M<@~%bL,jWU7&l5q]W?@|$tP[![e%@$c@dme+9s挚EĄܤldh 9@0[CקH:###[t @!ett4ihc;+̆ȴsDŽN:EK@X$j Jŋjjj3ehJYfcaHTiܹs_O*$2ΠHE8^XewQE?&54 /P>!Npz>WyI(CYPk$ .PmB|!R<-|@LNNRt\Ey  {<>fff(6j&#B_iw, V/9T:Hxgi1177G!Y>V.q>`3 0ZE<6cH#ZiF ͱ}V@r3qMCra14[<L~ JE@011`2 G8 LW2nf\ZŃR? VrݝnH4PO3Z2-eDfc=*vv6ؘU_rG ߕzE5}iկn#DA}㍆~mw :Fh !bW2,Oο'$}?G_21@יhd! @gC A_F~f~}]Ҽg1P! _1^d42_ ew TR'0!!hi4I }55> {C}t/З4Dgԗ!qz!m@#Hjf#"}|Y;<FFC 2gh<H#p^8<O{:3y24* ہ{Klw'H%7#ڑp#(]7ہ{p#(X wWce- eiq~6?UV(GL\p}OOUL OO!p2"N pU ہ{N pU=^?pک"pe9=x }Oy @# ~{hÚ,^e>pݧ!Dm:G3%@Cv۴߇ @=v[=Úal1@TS$Q-ii>{2dp{a@;!4{ G=R؎p湔Ӹ+B+!AKl;ծ2 p߱?M>{H\E{<GcI{Cx}s8 |t[7?K#Sl5RA- 5 DVӍ@GA h^7c{_mY?7\7k Az@Z z@ڝ={lvOZPX{x'!j; -I:@Gԇ@ޓ@>=ݷ&p8@-c{tY[AЩTq'A?d:(g +Yn{˦mL1y!HةIg=[aM245?۱{p|h؞>ۓ(| 8X\1Kc;R>{2^϶mgڴ94\zK~UvHЧc;ĥ9qNU8Se~?c`#|Ei8lvun@ICc;r=.@o`Ҝ!>۱n"bI&vIl? AO@@q؎Hu0vlG$ Ux@FBc;#^ @e#!  ؏}d.m@c; w$@n^c;c3ʂJ6c }m @h(vO.؎mL*$8!c׶ljs!c{mOoK'vvK3dp؎^۞t֪54?cmOb;+:::zn"ت]{^ǏW3338277GKjڵV@UⅫ@]0am?U."E ;׫l5mSHq[|m>M~u1 /-j;_|Lׂ@:y=}Op"q]4$H%!ٜ) ~_`@EvHO'F&"\i}-@Ų ۀ g^G#xTKpL@if?  _'6BRs:vַUήS~,u=F~܏)6@ns{e>l.P*fIHV_9].M1sS]( c; SvpAΓ۞ @XZ?lsg)ٌ @* Ο͑ ﻕޓ c{L } I#&W ΟIͧ~U:?cIڞ:[G8V\8?!Ps!*B; ۱6om5JTL;i;Ƌ vJ g+B\уc;nKs?{&'T0s*Ļnf7AP}blX4\{Ƨ)姿cI $)'ջV %c}@+kM|@#;! -FB x'iר *P-i<@Axq˔d\! Mik6vg7PI-Pz @}Ϗq# , B;,[C~|S{'Tgggq>/ێc;c;# ٕ ؏]Z;؏؎STlvl~붓DRp8lvGP۱T]Sy'؎؎ޖyk `;c?c;x"VL^/ӵ8lvvHE%h?۱;vl~l纱.?۱ ^8lvvlOOV?۱;cC(  c?cx)|%2Y۱۱vl"M@ z> |CNU\.G#Զy| Gي5> |^9.W)2?>HlE1@# $\ER-L^/P}.>77K5%G /> =@ozC'36L㠷O<H8PT 9>8Zc @G >:? !߂4z~# qrK2] 2.#py$w~+B0;;K 8? :2ýv2w2@CvlXc{Oq؎iI M8@lvlo4 ${؏N' ؘ̒Ɓvlv8J۽G p؎؞Xm?Yh"xuvl~| 9-V_]&;cw2-VivFCvlLb_=+!K.=8vo Ɓzj?=qmG8rcld}?c{rl3NhE1 PLYYq؎߮N]s\ 2tӆ?55ev۩"-\5,lVn+vOLLуV>iۙKεFBT7cTbL,X`sq؎؟:[mꌙ9Oa?c{loƷ}  ؏Yp! jC.5>+{٢48?c{R>66(_x ٝ*]eCaF3}؞Μ9cmm(\n2񤳳g;v lO Gm=m"Z -iу@:56O=JV*-b۽p.]j$~ #z=LgKv0 -[fsel[ l?77(" >'af۳g=؞xm_|`m D$dlV[9 lFTk&ld1T> 2۷o=؞z/>V_vte}V7.l,b@߹s馛~K}_]> B,ZRݹS.y鴾k־{Ŋ:`& je%@ ^ښDAo޼$*@TJ2gcz-k|obbb}պm1]XەpNN71~VgժUw.gj"[?j @7m d&:phfתy6/im'-z`͟:u\[w&@4dVkuHY<3fm^|C{ƍwp# ,ngي044dd7>8%KӟmL 8 ?|pvv[k׮U-~oz饗sm^*XT|5k ;0:I!.`"ȿb^[{3m^,ٱcG,6m DMt:`"%JMRmM c=N _nS|6JrJ588l7x8O}Jvp3d||8ĉ$>V|mwkqEęcXǏWYP~oؿ}__X'"HtD%kuvToQm۶M]x1tR1' {Uׯgmr;^xq#MZ7 @) ЌhwEݩlbm~=FFFw~ŵ x2z?999R\?9[&ZkdnݪvkiF*e6l(- @,?~&go*%,XDaS2F@yV.u]wmiWRh@dɒbJf"Z@drfp:w\q1::ڶK=PAaZWbj, [IPz׋d]B((/^\|@q g2 𢡊^_\s#IbUoNMMۻK?=×bk"~[oM=40SIWS[x衇D\(9V-D!j\r!=9zzzrK3up2ٹC\ rIPCKae/f@#܈HTCCCr d'ZȣQlj[s> Z;RI~GզMhe=~0uA"ٸ6+ٳc&@V)ۯ Sf@uwe\ȞeiZPvZvz駋ks,#iyԯS:N~CA`c3E'Jcuoڱc{@>i{/ @Yg:Jߊ01v"Ov|W{x$ Ї>Tl ߭2 @ |>)GbDlٲE_WGؾLpg}[,}L좔_:qYo}8R2O^ [KۘPZ"ac@R5-[>яSNKa<$Kʦ+VP 6j1 8* DI$9BGM=zT{ĉŧX\L!~\lo.)~C4̙3QtFTP@}Q{QWPJcƂ n9- 9K%+.JAb``@ ˗i]uؙ @bOGJ_΢J\hCLJqrȳRrݫG//<5ҨgQ)v@2_Q4ϕ6!K׽@U" "dTWs=f&pV*Y ʵ]kT:Ux) /?:[,N>Gv?25*Swk"7r:GAF"B)܆o٥otߓȓ]4lքƅ tp4gHc6O~mc;?YmBLMM WP!)% h8@?zIbdd$g_[C3(.@1qNșzk Q}t؎x_㸲 MP2 q؎؎dI썐ة rzbfffo }d[c;c?$Y(Bv;gQS2j*^mD kd۴9v=ON<@oR^BTvލv?S!;v,ZZL;GFF&Efj= X8na_W8@lc;={E[#A+/ *.L{n+8lރHۻwoϘ4c0`vvը@Ν;q؎v=8ͮ]d%H!Kt_tUe@S/6OS zN /D fB;'b۷>\z$v=@9k3$V8DoI *zAcvu'b;۩$"o=+RP_o @3D._QQvء>b;)ۧ~_D +uV'-hcf2sFBv=)dտo|cS)F?? @3jc׮]{tF]QGqNvpo~F6c Q'Fa0 /ɓ'q8@lc;~Z=?Gb|ܮ\PbcA-!0;;dIDE?uE?۩mA-#U333?PV1fv<  H${lXygx~^G\SjLֽ`ԍl6r\B+ Ԃ p8@loޛCOH_zꩧ}I:$QhZWUĀd+VmYP4sΩ_|Q\R]7Q(`~[}k_e￴t>ɓ'Uk=vz[w:<9qn7g~7u%a{sXigttT}V/ϞQtgc-ypJڐ@'GAf͚\>tvvmO.f1Aa tttv{i=zeرc?__i2vWʂ~^wʹfJLy@ M6mXn˕n~+΍4۞ le=m۶CY.^:2A~޽w>W_hW `^\^ĉc7n.H2qT9drԊ+.2@ 8@l~l"GgΜ)ƆY'VE_yuu겷h@gJu-ڡiԋ-RdkAtRl2dɒYDŋ?ˀlw=@RZ\el\2N.R2+=9 X'ge v(?Bx^Kx?WMf{{Ǐ_~uI ZcJ{z "a (Xpa\z-吿/,\~}lȪ:ಙH`S^<+c)Z;J~}j^ǽK4S*~:S')ea @YO,y?ӕE%|WaP>"<3R^>R^Qč4v"U]IbZ/Mz(l0  =qme|[)( rԿ|ϝ;wPj #d ?S#+"U^)~H"v07mdda׮] J$p>S>&WߡPo:7C+6; P\z9} k֬7+$)n 03@]0R<,\>^tғ|̙3Sq_h"7-L%T硡+W\.O &=??~'NUW?Tε0%@+===_=Ղ6-nR0555A_9_N0!Z*@8wGwwlz-^xR/~nPxGw_;paU}jР_m ["PU@kUE\]wݚ  \ٹ^WZ ,`}Яf/|N/=#M3t&_ B>ҾuV2)O~zrr訜/+UՂ~(;%ZZC~4}hδ!sDz۷HF^_y|5ʄ]P}]蹗>7_}U\XK4'aQ \.RyO({U#p :QMZ!J=͈jYT A =0V . YJ"u!l_pca{Ĺ*TB|RRA/4?MP`<Tf}f>hB$4owg\a~Z L`NTIHH h&|f@ZaD TF v%ৣH!yA$R/L|Ӂ?f)F=hok@@;#( ^x+B^;@[?l7a2?" f@-1PO)p=y w;Q1xS2.p pg{!fNBfp2H߽6$oX sowqAx JGG)tɽ(1:H/7P~ PCWT)QJ=ßd2(N7344СCoS<&7$ @q۴iY-vRG}}}${(//xb)@7WP(ܐffms' tՂ`~]`]ǴE)<ӟ\?S|>gyf?E#lG ASO=@@ yVFK\Ii@Н-O<1x#t:jP(Hgd2׹P-|_$@Z^& W|R@@x"_4i}\G1@{Y%iGYX‘\F1 AM)@3 @`\.7G)@X2 >igL pi);c?OA3JBS)"}R|" E>t%5x'Gqb*A(wg2/ꗳ!>z]?(طoߞ͛7oJ%f?_0S>OvwwK6q}ܨU 7 c>333SO˖"CIENDB`mate-hud-22.10.3/usr/share/icons/hicolor/32x32/000077500000000000000000000000001431310724000206245ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/32x32/apps/000077500000000000000000000000001431310724000215675ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/32x32/apps/mate-hud.png000066400000000000000000000022531431310724000240030ustar00rootroot00000000000000PNG  IHDR DCPLTE999666@@@===777444MMM333777NNNEEEGGGGGGFFFAAABBBHHHGGGHHHGGGHHHHHHGGGHHHHHH???IIIHHHHHHIIIDDDHHHFFFCCCEEEMMMNNNMMMEEELLLKKKDDDJJJJJJKKKMMMEEEKKKMMMdddfffnnnvvvzzz}}}~~~3GJKRXWa_`hivvwxy~}~ʳʷ̴̹gt0z3tRNS%'8<`3.~x>(|\^h6'lTpwO gÒl ŵ|u[)`\?CZo}XEL h#=;0,^v:ULr^IENDB`mate-hud-22.10.3/usr/share/icons/hicolor/32x32@2/000077500000000000000000000000001431310724000210065ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/32x32@2/apps/000077500000000000000000000000001431310724000217515ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/32x32@2/apps/mate-hud.png000066400000000000000000000043661431310724000241740ustar00rootroot00000000000000PNG  IHDR@@iqIDATx[[L\E]^X.rk5PHEb&Ҙė苏}oo>Dh}h I# i#6mY۲Üs\$'23g6sC4\Ǵ1UUUnnOpLJJrE77772^ym~~ݻwG |Rccg7m6{?x,0mllGXXpƓN>}fߴ}!*uɓ']. ??8q$}-A#!j6+[ Muz\B yZ^FUehŋ r9t: L1m\p !OȣJ8455Y<Fv:XkT:ꩁg > =xz-aZgKyy9Tl0ET_4\]]% `PȐ6@?[ʥ OQQ2٪ {Ie/4ڕL N.*QxzA)XIgg'%uuu6{9c @,lhU\u2ЇCyt%Z8d07K4mؔ\Zp8oD"Im jh?1O ey\oMU%& 0*2 v}}}5Ҭt]Z ?Y2%_#ڠ&-ʸQ/1 B+H܇qe!`T̲3j[5`,Ei!g(P(0hFܠ¸V[{=OH(2# gr.9t~ cbiLIIvBԑz˂$##+MA-q Ǫ ][}`aϜ)Y0aX.j;[oĖy?u~GoÄL|b'l^'ESg ΰ%IeD$HD>7CGvd?@DjFm$ӫ" =dlf?"aj\41B*PC|`ܒ՗&/y}gT@t? 3=l lD*Loiy%W⋚MQ+lAyvde:khYiPfِ 𾨰,..W_Zw1_tBPIL?W i^"K|dɖX+;KHeSbT8ʓ %X~Io%'Ќ5Ɗg+W$>"<Fygl:.gF@rqdbbۍIGT*fI򜍆syF8>>===JJJLLL???JJJ>>>MMMKKKHHHIIIKKKKKK@@@LLLJJJKKKLLLLLLMMMLLLMMMLLLMMMMMMLLLMMMHHHKKKMMMKKKMMMAAADDDEEEKKKLLLMMMNNNQQQVVVWWWXXXZZZ[[[^^^```bbbhhhjjjlllmmmyyyzzz{{{|||~~~45,9CHBQQ[ehijsrtry||{ɲʳ˴̵ϾyDtRNS6677NP_`bc5JIDATϊu;L XR E ?mBE- I"Sp3s缿' C Sq8:>J\fV`ڌKv}zqŠ9F4R(<8AAxPh`gaAv!  @ -0@@3( _`[b,0 ~K 03G90 PH1! (4la֌FB ?w) B $HKDP ܿ`Hkq@ xBHV"%B@\] "P0a0"P`  : = 8v.@ݛ!|{"`dAo OG4L Ÿ!ܿ?kp[WHZ^8 `g"`<:~֕~4}vk 4#iŢ?uyEխ<8\Ъvu ?'m\-x$.x @קS zt(``_,kZPy `ep`'[A;IENDB`mate-hud-22.10.3/usr/share/icons/hicolor/48x48@2/000077500000000000000000000000001431310724000210245ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/48x48@2/apps/000077500000000000000000000000001431310724000217675ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/48x48@2/apps/mate-hud.png000066400000000000000000000062231431310724000242040ustar00rootroot00000000000000PNG  IHDR``w8 ZIDATx[lή_5+;1-i*H.բJC*'Rm*R)m>dUvK` f6~1=gw{}=;iw{;g)@VAmQ4 ]2!T@y$Et ![a]"H466~ IR|p=+JV(+0d2)8OLL ESQ4dHD~fΝenBH$>D"޻wo6EO&Ǐ'i{<%ϟ?'w%SSSm]MM3 pc&*|Qޭ}y t 8EQh~RUUڼO`0;l1봼Wڑ0tv;dMK{&ٟ5F:[%-cyyY5~L]gt!R=?< (\ZGS¬izb^UСCY7"fZad_ԺΝ;*uuu1PWH___#gׯs!0w?Xi#{M5nsƹ e=HZ@gv!7fff䤈 9GSf^{>|H;ByYdʠIۯ]h[W^tY5 0K5dÓ. _?Nԋ"niVP2fs׆Gn+,Iꉏ;3A@4/4TC~lIB/7"&2-e%H:RY7v$sq{JVDދy8m4!J풤AX٧o4Q.HqLlE'*ɐXHc_GfJqz6%9[ݬ=?Wą51$^|֗/_aV&ץV5bFՕTnCJc,egqQaY Imp,W#JޚPRLТMF@NǺH$}nhhH-ӨDx/s '+,HMٳ0kZ6455m"vZh N;vs,uA0n$xkX܈X܀v'ȋ6ajO8Anܸ<tddDsr8hT_[}Ig ZTbxB[Ӵ<벢z"HJ3@9 ݾ}pN9bڎ+͔`4  T|,ƍh=k32Ϫ <{Vjk~޽[-Ãsr* Ţ-V^E]Csxs&h#P;@)r\p)O...~MtH$ ?J aPV2ڹ|2g .1-J(Gw|f}1,ߎ^&pA?VW+%)elvt"~T!GgޓfL ׋/Ԛ0٧|JEQGGggCڀY^^uoSA& Ћ|^ mANJr=Hn$y5½EV T$AP-|QP?@u}ɃFRBrP T i~Jp ptkR:Э|*2s~ foSz>R7 񦯳剠wh@WWײWR p|l(*+d뛴% tnChN.PF|R -OތfUwЇro,zԩomr[ww>p~Fn{'-}W^9tvv+** _In㥥{y|Ss-q x9zUgo*xlllCm^c n?؇HrIENDB`mate-hud-22.10.3/usr/share/icons/hicolor/512x512/000077500000000000000000000000001431310724000207725ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/512x512/apps/000077500000000000000000000000001431310724000217355ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/512x512/apps/mate-hud.png000066400000000000000000000444501431310724000241560ustar00rootroot00000000000000PNG  IHDRxHIDATx{ǝߙ=/`0 b"HHIH.)iE:ݰn%[6|gaG7.vm^:–bmzW KVCDi)H$"00<tל~TweVgU~>b 뗕}YJ@P1D@N@x ($Xf(34b`,H1z3;wב1Iuf<*#06~ ߓHW?pB IY@{{A 031B Y>SLA[ #\tQz &zC utX8!ЮJDX. j~`J4I!`*g)oM=o2XRkd{`9WТ8^?;#\D(W{VTyƍ˗/Xp኎l6;_u׽AtsPe2}9s>/}.AfAp^4>Os^kW[Y}|>?8=5559s&t [@2-LpwCCC֭k .J]x˪opZ\83cXsssG.^xGFFF. A6-f8@L쫝.]馛6ު{u߬ؠHxxP(Ǟ7v޽wll,_%W; fJ/.ۯZj7QݳҁvuB0Z2;;7><<|qw"Y!v`SD UA֭?#mZ ̙3Oܹ*b pF0 zիWg{Ts3E&!B|o׮]fA"0k|^sR n b;q۶mʄ@ hhKU:?:?Bo\ ߩ" D_M֭[WZ_dYwPAdmzر?~7F-d LQ/%'?_P ~<_$M 3IШ- ̖-[[tK4 w8Ow~>h*@")ey?|{&*IE:sپ}!ߊc׻<޿UR鉉{_rIb w__ RϯYÇ+ a7BT%yoŋ_SW etvuu=E Z,AX&:%mړ-w}e˖=KҊqZEBP|>fffQmԥKR'J-ϋ/F獵C[5QC^{ -rrCޓ!?&Nʕ+?222rYΠ@elٲJq]ŋբE.WRp+ʊ_* Z;9ࢅQ?1+~f剉199Y<]>N>]<;V7vmdz>}#b c?|ƍүbLkF}PׯWk֬Q]>l7d@D:uJ Ϻ?.\{5;۷z߀m'ya ]0e@fݺug_M7ݤu-4LAk|DzeˊǍ7x08{:zhAp15555 #-rCB~,@߷K^`@}ݧ>򑏨~d DܹS[ڋ Se޽gDf͚/ 2!7~7ԃ>X| vVYtiزeK1Pm۶8apynذj13h_"9=׵L(I^1t7@$sI9&) _|ŭYjz̀k%_~>}& M&}sS?xG\r*v{lO>2}H8qB,%;>|"7y]ئ(ft7B_W<}:p؎xǸ\1yUTjPSߤ*֯_0}TAnf" у"볈Xv1˗/i-V^ 7I`}_V]wb;ہd/][Dnߨ0Jf]]]1u?0=b;^W^}Qcc壪acoN3 .$j~:vD;Q?UVԕ;f¨}cB4QYp؎vg$Yw}fn M #~A .D~jƍD!b;۝z,@$ȱ @/Qr+ #zݵz/Tr+i64jGV֨"; lwoݺZlU caB;ܤ viۈLvD;[e  0pm[lF9`Cfɒ%[M|l vD\ey lU&<[Xu\.w{ԋ5M}?۩6F6U j6`厀]KXp؎v}OOڴiSѝf&F dL #z= ބrO|!b;}Ԛ{\vdB]FJdp؎{@[ru*O+`M&n0p؎%KŋGL L?WO0lz˖-+Nb;ۓbl\kԕ{T2\nC\f p؎' Clю.0Z 򡄀f# w؏؎IBf7l b 3Tvl~lO2|mPXSݥOЬ ݉{lO:K.5Q6+{{{su:mYu]v b 8 S7mڴi,T__ʨ,)xp8@lc{6&>D ĿY$ zIDJOOJU}SKg[ǵ6~gggdGz ݙ^QE4_wXgOvl~lGF6]nu >A/5;;.]t(ynnN⿑Y/_7dv5Y]]]Pϓ,ϕzOЏUl=ZLUM`#7C) jrrR?^]pt. Rϵ'M _ԢEToo{( XjLO 3gԩS籱1uܹH@ZA|<&#Ʋ> YY\, 'NP:}4=@T 9:T|/˩˗h]ZE+$3[J @Iuauȑ&px׊) 6!zjĀ @7jFD4۷ħ)h;_edb/ˆ $#{Zn |"K-47\Elva+-uf䑚;v^x^ :ӾHI{tU+فRoO{@Rd 7iQCߛڥl|le~-Ld9z)?x nL*,,9V dZoD'gS'JHiL Ic[2d^~d*B=P+ ճ>k}O$"Q|ʴ`j`Yб.J ?f ijȘisZ&''i _EI `W [fY]VFM:hX/6 C###ꭷޢ54ɛoN80ԩ6)D}@V}Ӑh۶mK*1fZ1~Ӻ@LMM;w"~-ƭDY{z@e. {MiKP,< WҾ@0jR'| Q#nRN>>L0 x Z+avڕ6љJM& X;v `y$0;TKcvطo_<u ~<;B,qĭ `"!f*~9Ge__i D~5:D̻KAp9Bf %dk6<M<@~%bL,jWU7&l5q]W?@|$tP[![e%@$c@dme+9s挚EĄܤldh 9@0[CקH:###[t @!ett4ihc;+̆ȴsDŽN:EK@X$j Jŋjjj3ehJYfcaHTiܹs_O*$2ΠHE8^XewQE?&54 /P>!Npz>WyI(CYPk$ .PmB|!R<-|@LNNRt\Ey  {<>fff(6j&#B_iw, V/9T:Hxgi1177G!Y>V.q>`3 0ZE<6cH#ZiF ͱ}V@r3qMCra14[<L~ JE@011`2 G8 LW2nf\ZŃR? VrݝnH4PO3Z2-eDfc=*vv6ؘU_rG ߕzE5}iկn#DA}㍆~mw :Fh !bW2,Oο'$}?G_21@יhd! @gC A_F~f~}]Ҽg1P! _1^d42_ ew TR'0!!hi4I }55> {C}t/З4Dgԗ!qz!m@#Hjf#"}|Y;<FFC 2gh<H#p^8<O{:3y24* ہ{Klw'H%7#ڑp#(]7ہ{p#(X wWce- eiq~6?UV(GL\p}OOUL OO!p2"N pU ہ{N pU=^?pک"pe9=x }Oy @# ~{hÚ,^e>pݧ!Dm:G3%@Cv۴߇ @=v[=Úal1@TS$Q-ii>{2dp{a@;!4{ G=R؎p湔Ӹ+B+!AKl;ծ2 p߱?M>{H\E{<GcI{Cx}s8 |t[7?K#Sl5RA- 5 DVӍ@GA h^7c{_mY?7\7k Az@Z z@ڝ={lvOZPX{x'!j; -I:@Gԇ@ޓ@>=ݷ&p8@-c{tY[AЩTq'A?d:(g +Yn{˦mL1y!HةIg=[aM245?۱{p|h؞>ۓ(| 8X\1Kc;R>{2^϶mgڴ94\zK~UvHЧc;ĥ9qNU8Se~?c`#|Ei8lvun@ICc;r=.@o`Ҝ!>۱n"bI&vIl? AO@@q؎Hu0vlG$ Ux@FBc;#^ @e#!  ؏}d.m@c; w$@n^c;c3ʂJ6c }m @h(vO.؎mL*$8!c׶ljs!c{mOoK'vvK3dp؎^۞t֪54?cmOb;+:::zn"ت]{^ǏW3338277GKjڵV@UⅫ@]0am?U."E ;׫l5mSHq[|m>M~u1 /-j;_|Lׂ@:y=}Op"q]4$H%!ٜ) ~_`@EvHO'F&"\i}-@Ų ۀ g^G#xTKpL@if?  _'6BRs:vַUήS~,u=F~܏)6@ns{e>l.P*fIHV_9].M1sS]( c; SvpAΓ۞ @XZ?lsg)ٌ @* Ο͑ ﻕޓ c{L } I#&W ΟIͧ~U:?cIڞ:[G8V\8?!Ps!*B; ۱6om5JTL;i;Ƌ vJ g+B\уc;nKs?{&'T0s*Ļnf7AP}blX4\{Ƨ)姿cI $)'ջV %c}@+kM|@#;! -FB x'iר *P-i<@Axq˔d\! Mik6vg7PI-Pz @}Ϗq# , B;,[C~|S{'Tgggq>/ێc;c;# ٕ ؏]Z;؏؎STlvl~붓DRp8lvGP۱T]Sy'؎؎ޖyk `;c?c;x"VL^/ӵ8lvvHE%h?۱;vl~l纱.?۱ ^8lvvlOOV?۱;cC(  c?cx)|%2Y۱۱vl"M@ z> |CNU\.G#Զy| Gي5> |^9.W)2?>HlE1@# $\ER-L^/P}.>77K5%G /> =@ozC'36L㠷O<H8PT 9>8Zc @G >:? !߂4z~# qrK2] 2.#py$w~+B0;;K 8? :2ýv2w2@CvlXc{Oq؎iI M8@lvlo4 ${؏N' ؘ̒Ɓvlv8J۽G p؎؞Xm?Yh"xuvl~| 9-V_]&;cw2-VivFCvlLb_=+!K.=8vo Ɓzj?=qmG8rcld}?c{rl3NhE1 PLYYq؎߮N]s\ 2tӆ?55ev۩"-\5,lVn+vOLLуV>iۙKεFBT7cTbL,X`sq؎؟:[mꌙ9Oa?c{loƷ}  ؏Yp! jC.5>+{٢48?c{R>66(_x ٝ*]eCaF3}؞Μ9cmm(\n2񤳳g;v lO Gm=m"Z -iу@:56O=JV*-b۽p.]j$~ #z=LgKv0 -[fsel[ l?77(" >'af۳g=؞xm_|`m D$dlV[9 lFTk&ld1T> 2۷o=؞z/>V_vte}V7.l,b@߹s馛~K}_]> B,ZRݹS.y鴾k־{Ŋ:`& je%@ ^ښDAo޼$*@TJ2gcz-k|obbb}պm1]XەpNN71~VgժUw.gj"[?j @7m d&:phfתy6/im'-z`͟:u\[w&@4dVkuHY<3fm^|C{ƍwp# ,ngي044dd7>8%KӟmL 8 ?|pvv[k׮U-~oz饗sm^*XT|5k ;0:I!.`"ȿb^[{3m^,ٱcG,6m DMt:`"%JMRmM c=N _nS|6JrJ588l7x8O}Jvp3d||8ĉ$>V|mwkqEęcXǏWYP~oؿ}__X'"HtD%kuvToQm۶M]x1tR1' {Uׯgmr;^xq#MZ7 @) ЌhwEݩlbm~=FFFw~ŵ x2z?999R\?9[&ZkdnݪvkiF*e6l(- @,?~&go*%,XDaS2F@yV.u]wmiWRh@dɒbJf"Z@drfp:w\q1::ڶK=PAaZWbj, [IPz׋d]B((/^\|@q g2 𢡊^_\s#IbUoNMMۻK?=×bk"~[oM=40SIWS[x衇D\(9V-D!j\r!=9zzzrK3up2ٹC\ rIPCKae/f@#܈HTCCCr d'ZȣQlj[s> Z;RI~GզMhe=~0uA"ٸ6+ٳc&@V)ۯ Sf@uwe\ȞeiZPvZvz駋ks,#iyԯS:N~CA`c3E'Jcuoڱc{@>i{/ @Yg:Jߊ01v"Ov|W{x$ Ї>Tl ߭2 @ |>)GbDlٲE_WGؾLpg}[,}L좔_:qYo}8R2O^ [KۘPZ"ac@R5-[>яSNKa<$Kʦ+VP 6j1 8* DI$9BGM=zT{ĉŧX\L!~\lo.)~C4̙3QtFTP@}Q{QWPJcƂ n9- 9K%+.JAb``@ ˗i]uؙ @bOGJ_΢J\hCLJqrȳRrݫG//<5ҨgQ)v@2_Q4ϕ6!K׽@U" "dTWs=f&pV*Y ʵ]kT:Ux) /?:[,N>Gv?25*Swk"7r:GAF"B)܆o٥otߓȓ]4lքƅ tp4gHc6O~mc;?YmBLMM WP!)% h8@?zIbdd$g_[C3(.@1qNșzk Q}t؎x_㸲 MP2 q؎؎dI썐ة rzbfffo }d[c;c?$Y(Bv;gQS2j*^mD kd۴9v=ON<@oR^BTvލv?S!;v,ZZL;GFF&Efj= X8na_W8@lc;={E[#A+/ *.L{n+8lރHۻwoϘ4c0`vvը@Ν;q؎v=8ͮ]d%H!Kt_tUe@S/6OS zN /D fB;'b۷>\z$v=@9k3$V8DoI *zAcvu'b;۩$"o=+RP_o @3D._QQvء>b;)ۧ~_D +uV'-hcf2sFBv=)dտo|cS)F?? @3jc׮]{tF]QGqNvpo~F6c Q'Fa0 /ɓ'q8@lc;~Z=?Gb|ܮ\PbcA-!0;;dIDE?uE?۩mA-#U333?PV1fv<  H${lXygx~^G\SjLֽ`ԍl6r\B+ Ԃ p8@loޛCOH_zꩧ}I:$QhZWUĀd+VmYP4sΩ_|Q\R]7Q(`~[}k_e￴t>ɓ'Uk=vz[w:<9qn7g~7u%a{sXigttT}V/ϞQtgc-ypJڐ@'GAf͚\>tvvmO.f1Aa tttv{i=zeرc?__i2vWʂ~^wʹfJLy@ M6mXn˕n~+΍4۞ le=m۶CY.^:2A~޽w>W_hW `^\^ĉc7n.H2qT9drԊ+.2@ 8@l~l"GgΜ)ƆY'VE_yuu겷h@gJu-ڡiԋ-RdkAtRl2dɒYDŋ?ˀlw=@RZ\el\2N.R2+=9 X'ge v(?Bx^Kx?WMf{{Ǐ_~uI ZcJ{z "a (Xpa\z-吿/,\~}lȪ:ಙH`S^<+c)Z;J~}j^ǽK4S*~:S')ea @YO,y?ӕE%|WaP>"<3R^>R^Qč4v"U]IbZ/Mz(l0  =qme|[)( rԿ|ϝ;wPj #d ?S#+"U^)~H"v07mdda׮] J$p>S>&WߡPo:7C+6; P\z9} k֬7+$)n 03@]0R<,\>^tғ|̙3Sq_h"7-L%T硡+W\.O &=??~'NUW?Tε0%@+===_=Ղ6-nR0555A_9_N0!Z*@8wGwwlz-^xR/~nPxGw_;paU}jР_m ["PU@kUE\]wݚ  \ٹ^WZ ,`}Яf/|N/=#M3t&_ B>ҾuV2)O~zrr訜/+UՂ~(;%ZZC~4}hδ!sDz۷HF^_y|5ʄ]P}]蹗>7_}U\XK4'aQ \.RyO({U#p :QMZ!J=͈jYT A =0V . YJ"u!l_pca{Ĺ*TB|RRA/4?MP`<Tf}f>hB$4owg\a~Z L`NTIHH h&|f@ZaD TF v%ৣH!yA$R/L|Ӂ?f)F=hok@@;#( ^x+B^;@[?l7a2?" f@-1PO)p=y w;Q1xS2.p pg{!fNBfp2H߽6$oX sowqAx JGG)tɽ(1:H/7P~ PCWT)QJ=ßd2(N7344СCoS<&7$ @q۴iY-vRG}}}${(//xb)@7WP(ܐffms' tՂ`~]`]ǴE)<ӟ\?S|>gyf?E#lG ASO=@@ yVFK\Ii@Н-O<1x#t:jP(Hgd2׹P-|_$@Z^& W|R@@x"_4i}\G1@{Y%iGYX‘\F1 AM)@3 @`\.7G)@X2 >igL pi);c?OA3JBS)"}R|" E>t%5x'Gqb*A(wg2/ꗳ!>z]?(طoߞ͛7oJ%f?_0S>OvwwK6q}ܨU 7 c>333SO˖"CIENDB`mate-hud-22.10.3/usr/share/icons/hicolor/64x64/000077500000000000000000000000001431310724000206365ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/64x64/apps/000077500000000000000000000000001431310724000216015ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/64x64/apps/mate-hud.png000066400000000000000000000043661431310724000240240ustar00rootroot00000000000000PNG  IHDR@@iqIDATx[[L\E]^X.rk5PHEb&Ҙė苏}oo>Dh}h I# i#6mY۲Üs\$'23g6sC4\Ǵ1UUUnnOpLJJrE77772^ym~~ݻwG |Rccg7m6{?x,0mllGXXpƓN>}fߴ}!*uɓ']. ??8q$}-A#!j6+[ Muz\B yZ^FUehŋ r9t: L1m\p !OȣJ8455Y<Fv:XkT:ꩁg > =xz-aZgKyy9Tl0ET_4\]]% `PȐ6@?[ʥ OQQ2٪ {Ie/4ڕL N.*QxzA)XIgg'%uuu6{9c @,lhU\u2ЇCyt%Z8d07K4mؔ\Zp8oD"Im jh?1O ey\oMU%& 0*2 v}}}5Ҭt]Z ?Y2%_#ڠ&-ʸQ/1 B+H܇qe!`T̲3j[5`,Ei!g(P(0hFܠ¸V[{=OH(2# gr.9t~ cbiLIIvBԑz˂$##+MA-q Ǫ ][}`aϜ)Y0aX.j;[oĖy?u~GoÄL|b'l^'ESg ΰ%IeD$HD>7CGvd?@DjFm$ӫ" =dlf?"aj\41B*PC|`ܒ՗&/y}gT@t? 3=l lD*Loiy%W⋚MQ+lAyvde:khYiPfِ 𾨰,..W_Zw1_tBPIL?W i^"K|dɖX+;KHeSbT8ʓ %X~Io%'Ќ5Ɗg+W$>"<Fygl:.gF@rqdbbۍIGT*fI򜍆syF8aIDATx][L>5m84LHlJ-R$RݪiD}"U}i*SۧnU%RHy*nڭ#Ɩ[ ũ/8@;s[? Ù33g./=ssfҚćN P=M@} }z> d@l555ׯߴnݺ"A @8j<.v/?봼< 'oF;::;XE766>   |!KNF?>k2@233O޵_\x,|A+_\\yС?goP,S{{@T@ jhh8"vww_P~4.?_U `H$qVVm:C!q` $pH&b<5CS)L"/ZZZ"Qym&`CG&&&8Zs}@5 @A1;;<󤶶V^!=i0F'+Cv&|^RZ6//R믓-<~:u ҥK0b&YzW<-|doZ^zi;,[*o?+Y]]M=-x7{tR o߾@U/t@p;v!m~eP,ӷDd.DJ宼zL/)U9)U U/4| `ގW#y/wslL1h8222J Wﹹ܄E [ S1(EOA bA drmذH(`zzZv,+̇B~駤[@ +zjʶsNg(f &L=_E(T3Z}ҷ͛æ/y=ahu kU׮]#]]]TMZ͖]bhL^p o1c_ ݽ{WU 2 ]@ЊZ;w|q۷opiG_8HfDqAS bցO=x@N_$iqҳ@YeeݻwX7hA3 œP2[Jnt% WSǣG|IDX9*"mJ?IP5ºO.bQVVx|r+@KYb9U,aUZKP65lB;LNϿgLgqmȞq4Xϗ *!3B k"Sk̡`5Vr9F%]Y0t|f-uTB2#'^L(j窭F,c.e ɘZNvxn.U:hFO2a[j#` 2NBswRb% Lm|tJnNo5uT:tvZ.@Q 7d0nax0j E22x;un NVN`*TD^ G7kaUilf'MLjUI,'f Z.'Ó=%HV7Z=0ƃA*Ƒ,lDv}J. 3j{B8kj@nn. KeP;Stv`B!G= ֵ؄zcet_c;҂JRwA+}I4,d.C"MGwbxMlRZ$ֹkޮdx !(lI`U(_`&[NN(W!bM8Roߞ|\kk#.\PfPK?`fv #G|{\b~۶mbL,B8VLizęunmNƳ(g$Y@iUk,l AV/>;~*I~Xʓb[1V#Ipji|4p LIf53386/bPL@@p/>ĠLJI4>88Iii0#i'wI*AY[[۟1 P>(c)صk׶ @z RH>IߥOxl= 8 Y{{{d_V$#w':挂HUUQG@@Y'>9 4|@wApLBK2S_ B$jB 1џ?vXyQcGef=hO>!ڷۂT%L (I@l4к[n]tk4-3*–SMuB+ SVD(Q#1+t h$CPj;q!.qf   FO,C8 5N {,,C(樓,'V xx-0.)` CıS E"ݐSզ@נti 퐂>?1΅ủOp%hHzPx>M7_"!Nc ՗}2>b>`,  _IH;8p64</\g3~IENDB`mate-hud-22.10.3/usr/share/icons/hicolor/scalable/000077500000000000000000000000001431310724000216115ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/scalable/apps/000077500000000000000000000000001431310724000225545ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/icons/hicolor/scalable/apps/mate-hud.svg000066400000000000000000000166761431310724000250210ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/mate/000077500000000000000000000000001431310724000162175ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/mate/autostart/000077500000000000000000000000001431310724000202455ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/mate/autostart/mate-hud.desktop000066400000000000000000000002321431310724000233410ustar00rootroot00000000000000[Desktop Entry] Type=Application Name=MATE HUD Exec=/usr/lib/mate-hud/mate-hud NoDisplay=true StartupNotify=false Terminal=false X-MATE-Autostart-Delay=5 mate-hud-22.10.3/usr/share/pixmaps/000077500000000000000000000000001431310724000167525ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/pixmaps/mate-hud.svg000066400000000000000000000166761431310724000212170ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/rofi/000077500000000000000000000000001431310724000162305ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/rofi/themes/000077500000000000000000000000001431310724000175155ustar00rootroot00000000000000mate-hud-22.10.3/usr/share/rofi/themes/mate-hud-hidpi.rasi000066400000000000000000000035511431310724000232000ustar00rootroot00000000000000/** * mate-hud rofi theme * Incomplete theme designed to have certain properties applied at mate-hud runtime * Don't use this for anything else than mate-hud * Adapted by twa022 */ configuration { font: "Sans Regular 10"; display-ssh: ""; display-run: ""; display-drun: ""; display-window: ""; display-combi: ""; show-icons: true; } * { backlight: #ccffeedd; background-color: transparent; } window { location: north west; anchor: north west; width: 800px; transparency: "screenshot"; border: 0px; /* background-color: matched to GTK theme by mate-hud */ spacing: 0; children: [mainbox]; orientation: horizontal; margin: 24px 24px; font: "Sans Regular 10"; } mainbox { spacing: 0; children: [ inputbar, message, listview ]; } inputbar { /* text-color: matched to GTK theme by mate-hud */ padding: 22px; /* background-color: matched to GTK theme by mate-hud */ border: 2px; //border-radius: 6px 6px 0px 0px; /* border-color: matched to GTK theme by mate-hud */ } entry, prompt, case-indicator { text-font: inherit; text-color:inherit; } prompt { margin: 0px 0.3em 0em 0em ; } listview { padding: 16px; /* border-color: matched to GTK theme by mate-hud */ border: 0px 2px 2px 2px; /* background-color: matched to GTK theme by mate-hud */ dynamic: false; font: "Sans Regular 10"; } element { padding: 6px 0px; vertical-align: 0.5; background-color: transparent; /* text-color: matched to GTK theme by mate-hud */ } element selected.normal { /* background-color: matched to GTK theme by mate-hud */ /* text-color: matched to GTK theme by mate-hud */ } element-text, element-icon { background-color: inherit; text-color: inherit; } mate-hud-22.10.3/usr/share/rofi/themes/mate-hud-rounded-hidpi.rasi000066400000000000000000000037261431310724000246420ustar00rootroot00000000000000/** * mate-hud-rounded rofi theme (rounded corners) * Incomplete theme designed to have certain properties applied at mate-hud runtime * Don't use this for anything else than mate-hud * Adapted by twa022 */ configuration { font: "Sans Regular 10"; display-ssh: ""; display-run: ""; display-drun: ""; display-window: ""; display-combi: ""; show-icons: true; } * { backlight: #ccffeedd; background-color: transparent; } window { location: north west; anchor: north west; width: 800px; transparency: "screenshot"; border: 0px; border-radius: 12px; /* background-color: matched to GTK theme by mate-hud */ spacing: 0; children: [mainbox]; orientation: horizontal; margin: 24px 24px; font: "Sans Regular 10"; } mainbox { spacing: 0; children: [ inputbar, message, listview ]; } inputbar { /* text-color: matched to GTK theme by mate-hud */ padding: 22px; /* background-color: matched to GTK theme by mate-hud */ border: 2px; border-radius: 12px 12px 0px 0px; /* border-color: matched to GTK theme by mate-hud */ } entry, prompt, case-indicator { text-font: inherit; text-color:inherit; } prompt { margin: 0px 0.3em 0em 0em ; } listview { padding: 16px; border-radius: 0px 0px 12px 12px; /* border-color: matched to GTK theme by mate-hud */ border: 0px 2px 2px 2px; /* background-color: matched to GTK theme by mate-hud */ dynamic: false; font: "Sans Regular 10"; } element { padding: 6px; vertical-align: 0.5; border-radius: 8px; background-color: transparent; /* text-color: matched to GTK theme by mate-hud */ } element selected.normal { /* background-color: matched to GTK theme by mate-hud */ /* text-color: matched to GTK theme by mate-hud */ } element-text, element-icon { background-color: inherit; text-color: inherit; } mate-hud-22.10.3/usr/share/rofi/themes/mate-hud-rounded.rasi000066400000000000000000000037451431310724000235500ustar00rootroot00000000000000/** * mate-hud-rounded rofi theme (rounded corners) * Incomplete theme designed to have certain properties applied at mate-hud runtime * Don't use this for anything else than mate-hud * Adapted by twa022 */ configuration { font: "Sans Regular 10"; display-ssh: ""; display-run: ""; display-drun: ""; display-window: ""; display-combi: ""; show-icons: true; } * { backlight: #ccffeedd; background-color: transparent; } window { location: north west; anchor: north west; width: 400px; transparency: "screenshot"; //padding: 10px; border: 0px; border-radius: 6px; /* background-color: matched to GTK theme by mate-hud */ spacing: 0; children: [mainbox]; orientation: horizontal; margin: 12px 12px; font: "Sans Regular 10"; } mainbox { spacing: 0; children: [ inputbar, message, listview ]; } inputbar { /* text-color: matched to GTK theme by mate-hud */ padding: 11px; /* background-color: matched to GTK theme by mate-hud */ border: 1px; border-radius: 6px 6px 0px 0px; /* border-color: matched to GTK theme by mate-hud */ } entry, prompt, case-indicator { text-font: inherit; text-color:inherit; } prompt { margin: 0px 0.3em 0em 0em ; } listview { padding: 8px; border-radius: 0px 0px 6px 6px; /* border-color: matched to GTK theme by mate-hud */ border: 0px 1px 1px 1px; /* background-color: matched to GTK theme by mate-hud */ dynamic: false; font: "Sans Regular 10"; } element { padding: 3px; vertical-align: 0.5; border-radius: 4px; background-color: transparent; /* text-color: matched to GTK theme by mate-hud */ } element selected.normal { /* background-color: matched to GTK theme by mate-hud */ /* text-color: matched to GTK theme by mate-hud */ } element-text, element-icon { background-color: inherit; text-color: inherit; } mate-hud-22.10.3/usr/share/rofi/themes/mate-hud.rasi000066400000000000000000000035751431310724000221130ustar00rootroot00000000000000/** * mate-hud rofi theme * Incomplete theme designed to have certain properties applied at mate-hud runtime * Don't use this for anything else than mate-hud * Adapted by twa022 */ configuration { font: "Sans Regular 10"; display-ssh: ""; display-run: ""; display-drun: ""; display-window: ""; display-combi: ""; show-icons: true; } * { backlight: #ccffeedd; background-color: transparent; } window { location: north west; anchor: north west; width: 400px; transparency: "screenshot"; //padding: 10px; border: 0px; /* background-color: matched to GTK theme by mate-hud */ spacing: 0; children: [mainbox]; orientation: horizontal; margin: 12px 12px; font: "Sans Regular 10"; } mainbox { spacing: 0; children: [ inputbar, message, listview ]; } inputbar { /* text-color: matched to GTK theme by mate-hud */ padding: 11px; /* background-color: matched to GTK theme by mate-hud */ border: 1px; //border-radius: 6px 6px 0px 0px; /* border-color: matched to GTK theme by mate-hud */ } entry, prompt, case-indicator { text-font: inherit; text-color:inherit; } prompt { margin: 0px 0.3em 0em 0em ; } listview { padding: 8px; /* border-color: matched to GTK theme by mate-hud */ border: 0px 1px 1px 1px; /* background-color: matched to GTK theme by mate-hud */ dynamic: false; font: "Sans Regular 10"; } element { padding: 3px 0px; vertical-align: 0.5; background-color: transparent; /* text-color: matched to GTK theme by mate-hud */ } element selected.normal { /* background-color: matched to GTK theme by mate-hud */ /* text-color: matched to GTK theme by mate-hud */ } element-text, element-icon { background-color: inherit; text-color: inherit; }