|  07-17-2020, 01:18 PM | #1 | 
| Member  Posts: 10 Karma: 10 Join Date: Jul 2020 Device: Bookeen Cybook Odyssey 2013 | 
				
				File associations added without prompt; portable mode not honored.
			 
			
			Please, consider changing the way the program handles file associations under certain conditions and the way it behaves when you use the portable mode and expect all the components to conform to it. I never install anything unless pressed to the wall, so consider my scenarios: Scenario a): I take the .MSI installer, unpack it by running msiexec /a, launch the program, and Calibre decides that I need all those file associations added to my HKCU\*\Software\Classes. No prompt, no nothing. As Calibre is not advertised to the OS and is not installed, I have to weed them out manually if need be. Isn't it possible to add file associations dialog to the configuration master, so that we know what we subscribe to? Scenario b): I take the portable installer, unpack the program, run calibre-portable.exe -- OK, fine, nothing is added or changed. Then I somehow navigate to Calibre Portable\Calibre and launch calibre.exe from there. Guess what happens? I get the configuration master yet again, and even though I don't even finish it (as I press "Cancel"), I get everything added to the registry, to the AppData, and all those file associations. Isn't it possible to make *everything* under Calibre Portable\* aware of the fact that we're using the portable mode? | 
|   | 
|  07-18-2020, 12:18 AM | #2 | 
| creator of calibre            Posts: 45,598 Karma: 28548962 Join Date: Oct 2006 Location: Mumbai, India Device: Various | 
			
			thats how microsoft recommends applications inform the os of what files they are capable of handling. you dont like it complain to microsoft. and no, if you want to run calibre in portable mode, use calibre-portable.exe
		 | 
|   | 
|  07-18-2020, 02:59 AM | #3 | 
| Member  Posts: 10 Karma: 10 Join Date: Jul 2020 Device: Bookeen Cybook Odyssey 2013 | 
			
			Well, first of all it's not about what I personally want, really. I've just suggested a couple of scenarios to illustrate the point that the app could be made a bit more predictable in certain aspects. Where did I say that I don't like the way the app advertises its handling capabilities to the OS? I only said I'd prefer to be informed what the app is going to do, and have a choice to agree to that or not. One of those "do you want the app to register file associations" dialogs with a list to choose from. And it'd be nice to have that applied only once you've pressed "Finish": it doesn't even matter now if you cancel of finish the welcome wizard — you've run the app and here you go. So, the polite behaviour would be to display the dialog, register file associations once the welcome wizard was successfully run and not do anything if it was cancelled, given that you can always run it again. I've already figured out a somewhat cheesy but functional way to keep Calibre from doing that: Create an empty AppData\Roaming\calibre directory in your profile and put a dynamic.pickle.json file there with only the following before running the app for the first time: { "welcome_wizard_device": "cybook_odyssey (or whatever you have)", "welcome_wizard_was_run": true } No associations added, just the way I want it. That's essentially what I'd like to see if I cancel the welcome wizard. As for the portable mode, I just reported something that's not exactly the way one would expect a portable app to behave, and I'm somewhat perplexed by the answer. Let's say you want to run the ebook-viewer component directly in the portable mode. And all of a sudden the app is not so portable, writes its configuration files to your home directory and writes a bunch of settings to the registry. All of that with no warning whatsoever. It's not a question of what I or anyone else has to use, it's a question of how an app should behave — in a polite and predictable way. | 
|   | 
|  07-18-2020, 03:46 AM | #4 | 
| creator of calibre            Posts: 45,598 Karma: 28548962 Join Date: Oct 2006 Location: Mumbai, India Device: Various | 
			
			the welcome wizard does not add associations. and no i am not going to prompt millions of people about calibre doing something that it is supposed to be doing just because YOU deem it to be the polite thing to do. I am really fed up of people that think that their particular preferences are gospel. And again, you want portable behavior, use the portable exe. You want to run other exes by themselves setup the needed env vars yourself. You dont get to claim that you do something unsupported and then claim the resulting behavior is rude. This will be my last response to you, good luck. | 
|   | 
|  07-18-2020, 05:09 AM | #5 | 
| Member  Posts: 10 Karma: 10 Join Date: Jul 2020 Device: Bookeen Cybook Odyssey 2013 | 
			
			Yup, my cheesy dynamic.pickle.json thingy didn't even affect anything, so that one was off-target. I thought there was a setting or a command-line switch to control that, but there doesn't seem to be. Particular preferences are gospel? Erm, whatever. All the best. | 
