Jump to content

Frameworks/Epics/KDEUI Crumble

From KDE Community Wiki

KDEUI Crumble

This page is the battle plan to finally get rid of KDEUI in kdelibs/frameworks. It lists the header name of all the classes in kdeui, they are sorted in sections per new destination for them.

Each section tries to also provide simple indications of the contraints to follow during the move (mostly about dependencies). If a class is not fitting one of the constraints, it is part of the job to first reduce the dependencies of the class to fit the contraints prior to the move. If you are too blocked to carry on, please add a note for the class.

The sections are roughly sorted by order of difficulty. The classes in the first sections should be reasonably easy to move, while the ones in the last sections are more challenging.

KDE4Support

Points to verify before moving the class in KDE4Support:

  • Make sure the class is used only in kde4support itself or kde4attic but not anywhere else in kdelibs


Status Description Notes Contact
DONE ./fonts/kfontdialog.h deprecated for QFontDialog Anne-Marie Mahfouf <annma@kde.org>
TODO ./fonts/kfontcombobox.h deprecated for QFontComboBox ... <null@kde.org>
IN PROGRESS ./dialogs/kinputdialog.h deprecated for QInputDialog David Gil <davidgiloliva@gmail.com>
TODO ./dialogs/kdeprintdialog.h (should be done by Qt, kcups* goes with it) ... <null@kde.org>
TODO ./widgets/keditlistbox.h deprecated for KEditListWidget ... <null@kde.org>
TODO ./widgets/kstringvalidator.h only the zombie kfilemetainfowidget uses it ... <null@kde.org>
TODO ./widgets/ktabbar.h deprecated for QTabBar ... <null@kde.org>
DONE ./widgets/ktabwidget.h deprecated for QTabWidget ... <sebas@kde.org>
TODO ./widgets/kbuttongroup.h Use real QGroupBox and QButtonGroup instances please, kthxbye ... <null@kde.org>
IN PROGRESS ./widgets/knuminput.h Use real QSpinBox Anne-Marie Mahfouf <annmal@kde.org>
TODO ./widgets/ktextbrowser.h deprecated for QTextBrowser ... <null@kde.org>
TODO ./util/kpixmapcache.h deprecated for KImageCache or KSharedDataCache ... <null@kde.org>
TODO ./util/kaccelgen.h ... <null@kde.org>
TODO ./actions/ktoolbarspaceraction.h ... <null@kde.org>

KDE4Attic

Points to verify before moving the class in KDE4Attic:

  • Make sure the class is not used anywhere in kdelibs anymore


Status Description Notes Contact
IN PROGRESS ./widgets/kdatetimeedit.h ... <wojtask9.kde@gmail.com>
IN PROGRESS ./widgets/kdatepicker.h ... <wojtask9.kde@gmail.com>
TODO ./widgets/kmultitabbar.h (used by kate, digikam, kexi --- but could use a cleanup, see e.g. KDEV3ICON...) ... <null@kde.org>
IN PROGRESS ./widgets/kdatecombobox.h ... <wojtask9.kde@gmail.com>
TODO ./widgets/ktimezonewidget.h ... <null@kde.org>
TODO ./widgets/kdatetimewidget.h ... <null@kde.org>
TODO ./widgets/kcharselect.h Can soon go into kwidgetsaddons (needs clear button in QLineEdit) ... <null@kde.org>
TODO ./widgets/kdatewidget.h ... <null@kde.org>
TODO ./widgets/ktimecombobox.h ... <null@kde.org>
TODO ./widgets/klanguagebutton.h ... <null@kde.org>
TODO ./widgets/kdatetable.h ... <null@kde.org>
TODO ./util/kpassivepopupmessagehandler.h only user is kde-runtime/knotify. Move it there? ... <null@kde.org>
TODO ./shortcuts/kgesture.h use #if 0 for the code in xmlgui (KShortcutsEditor) that uses KGesture (it's already hidden from the user anyway) ... <null@kde.org>
TODO ./shortcuts/kgesturemap.h needs polish before it can be resurrected ... <null@kde.org>

KGuiAddons

Points to verify before moving a class in KGuiAddons:

  • It depends only on QtGui or QtCore, eventually QX11Info


Status Description Notes Contact
TODO ./util/kmodifierkeyinfo.h ... <null@kde.org>
TODO ./fonts/kfontutils.h ... <null@kde.org>
TODO ./util/kimagecache.h but but but... KsharedDataCache is in kcoreaddons :-/ (tough problem) ... <null@kde.org>

KWidgetsAddons

Points to verify before moving a class in KWidgetsAddons:

  • It depends only on QtWidgets, QtGui or QtCore
  • It can depend on other classes in KWidgetsAddons, but that should be kept minimal


Status Description Notes Contact
TODO ./fonts/kfontrequester.h ... <null@kde.org>
TODO ./dialogs/kassistantdialog.h ... <null@kde.org>
TODO ./dialogs/kpixmapregionselectordialog.h ... <null@kde.org>
TODO ./dialogs/klinkdialog.h ... <null@kde.org>
TODO ./dialogs/knewpassworddialog.h ... <null@kde.org>
TODO ./dialogs/kpassworddialog.h ... <null@kde.org>
TODO ./widgets/kpixmapregionselectorwidget.h ... <null@kde.org>
TODO ./widgets/ktitlewidget.h ... <null@kde.org>
TODO ./widgets/kratingwidget.h ... <null@kde.org>
TODO ./widgets/kratingpainter.h ... <null@kde.org>
TODO ./widgets/kmessagewidget.h (Needs to get rid of K* using fixed default colors, Qstyle :styleHint and Qstyle :standardPixmap) ... <null@kde.org>
TODO ./widgets/keditlistwidget.h ... <null@kde.org>
TODO ./widgets/kactionselector.h ... <null@kde.org>
TODO ./util/kpassivepopup.h ... <null@kde.org>
TODO ./util/kcursor.h ... <null@kde.org>
TODO ./paged/kpagewidget.h ... <null@kde.org>
TODO ./paged/kpagedialog.h ... <null@kde.org>
TODO ./paged/kpageview.h ... <null@kde.org>
TODO ./paged/kpagemodel.h ... <null@kde.org>
TODO ./paged/kpagewidgetmodel.h ... <null@kde.org>
TODO ./shortcuts/kacceleratormanager.h the list of translated texts from standard actions will have to be set by the first KStandardAction being constructed ... <null@kde.org>
TODO ./colors/kcolorbutton.h minor duplication of KcolorMimeData though ... <null@kde.org>
TODO ./colors/kcolorcombo.h ... <null@kde.org>
TODO ./actions/kactionmenu.h ... <null@kde.org>
TODO ./actions/ktoolbarlabelaction.h ... <null@kde.org>
TODO ./actions/ktoolbarpopupaction.h ... <null@kde.org>

KWindowSystem

Points to verify before moving a class in KWindowSystem:

  • It depends only on QtWidgets, QtGui or QtCore
  • It can depend on other classes in KWindowSystem, but that should be kept minimal


Status Description Notes Contact
TODO ./util/kkeyserver_x11.h ... <null@kde.org>
TODO ./util/kxerrorhandler.h ... <null@kde.org>
TODO ./util/kkeyserver_win.h ... <null@kde.org>
TODO ./util/kkeyserver_mac.h ... <null@kde.org>
TODO ./util/kkeyserver.h ... <null@kde.org>

KWidgets

Points to verify before moving a class in KWidgets:

  • It doesn't use anything aimed at KCompletion (e.g. KLineEdit or KComboBox)
  • It doesn't use anything aimed at ItemViews
  • It doesn't use anything from kdecore
  • Using things from tier1 is fine
  • Using things from tier2 is forbidden


Status Description Notes Contact
TODO ./dialogs/kaboutapplicationdialog.h (probably difficult) ... <null@kde.org>
TODO ./dialogs/kbugreport.h ... <null@kde.org>
TODO ./dialogs/ktip.h ... <null@kde.org>
TODO ./widgets/khelpmenu.h ... <null@kde.org>

ItemViews

Points to verify before moving a class in ItemViews:

  • It doesn't use anything aimed at KCompletion (e.g. KLineEdit or KComboBox)
  • It doesn't use ki18n
  • It doesn't use anything from kdecore
  • It doesn't use anything from kwidgets
  • Using things from tier1 is fine


Status Description Notes Contact
TODO ./itemviews/kcategorizedview.h ... <null@kde.org>
TODO ./itemviews/klistwidgetsearchline.h (port away from KlineEdit and i18n) ... <null@kde.org>
TODO ./itemviews/ktreewidgetsearchline.h (port away from KlineEdit and i18n) ... <null@kde.org>
TODO ./itemviews/kcategorizedsortfilterproxymodel.h (need porting away from KstringHandler) ... <null@kde.org>
TODO ./itemviews/kwidgetitemdelegate.h ... <null@kde.org>
TODO ./itemviews/kfilterproxysearchline.h (port away from KlineEdit and i18n) ... <null@kde.org>
TODO ./itemviews/kcategorydrawer.h ... <null@kde.org>

KCompletion

Points to verify before moving a class in KCompletion:

  • It doesn't use anything from kwidgets
  • It doesn't use anything from kdecore
  • It doesn't use anything from kdeui
  • Using things from tier1 is fine


Status Description Notes Contact
TODO ./widgets/khistorycombobox.h ... <null@kde.org>
TODO ./widgets/kcombobox.h ... <null@kde.org>
TODO ./widgets/klineedit.h ... <null@kde.org>
TODO ./widgets/kcompletionbox.h ... <null@kde.org>
DONE ./util/kcompletion.h move ksortablelist.h with it ... <ervin@kde.org>

KConfigWidgets

Points to verify before moving a class in KConfigWidgets:

  • It uses only classes from kconfigcore, kconfigui or kwidgetsaddons


Status Description Notes Contact
TODO ./dialogs/kconfigdialogmanager.h ... <null@kde.org>
TODO ./dialogs/kconfigdialog.h ... <null@kde.org>
TODO ./widgets/kcmodule.h ... <null@kde.org>
TODO ./itemviews/kviewstatesaver.h ... <null@kde.org>
TODO ./itemviews/kviewstatemaintainer.h ... <null@kde.org>

KCrash

Important: At time of writing the KCrash framework doesn't exist yet in staging, the person picking the first move task here would have to do that.

Points to verify before moving a class in KCrash:

  • It uses only classes from kcoreaddons or kwindowsystem


Status Description Notes Contact
TODO ./util/kcrash.h ... <null@kde.org>

KIconThemes

Points to verify before moving a class in KIconThemes:

  • It uses only classes from tier1 or tier2
  • It uses nothing from kdeui or kdecore


Status Description Notes Contact
TODO ./util/kpixmapsequencewidget.h ... <null@kde.org>
TODO ./util/kpixmapsequenceoverlaypainter.h ... <null@kde.org>
TODO ./util/kpixmapsequence.h ... <null@kde.org>
TODO ./icons/kiconbutton.h ... <null@kde.org>
TODO ./icons/kicondialog.h ... <null@kde.org>

KJobWidgets

Points to verify before moving a class in KJobWidgets:

  • It uses only classes from Qt, kcoreaddons or kwidgetsaddons


Status Description Notes Contact
TODO ./jobs/kwidgetjobtracker.h ... <null@kde.org>
TODO ./jobs/kabstractwidgetjobtracker.h ... <null@kde.org>
TODO ./jobs/kdialogjobuidelegate.h ... <null@kde.org>
TODO ./jobs/kstatusbarjobtracker.h ... <null@kde.org>

KNotifications

Points to verify before moving a class in KNotifications:

  • It uses only classes from KWindowSystem, QtWidgets, QtDBus


Status Description Notes Contact
TODO ./notifications/kstatusnotifieritem.h ... <null@kde.org>
TODO ./notifications/knotificationrestrictions.h ... <null@kde.org>

KWallet

Important: At time of writing the KWallet framework doesn't exist yet in staging, the person picking the first move task here would have to do that.

Points to verify before moving a class in KWallet:

  • It uses only classes from kconfigcore, kconfigui or kwindowsystem


Status Description Notes Contact
TODO ./util/kwallet.h ... <null@kde.org>

XmlGui

Points to verify before moving a class in XmlGui:

  • It uses only classes from tier1 or tier2
  • It uses nothing from kdeui or kdecore


Status Description Notes Contact
TODO ./dialogs/kshortcutseditor.h ... <null@kde.org>
TODO ./dialogs/kshortcutsdialog.h ... <null@kde.org>
TODO ./dialogs/kedittoolbar.h ... <null@kde.org>
TODO ./widgets/kshortcutwidget.h ... <null@kde.org>
TODO ./widgets/kkeysequencewidget.h ... <null@kde.org>
TODO ./util/kundoactions.h ... <null@kde.org>
TODO ./kdepackages.h (goes with kbugreport) ... <null@kde.org>
TODO ./xmlgui/kxmlguiclient.h ... <null@kde.org>
TODO ./xmlgui/kxmlguiwindow.h ... <null@kde.org>
TODO ./xmlgui/kxmlguifactory.h ... <null@kde.org>
TODO ./xmlgui/kmainwindow.h ... <null@kde.org>
TODO ./xmlgui/kxmlguibuilder.h ... <null@kde.org>
TODO ./xmlgui/ktoolbar.h ... <null@kde.org>
TODO ./shortcuts/kcheckaccelerators.h ... <null@kde.org>
TODO ./actions/kactioncollection.h ... <null@kde.org>
TODO ./actions/ktoggletoolbaraction.h ... <null@kde.org>
TODO ./actions/kactioncategory.h ... <null@kde.org>

KTextWidgets

Important: At time of writing the KTextWidgets framework doesn't exist yet in staging, the person picking the first move task here would have to do that.

Points to verify before moving a class in KTextWidgets:

  • It uses only classes from tier1 or tier2
  • It uses nothing from kdeui or kdecore


Status Description Notes Contact
TODO ./findreplace/kfinddialog.h ... <null@kde.org>
TODO ./findreplace/kreplacedialog.h ... <null@kde.org>
TODO ./findreplace/kfind.h ... <null@kde.org>
TODO ./findreplace/kreplace.h ... <null@kde.org>
TODO ./widgets/krichtextwidget.h ... <null@kde.org>
TODO ./widgets/nestedlisthelper.h (goes with krichtextedit) ... <null@kde.org>
TODO ./widgets/ktextedit.h ... <null@kde.org>
TODO ./widgets/krichtextedit.h ... <null@kde.org>