Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Some settings changes do not stick #1235

Open
freecycler opened this issue May 16, 2023 · 14 comments
Open

Some settings changes do not stick #1235

freecycler opened this issue May 16, 2023 · 14 comments

Comments

@freecycler
Copy link

I'm using v0.5.6 Android build, installed from F-Droid on a Moto E6 running Pie. The device has limited internal storage (only 16GB) but I have added a 256GB SD card where I would like to store the maps and other bulky data.

I like to add to the default configuration so it can display my bookmarked locations on the map, which means adding a few lines to each layout file. I also adjust to use imperial units rather than metric, etc, which means adjusting some stuff in navit.xml.

Since the device is not rooted this seems problematic (the "custom map location" file picker will NOT offer me to choose any location that is not on the internal storage, and there does not seem to be a way to type in the desired path anymore like previous versions did, which kinda defeats the whole point of choosing a map location in the first place). And without root I can't see the default navit.xml or the layout files anywhere on the device, so I had to download the APK to my windows laptop and use 7-Zip to extract the "config" folder to find these files. Based on the device screen resolution I had to guess that the "xhdpi" folder would be the best fit, and used those files as a starting point for my edits.

I had to resort to moving things around using ADB and especially manual edits to navit.xml, so it is possible I've managed to mangle something in the process. Or ended up with some files that should have been on the sd card being in internal storage instead, or vice versa.

When I try to change some settings - for instance MainMenu->Settings->Rules->Northing, the icon for the item switches to the expected value (eg, from the green checkmark to the white X), but a second or two later it undoes the change and puts back the icon for the "old" state, undoing my change. The 2D<->3D toggle also seems to get stuck.

I'm guessing there is a file/folder permissions or ownership issue somewhere... can someone suggest what file or folder I should look for and where? Also what should be the correct setting and owner?

@gefin
Copy link
Contributor

gefin commented May 16, 2023

There are some automatic settings in navit.xml which overwrite your changes. You can use your own navit.xml to change this automatics.

I use /sdcard in the path tool to store maps and my own navit.xml internal.
try /storage/nnnn-nnnn/Android/data/org.navitproject.navit/files to use the card.

nnnn-nnn is the uuid of the filesystem.

@freecycler
Copy link
Author

I use /sdcard in the path tool to store maps and my own navit.xml internal.
try /storage/nnnn-nnnn/Android/data/org.navitproject.navit/files to use the card.

That's exactly the problem... while /sdcard is on the custom map location menu, /storage is not. So how can I choose it?

@gefin
Copy link
Contributor

gefin commented May 16, 2023

maybe your device use an other path.

I checked the path with adb shell.

mount
/dev/fuse on /storage/4DDA-23FE type fuse (rw,nosuid,nodev,noexec,noatime,user_id=1023,group_id=1023,default_permissions,allow_other)

Use your android an other path?
Navit should show the path even there is no access allowed.

@freecycler
Copy link
Author

freecycler commented May 17, 2023

Here is output from mount

