Error getting D-Rats to first install - GUI Exception
KP4AJ opened this issue · 13 comments
Hi:
Being trying since last night. Get this:
09/24/2023 11:35:47:INFO:D-Rats:main: re-config option found -- Reconfigure D-rats
09/24/2023 11:35:47:INFO:D-Rats:main: args.config = /root/.d-rats-ev
09/24/2023 11:35:48:INFO:DratsConfig:File /root/.d-rats-ev/d-rats.config
09/24/2023 11:35:48:INFO:DratsConfig:/root/D-RATS Shared
09/24/2023 11:35:48:INFO:MainApp:_refresh_lang: Loading locale `en'
09/24/2023 11:35:48:INFO:MainApp:_refresh_lang: Locale dir is: /home/D-Rats/locale
09/24/2023 11:35:48:ERROR:MainApp:_refresh_lang: Messages catalog file missing for en. Need to use 'msgfmt tool to generate.
09/24/2023 11:35:48:INFO:MainApp:D-RATS v0.4.1.dev0 starting at Sun Sep 24 11:35:48 2023 on Platform UnixPlatform:
configuration: /root/.d-rats-ev
system_data: /home/D-Rats
OS version: Linux - Ubuntu 22.04.3 LTS
09/24/2023 11:35:50:INFO:D-Rats:---- GUI Exception ----
%s
---- End ----
Stack (most recent call last):
File "/home/D-Rats/d-rats.py", line 94, in handle_exception
MODULE_LOGGER.info("---- GUI Exception ----\n%s\n---- End ----\n",
Probably a missing library but no idea. Will appreciate any pointer. Calling D-Rats:
#sudo /usr/bin/python3 /home/D-Rats/d-rats.py
.d-rats-ev shows only a maps directory but no config.
Thanks.
Edfel
KP4AJ
The Linux install is similar to what is done on Microsoft Windows after Msys2, a Linux emulation product is installed.
Installation on Microsoft Windows Which states if you install from the git repository that the message catalog needs to be manually built and shows a simple script to rebuild it.
The README.md file in Master also specifies that the message catalog must be built, and references the WIKI Translating-D-Rats-in-your-language for a more complex way of creating the message catalog that the simple script that was developed since that Wiki page was written as part of creating python packaging.
The binary message catalog is intentionally not installed in the D-Rats repository.
Unfortunately it seems that the instructions to run build_pot.sh are not sufficient to generate needed mo files.
The only way to create the mo files currently is to run the python_prebuild.py, which requires having a virtualenv setup as per in the README.md
Fixed build_pot.sh for future PR:
#!/bin/bash
set -uex
# First create the base.pot file
xgettext -d D-RATS -o locale/base.pot -D . *.py
# Next directory - Because of an odd string in ax25 need to
# specify a --from-code
xgettext -d D-RATS -o locale/base.pot -j --from-code ISO-8859-15 d_rats/*.py
# Repeat for each directory
# Any warnings probably need to be looked at.
xgettext -d D-RATS -o locale/base.pot -j d_rats/map/*.py
xgettext -d D-RATS -o locale/base.pot -j d_rats/sessions/*.py
xgettext -d D-RATS -o locale/base.pot -j d_rats/ui/*.py
xgettext -d D-RATS -o locale/base.pot -j -L Glade ui/*.glade
for file_name in $(find locale -name '*.po'); do
locale_dir="$(dirname "$file_name")"
msgfmt -o "$locale_dir/D-RATS.mo" "$locale_dir/D-RATS"
done
Hi John:
Thanks. Here the result:
dminuser@emcommpr:/installs/GitHub/D-Rats$ sudo ./build_pot.sh
- xgettext -d D-RATS -o locale/base.pot -D . d-rats.py d-rats_repeater.py internationalization_test.py plugin_test.py python_prebuild.py setup.py
- xgettext -d D-RATS -o locale/base.pot -j --from-code ISO-8859-15 d_rats/agw.py d_rats/aprs_dprs.py d_rats/aprs_icons.py d_rats/ax25.py d_rats/callsigns.py d_rats/cap.py d_rats/comm.py d_rats/config.py d_rats/config_tips.py d_rats/crc_checksum.py d_rats/ddt2.py d_rats/debug.py d_rats/dplatform_generic.py d_rats/dplatform_macos.py d_rats/dplatform.py d_rats/dplatform_unix.py d_rats/dplatform_win32.py d_rats/dratsexception.py d_rats/emailgw.py d_rats/filenamebox.py d_rats/formbuilder.py d_rats/formgui.py d_rats/geocode_ui.py d_rats/gps.py d_rats/image.py d_rats/init.py d_rats/inputdialog.py d_rats/keyedlistwidget.py d_rats/latlonentry.py d_rats/listwidget.py d_rats/lzhuf.py d_rats/mailsrv.py d_rats/mainapp.py d_rats/mainwindow.py d_rats/map_source_editor.py d_rats/map_sources.py d_rats/menu_helpers.py d_rats/miscwidgets.py d_rats/msgrouting.py d_rats/pluginsrv.py d_rats/progressdialog.py d_rats/qst.py d_rats/reqobject.py d_rats/session_coordinator.py d_rats/sessionmgr.py d_rats/signals.py d_rats/spell.py d_rats/station_status.py d_rats/transport.py d_rats/treewidget.py d_rats/utils.py d_rats/version.py d_rats/wl2k.py d_rats/wu.py d_rats/yencode.py
- xgettext -d D-RATS -o locale/base.pot -j d_rats/map/init.py d_rats/map/mapbottompanel.py d_rats/map/mapdisplay.py d_rats/map/mapdraw.py d_rats/map/mapexception.py d_rats/map/mapmarkerlist.py d_rats/map/mapmenumodel.py d_rats/map/mappopupmodel.py d_rats/map/mapposition.py d_rats/map/mapstatusbox.py d_rats/map/maptile.py d_rats/map/mapwidget.py d_rats/map/mapwindow.py d_rats/map/mapzoomcontrols.py d_rats/map/markereditdialog.py d_rats/map/markerpopupmodel.py
- xgettext -d D-RATS -o locale/base.pot -j d_rats/sessions/base.py d_rats/sessions/chat.py d_rats/sessions/control.py d_rats/sessions/file.py d_rats/sessions/form.py d_rats/sessions/init.py d_rats/sessions/rpc.py d_rats/sessions/sniff.py d_rats/sessions/sock.py d_rats/sessions/stateful.py d_rats/sessions/stateless.py
- xgettext -d D-RATS -o locale/base.pot -j d_rats/ui/account_dialog.py d_rats/ui/conntest.py d_rats/ui/event_popup_model.py d_rats/ui/event_tab.py d_rats/ui/init.py d_rats/ui/main_chat.py d_rats/ui/main_common.py d_rats/ui/main_events.py d_rats/ui/main_files.py d_rats/ui/main_messages.py d_rats/ui/main_stations.py d_rats/ui/message_folder_info.py d_rats/ui/message_folders.py d_rats/ui/message_list.py d_rats/ui/message_popup_model.py d_rats/ui/station_popup_model.py d_rats/ui/test_message_popup_model.py
- xgettext -d D-RATS -o locale/base.pot -j -L Glade ui/addport.glade ui/mainwindow.glade
++ find locale -name '*.po' - for file_name in $(find locale -name '*.po')
++ dirname locale/de/LC_MESSAGES/D-RATS.po - locale_dir=locale/de/LC_MESSAGES
- msgfmt -o locale/de/LC_MESSAGES/D-RATS.mo locale/de/LC_MESSAGES/D-RATS
- for file_name in $(find locale -name '*.po')
++ dirname locale/nl/LC_MESSAGES/D-RATS.po - locale_dir=locale/nl/LC_MESSAGES
- msgfmt -o locale/nl/LC_MESSAGES/D-RATS.mo locale/nl/LC_MESSAGES/D-RATS
- for file_name in $(find locale -name '*.po')
++ dirname locale/es/LC_MESSAGES/D-RATS.po - locale_dir=locale/es/LC_MESSAGES
- msgfmt -o locale/es/LC_MESSAGES/D-RATS.mo locale/es/LC_MESSAGES/D-RATS
- for file_name in $(find locale -name '*.po')
++ dirname locale/it/LC_MESSAGES/D-RATS.po - locale_dir=locale/it/LC_MESSAGES
- msgfmt -o locale/it/LC_MESSAGES/D-RATS.mo locale/it/LC_MESSAGES/D-RATS
- for file_name in $(find locale -name '*.po')
++ dirname locale/en/LC_MESSAGES/D-RATS.po - locale_dir=locale/en/LC_MESSAGES
- msgfmt -o locale/en/LC_MESSAGES/D-RATS.mo locale/en/LC_MESSAGES/D-RATS
adminuser@emcommpr:/installs/GitHub/D-Rats$ cd locale
adminuser@emcommpr:/installs/GitHub/D-Rats/locale$ ls
base.pot de en es it nl
adminuser@emcommpr:/installs/GitHub/D-Rats/locale$ cd en
adminuser@emcommpr:/installs/GitHub/D-Rats/locale/en$ ls
LC_MESSAGES
adminuser@emcommpr:/installs/GitHub/D-Rats/locale/en$ cd LC_MESSAGES
adminuser@emcommpr:/installs/GitHub/D-Rats/locale/en/LC_MESSAGES$ ls
D-RATS.mo D-RATS.po
adminuser@emcommpr:/installs/GitHub/D-Rats/locale/en/LC_MESSAGES$ ls -
ls: cannot access '-': No such file or directory
adminuser@emcommpr:/installs/GitHub/D-Rats/locale/en/LC_MESSAGES$ ls -o
total 88
-rw-r--r-- 1 root 29470 sep 24 18:10 D-RATS.mo
-rw-r--r-- 1 root 56906 sep 24 18:06 D-RATS.po
adminuser@emcommpr:/installs/GitHub/D-Rats/locale/en/LC_MESSAGES$
The .mo file got created. However D-Rats still refuses to start.
dminuser@emcommpr:/installs/GitHub/D-Rats$ sudo ./d-rats.py
09/24/2023 18:20:48:INFO:D-Rats:main: re-config option found -- Reconfigure D-rats
09/24/2023 18:20:48:INFO:D-Rats:main: args.config = /root/.d-rats-ev
09/24/2023 18:20:48:INFO:DratsConfig:File /root/.d-rats-ev/d-rats.config
09/24/2023 18:20:48:INFO:DratsConfig:/root/D-RATS Shared
09/24/2023 18:20:48:INFO:MainApp:_refresh_lang: Loading locale `en'
09/24/2023 18:20:48:INFO:MainApp:_refresh_lang: Locale dir is: /installs/GitHub/D-Rats/locale
09/24/2023 18:20:48:INFO:MainApp:D-RATS v0.4.1.dev17-ga0b0c90-dirty starting at Sun Sep 24 18:20:48 2023 on Platform UnixPlatform:
configuration: /root/.d-rats-ev
system_data: /installs/GitHub/D-Rats
OS version: Linux - Ubuntu 22.04.3 LTS
09/24/2023 18:20:54:INFO:D-Rats:---- GUI Exception ----
%s
---- End ----
Stack (most recent call last):
File "/installs/GitHub/D-Rats/./d-rats.py", line 94, in handle_exception
MODULE_LOGGER.info("---- GUI Exception ----\n%s\n---- End ----\n",
same result if I invoke via /usr/bin/python3.10:
adminuser@emcommpr:/installs/GitHub/D-Rats$ sudo /usr/bin/python3.10 /installs/GitHub/D-Rats/d-rats.py
09/24/2023 18:22:22:INFO:D-Rats:main: re-config option found -- Reconfigure D-rats
09/24/2023 18:22:22:INFO:D-Rats:main: args.config = /root/.d-rats-ev
09/24/2023 18:22:22:INFO:DratsConfig:File /root/.d-rats-ev/d-rats.config
09/24/2023 18:22:22:INFO:DratsConfig:/root/D-RATS Shared
09/24/2023 18:22:22:INFO:MainApp:_refresh_lang: Loading locale `en'
09/24/2023 18:22:22:INFO:MainApp:_refresh_lang: Locale dir is: /installs/GitHub/D-Rats/locale
09/24/2023 18:22:22:INFO:MainApp:D-RATS v0.4.1.dev17-ga0b0c90-dirty starting at Sun Sep 24 18:22:22 2023 on Platform UnixPlatform:
configuration: /root/.d-rats-ev
system_data: /installs/GitHub/D-Rats
OS version: Linux - Ubuntu 22.04.3 LTS
09/24/2023 18:22:26:INFO:D-Rats:---- GUI Exception ----
%s
---- End ----
Stack (most recent call last):
File "/installs/GitHub/D-Rats/d-rats.py", line 94, in handle_exception
MODULE_LOGGER.info("---- GUI Exception ----\n%s\n---- End ----\n",
adminuser@emcommpr:/installs/GitHub/D-Rats$
Thanks for your help!
Edfel
09/24/2023 18:20:48:INFO:MainApp:_refresh_lang: Locale dir is: /installs/GitHub/D-Rats/locale
09/24/2023 18:20:48:INFO:MainApp:D-RATS v0.4.1.dev17-ga0b0c90-dirty starting at Sun Sep 24 18:20:48 2023 on Platform UnixPlatform:
configuration: /root/.d-rats-ev
system_data: /installs/GitHub/D-Rats
Unfortunately the feature of D-Rats of putting up the GUI exception means that the information needed to diaglose the problem is only in the GUI popup in a section that must b expanded. None of that critical information makes it into the message log.
Nothing in d-rats or the d-rats repeater requires root privileges.
It is an extremely unsafe practice to use the root account for anything other than system maintenance.
Running d-rats or d-rats_repeater from root will not be allowed in a future update to d-rats.
Roger that John! Thanks for looking at this. Will re-check my setup. Appreciated.
73'
Edfel
KP4AJ
John:
Not sure if this could help:
Traceback (most recent call last):
File "/installs/GitHub/D-Rats/./d-rats.py", line 250, in
main()
File "/installs/GitHub/D-Rats/./d-rats.py", line 228, in main
app = mainapp.MainApp(safe=args.safe)
File "/installs/GitHub/D-Rats/d_rats/mainapp.py", line 380, in init
if not self.config.show():
File "/installs/GitHub/D-Rats/d_rats/config.py", line 2720, in show
drats_ui = DratsConfigUI(self, parent)
File "/installs/GitHub/D-Rats/d_rats/config.py", line 2530, in init
self.build_ui()
File "/installs/GitHub/D-Rats/d_rats/config.py", line 2616, in build_ui
add_panel(DratsGPSPanel, "gps", _("GPS config"), prefs, self)
File "/installs/GitHub/D-Rats/d_rats/config.py", line 2591, in add_panel
panel = c_arg(self.config, *args)
File "/installs/GitHub/D-Rats/d_rats/config.py", line 1403, in init
dprs_code = dprs_info['code']
KeyError: 'code'
73'
Edfel
John:
Changed folder permissions and executed from user 'adminuser' (no sudo). Per the build_pot.sh fix .mo file was created and at locale/en/LC_MESSAGES dir:
adminuser@emcommpr:/home/D-Rats$ ./d-rats.py
09/25/2023 12:44:32:INFO:D-Rats:main: re-config option found -- Reconfigure D-rats
09/25/2023 12:44:32:INFO:D-Rats:main: args.config = /home/adminuser/.d-rats-ev
09/25/2023 12:44:32:INFO:DratsConfig:File /home/adminuser/.d-rats-ev/d-rats.config
09/25/2023 12:44:32:INFO:DratsConfig:/home/adminuser/D-RATS Shared
09/25/2023 12:44:32:INFO:MainApp:_refresh_lang: Loading locale `en'
09/25/2023 12:44:32:INFO:MainApp:_refresh_lang: Locale dir is: /home/D-Rats/locale
09/25/2023 12:44:32:INFO:MainApp:D-RATS v0.4.1.dev17 starting at Mon Sep 25 12:44:32 2023 on Platform UnixPlatform:
configuration: /home/adminuser/.d-rats-ev
system_data: /home/D-Rats
OS version: Linux - Ubuntu 22.04.3 LTS
09/25/2023 12:44:36:INFO:D-Rats:---- GUI Exception ----
%s
---- End ----
Stack (most recent call last):
File "/home/D-Rats/./d-rats.py", line 94, in handle_exception
MODULE_LOGGER.info("---- GUI Exception ----\n%s\n---- End ----\n",
This is a Ubuntu Laptop with GtK3 installed.
Edfel
Click ignore the ignore or similar button on the error popup when it comes up, it is not fatal, and is only present at the current tip of the master branch.
Then go into the Preferences menu, GPS Config, and Edit a new Default GPS Comment. The edit button forces the Default GPS comment to be in a valid format now. In the past the default value of the Default GPS comment was not a valid GPS comment.
This will be fixed in a future PR.
John, it causes a crash, program closes after pressing ignore or ignore all. No access to go into Preferences. Maybe a manual cp of a config file into the directory could work. But my interest is help make it work without manual work around.
Very appreciated your work with D-Rats.
Edfel
KP4AJ
Inside of ~/.d-rats-ev/d-rats.config find the line that starts with "default_gps_comment =".
First save what is in there now line and add that to the ticket with double quotes around the paste.
This string I know should not crash if put in the file exactly:
default_gps_comment = LY MY HOME2*58
The "LY" is for the DPRS icon of a house with beam antenna on it, the *58 is a checksum for the text up to that point.
D-Rats has always required that string to have a valid 2 letter DPRS code and a valid checksum, it just did not always visibly report the configuration error. What D-RATS was previously not aware is that the some DPRS codes can actually have 3 characters, where the 3rd character is optional.
That should allow D-Rats to start so that you can use the EDIT button in preferences as above to modify the text and icon in the message.
This is from a different branch than master, so the line numbers might not be right. I is unlikely that I will get the pull request that will include this fix ready before at least next week.
diff --git a/d_rats/config.py b/d_rats/config.py
index 9fd5b73..ee287f1 100755
--- a/d_rats/config.py
+++ b/d_rats/config.py
@@ -1386,23 +1386,27 @@ class DratsGPSPanel(DratsPanel):
config.set("settings", "default_gps_comment", dprs)
val.child_widget.set_text(dprs)
dprs_info = APRSicons.parse_dprs_message(text=dprs)
- dprs_code = dprs_info['code']
- if 'overlay' in dprs_info:
- dprs_code = dprs_info['code'] + dprs_info['overlay']
- aprs_code = AprsDprsCodes.dprs_to_aprs(
- code=dprs_code,
- default=AprsDprsCodes.APRS_FALLBACK_CODE)
- pixbuf = APRSicons.get_icon(code=aprs_code)
- dprs_icon.set_from_pixbuf(pixbuf)
+ if 'code' in dprs_info:
+ dprs_code = dprs_info['code']
+ if 'overlay' in dprs_info:
+ dprs_code = dprs_info['code'] + dprs_info['overlay']
+ aprs_code = AprsDprsCodes.dprs_to_aprs(
+ code=dprs_code,
+ default=AprsDprsCodes.APRS_FALLBACK_CODE)
+ pixbuf = APRSicons.get_icon(code=aprs_code)
+ dprs_icon.set_from_pixbuf(pixbuf)
val = DratsConfigWidget(config, "settings", "default_gps_comment")
val.add_text(20)
val.set_sensitive(False)
dprs_comment = config.get("settings", "default_gps_comment")
dprs_info = APRSicons.parse_dprs_message(text=dprs_comment)
- dprs_code = dprs_info['code']
- if 'overlay' in dprs_info:
- dprs_code = dprs_info['code'] + dprs_info['overlay']
+ if 'code' in dprs_info:
+ dprs_code = dprs_info['code']
+ if 'overlay' in dprs_info:
+ if 'overlay' in dprs_info:
+ dprs_code = dprs_info['code'] + dprs_info['overlay']
+ else:
+ dprs_code = ' '
aprs_code = AprsDprsCodes.dprs_to_aprs(
code=dprs_code,
default=AprsDprsCodes.APRS_FALLBACK_CODE)
$ git diff d_rats/mainapp.py
diff --git a/d_rats/mainapp.py b/d_rats/mainapp.py
index bb8de57..7a80cf2 100755
--- a/d_rats/mainapp.py
+++ b/d_rats/mainapp.py
@@ -1186,7 +1186,7 @@ class MainApp(Gtk.Application):
fix.aprs_code = AprsDprsCodes.dprs_to_aprs(
code=dprs_code)
self.default_comment = comment
- except (NoOptionError, DPRSInvalidCode):
+ except (KeyError, NoOptionError, DPRSInvalidCode):
# silently fix this up. Notifications here at info level will
# flood the console log.
self.logger.debug("_refresh_location comment='%s'",
There will also be a patch to change the default string to one that will pass the checksum but this code just falls back to making up its own string if the value in the configuration file is bad quietly, which is pretty close the what the old behavior was.
Thanks John will test tomorrow after returning home from work.
Edfel
KP4AJ