|   | 
|  07-18-2020, 02:36 PM | #6 | 
| Member  Posts: 10 Karma: 10 Join Date: Jul 2020 Device: Bookeen Cybook Odyssey 2013 | 
			
			I've been to the beta section, and I'm sorry you hurt your back and I sincerely wish you a speedy recovery, but I still wonder, what was the point of answering me at all in the first place? OK, I've never used the app before and I didn't figure out at first that one had to look for app settings in — of all things — the environment variables section of the manual (which is an unconventional way of passing settings to an app, to be honest, compared to far more conventional configuration files). I didn't claim that something is "rude" — the idea of software politeness is, basically, predictability and explicitness where it counts, just to eliminate all those "What was that?" and "Why did that happen?" moments. And, just to conclude the thread and let bygones be bygones, a one-liner along the lines of "add the CALIBRE_NO_DEFAULT_PROGRAMS variable and assign it a value of 1; use calibre-debug --default-programs=unregister command to delete associations" would've been enough for both scenarios mentioned; just as ignoring the question/suggestion altogether would've been more useful than the way it turned out. | 
|   | 
|  07-21-2020, 04:07 PM | #7 | 
| Custom User Title            Posts: 11,329 Karma: 79528341 Join Date: Oct 2018 Location: Canada Device: Kobo Libra H2O, formerly Aura HD | 
			
			When the 4.xx viewer was still something of a work-in-progress (I was using the 3.48 portable viewer), I had to use Types to change the file class to something other than "calibreViewer.AssocFile.EPUB" to prevent the main installer from overwriting the association when I updated.
		 | 
|   | 
|  07-22-2020, 04:26 PM | #8 | 
| Member  Posts: 10 Karma: 10 Join Date: Jul 2020 Device: Bookeen Cybook Odyssey 2013 | 
			
			That's involved, but at least you had a reason to do that. I just run the program a couple of times without installing anything and then saw all those .azw, .pobi and .kobo, together with Windows going, like, "I was told there's a new program for your .chm's and .pdf's, which one do you want?" Anyway, I don't really care as long as there's a way to prevent that. What I still don't get is the Unix-inspired logic of using CALIBRE_NO_DEFAULT_PROGRAMS and other settings *only* as environment variables. It's not even that it feels a bit wierd on Windows, like, PROCESSOR_ARCHITECTURE=AMD64, NUMBER_OF_PROCESSORS=4, CALIBRE_NO_DEFAULT_PROGRAMS=1. It's more that it seems reasonable for the program to also be able to look for settings in some kind of 'calibre.ini' file under 'AppData\Roaming\calibre' (normal mode), 'Calibre\app\resources' (portable mode) or something along those lines. Also, in the portable mode, it could be used to eliminate the "if you want to run calibre in portable mode, use calibre-portable.exe" requirement. | 
|   | 
|  07-23-2020, 02:32 PM | #9 | |
| Bibliophagist            Posts: 47,971 Karma: 174315100 Join Date: Jul 2010 Location: Vancouver Device: Kobo Sage, Libra Colour, Lenovo M8 FHD, Paperwhite 4, Tolino epos | Quote: 
 Why do you keep complaining that the non-portable version of calibre does not behave like a portable app? Did I miss the memo that said unpacking an non-portable installer and running executables directly is how to generate a portable mode application? There are reasons that calibre has a Windows x64, Windows x86 and portable installer. So quit trying to claim that the non-portable version of calibre should behave the same as the portable version. If you want to continue to use calibre in a non-standard mode, depend on yourself for tech support. | |
|   | 
|  07-23-2020, 05:19 PM | #10 | 
| Member  Posts: 10 Karma: 10 Join Date: Jul 2020 Device: Bookeen Cybook Odyssey 2013 | 
			
			I've long since provided all the needed tech support to myself after getting a gentle nudge in the right direction. Just as I've long since reconciled my irreverent habits of using software products with stern reality. So all things non-portable can be safely thrown out of consideration. As for the rest, me complaining? That's stretching it. It's me wondering and me suggesting. As for the app being multiplatform - oh my, I missed that, thank you. But I guess you know that some aspects of any multiplatform app are indeed platform-dependent. Like, where the configuration is stored and all that stuff. And on Windows, environment variables are not the conventional way of storing non-PATH related settings of third-party apps. I've just tried to point out that, on Windows, it's somewhat strange to stick to that way as the only way. I don't see how it depends on or could affect the app's being multiplatform. Now, the portable mode itself isn't without its curious caveats, as I've already said. The thing is that the requirement to only use the 'calibre-portable.exe' and strictly avoid running any apps from any subdirectories of the portable installation lest the app suddenly stops being portable is one hell of a curious caveat, sorry about that, I don't care if that's also considered non-standard. And that caveat could be alleviated by putting a configuration file with all those CALIBRE_NO_DEFAULT_PROGRAMS and other settings somewhere within the portable installation directory structure, so that all the components have a common means of knowing what's going on. If this suggestion is considered a sacrilegious encroachment upon the ways of the world - fine, you're in charge. But I don't see what's so surprising in me finding something surprising. | 
|   | 
|  07-23-2020, 05:57 PM | #11 | ||
| Bibliophagist            Posts: 47,971 Karma: 174315100 Join Date: Jul 2010 Location: Vancouver Device: Kobo Sage, Libra Colour, Lenovo M8 FHD, Paperwhite 4, Tolino epos | Quote: 
 Checking where those programs stored their configuration information, the most popular approach seems to be saving settings in the registry. A few apps allow exporting their settings to a .ini file which comes in handy when moving to a new machine. As for Path? Last time I looked Path was simply one of a large number of variables including such oddities as Domain controller used to process the login. Kovid Goyal's design choice to use a method of storing calibre's configuration information that could be applied somewhat consistently across multiple platforms saving him having to support multiple methods was his choice. You may not agree with that design choice, that is your right. OTOH, since Kovid did make calibre open source, feel free to download the source and modify it until it works the way you would prefer. Quote: 
 However, when you are using very non-standard and non-supported ways of running programs, IMNSHO, you should not be wasting bandwidth by complaining that the programmer did not handle operations the way you prefer. | ||
|   | 
|  07-23-2020, 06:08 PM | #12 | |
| null operator (he/him)            Posts: 22,006 Karma: 30277294 Join Date: Mar 2012 Location: Sydney Australia Device: none | Quote: 
 You have three choices, a) don't use calibre, b) do what millions of active users do, use calibre as it is shipped, c) do what many other people have done, download the source and change it to meet your special needs. https://calibre-ebook.com/dynamic/calibre-usage BR | |
|   | 
|  07-23-2020, 08:41 PM | #13 | 
| Member  Posts: 10 Karma: 10 Join Date: Jul 2020 Device: Bookeen Cybook Odyssey 2013 | 
			
			I mentioned .ini only as an example. On my machine, for example, the majority of non-essential (and some essential, too) stuff isn't installed and is configured via configuration files. All those mpv's, vlc's, sumatra's, audacity's, foobar's, keepass'es and what not. Configuration files are either within the app's directory itself or somewhere under \AppData. My latest bandwidth-wasting ramble was about what's peculiar about the portable mode, so the registry is not what we're talking about here. I mentioned PATH because that's the most exemplar of what gets additions or changes among Windows environment variables, unlike in the Unix-like-world, where you'd expect to be stuffing all kinds of pretty disparate settings into your environment. I don't question the way the setting are stored, but sometimes it's reasonable to provide for some flexibility - to make the portable mode a little more portable in a little less conditional way, for example. "You're in charge" was just a way of saying, like, "look, whoever in charge of whatever has a final say in whatever they're in charge of". Yup, the millions is a very powerful argument, except it doesn't matter. Like, let's say I've used the app for a couple of days and have noticed a couple of very minor bugs that could be reported, but why would I, if they don't affect me? Like, that the viewer stops responding to zooming up using the keyboard or toolbar buttons if the 'Zoom step size' setting is set to or below 12% and you zoom out to or below 9px or that pressing on 'Previous/Next page' toolbar buttons without a book loaded results in an error. It's completely minor, it may or may not have been reported before, but it's there. Same goes for the way millions use any kind of software. Unless something is broken like there's no tomorrow or breaks something else, no one cares. You can disregard suggestions, you can ignore suggestions, you can consider suggestions and deem them not worth the time, pointless or whatever. And again, let's distinguish between complaints and suggestions and stop making it seem that I want something from someone. I don't want anything and I don't care. Again, I don't care. But somehow I don't bother explaining myself over and over, as my bandwidth isn't limited. And no need to use those "special needs" puns. Those things do not get to me, just take my word for it. | 
|   | 
|  07-23-2020, 11:40 PM | #14 | |
| Bibliophagist            Posts: 47,971 Karma: 174315100 Join Date: Jul 2010 Location: Vancouver Device: Kobo Sage, Libra Colour, Lenovo M8 FHD, Paperwhite 4, Tolino epos | Quote: 
 For many people, special needs can refer to anything from wanting a vegan meal at a business conference, being supplied with an external optical drive for their new laptop or the ever popular why can't the computer read my mind instead of doing what I told it to. | |
|   | 
|  07-24-2020, 01:04 AM | #15 | |
| Member  Posts: 10 Karma: 10 Join Date: Jul 2020 Device: Bookeen Cybook Odyssey 2013 | 
			
			If there was no pun in there, I'm sorry for overreacting. Quote: 
 It's just the way it is that its use as the go-to euphemism have led to a degree of certainty as to what it connotes. I've grown accustomed to steering miles clear of it and making sure I use something like "specific needs" instead when it comes to meals or "specific requirements", which perfectly covers both optical drives and mind-reading computers. | |
|   | 
|  | 
| 
 | 
|  Similar Threads | ||||
| Thread | Thread Starter | Forum | Replies | Last Post | 
| File Associations | OscarAlx | Calibre | 3 | 06-24-2020 12:27 PM | 
| Having trouble with file associations and Calibre | Magelord | Library Management | 6 | 02-21-2020 04:51 PM | 
| kpvbooklet file associations | procyon | Kindle Developer's Corner | 2 | 11-30-2016 03:16 PM | 
| Set File associations to the portable viewer? | Vortex | Calibre | 5 | 01-29-2013 02:24 PM | 
| [Linux] File Associations, again | markhale | Devices | 6 | 03-17-2011 12:16 PM |