/dev/root on / type ext4 (ro,seclabel,relatime,block_validity,delalloc,barrier,user_xattr)
tmpfs on /dev type tmpfs (rw,seclabel,nosuid,relatime,size=926908k,nr_inodes=122750,mode=755)
devpts on /dev/pts type devpts (rw,seclabel,relatime,mode=600,ptmxmode=000)
none on /dev/stune type cgroup (rw,nosuid,nodev,noexec,relatime,schedtune)
none on /dev/cpuctl type cgroup (rw,nosuid,nodev,noexec,relatime,cpu)
none on /dev/cpuset type cgroup (rw,nosuid,nodev,noexec,relatime,cpuset,noprefix,release_agent=/sbin/cpuset_release_agent)
cg2_bpf on /dev/cg2_bpf type cgroup2 (rw,nosuid,nodev,noexec,relatime)
adb on /dev/usb-ffs/adb type functionfs (rw,relatime)
proc on /proc type proc (rw,relatime,gid=3009,hidepid=2)
sysfs on /sys type sysfs (rw,seclabel,relatime)
selinuxfs on /sys/fs/selinux type selinuxfs (rw,relatime)
debugfs on /sys/kernel/debug type debugfs (rw,seclabel,relatime)
tracefs on /sys/kernel/debug/tracing type tracefs (rw,seclabel,relatime)
bpf on /sys/fs/bpf type bpf (rw,nosuid,nodev,noexec,relatime)
pstore on /sys/fs/pstore type pstore (rw,seclabel,nosuid,nodev,noexec,relatime)
tmpfs on /mnt type tmpfs (rw,seclabel,nosuid,nodev,noexec,relatime,size=926908k,nr_inodes=122750,mode=755,gid=1000)
/dev/block/bootdevice/by-name/persist on /mnt/vendor/persist type ext4 (rw,seclabel,nosuid,nodev,noatime,data=ordered)
/dev/block/bootdevice/by-name/persist2 on /mnt/product/persist type ext4 (rw,seclabel,nosuid,nodev,noatime,data=ordered)
/data/media on /mnt/runtime/default/emulated type sdcardfs (rw,nosuid,nodev,noexec,noatime,fsuid=1023,fsgid=1023,gid=1015,multiuser,mask=6,derive_gid,default_normal)
/data/media on /mnt/runtime/read/emulated type sdcardfs (rw,nosuid,nodev,noexec,noatime,fsuid=1023,fsgid=1023,gid=9997,multiuser,mask=23,derive_gid,default_normal)
/data/media on /mnt/runtime/write/emulated type sdcardfs (rw,nosuid,nodev,noexec,noatime,fsuid=1023,fsgid=1023,gid=9997,multiuser,mask=7,derive_gid,default_normal)
/dev/block/vold/public:179,65 on /mnt/media_rw/9C33-6BBD type exfat (rw,dirsync,nosuid,nodev,noexec,noatime,uid=1023,gid=1023,fmask=0007,dmask=0007,allow_utime=0020,namecase=0,errors=remount-ro)
/dev/block/vold/public:179,65 on /mnt/secure/asec type exfat (rw,dirsync,nosuid,nodev,noexec,noatime,uid=1023,gid=1023,fmask=0007,dmask=0007,allow_utime=0020,namecase=0,errors=remount-ro)
/mnt/media_rw/9C33-6BBD on /mnt/runtime/default/9C33-6BBD type sdcardfs (rw,nosuid,nodev,noexec,noatime,fsuid=1023,fsgid=1023,gid=1015,mask=6)
/mnt/media_rw/9C33-6BBD on /mnt/runtime/read/9C33-6BBD type sdcardfs (rw,nosuid,nodev,noexec,noatime,fsuid=1023,fsgid=1023,gid=9997,mask=18)
/mnt/media_rw/9C33-6BBD on /mnt/runtime/write/9C33-6BBD type sdcardfs (rw,nosuid,nodev,noexec,noatime,fsuid=1023,fsgid=1023,gid=9997,mask=18)
/dev/block/dm-1 on /vendor type ext4 (ro,seclabel,relatime,block_validity,discard,delalloc,barrier,user_xattr)
/dev/block/bootdevice/by-name/modem on /vendor/firmware_mnt type ext4 (ro,context=u:object_r:firmware_file:s0,nosuid,nodev,relatime,block_validity,delalloc,barrier,user_xattr)
/dev/block/bootdevice/by-name/dsp on /vendor/dsp type ext4 (ro,seclabel,nosuid,nodev,relatime,data=ordered)
/dev/block/bootdevice/by-name/fsg on /vendor/fsg type ext4 (ro,context=u:object_r:fsg_file:s0,nosuid,nodev,relatime,block_validity,delalloc,barrier,user_xattr)
none on /acct type cgroup (rw,nosuid,nodev,noexec,relatime,cpuacct)
none on /config type configfs (rw,nosuid,nodev,noexec,relatime)
/dev/block/bootdevice/by-name/userdata on /data type ext4 (rw,seclabel,nosuid,nodev,noatime,discard,nobarrier,noauto_da_alloc,resgid=1065,data=ordered)
/dev/block/bootdevice/by-name/cache on /cache type ext4 (rw,seclabel,nosuid,nodev,noatime,data=ordered)
/dev/block/dm-2 on /oem type ext4 (ro,context=u:object_r:oemfs:s0,nosuid,nodev,relatime,block_validity,delalloc,barrier,user_xattr)
tmpfs on /storage type tmpfs (rw,seclabel,nosuid,nodev,noexec,relatime,size=926908k,nr_inodes=122750,mode=755,gid=1000)
/data/media on /storage/emulated type sdcardfs (rw,nosuid,nodev,noexec,noatime,fsuid=1023,fsgid=1023,gid=9997,multiuser,mask=7,derive_gid,default_normal)
/mnt/media_rw/9C33-6BBD on /storage/9C33-6BBD type sdcardfs (rw,nosuid,nodev,noexec,noatime,fsuid=1023,fsgid=1023,gid=9997,mask=18)
tmpfs on /storage/self type tmpfs (rw,seclabel,nosuid,nodev,noexec,relatime,size=926908k,nr_inodes=122750,mode=755,gid=1000)

and the custom map location menu
Screenshot_20230516-193853

@freecycler
Copy link
Author

freecycler commented May 17, 2023

Ugh... give me a few minutes to see if I can clean up that formatting...

edit: sorry, it just won't format nicely

@gefin
Copy link
Contributor

gefin commented May 17, 2023

your screenshot shows the current directory is /mnt
Tap on "Up" then storage should be showed.

@freecycler
Copy link
Author

No such luck...
Screenshot_20230517-054026

I think my navit.xml is just being ignored and the hidden default one is still being used, along with ignoring my layout files in favor of the shipped ones too.

@gefin
Copy link
Contributor

gefin commented May 17, 2023

Which Android version use you?
My devices show the directorys in /
Grant you Storage access for navit?
Unfortunately I have no further ideas.

@freecycler
Copy link
Author

Which Android version use you?

Pie

Grant you Storage access for navit?

yes

thank you for trying to help.... annoying thing is this same version does work as expected on an older device running Lollipop, without all this nonsense. I might have to try an older version of Navit from before this file picker thing got added for this one device.

