From Fedora Project Wiki

🔗 Fedora Workstation Tasklist

This document aims to outline the tasks planned for the workstation as derived from the Workstation/Workstation_PRD and Workstation/Technical_Specification. Also some general information on how to get involved.

🔗 How to get involved

There are two good steps to take to get involved. First you should decide where you think you would want to get involved. Are you a Coder? Web developer? Tester? Designer? Marketing? The tables beneath show some of the tasks we are currently looking at. We would love your help with any of them. If you are interested in joining one of these efforts send an email to the desktop@lists.fedoraproject.org introducing yourself to the project. Follow that up with either contacting the people listed directly or contact one of the working group leaders, for instance through the Fedora Workstation IRC channel, who will help put you in touch. Some of these tasks will also require you to get involved with various upstream communities.

🔗 Older tasks

Previous task lists are maintained in this archive page.

🔗 Fedora Workstation 22

Software Installer - better app data Ryan Lerch Underway, looking at making part of Fedora packaging guidelines The Application installer is the primary method for our users to find new software. Having good application installer metadata for all Fedora software meant to be installed with the software installer is thus crucial for our end user experience. https://fedorahosted.org/fpc/ticket/414
gnome-session gdbus port Ray Strode DONE Preparation for systemd user sesssions
Boxes - add a way to change vts Zeeshan Ali DONE (initial support done, may add more later) https://bugzilla.gnome.org/show_bug.cgi?id=725303
Terminal - long-running job notification Debarshi Ray done as downstream patches in Fedora Feature parity with other OS's. https://bugzilla.gnome.org/show_bug.cgi?id=711059, will copy the elementary OS approach
Wayland - input configuration protocol/library API Peter Hutterer/Hans de Goede/Carlos Garnacho mostly DONE here Feature parity with X
Wayland - input configuration UI Rui Matos Done feature parity with X
Wayland - pointer barriers Jonas Ådahl DONE Feature parity with X. https://bugzilla.gnome.org/show_bug.cgi?id=706655
Use Wayland on the login screen Ray Strode done gets us wider exposure without requiring a full session Changes/Login_Screen_Over_Wayland
Make sure xorg-x11-drv-libinput is in the Workstation package set Hans de Goede Done Add a dependency in the fedora-workstation package, since we don't want to force it across board yet in xorg-x11-drivers
Software Installer - Search in disabled repositories Richard Hughes Done code blog post
Software Installer - Codec installation Kalev Lember done Move the gnome-packagekit session service for codec, mime handler, font, etc installation to gnome-software and drop our remaining gnome-packagekit dependency
Desktop log viewer - improve performance David King Done Investigate using a worker thread for journal interaction, using async api
Abrt - integrate with privacy settings
Bastien Nocera, Abrt team done Use a privacy panel setting rather than gnome-abrt preferences, https://bugzilla.gnome.org/show_bug.cgi?id=742375, https://github.com/abrt/gnome-abrt/issues/74, http://lists.freedesktop.org/archives/systemd-devel/2015-January/027006.html, https://bugzilla.redhat.com/show_bug.cgi?id=1182635
Abrt - improve notifications Bastien Nocera, Abrt team done https://github.com/abrt/gnome-abrt/issues/105
nautilus - port to GAction, complete the design refresh work Carlos Soriano done Changes/Nautilus_Improvements
Firefox GTK3 port Martin Stransky Enabled in rawhide Important migration to make sure Firefox can keep working as an integral part of the desktop
Firefox screensaver inhibition Martin Stransky done Firefox uses the dbus interface to inhibit screen locking during media playback
Qt - Adwaita theme Martin Briza done We want all applications to feel native and run well in the Workstation, regardless of if they are written using GTK, Qt, Java or something else. A developer should be able to choose the tools he or she wants without having to think about how their tools of choice have been implemented. https://bugzilla.redhat.com/show_bug.cgi?id=1176658
Qt - ibus support Martin Briza OK Support for various kinds of language input should also be transparent across toolkits

status: ibus works with Qt apps out of the box. You just need to install ibus-qt to have the popup right over the text you're writing - otherwise it's at the bottom of the window.

Qt - ensure ibus-qt is installed by default Matthias done
Qt notifications Martin Briza OK This may need work on the gnome-shell side too

status: Notifications do work - they're shown right. However, some Qt apps use tray status icons, which aren't shown anywhere - Clementine does this, for example.

gnome-shell - new notification design Florian Muellner done here The message tray is a remaining weak spot of the original gnome-shell design Changes/GnomeShell_NewNotifications https://git.gnome.org/browse/gnome-shell/log/?h=wip/fmuellner/notification-redux

🔗 Fedora Workstation 23

Project Name Developer/Owner Status Justification
Optimus Bastien Nocera hardware shipped Better support for Optimus systems are also important for a long range of power users and developers. Mode switch UI - https://bugzilla.gnome.org/show_bug.cgi?id=704387, https://bugzilla.gnome.org/show_bug.cgi?id=734346 also relevant
Terminal -automatic title updates Debarshi Ray working patch posted This feature will make working with a large quantity of terminals easier as identifying each one will be a lot easier. Feature parity with other OS's. https://bugzilla.gnome.org/show_bug.cgi?id=711060
Terminal - Better tiling Debarshi Ray upstream designers wary of tiling - exploring as a shell extension now Another crucial feature for developers working with a lot of terminals.
Terminal - Allow to search selected text on Web Allan Day Under discussion: https://bugzilla.gnome.org/show_bug.cgi?id=723088
Terminal - Allow to send selected text to a pastebin Allan Day Under discussion: https://bugzilla.gnome.org/show_bug.cgi?id=723089
Wayland - mixed HiDPI display support Jonas Ådahl in progress We want perfect support for HiDPI displays with Wayland as going forward those are probably going to end up being the default displays on any new system. https://bugzilla.gnome.org/show_bug.cgi?id=728902
Wayland - mouse accessibility GNOME a11y team Feature parity with X
Wayland - input device information Jonas Ådahl Feature parity with X
Wayland - Wacom support Peter Hutterer, Carlos Garnacho in progress This is a crucial tool for animators and graphics artists wanting to use our platform. Working closely with Wacom on this. feature partity with X
Wayland - IBUS Rui Matos Wayland protocol needs defining, sync with Daiki Ueno from the IBus side IBUS is the input system we rely in in Fedora for a large range of languages. We need IBUS support to be to notch in order not have switching to Wayland be a regression for our international userbase
Wayland On-screen keyboard Rui Matos Not yet begun, needs to be synced with IBUS support. A protocol needs to be defined Important for especially non-desktop use of Wayland
Wayland pointer locking and confinement - protocol Jonas Ådahl in progress needed for many games
Wayland pointer locking and confinement - compositor implementations Jonas Ådahl in progress needed for many games
Wayland pointer locking and confinement - SDL support Jonas Ådahl in progress needed for many games
Fedora account integration
Pidgin integration With 3.16, gnome-shell is much less entangled with empathy. We should look at making pidgin work nicely in GNOME
Software Installer - Fedora hosting + generation for app data Fedora Rel. Engineering q.v. https://fedorahosted.org/rel-eng/ticket/5721
Software Installer - support developer tools Allan Day needs design A lot of developer tools are command line and thus might not be a great fit for the application installer. Could be that for instance the Developer assistance is a better home for installing such tools. Or maybe a 3rd separate tool.
Software Installer - Chrome/firefox webapps Tomas Popela A lot of desktop development these days actually come in the form of webapps. We need to integrate these apps into out platform so that they help drive people to our platform and not away from it.
Software Installer - Integrate distro upgrade Richard Hughes early design ideas here gnome-software should inform the user when an upgrade of the OS is available, and offer to start it. https://bugzilla.gnome.org/show_bug.cgi?id=712149 https://fedorahosted.org/rel-eng/ticket/6081
Chrome Apps integration Tomas Popela Need to discuss with Chrome guys upstream
Software Installer - user feedback Richard Hughes blocked on Fedora account integration deferred until post
Software Installer - Third-party repo (chrome, etc) under discussion in FESCO https://fedoraproject.org/wiki/Workstation/3rdPartyApps#Third-Party_Software_in_Fedora_Workstation
Software Installer - Offer a way to override 'metered' connection heuristics The idea is for !NetworkManager to offer this information on a per-connection basis, then we can offer a user override for it in the network panel https://bugzilla.gnome.org/show_bug.cgi?id=741725
Software Installer - Install alternative desktops Allan Day little interest from KDE side While the product aims at a strongly integrated vertical system we do want to allow those users who want it to install other options even if that means they lose out on a big part of the value proposition we are trying to bring to the table with the Workstation product. Need to take care to figure out how to do it in a way that is actually useful to users yet also not introducing risk of breaking core workstation experience through for instance library incompatibilities and similar.
Software Installer - Integrate Bios/Firmware updates Richard Hughes, Peter Jones in progress
kdbus Systemd team Proposed on lkml, expected to get merged during winter, kernel-playground COPR has it Important in order to have an efficient way to do data transport between containers.
kbus glib support David King in progress Needed to benefit from kdbus in the desktop
Multimonitor - edge resistance Florian Muellner Florian has an unfinished patch A lot of developers and sysadmins use multimonitor setups. We need to have best of class handling of these kind of setups.
Docking station teardown behaviour Design team/Jon McCann design needed A lot of developers, sysadmins and other power users use a docking station at the office and then bring their laptops home in the evening to continue working. Currently we don't have a great behaviour for dealing with the external monitor appearing/disappearing, with all apps just migrating to the internal screen on disconnect.
Application grouping support Design team/Jon McCann design needed Developers and devops are task oriented more than application oriented and we want to have a way to group a large set of application/windows together and be able to deal with them as a group. So that you can have for instance 5 terminals and a browser with 10 tabs set to specific pages associated with one project and another set of applications and terminals for another project.
Design work for Developer Assistant Allan Day Initial discussions had with Dev.Exp. Team The developer assistant is likely to become of our core value adds. Need to make sure it evolves in harmony with the rest of the developer experience we are providing and that features end up in the right place.
Mylyn support added to Online accounts Mylyn can be a portal for enabling developers easy access to a lot of developer resources
Desktop log viewer - per-application logs David King unfinished patch exists The desktop log viewer is meant to be a good debug tool for developers and a bit easier to interact with for such purposes than the log viewer included in cockpit.
Desktop log viewer - hook up GLib logging to the journal David King
Desktop log viewer - move log-triggered actions (eg SMART, abrt) from gsd and abrt David King needs discussion with abrt team
Move apps to desktop file name == bus id Part of the move to systemd user sessions, and isolated applications. Suitable for crowd sourcing
Prefer D-Bus activation in gnome-session Ray Strode Part of the move to systemd user sessions
Make X launching code paths similar to Wayland in gdm Ray Strode Move towards socket activation for X and Wayland
Define 'portals' policy David King need to do some experimental prototyping more than for server containers, desktop containers need to be able to access various system services, like online accounts.
Desktop log viewer - add support for activate-by-message id to journal David King needs discussion with systemd guys
Desktop log viewer - clean up logs suitable for crowdsourcing
Abrt - improve crash collection Bastien Nocera, Abrt team https://github.com/abrt/abrt/milestones/Fedora%2022, https://github.com/abrt/abrt/issues/891, https://github.com/abrt/abrt/issues/887
Abrt - improve desktop client Bastien Nocera, Abrt team in progress https://github.com/abrt/gnome-abrt/issues
nautilus - Google Drive support Debarshi Ray in progress Will be implemented as a gvfs module, https://bugzilla.gnome.org/show_bug.cgi?id=739008
port libgdata to newer Google apis Debarshi Ray The api used in the Google Drive backend will stop working April 2015
Evolution - composer webkit port Tomas Popela in progress
Chromium screensaver inhibition Tomas Popela waiting on completion of Evolution webkit port
caldav support for general IMAP connector in Online accounts the generic IMAP connector should be suplemented by a general caldav one as most email servers using IMAP would be used with a caldav server
Boxes - OVF/OVA import/export of vms Kalev Lember in progress https://bugzilla.gnome.org/show_bug.cgi?id=723008
Boxes - file transfers from/to vm Zeeshan Ali https://bugzilla.gnome.org/show_bug.cgi?id=730259
Boxes GPU passthrough Zeeshan Ali in progress Being able to assign a separate GPU to a virtual machine is a crucial feature for a lot of developers, for instance game developers and animators https://bugzilla.gnome.org/show_bug.cgi?id=746345
Eclipse port to GTK3 Red Hat Tools team in progress We want this premier IDE to look and feel native on the desktop
Qt - High Contrast theme Martin Briza Accessibility is important for us and should work without a hitch accross toolkits
Qt application menu Dan Vrátil needs work status: Qt apps can export their menus via the com.canonical.dbusmenu interface. They export the complete menubar though so we should probably just utilize the first submenu or the complete menu in one button (it's possible, yet the menus are quite complex)
Qt - test Qt/KDE apps under XWayland Dan Vrátil
Qt - CSD under wayland Dan Vrátil/Lukáš Tinkl unlikely to materialize status: Qt Wayland apps don't run in Rawhide at all. There is support for CSDs in QtWayland but there is no application utilizing it. Upstream KDE (Martin Graesslin) is strongly against using CSDs, see http://blog.martin-graesslin.com/blog/2013/02/client-side-window-decorations-and-wayland/
Qt - hi-dpi support Dan Vrátil in progress Make sure Qt applications support hi-dpi scaling when running on high resolution displays (experimental patches to land soon in qt5/rawhide. The topic explained here: http://doc.qt.io/qt-5/highdpi.html)
Qt/KDE - ensure mouse and other input settings transfer accross when running Qt/KDE apps Lukáš Tinkl verify mbriza: Will test when the configuration dialog works in F22 GNOME. Anyway, since there are virtually no settings there, it will be fun. Also: regarding keyboard layout, GNOME doesn't use ibus-setup so it's not likely anything will be transferred.
eclipse-jbosstools integration? talk to jboss team about linuxapps and their needs
gnome-shell - system keybinding overview https://wiki.gnome.org/Design/OS/HelpOverlay#System_Shortcuts
GTK+ - application keybinding overview https://wiki.gnome.org/Design/OS/HelpOverlay#System_Shortcuts
liveusb-creator - visual refresh Martin Briza/Jakub Steiner in progress mockups This is the 'first point of contact' with Fedora - it should look polished and modern
battery life monitoring Owen Taylor research underway Put a system in place that allows us to evaluate power consumption under well-defined scenarios on an ongoing basis
ambient backlight handling research underway Make sure we have ambient backlight drivers for important modules in the kernel, add support to gnome-settings-daemon.
power tunables research underway Some of the kernel tunables such as SATA link power management and USB autosuspend can make a difference of multiple watts. These need to be investigated and udev/kernel configuration adjusted as appropriate.
btrfs Kernel team/Jon McCann Design user interface for rollback feature - https://blogs.oracle.com/erwann/entry/zfs_on_the_desktop_zfs The rollback feature that btrfs will give us can improve system robustness and upgrade pains significantly. btrfs has unfortunately taken a long time to mature, but hopefully with Facebook investing heavily in it, that will quickly change.
Scriptless RPMS for desktop None assigned Blocked on file triggers in rpm Good way for new community members to get involved. We want to avoid requiring scripts to be called from RPMS as far as possible as any such manual steps increase the risk for bugs and issues happening during upgrades. Working on removing the need for such things will increase overall system robustness and make upgrades less of a challenge. It also makes our updates more alike to image based installations.
  • gsettings schemas
  • gconf schemas
  • im modules - this cache doesn't add much value, could make it optional
  • gio modules – make optional
  • pango modules – make optional
  • pixbuf loaders – make optional
  • systemd unit - not a cache – just annoying post scripts

The rpm team is working on 'file triggers' that will enable this

Virtual 3D for SPICE David Arlie Need more community involvement to move forward
Polari IRC client Already somewhat done, need community involvement to take to production level
improve git GUI tool more like sourcetree? Great tooling is a big part of the issue we need to address. Especially as we try to lure developers away from MacOS making sure our development tools like gitg are top notch is crucial.
Wayland - xsettings replacement for Wayland not a short-term priority If we ever want be be able to run the desktop without requiring some form of X Window support, then this needs to be resolved.
EGL Work on Nvidia enabling technologies in the graphics stack (basically try to help move some of their proposal forward to help encourage their Wayland support quicker) People like game developers, animation artists and similar require the binary Nvidia driver for their work, we need to work with NVidia to make sure it works really well with Wayland.
Screencasting with audio Need community member involvement We been getting requests for better screencasting support in the desktop, needs review of current status and what can be done to improve performance and features.
Fleet Commander Alberto Ruiz Proof of concept under development We want our systems to be deployed in large software engineering organizations. Providing good tools for managing such deployments could be an important differentiator for us.
Remote Windows Apps Ondrej Holy and Debarshi Ray GOA account handling for Windows terminal server and remote windows applications