Bug #10241
openCopy and Paste issues on Linux in a minimal environment
100%
Description
Various documentation indicates that I should be able to read my radio, then import from CSV to replace part or all of the defined channels. I can find no "Import" anywhere in the interface.
CHIRP next-20230108 on Linux ozymandias 5.19.0-1-amd64 #1 SMP PREEMPT_DYNAMIC Debian 5.19.6-1 (2022-09-01) x86_64 (Python 3.10.7)
Files
Updated by Dan Smith about 2 years ago
- Status changed from New to Feedback
The import dialog is part of the legacy interface and is no longer present in CHIRP-next. The suggested workflow is to just open the CSV file directly and copy/paste between them, which is more flexible and less confusing for most people.
Can you point me at the doc that needs updating?
Updated by Dennis Boone about 2 years ago
These places specifically say something about an Import function, or mention 'File > Import':
https://chirp.danplanet.com/projects/chirp/wiki/Beginners_Guide in the last section
https://chirp.danplanet.com/projects/chirp/wiki/CSV_HowTo in the Clean Start and Getting The Data Back Into A Radio method #1 sections
https://chirp.danplanet.com/projects/chirp/wiki/FAQ in the Transferring data between radios - I have two different radios, how do I transfer data between them section
There are several other places that just say 'import' without implying how.
BTW, thanks to you and contributors for python3 support. I was pretty much unable to run Chirp any more in Debian due to python2 going away.
Updated by Dennis Boone about 2 years ago
I'm having trouble with the paste operation. I've got an updated CSV file that I intend to use to completely replace the contents of the radio. It contains about 430 lines of memory data. Should I be able to block copypasta that?
Updated by Dan Smith about 2 years ago
Yep, you should be able to paste that. What trouble? Attach the debug log or the console output if there's anything obvious. You could also attach your CSV file here and I can try to repro.
Updated by Dennis Boone about 2 years ago
- File vx7r.csv vx7r.csv added
- File drb_vx7r_pre20230108.img drb_vx7r_pre20230108.img added
- File log log added
It seems to replace parts of line 1 (prompts to overwrite it), and nothing else.
Updated by Dan Smith about 2 years ago
Okay, I was able to paste the memories from your csv into your img, with some exceptions. Your CSV file has some things like a Cross mode of tone/tone which the vx7 doesn't support, so you can't paste that in. Like memory #15. That is cross tone/tone but with the same 100.0Hz tone. That should be TSQL with ctone of 100.0. When I paste them all, I get a bunch of warnings memories are incompatible with the vx7, for reasons like that tone issue, and some others where you have 2.5kHz steps. You don't see those warnings?
I don't see any errors in your log related to the paste-ing, so I would expect it should have pastes most of the memories, except for the ones it can't.
Updated by Dennis Boone about 2 years ago
Ok, Cross vs TSQL I think I can trivially fix. (I'm converting a local format into Chirp-edible CSV.)
I'm not seeing errors about that during the copy/paste run, though. I do see some errors about invalid power levels, which are in the debug log too.
Updated by Dan Smith about 2 years ago
Weird, this is the error I see when I copy 15 from the csv and paste it into the vx7. You don't see that? Maybe there's a linux thing going on.
Updated by Dennis Boone about 2 years ago
- File stderr stderr added
- File 2023-01-08-162725_1920x1200_scrot.png 2023-01-08-162725_1920x1200_scrot.png added
- File 2023-01-08-162745_1920x1200_scrot.png 2023-01-08-162745_1920x1200_scrot.png added
Definitely no dialog boxes like yours. Using an updated CSV that doesn't set 2.5 deviation, and uses TSQL instead of Cross, messages from stderr attached. Also two screen shots: of the csv with #15 selected, and the img with the corresponding row selected and the "will overwrite" dialog box.
Updated by Dan Smith about 2 years ago
Are the two screenshots showing that you can paste that memory now with the TSQL fix? I'll try to repro the missing error boxes on linux...
Updated by Dan Smith about 2 years ago
Weird, it works fine for me on Linux (ubuntu 20.04, distro packages for everything).
Updated by Dennis Boone about 2 years ago
Even as a single line copy-paste, it still ends up not really pasting everything. The name and tone value are blank.
Updated by Dennis Boone about 2 years ago
Is the 'missing locale dir' message from the debug log at all relevant here?
Updated by Dan Smith about 2 years ago
Even as a single line copy-paste, it still ends up not really pasting everything. The name and tone value are blank.
Are you saying that's the case for any copy/paste or just one/some specific channels?
I can do this procedure:
- Open both your .img and your .csv
- Edit memory 15 in your CSV to be TSQL/100.0
- Copy that line
- Switch to the .img, select memory 15, paste
- I get the "Overwrite?" dialog, click Yes
- Observe that memory 15 in the VX-7 img file has the same name (Dmndl), frequency (442.050)
I'm just noticing that the VX-7 driver isn't exposing has_ctone so that column is missing, which is maybe part of the confusion? But I definitely see the name...
No, the missing locale dir message is not relevant.
Updated by Dennis Boone about 2 years ago
The behavior seems the same whether I select one record or a large block. Select, copy, select, paste, I get the overwrite dialog and an incomplete copy. Results in the img file attached. (Note that I pasted into 11, the corresponding entry, rather than 15, but I don't think that should matter.)
Also attaching the updated CSV file that doesn't have the Cross/2.5 problems.
Updated by Dan Smith about 2 years ago
But are you copying 15 from the source file? I'm trying to narrow down the inputs here so I need to make sure we're looking at the same thing.
The "missing" tone thing is definitely a bug, but only in the display. I think that after you do the paste if you right click->properties, you'll see the tone is set. For that matter, can you check on the name as well?
I can't think of any reason the name wouldn't copy, especially since it does fine for me.
Just FYI, the paste operation is doing exactly the same code that import would loop through before - that part of the code hasn't changed in a looong time.
Updated by Dennis Boone about 2 years ago
- File properties.png properties.png added
Sorry, I keep leaving bits out of my description.
If I do this as a single line copy-paste:
Select 15 in revised csv. Copy. Select 11 in img. Paste. Get overwrite dialog, click yes. Results: tone and name are missing or wrong. Tmode and tuning step change to the values from the CSV. Power changes to L1.
If I do this as a block copy-paste:
Select row 1 in CSV (CSV comes in with a "0" record that's blank, for whatever reason). Shift-page/cursor down to include everything through 437. Copy. Select row 1 in img. Shift-page/cursor down to include everything through 437. Paste. Get overwrite dialog, click yes. Results: in row 1, missing tone and name, power changed to L1, no other entries appear to have been touched, only 255 entries exist.
Properties dialog screenshot from img file after single-row paste is attached.
Updated by Dan Smith about 2 years ago
Select 15 in revised csv. Copy. Select 11 in img. Paste. Get overwrite dialog, click yes. Results: tone and name are missing or wrong. Tmode and tuning step change to the values from the CSV. Power changes to L1.
Okay, the tone thing will be fixed as part of #10244 . I totally cannot reproduce your missing name thing, and from the post-paste properties screenshot, it looks like the tone isn't updated either, which I also cannot reproduce.
If I do this as a block copy-paste:
Select row 1 in CSV (CSV comes in with a "0" record that's blank, for whatever reason).
Because CSV files' memories start at zero like many other non-Yaesu radios.
Shift-page/cursor down to include everything through 437. Copy. Select row 1 in img. Shift-page/cursor down to include everything through 437. Paste. Get overwrite dialog, click yes. Results: in row 1, missing tone and name, power changed to L1, no other entries appear to have been touched, only 255 entries exist.
I wonder if whatever is preventing you from getting the dialog about the unsupported memories is related here. The partial single-line paste, and the only-trying-the-first-row thing ... maybe it's choking on displaying that box and not going further or something. I see you're running against wxPython 4.2.0, and you installed from the wheel right? Where is your wxpython coming from? Do you have python3-wxgtk*
installed via debian packages, or something from pip?
Updated by Dennis Boone about 2 years ago
Looking at the METADATA file in the wheel, there's:
Requires-Dist: importlib-resources ; python_version < "3.10"
but python is:
Python 3.10.7 (main, Sep 8 2022, 14:34:29) [GCC 12.2.0] on linux
Also, I don't seem to have importlib-resources installed. Any of this relevant here?
Updated by Dan Smith about 2 years ago
Dennis Boone wrote in #note-19:
Looking at the METADATA file in the wheel, there's:
Requires-Dist: importlib-resources ; python_version < "3.10"
but python is:
Python 3.10.7 (main, Sep 8 2022, 14:34:29) [GCC 12.2.0] on linux
Also, I don't seem to have importlib-resources installed. Any of this relevant here?
No, importlib-resources is required for pythons older than 3.10. You have 3.10 so you don't need (or want) it installed.
Updated by Dennis Boone about 2 years ago
Versions of stuff from pip:
requests 2.27.1
six 1.16.0
future 0.18.2
yattag 1.15.0
wxPython 4.2.0
I downloaded the .whl file earlier today, and installed it with pip install chirp-next_20230108-py3-none-any.whl
. wxPython seems to have come in via pip. pyserial is 3.5, and came in via apt. Python3 itself came in via apt also. python3-wxgtk4.0 via apt.
Updated by Dan Smith about 2 years ago
Can you uninstall wxpython via pip? What's the version of python3-wxgtk4.0 in apt? Hoping it's 4.0.7ish.
Updated by Dennis Boone about 2 years ago
Hmm, not sure what's going on with the pip-listed wxPython. When I tried to have pip remove it, it grumbled about it being outside /usr.
Here's the apt line for python3-wxgtk4.0 -- newer than 4.0.7:
ii python3-wxgtk4.0 4.2.0+dfsg-1 amd64 Python 3 interface to the wxWidgets Cross-platform C++ GUI toolkit
Updated by Dennis Boone about 2 years ago
It might be useful to note here that this box runs Debian Sid.
Updated by Dennis Boone about 2 years ago
Arrrrgh, in the process of removing and re-installing the apt-provided python3-wxgtk4.0 package, I had to remove a bunch of stuff with interlocking dependencies, and when I reinstalled the ones I cared about, I got a python3 upgrade to 3.11.1.
Updated by Dan Smith about 2 years ago
Okay, but does that mean you got the pip-installed wxpython uninstalled or not?
You can tell where your wx is coming from with:
$ python
import wx
print(wx.__file__)
We run 4.2.0 on macos and Windows, so I would expect that's fine. However, both of my linux test boxes provide 4.0.7. Just looking for differences that might explain how or why you'd not be getting the incompatible dialog box, if that's even the problem. Running with the distro package for wxpython would definitely be my suggestion for minimal problems.
I've done no testing on python 3.11, although I know it has broken things for other projects .. so not sure if that will help or hurt.
Updated by Dennis Boone about 2 years ago
ozymandias 62 # python
Python 3.11.1 (main, Dec 31 2022, 10:23:59) [GCC 12.2.0] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import wx
>>> print(wx.__file__)
/usr/lib/python3/dist-packages/wx/__init__.py
>>>
ozymandias 63 # dpkg -L python3-wxgtk4.0
/.
/usr
/usr/lib
/usr/lib/python3
/usr/lib/python3/dist-packages
/usr/lib/python3/dist-packages/wx
/usr/lib/python3/dist-packages/wx/__init__.py
/usr/lib/python3/dist-packages/wx/__version__.py
/usr/lib/python3/dist-packages/wx/_adv.cpython-310-x86_64-linux-gnu.so
...
I'm now getting an "unknown file format" dialog trying to open the CSV, so I'll have to explicitly use 3.10 for now. All of the package wrangling hasn't changed the behavior, though.
Updated by Dennis Boone about 2 years ago
I think pip is seeing the apt-installed stuff, partially.
ozymandias 306 # pip show -f wxPython
Name: wxPython
Version: 4.2.0
Summary: Cross platform GUI toolkit for Python, "Phoenix" version
Home-page: http://wxPython.org/
Author: Robin Dunn
Author-email: robin@alldunn.com
License: wxWindows Library License (https://opensource.org/licenses/wxwindows.php)
Location: /usr/lib/python3/dist-packages
Requires:
Required-by:
Files:
Cannot locate RECORD or installed-files.txt
Updated by Dan Smith about 2 years ago
I'm now getting an "unknown file format" dialog trying to open the CSV, so I'll have to explicitly use 3.10 for now.
Um, that would be extremely surprising if that were a 3.11 thing...
All of the package wrangling hasn't changed the behavior, though.
Okay, well, I'm not sure what else to try since I can't reproduce any of that locally. I've queued an extra log statement for tomorrow's build that you could try to patch in if you want:
https://github.com/kk7ds/chirp/pull/367/commits/400ec735a9c82b25094543348da660ebbffcbd14
Which will expose the paste errors to the log (stderr) so we can see them even if the dialog isn't being shown. However, reviewing the code in the paste routine there, it will try to paste everything and then just report the errors in one step, so that pretty much shoots my idea that failure to show the dialog was stopping it short. Certainly the half paste of a single row doesn't follow that reasoning anyway, since the underlying operation is an atomic set_memory() to the driver, which the UI repopulates from after refresh.
Updated by Dennis Boone about 2 years ago
Here's the debug log for a 3.11 run that experienced the CSV format error thing.
Updated by Dennis Boone about 2 years ago
I'll try the extra logging tomorrow. If you have any other suggestions as to tracing/debugging strategy, I can dig into them as well.
Updated by Dan Smith about 2 years ago
[2023-01-08 18:27:30,668] chirp.directory - ERROR: Radio class CSVRadio failed during detection: invalid mode: 'rU'
Looks like more "screw compatibility, break things in every version" from the python team :(
Updated by Dennis Boone about 2 years ago
I just tried CHIRP next-20230111. The weird CSV reading problem is gone. But the copypasta issue still exists.
Updated by Dennis Boone about 2 years ago
While I still don't know what is really going on here, after various CSV file changes, I did get Chirp to put up a dialog saying several hundred memories would be replaced, and the results seem to be rational. Maybe we walk away while the walking is good? :) Thanks for your assistance!
Updated by Dan Smith about 2 years ago
For what it's worth, I've spent hours trying to reproduce your results and have failed.
I was going to suggest that you try copy and paste between csv tabs to narrow down the problem to something VX7-driver-specific or a generic GUI problem.
I figure I'll have to wait until someone else reports a similar problem so I have another data point, because I'm pretty much out of ideas, sorry :(
Updated by Dan Smith about 2 years ago
I just had an idea. What desktop environment are you running? When you copy and paste, chirp sends two things to the clipboard: a rich data object for chirp-to-chirp copy/paste, and a text format for if you paste into another application. I wonder if your desktop environment's clipboard is only persisting the plaintext version?
Updated by Dennis Boone about 2 years ago
I just run a window manager, not a full blown gnome or kde sort of thing. I do have xclipboard running. I'll have to experiment with this a bit to see if I can cause the behavior to change.
Updated by Dan Smith about 2 years ago
- Subject changed from Import function missing to Copy and Paste issues on Linux in a minimal environment
Aha! I bet this is it. The text representation is not the full deal, so that would totally explain the difference. If you could start a full desktop instance just to test, that might be worth it.
I've been meaning to, but I'm going to change the title of this bug to more accurately represent where it has gone, if that's okay, since I think I scrubbed the import from the docs early on :)
Updated by Dennis Boone about 2 years ago
Yes, title change makes sense. I probably should have opened a second issue rather than just forging ahead.
I spent a few minutes playing with an alternate clipboard manager which will show me the content types, and I'm definitely getting just text/plain. Interestingly, the stuff which winds up in the clipboard is different for Ctrl-C ([146.010000/+0.600/67.0/69.3]) vs Edit menu/Copy (hundreds of lines, including all the empty rows, with sort of a columnar text version of the content items).
It'd take some work to spin up a full gnome desktop environment, but I'll do some more fiddling here.
What type is Chirp trying to use with the clipboard?
Updated by Dan Smith about 2 years ago
I spent a few minutes playing with an alternate clipboard manager which will show me the content types, and I'm definitely getting just text/plain. Interestingly, the stuff which winds up in the clipboard is different for Ctrl-C ([146.010000/+0.600/67.0/69.3]) vs Edit menu/Copy (hundreds of lines, including all the empty rows, with sort of a columnar text version of the content items).
Edit/Copy should (and does for me) only copy the selected rows. Perhaps there's a situation where you're selecting everything or have selected nothing and it grabs the whole sheet? I'll have to poke around there.
It'd take some work to spin up a full gnome desktop environment, but I'll do some more fiddling here.
Cool, well, sounds like we're onto something here then.
What type is Chirp trying to use with the clipboard?
Well, it's defined through wx, but I give it a mimetype of "x-chirp/memory-channel" but I dunno if that actually makes it to the clipboard like that.
Updated by Dennis Boone about 2 years ago
Edit/Copy should (and does for me) only copy the selected rows. Perhaps there's a situation where you're selecting everything or have selected nothing and it grabs the whole sheet? I'll have to poke around there.
I had done select-all (using the top left corner of the grid).
Well, it's defined through wx, but I give it a mimetype of "x-chirp/memory-channel" but I dunno if that actually makes it to the clipboard like that.
I wonder if it's about the type. I'll have to see if I can come up with a way to frob that a little.