@gefin
Copy link
Contributor

gefin commented May 17, 2023

Get you access to this path?
/mnt/runtime/default/9C33-6BBD

@freecycler
Copy link
Author

No, it gets a brief popup message saying
"Path does not exist or cannot be read"
the message does not seem to allow screenshots either

@freecycler
Copy link
Author

freecycler commented May 18, 2023

I found sort of a workaround for some of this...

navit.xml and bookmark.txt must be on internal storage, at /storage/emulated/0/Android/data/org/navitproject.navit/files/navit , they cannot be moved to sdcard or the app will not find them

newbees should note the android naming system is confusing, the location /sdcard is NOT on the physical card, it is on internal storage

the paths $NAVIT_USER_DATADIR and $NAVIT_SHAREDIR can never include anything on the physical sd card, so an explicit path to the physical sd card must be specified inside navit.xml for both the maps and the layout files (if you do not want them to stay on internal storage)

eg, after the line <maps type="binfile" data="/sdcard/Download/osm_bbox_*.bin"/>
add:
<maps type="binfile" data="/storage/1234-ABCD/Android/data/org.navitproject.navit/files/navit/*.bin"/>

and above the line <xi:include href="$NAVIT_USER_DATADIR/navit/navit_layout_*.xml"/>
add:
<xi:include href="/storage/1234-ABCD/Android/data/org.navitproject.navit/files/navit/navit_layout_*.xml"/>

Optional extra if you want to see bookmarks on the map, you can also toggle visibility in layers w/this, after the above maps type=binfile line add:
<map type="textfile" data="/storage/emulated/0/Android/data/org.navitproject.navit/files/navit/bookmark.txt"/>
and after the mapset section but before the layer for found items also add (and provide a suitable .png image to use for the bookmark icon, copied into the specified location) add:

<layer name="bookmarks">
  <itemgra item_types="bookmark">
    <icon src="/path/to/png-file/somefile.png" w="64" h="64"/>
    <circle color="#009640" radius="0" width="0" x="10" y="10" text_size="27"/>
  </itemgra>
</layer>

sizes may need adjusting depending on your device screen resolution

this puts everything where I want and displays properly. The only hassle left is trying to download additional maps; the app still wants to put them on the internal storage and I cannot get the sd card to be selected for this, per screenshots in previous posts. I think the root of this problem is that the set map location is not doing the suitable SAF request, and I have no way to grant a permission it has never requested for this. My workaround is to use ADB or a teminal app to move downloaded maps from internal storage to the sd card manually. If the map is too big and I am really short of internal space to temporarily hold the download, this is not going to work, and I would have to download them to a PC and then use ADB to push the file, which might be a problem for users who do not have a PC. So I think there needs to be some improvement to how the "set custom map location" function works, to allow for using SAF mode.

Of course, it would be nice if the new wiki could add a section explaining about what items could be stored where and how to change the storage locations... there used to be forum threads about this in the now-lost forums, and more stuff in the old wiki that did not get transferred to the new wiki (maybe because some portions were out of date and needed updating first?)

As for the settings changes that do not stick, it turns out the Northing setting can be made to stick, but one must first toggle between autozoom and manual zoom, then it will stick. Even more confusing, it can be "stuck" in either enabled, or disabled mode, and only using the opposite auto/manual zoom setting will allow changing it again. This also seems to apply to the 2D/3D selection. I really don't understand the reasoning behind this, but it seems related to code in navit.xml where settings are conditional on autozoom. This also seems like something that should be explained in the wiki (if it is even intended behavior rather than an oversight that might be fixed in a future release).

@freecycler
Copy link
Author

your screenshot shows the current directory is /mnt Tap on "Up" then storage should be showed.

No such luck...

I later went and installed this on a few more devices. It seems that it is just the one device type that has this issue. A second sample of the original device (Moto E6 running Pie, one on MetroPCS, the other on T-Mobile) also behaves the same way, no real surprise there.

But I now also have 2 samples of Samsung S7 running Oreo (one on AT&T, the other on Straight Talk) that do allow choosing the custom map location as @gefin says; starting from /mnt and tapping Up lets me see available choices including the SD card, and everything seems to work as expected on both of these devices.

So, I'm not sure if the file picker problem is an Oreo vs Pie issue, or maybe Motorola vs Samsung issue.

@edd-cgfan
Copy link

Hi @freecycler,

Navit is successfully used here with Android Pie too.

/storage/emulated/0/Android/data/org/navitproject.navit/files/navit

That is too complicated thought:
Simply create a directory named "navit" (without quotes) under /storage/emulated/0/
Navit will find that directory and your navit.xml there if it is there.

Also, on external sd-card:

data="/storage/1234-ABCD/Android/data/org.navitproject.navit/files/navit/*.bin"

You could simply use /storage/1234-ABCD/navit or other directory names and use them in your navit.xml.

For a more convenient work with the file system you could install the app "Total Commander" from Swiss author C. Ghisler from the Play Store.
It shows for example the access to the external sd-card:
Screenshot_20230612-205952_Total Commander_

Regards,
cgfan

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants