GNOME Bugzilla – Bug 660760
.prs presets needs to have a per-application option
Last modified: 2011-12-09 15:16:49 UTC
With the introduction of encodebin the .prs presets have become a lot more prominent. One thing I realized while working on Transmageddon is that it isn't really very useful to have system wide presets, at least not for most of what you want to use presets for with encodebin. For instance if I need a preset to set a specific bitrate on an encoder, adding that as a gstreamer install wide preset is just messy. And trying to namespace presets would just create a very long preset list and also make adding presets a chore for application developers. Instead I suggest an API addition where you can point to an application specific directory for storing your .prs files, and that the files in this directory takes precedence of any system ones.That way every application can create whatever .prs files they find useful.
The default implementation in the preset interface already overlays the presets in the system wide installation with those in the users home dir (under .gstreamer-0.10/presets or .config/gstreamer-0.11/presets). Presets in the homedir will shadow system wide presets. This allows to ship defaults and lets users to modify and save them. If applications start to have special needs, we would need something like either: gst_preset_set_domain(GstPreset *, gchar *domain); this would need to be the first call on the iface and it would need to be repeated for each element.
Sent too quickly. The problem with adding new API here is that this would be specific to the default implementations. E.g. in buzztard I have elements uniquely implementing the preset interface (not using the default implementation) and for those this API addition would not make any sense.
Created attachment 198142 [details] Example prs file Attached example file. Originally I tried to add presets that where generic, like Quality low, normal, high, but due to requirements of specific devices I will need to add device specific entries like the example one added for PSP. Of course, the question is if there even might be an argument for quality level profiles per devices. Which would quickly populate the prs file. Also as pointed out on IRC, since using a prs file is an integral part of the encodebin API (for setting anything not in caps, but which is properties) app developers will need to be able to create prs entries, and if they have to get these entries merged upstream, we are making things hard for people.
Instead of the gst_preset_set_domain(GstPreset *, gchar *domain); it could also be a gst_preset_set_search_path(GstPreset *, gchar *path); or gst_preset_set_app_dir(GstPreset *, gchar *dir); The def. impl. would read the presets from system, app-path/dir and then user-dir to create merged list. I am thinking that gst_preset_set_app_dir() would be sufficient. The new API would come with an warning, to indication that not all preset implementations will handle it.
If we are going to follow the per-application presets route. We need to expand the tags of the presets to include where they come from. The usecase I have in mind is when an application wants to browse just its own presets. Instead of all applications showing the exponentially growing list of all of them.
luis: while I am not against namespacing I don't think the list would be exponential as no application would see the presets of another application, they would only see their own, the user specific ones and the system one.
For each application to only see its own presets and the system wide ones, a "look for presets here" call needs to be added. So each application can store its presets in /usr/share or wherever and have GStreamer add those to the list. This promotes duplication, but if we are diligent in finding any of this duplication and moving common presets into the system wide list, making this wide list a lowest common denominator, it would be good. The best solution of all the ones I've pondered. My +1
We may want "role" presets (like an encoder preset for VoIP being different than a preset for streaming or a preset for recording). Also, applications should be able to mark their presets to not be visible in other apps. Currently, I've completely duplicated the presets system inside Farstream http://www.freedesktop.org/software/farstream/apidoc/farsight2/FsElementAddedNotifier.html .. In particular see the keyfile bit.. Actually, inside farstream, I may have more than one role (if the other side supports keyframe requests or not for example). That said, maybe presets are only for user visible stuff and are not appropriate for what I do.
I see two options: a) the application wants to have a bunch of extra presets. the application would install them to $prefix/share/<appname>/presets instead of $prefix/share/gstreamer-0.XX/presets. Presets users edit are always in the preset dir in $HOME. The gstreamer preset system would read system-dir / app-dir / user-dir and shadow presets in layers below. For this we just need an extra function to set the appdir or even just check the application-name. The advantage here is that submitting presets to gstreamer will move them from app-dir to system-dir and thus provides an easy migration path (we might want a function that removed presets from upper layers if they have been merge to lower layers). b) the application wants to have own presets in a completely separate namespace. This way app A won't see app Bs' presets. For this cloning the preset system might be the way to go.
API suggestion: To me this should simply be a API where you set the application prs path path so from python I would do : "gst.ApplicationPresetDiretory=file://usr/share/transmageddon/prs/"
Created attachment 203007 [details] [review] add app_dir preset api This should do the trick. Please try it and comment on the API. Will do a bit more testing in the meantime.
API looks fine to me, though I would prefer _{set,get}_application_directory() instead of _app_dir(). Is there a technical reasons why we don't allow changing an already-set directory? (Other than that it's hard to come up with a use case where that's needed)
Oh, and the docs could be clearer about what takes precedence - I presume the application directory?
(In reply to comment #12) > API looks fine to me, though I would prefer _{set,get}_application_directory() > instead of _app_dir(). > app was choosen due to app src/sink dir was chose as glib uses dir instead of directory > Is there a technical reasons why we don't allow changing an already-set > directory? (Other than that it's hard to come up with a use case where that's > needed) One the path has been determined it is stored in qdata of the element-type. Invalidating the path' would be difficult. Also computing them every time would be fine, but then we would leak them (the current API returns read-only references for the other two path). > Oh, and the docs could be clearer about what takes precedence - I presume the > application directory? Will explain better. It is system < app < user. Rational is that most likely the user folder is the only writable one.
Created attachment 203024 [details] [review] add app_dir preset api more docs.
Created attachment 203146 [details] [review] add python bindings > python >>> import gst; >>> gst.preset_set_app_dir("/home/ensonic") True >>> gst.preset_get_app_dir() '/home/ensonic' >>>
I think the better naming of this API would be gst.Preset.get_app_dir, would fit in with the other Preset related API calls then
Another python API question (maybe also cover C Api), should it be in uri format?
(In reply to comment #18) > Another python API question (maybe also cover C Api), should it be in uri > format? no, those are local directories.
Ok, git master of transmageddon now use this new API, tested and working.