Jump to content

Development/FAQs/General FAQ/fr: Difference between revisions

From KDE TechBase
ChristianW (talk | contribs)
Created page with "Comment pouvez-vous faire cela à partir de votre validation Subversion. Pour cela, ajouter à votre message de validation une ligne comme :"
FuzzyBot (talk | contribs)
Updating to match new version of source page
 
Line 1: Line 1:
{{Proposed_deletion|Content is now at https://community.kde.org/KDE/FAQs/General_FAQ and this page may no longer be up-to-date. Translations are still available for this page, however.}}
<languages />
<languages />


== Je veux commencer cette nouvelle application. Que me conseillez-vous ? ==
== I want to start this new application. What do you advise? ==


Nous sommes tous d'accord qu'il y a plein d'applications KDE à écrire. Mais il y a aussi beaucoup d'applications KDE existantes qui réclament votre assistance.
We all agree that there are plenty of KDE applications that need to be written. But there are also a lot of existing kde applications that need your help.


Pour voir les domaines qui ont besoin d'aide, allez voir [http://www.kde.org/jobs/ cette page].
To see the areas where help is needed, check [http://www.kde.org/jobs/ this page].


Avant de démarrer une nouvelle application, il est toujours bon d'aller voir sur  [http://www.kde-apps.org/ KDE-Apps.org] et sur d'autres services d'hébergement de logiciels en sources libres comme [https://github.com/ GitHub], [https://code.google.com Google Code], et [http://sourceforge.net/ SourceForge] pour voir la liste des applications existantes et de demander à la liste de diffusion du [https://mail.kde.org/mailman/listinfo/kde-devel developpement KDE] si quelqu'un travaille déja sur un projet similaire.
Before starting a new application, it's always a good idea to check [http://www.kde-apps.org/ KDE-Apps.org] and other open source software hosting services like [https://github.com/ GitHub], [https://code.google.com Google Code], and [http://sourceforge.net/ SourceForge] for existing applications and to ask on the  [https://mail.kde.org/mailman/listinfo/kde-devel kde-devel] mailing-list whether someone is already working on a similar project.


== Je suis un développeur, comment puis-je contribuer au logiciel KDE ? ==
== I am a developer, how can I contribute to KDE software? ==


Calligra et KDevelop, bien qu'étant très populaires, ont très peu de développeurs , vous pourriez donc aller voir là-bas. Il n'est pas utile d'être un développeur d'espaces de travail KDE ou de bibliothèques pour la plateforme KDE pour apporter votre aide. L'éventail complet du logiciel KDE est très modulaire et donc vous pouvez parfaitement améliorer un domaine sans connaître le fonctionnement des autres.
Calligra and KDevelop, despite being very praised, have very few developers, so you might check there. There is no need to be a developer of the KDE workspaces or KDE platform libraries to help. The whole range of KDE software is very modular so you can perfectly improve one area without knowing how others work.


Vous pouvez aussi demander sur [https://mail.kde.org/mailman/listinfo/kde-devel kde-devel] si quelqu'un a besoin d'aide sur une application.
You can also ask on  [https://mail.kde.org/mailman/listinfo/kde-devel kde-devel] if someone needs help on an application.
Utilisez la dernière version de votre logiciel KDE favorit et identifiez les besoins nécessaires. Un générateur de thème ? Un éditeur de schema en mode console ? Améliorer un jeu ? Il y a toujours un petit détail qui manque. Allez-y et implémentez-le !
Use the latest version of your favourite KDE software and spot things that are needed. A theme generator? A konsole schema editor? Improve a game? There is always a small feature missing. Go and implement it!


Etes-vous familier ou attiré par un domaine spécifique ? Regardez s'il existe une application qui pourrait requierir votre aide. Ou écrivez-en une. KDE accueille plus d'applications qui n'émanent pas de férus.
Are you familiar or attracted with a specific field? See if there is a related application that could use your help. Or write one. KDE especially welcomes more non-geek oriented applications.


== Je ne suis pas développeur, comment puis-je aider ? ==
== I am not a developer, how can I help? ==


Il existe de nombreuses tâches ne réclamant pas les talents de développeur. Ecrire des articles sur les applications pour promouvoir KDE (voir la liste de diffusion [https://mail.kde.org/mailman/listinfo/kde-promo kde-promo]) , aider l'équipe de documentation (voir [http://l10n.kde.org/docs/ i18n.kde.org/doc]), aider aux traductions (voir [http://l10n.kde.org/ i18n.kde.org]), aider à filtrer les bogues signalés (voir [https://bugs.kde.org/ bugs.kde.org]).  
There are plenty of tasks that don't require development skills. Write reviews of applications for the promoting of KDE (see the [https://mail.kde.org/mailman/listinfo/kde-promo kde-promo] mailing-list), help the documentation team (see [http://l10n.kde.org/docs/ i18n.kde.org/doc]), help the translations (see [http://l10n.kde.org/ i18n.kde.org]), help to filter the incoming bugs (see [https://bugs.kde.org/ bugs.kde.org]).  


== Où puis-je trouver des images de Konqi le dragon ? ==
== Where can I find images of Konqi the dragon? ==


Le Konqi pour quelques personnes SDK se trouve sur [ftp://ftp.kde.org/pub/kde/devel/konqi_sdk.tar.bz2 ftp.kde.org/pub/kde/devel/konqi_sdk.tar.bz2]<br />
The Konqi for some people SDK is at [ftp://ftp.kde.org/pub/kde/devel/konqi_sdk.tar.bz2 ftp.kde.org/pub/kde/devel/konqi_sdk.tar.bz2]<br />
Il a été déposé sur artist.kde.org avant que ce site n'ait cessé d'être mis à jour.
It was posted to artist.kde.org before that site ceased to be updated.


Les images suivantes sont sur [http://kde.org/stuff/clipart.php KDE merchandise]. Vous pouvez trouver aussi quelques images Konqi non officielles sur [http://forum.kde.org/viewforum.php?f=254 Créer Konqi avec Krita Contest] et le jeu [http://sourceforge.net/projects/supertuxkart/ SuperTuxKart] .
Further images are on [http://kde.org/stuff/clipart.php KDE merchandise]. Also you can find some  unofficial Konqi images and models from [http://forum.kde.org/viewforum.php?f=254 Create Konqi with Krita Contest] and [http://sourceforge.net/projects/supertuxkart/ SuperTuxKart] game.


== Quel est le niveau requis pour contribuer à KDE ? Que devrais-je apprendre ? Que devrais-je lire ? ==
== What is the level required to contribute to KDE? What should I learn? What should I read? ==


Vous devez connaître le C++. Lisez le [http://qt-project.org/doc/qt-4.8/tutorials.html tutoriel Qt] et parcourez la documentation Qt pour être familier avec ce qui est disponible dans Qt. Ensuite lisez les [http://techbase.kde.org/Development/Tutorials tutoriels KDE] et parcourez l'architecture et la documentation. Vous pouvez aussi lire le [http://flossmanuals.net/kde-guide/ livre KDE], ça ne peut pas faire de mal. Mais vous ne devez pas être familier avec toute l'architecture de KDE pour être un développeur KDE. Utiliser les technologies KDE est très facile, aussi concentrez vous sur ce dont vous avez réellement besoin, vous pourrez apprendre les autres choses plus tard.
You need to know C++. Read the [http://qt-project.org/doc/qt-4.8/tutorials.html Qt tutorials] and browse the Qt docs to get familiar with what's available with Qt. Then read the [http://techbase.kde.org/Development/Tutorials KDE tutorials] and browse architecture and documentation. You can also read the [http://flossmanuals.net/kde-guide/ KDE Book], it can not harm. But you don't have to be familiar with the whole KDE architecture to become a KDE developer. Using KDE's technologies is quite easy, so concentrate on what you really need, you can learn the other bits later on.  
[http://techbase.kde.org KDE TechBase] et [http://doc.qt.digia.com/ doc.qt.digia.com] (aussi dans votre  {{path|$QTDIR/doc/html}}) sont des ressources inestimables, tirez-en avantage.
[http://techbase.kde.org KDE TechBase] and [http://doc.qt.digia.com/ doc.qt.digia.com] (also in your {{path|$QTDIR/doc/html}}) are invaluable resources, take advantage of them.
Ensuite, ouvrez les sources, cherchez les répertoires d'exemples, regardez comment les autres ont codé leurs applications. Lire et écrire du code est le meilleur moyen d'apprendre.
Then, browse the source, look for the examples directories, see how the other did code their applications. Reading and writing code is the best way to learn.


== Comment obtenir le logiciel KDE à partir des dépôts Git KDE ou SVN ? ==
== How do I get KDE software from the KDE git or SVN repositories? ==


Voyez la section [[Special:myLanguage/Getting_Started#Building_and_Running_KDE_Software_From_Source|Ecrire et exécuter du logiciel KDE à partir des sources]] sur la page [[Special:myLanguage/Getting_Started|Pour commencer]] .
See the [[Special:myLanguage/Getting_Started#Building_and_Running_KDE_Software_From_Source|Building and Running KDE Software From Source]] section on the [[Special:myLanguage/Getting_Started|Getting Started]] page.


== Puis-je accéder en ligne au code source KDE source ? ==
== Can I access KDE source code online? ==


Oui. Il y a plusieurs manières de faire cela :
Yes. There are many ways to do this:
* Affichez [http://websvn.kde.org/ websvn.kde.org], et [http://quickgit.kde.org/ quickgit.kde.org].
* Browse [http://websvn.kde.org/ websvn.kde.org], and [http://quickgit.kde.org/ quickgit.kde.org].
* Chercher le code souce sur [http://lxr.kde.org/search lxr.kde.org/search]
* Search the source code at [http://lxr.kde.org/search lxr.kde.org/search]
* Ouvrez la documentation d'API générée à partir du code source sur [http://api.kde.org/ api.kde.org]
* Browse API docs generated from the source code at [http://api.kde.org/ api.kde.org]
* Affichez le code source sur http://code.woboq.org/kde as in KDevelop
* Browse the source code on http://code.woboq.org/kde as in KDevelop


== Que dois-je mettre dans mon .subversion/config ? ==
== What should I put in my .subversion/config? ==


You need to add the ignore list to the [miscellany] group in your ~/.subversion/config:
You need to add the ignore list to the [miscellany] group in your ~/.subversion/config:
Line 61: Line 63:
</syntaxhighlight>
</syntaxhighlight>


Et pour demander à svn diff d'ignorer les espaces,et d'imprimer les noms des fonctions :
And to make svn diff ignore whitespace, and print function names:


<syntaxhighlight lang="bash">
<syntaxhighlight lang="bash">
Line 68: Line 70:
</syntaxhighlight>
</syntaxhighlight>


avec la suite dans {{path|/usr/local/bin/_svndiff}}:
with the following in {{path|/usr/local/bin/_svndiff}}:


<syntaxhighlight lang="bash">
<syntaxhighlight lang="bash">
Line 75: Line 77:
</syntaxhighlight>
</syntaxhighlight>


N'oubliez pas de rendre {{path|/usr/local/bin/_svndiff}} exécutable.
Don't forget to make {{path|/usr/local/bin/_svndiff}} executable.


== Je voudraits mettre mon application dans KDE ==
== I want to put my app in KDE ==


Il existe trois conditions :  
There are three requirements:  
* Votre application doit compiler avec la dernière version de KDE (git branche master ou SVN trunk).
* Your app must compile with the latest version of KDE (git master or SVN trunk).
* Votre application doit être stable.
* Your app must be stable.
* Votre application doit être maintenue. Vous aurez certainement un bon paquet de rapports d'erreurs et de demandes de souhaits. Les gens s'attendent à ce que vous corrigiez les bogues et implémentiez les souhaits qui ont un sens.
* Your app must be maintained. You will probably get a good deal of bug reports and wishes. People expect you to fix the bugs and implement the wishes that make sense.
Voyez également la question suivante.
See also the next question.


== Est-il préférable de développer dans ou en dehors de KDE ? ==
== Is it better to develop inside or outside KDE? ==


En tant que dévoloppeur du coeur Waldo Bastian explique dans un courriel patenté:  
As core developer Waldo Bastian explains in a copyrighted mail:  
<blockquote>
<blockquote>
Faire partie de KDE c'est travailler ensemble avec les autres. Ce type de coopération apporte à la longue des avantages mais implique également des responsabilités.
Being part of KDE means that you have to work together with others. Such cooperation brings along advantages but it also brings along responsibilities.
<br /><br />
<br /><br />


Quelques uns de ces avantages sont: votre code de retrouve dans toutes les distributions, les gens peuvent corriger vos fautes, vous obtenez des traductions gratuites ainsi que la documentation, vous recevez des tonnes de rapports de fautes.  
Some of those advantages are: your code ends up on all distro's, people might fix your bugs, you get free translations and documentation, you get tons of bugreports.
<br /><br />
<br /><br />


D'un autre côté, il y a des inconvénients et des responsabilités: vous devrez communiquer avec d'autres développeurs au sujet de votre travail, d'autres personnes pourraient apporter des modifications à votre code, vous devrez respecter les gels de versions, corrigez-les aussi (que fument-ils?), les gens s'attendent à ce que vous gardiez votre code à jour.
On the other side there are disadvantages and responsibilities: you will have to communicate with other developers about your work, other people might make changes to your code, you will have to respect release freezes, you get tons of bugreports and people actually expect that you fix them as well (what are they smoking?), people expect you to maintain your code.
<br /><br />
<br /><br />


Vous ne pouvez pas choisir les avantages et ignorer les responsabilités qui vont avec, c'est un paquetage complet, c'est tout ou rien.
You can't chose for the advantages and ignore the responsibilities that come with it, it's a complete package, it's both or nothing.
<br /><br />
<br /><br />


Line 107: Line 109:
</blockquote>
</blockquote>


C'est important de le savoir, mais n'ayez pas peur. Habituellement les choses se passent très bien. En 5 ans, cela n'est arrivé qu'une fois qu'un développeur ait vu son code dans KDE alors qu'il voulait le supprimer.
It is important to know that but don't be afraid. Usually, things work very well. In 5 years, it has only happened once that a developer had his work put kept in KDE while he wanted to remove it.


== Comment avoir accès en écriture sur les dépôts KDE ? ==
== How do I get write access to KDE repositories? ==


Voir l'article complet sur [[Special:myLanguage/Contribute/Get_a_Contributor_Account|Obtenir un compte de contributeur KDE]].
See full article at [[Special:myLanguage/Contribute/Get_a_Contributor_Account|Get a KDE Contributor Account]].


Allez sur [http://identity.kde.org KDE Identity], remplissez le formulaire et décrivez pourquoi vous avez besion d'un accès en écriture. Assurez-vous d'avoir bien marqué votre nom et votre adresse courriel.
Go to [http://identity.kde.org KDE Identity], fill out the form and describe why you need write access. Make sure to specify your full name and e-mail address.


Please also include the name of your [https://bugs.kde.org/ bugs.kde.org] account, if non-existent please create one so that it can be given usual developer rights. Closing bugs.kde.org reports with keywords in commit comments only works if the email address of your KDE Identity and bugs.kde.org accounts match. You can change your bugs.kde.org address in the Bugzilla user settings.
Please also include the name of your [https://bugs.kde.org/ bugs.kde.org] account, if non-existent please create one so that it can be given usual developer rights. Closing bugs.kde.org reports with keywords in commit comments only works if the email address of your KDE Identity and bugs.kde.org accounts match. You can change your bugs.kde.org address in the Bugzilla user settings.


Git demande à utiliser une clé ssh, et les nouveaux comptes pour SVN doivent aussi choisir le protocole svn+ssh . Envoyez une clé publique ssh (par exemple {{path|~/.ssh/id_dsa.pub}})
Git requires use of an ssh key, and new accounts for SVN must also choose the svn+ssh protocol. Send a public ssh key (e.g. {{path|~/.ssh/id_dsa.pub}})
   
   
Voir aussi [[#Comment créer une clé SSH ?]]
See also [[#How do I create a SSH key?]]


If you are contributing to an application that is not yours, it is a good idea to first submitting your coding as patches to the author and let him apply them. If the author is not maintaining his application, you might become the new maintainer...
If you are contributing to an application that is not yours, it is a good idea to first submitting your coding as patches to the author and let him apply them. If the author is not maintaining his application, you might become the new maintainer...
Line 125: Line 127:
Although there are few restrictions on repository commit rights, we expect you not to disrupt other developers' code without their consent. You must also respect the feature freezes of the release schedule (published on [[Schedules]] page)
Although there are few restrictions on repository commit rights, we expect you not to disrupt other developers' code without their consent. You must also respect the feature freezes of the release schedule (published on [[Schedules]] page)


Une liste détaillée des règles à suivre lorsque vous validez dans les dépôte KDE sont énumérées dans la [[Special:myLanguage/Policies/SVN_Commit_Policy|police KDE de validation]].
A detailed list of rules you should follow when committing to KDE repositories are listed in the [[Special:myLanguage/Policies/SVN_Commit_Policy|KDE Commit Policy]].


== Mon application n'est pas stable mais je voudrais l'avoir dans KDE ==
== My app is not stable but I would like to have it in KDE ==


As a first step, we can put it in playground, which is essentially "kde-alpha". Develop it there and when it is ready, request that your app to be moved to the appropriate KDE package or the extragear module.
As a first step, we can put it in playground, which is essentially "kde-alpha". Develop it there and when it is ready, request that your app to be moved to the appropriate KDE package or the extragear module.


== Je ne veux pas perdre mon historique SVN. ==
== I don't want to lose my SVN history. ==


Ceci n'est plus possible avec les sous-versions. Peut-être dans le futur, si le serveur est mis à jour et le permet. Notez que pour git ce n'est pas un problème.
This is no longer possible with Subversion. Maybe in the future, if the server is upgraded and allows that. Note that for git this is not an issue.


== Qu'est-ce que le kdebindings ? ==
== What is kdebindings? ==


It contains Qt bindings for Ruby, PHP, C# to use Qt classes with those langages, KDE bindings for  Ruby, C#, python to use KDE classes with those langages, and XParts to embed non-KDE apps as a KPart. Check the [[Special:myLanguage/Development/Languages|binding page]] of TechBase.  
It contains Qt bindings for Ruby, PHP, C# to use Qt classes with those langages, KDE bindings for  Ruby, C#, python to use KDE classes with those langages, and XParts to embed non-KDE apps as a KPart. Check the [[Special:myLanguage/Development/Languages|binding page]] of TechBase.  
Line 143: Line 145:
No, playground are not a released packages. The same is true for kdereview and extragear: they are not frozen and released. But if you want your app to move to a package, ask for it before the beta-release.
No, playground are not a released packages. The same is true for kdereview and extragear: they are not frozen and released. But if you want your app to move to a package, ask for it before the beta-release.


== Puis-je avoir une version stable et une version instable  de KDE sur le même ordinateur ? ==
==Can I have a stable and an unstable KDE on the same computer?==


Yes, check Building KDE Software from git.kde.org video series:
Yes, check Building KDE Software from git.kde.org video series:
Line 150: Line 152:
* [http://www.youtube.com/watch?v=SgwEnLeqsg8 Building KDE Software from git.kde.org Part 3]
* [http://www.youtube.com/watch?v=SgwEnLeqsg8 Building KDE Software from git.kde.org Part 3]


== Comment savoir la version de Qt/KDE que j'utilise ? ==
== How do I know which version of Qt/KDE I am using? ==


<tt>kde-config</tt> et toutes les applications KDE acceptent <tt>--version</tt> comme argument.
<tt>kde-config</tt> and all KDE programs accept <tt>--version</tt> as argument.


== Qt-copy or Qt de qt.digia.com: si on devait faire une compilation propre du tronc, que serait-il préférable ? ==
==Qt-copy or Qt from qt.digia.com: if one were doing a clean build of trunk, which would be preferable?==


You can use either. They are binary compatible (forward and backward). There can be, however, a few bugfixes in qt-copy over the most recent Qt release. Especially if building from qt-copy, pay attention to the apply-patches script.
You can use either. They are binary compatible (forward and backward). There can be, however, a few bugfixes in qt-copy over the most recent Qt release. Especially if building from qt-copy, pay attention to the apply-patches script.
Line 174: Line 176:
kdesdk/scripts/svn2dist is a script to extract an application from the KDE source tree and package it as a standalone application.  
kdesdk/scripts/svn2dist is a script to extract an application from the KDE source tree and package it as a standalone application.  


== Comment fermer mes propres rapports de bogue ? ==
== How do I close my own bug reports? ==


If you reported a bug that is fixed in a new release of KDE but is still reported as open, you can close it. It might happen because your bug is the same as another one, or simply because the developer fixed something without noticing that it would correct your bug.
If you reported a bug that is fixed in a new release of KDE but is still reported as open, you can close it. It might happen because your bug is the same as another one, or simply because the developer fixed something without noticing that it would correct your bug.


Comment pouvez-vous faire cela à partir de votre validation Subversion. Pour cela, ajouter à votre message de validation une ligne comme :
You can do that from your Subversion commit. To do so, append to your commit message a line like this:


<Code>BUG: XXXXX</code> where '''''XXXXX''''' is the bug report you want to close. If the report you're closing is adding a new feature, you can use FEATURE instead of BUG.  
<Code>BUG: XXXXX</code> where '''''XXXXX''''' is the bug report you want to close. If the report you're closing is adding a new feature, you can use FEATURE instead of BUG.  
Line 184: Line 186:
Managing a bug list is a huge task for the developers and they usually have a lot of bugs listed, some being fixed already without their knowledge, some being unreproducible, some without enough information to be corrected, etc. If you can help by managing and updating the list of outstanding bugs, you will be gladly welcome. And you will receive an even happier welcome if you provide a patch.
Managing a bug list is a huge task for the developers and they usually have a lot of bugs listed, some being fixed already without their knowledge, some being unreproducible, some without enough information to be corrected, etc. If you can help by managing and updating the list of outstanding bugs, you will be gladly welcome. And you will receive an even happier welcome if you provide a patch.


== Comment créer une clé SSH ? ==
== How do I create a SSH key? ==


SSH makes use of two keys: a private key and a public key. You should keep the private key secret at all times and only place it on machines over which you have direct control. Public, shared, and community machines are not suitable environments to store SSH private keys. Take action to help prevent theft of your SSH private key data. Setting a password on your SSH private key will help reduce the risks involved with private key theft.
SSH makes use of two keys: a private key and a public key. You should keep the private key secret at all times and only place it on machines over which you have direct control. Public, shared, and community machines are not suitable environments to store SSH private keys. Take action to help prevent theft of your SSH private key data. Setting a password on your SSH private key will help reduce the risks involved with private key theft.
Line 202: Line 204:
In order to use SSH to access KDE servers you need to send your public key to sysadmin (at) kde (dot) org.
In order to use SSH to access KDE servers you need to send your public key to sysadmin (at) kde (dot) org.


== Comment monitorer les modifications faites par les autres ? ==
== How can I monitor changes made by others? ==


The [https://mail.kde.org/mailman/listinfo/kde-commits kde-commits] mailinglist carries automatic notifications for all changes made in the KDE repositories. The KDE-Commits mailinglist is very high traffic. An alternative is [http://commitfilter.kde.org/ CommitFilter] which allows you to get notification for only those areas that interest you.
The [https://mail.kde.org/mailman/listinfo/kde-commits kde-commits] mailinglist carries automatic notifications for all changes made in the KDE repositories. The KDE-Commits mailinglist is very high traffic. An alternative is [http://commitfilter.kde.org/ CommitFilter] which allows you to get notification for only those areas that interest you.


[[Category:FAQs]]
[[Category:FAQs]]

Latest revision as of 10:10, 17 May 2019

 
Proposed for Deletion
This page has been proposed for deletion for the following reason:

Content is now at https://community.kde.org/KDE/FAQs/General_FAQ and this page may no longer be up-to-date. Translations are still available for this page, however.

I want to start this new application. What do you advise?

We all agree that there are plenty of KDE applications that need to be written. But there are also a lot of existing kde applications that need your help.

To see the areas where help is needed, check this page.

Before starting a new application, it's always a good idea to check KDE-Apps.org and other open source software hosting services like GitHub, Google Code, and SourceForge for existing applications and to ask on the kde-devel mailing-list whether someone is already working on a similar project.

I am a developer, how can I contribute to KDE software?

Calligra and KDevelop, despite being very praised, have very few developers, so you might check there. There is no need to be a developer of the KDE workspaces or KDE platform libraries to help. The whole range of KDE software is very modular so you can perfectly improve one area without knowing how others work.

You can also ask on kde-devel if someone needs help on an application. Use the latest version of your favourite KDE software and spot things that are needed. A theme generator? A konsole schema editor? Improve a game? There is always a small feature missing. Go and implement it!

Are you familiar or attracted with a specific field? See if there is a related application that could use your help. Or write one. KDE especially welcomes more non-geek oriented applications.

I am not a developer, how can I help?

There are plenty of tasks that don't require development skills. Write reviews of applications for the promoting of KDE (see the kde-promo mailing-list), help the documentation team (see i18n.kde.org/doc), help the translations (see i18n.kde.org), help to filter the incoming bugs (see bugs.kde.org).

Where can I find images of Konqi the dragon?

The Konqi for some people SDK is at ftp.kde.org/pub/kde/devel/konqi_sdk.tar.bz2
It was posted to artist.kde.org before that site ceased to be updated.

Further images are on KDE merchandise. Also you can find some unofficial Konqi images and models from Create Konqi with Krita Contest and SuperTuxKart game.

What is the level required to contribute to KDE? What should I learn? What should I read?

You need to know C++. Read the Qt tutorials and browse the Qt docs to get familiar with what's available with Qt. Then read the KDE tutorials and browse architecture and documentation. You can also read the KDE Book, it can not harm. But you don't have to be familiar with the whole KDE architecture to become a KDE developer. Using KDE's technologies is quite easy, so concentrate on what you really need, you can learn the other bits later on. KDE TechBase and doc.qt.digia.com (also in your $QTDIR/doc/html) are invaluable resources, take advantage of them. Then, browse the source, look for the examples directories, see how the other did code their applications. Reading and writing code is the best way to learn.

How do I get KDE software from the KDE git or SVN repositories?

See the Building and Running KDE Software From Source section on the Getting Started page.

Can I access KDE source code online?

Yes. There are many ways to do this:

What should I put in my .subversion/config?

You need to add the ignore list to the [miscellany] group in your ~/.subversion/config:

[miscellany]
global-ignores = *.moc *.moc.cc *.moc.cpp config.log config.status \
config.cache *.gmo .deps .libs SunWS_cache *.lo *.la *.rpo *.la.closure \
*_la_closure.cpp *_la_closure.cc *_la_closure.cxx *.all_cc.cc *.all_cpp.cpp \
*.all_C.C *.all_cxx.cxx *_meta_unload.cc *_meta_unload.h *_meta_unload.cpp \
*_meta_unload.C *_meta_unload.cxx index.cache.bz2 .memdump Makefile.rules.in \
Makefile.calls.in Makefile.rules Makefile.calls autom4te.cache *.kidl \
*.o *.lo *.la #*# .*.rej *.rej *.pyc

And to make svn diff ignore whitespace, and print function names:

[helpers]
diff-cmd = /usr/local/bin/_svndiff

with the following in /usr/local/bin/_svndiff:

#!/bin/sh
exec /usr/bin/diff -b -u -p "$@"

Don't forget to make /usr/local/bin/_svndiff executable.

I want to put my app in KDE

There are three requirements:

  • Your app must compile with the latest version of KDE (git master or SVN trunk).
  • Your app must be stable.
  • Your app must be maintained. You will probably get a good deal of bug reports and wishes. People expect you to fix the bugs and implement the wishes that make sense.

See also the next question.

Is it better to develop inside or outside KDE?

As core developer Waldo Bastian explains in a copyrighted mail:

Being part of KDE means that you have to work together with others. Such cooperation brings along advantages but it also brings along responsibilities.

Some of those advantages are: your code ends up on all distro's, people might fix your bugs, you get free translations and documentation, you get tons of bugreports.

On the other side there are disadvantages and responsibilities: you will have to communicate with other developers about your work, other people might make changes to your code, you will have to respect release freezes, you get tons of bugreports and people actually expect that you fix them as well (what are they smoking?), people expect you to maintain your code.

You can't chose for the advantages and ignore the responsibilities that come with it, it's a complete package, it's both or nothing.

In general it should be the author of a piece of software that chooses to put his application in KDE's repositories. We usually don't put software in KDE's repositories unless the author wishes to do so. The other way around, if the author prefers to work on his application elsewhere then that's his right as well. Unless there is a split in the actual group of people working on the application it makes no sense to fork the development of an application because of that.

BUT... by putting your code under and open source license and putting it in a KDE repository you give the world at large, as well as KDE in particular, the irrevocable right to use your code. And KDE will use that right at its discretion to protect the interests of KDE, even if that goes against the wishes of the author at that point in time.

It is important to know that but don't be afraid. Usually, things work very well. In 5 years, it has only happened once that a developer had his work put kept in KDE while he wanted to remove it.

How do I get write access to KDE repositories?

See full article at Get a KDE Contributor Account.

Go to KDE Identity, fill out the form and describe why you need write access. Make sure to specify your full name and e-mail address.

Please also include the name of your bugs.kde.org account, if non-existent please create one so that it can be given usual developer rights. Closing bugs.kde.org reports with keywords in commit comments only works if the email address of your KDE Identity and bugs.kde.org accounts match. You can change your bugs.kde.org address in the Bugzilla user settings.

Git requires use of an ssh key, and new accounts for SVN must also choose the svn+ssh protocol. Send a public ssh key (e.g. ~/.ssh/id_dsa.pub)

See also #How do I create a SSH key?

If you are contributing to an application that is not yours, it is a good idea to first submitting your coding as patches to the author and let him apply them. If the author is not maintaining his application, you might become the new maintainer...

Although there are few restrictions on repository commit rights, we expect you not to disrupt other developers' code without their consent. You must also respect the feature freezes of the release schedule (published on Schedules page)

A detailed list of rules you should follow when committing to KDE repositories are listed in the KDE Commit Policy.

My app is not stable but I would like to have it in KDE

As a first step, we can put it in playground, which is essentially "kde-alpha". Develop it there and when it is ready, request that your app to be moved to the appropriate KDE package or the extragear module.

I don't want to lose my SVN history.

This is no longer possible with Subversion. Maybe in the future, if the server is upgraded and allows that. Note that for git this is not an issue.

What is kdebindings?

It contains Qt bindings for Ruby, PHP, C# to use Qt classes with those langages, KDE bindings for Ruby, C#, python to use KDE classes with those langages, and XParts to embed non-KDE apps as a KPart. Check the binding page of TechBase.

Does the feature freeze apply to playground?

No, playground are not a released packages. The same is true for kdereview and extragear: they are not frozen and released. But if you want your app to move to a package, ask for it before the beta-release.

Can I have a stable and an unstable KDE on the same computer?

Yes, check Building KDE Software from git.kde.org video series:

How do I know which version of Qt/KDE I am using?

kde-config and all KDE programs accept --version as argument.

Qt-copy or Qt from qt.digia.com: if one were doing a clean build of trunk, which would be preferable?

You can use either. They are binary compatible (forward and backward). There can be, however, a few bugfixes in qt-copy over the most recent Qt release. Especially if building from qt-copy, pay attention to the apply-patches script.

How can I checkout a single directory from a SVN module?

Checkout the top-level dir with 'svn co -N /modulename', 'cd modulename', 'svn up admin' to get the admin/ dir and then finally checkout the dir you want with 'svn up subdir'

For instance, to get only reaktivate from playground/utils: svn co -N /playground/utils; svn up reaktivate Then compile as usual.

The same answer applies to the question "How do I get a single language out of kde-i18n?".

If you don't know the name of the directory you want to check out, you can browse websvn.kde.org to find it.

How can I get one of the KDE application as a standalone tarball?

kdesdk/scripts/svn2dist is a script to extract an application from the KDE source tree and package it as a standalone application.

How do I close my own bug reports?

If you reported a bug that is fixed in a new release of KDE but is still reported as open, you can close it. It might happen because your bug is the same as another one, or simply because the developer fixed something without noticing that it would correct your bug.

You can do that from your Subversion commit. To do so, append to your commit message a line like this:

BUG: XXXXX where XXXXX is the bug report you want to close. If the report you're closing is adding a new feature, you can use FEATURE instead of BUG.

Managing a bug list is a huge task for the developers and they usually have a lot of bugs listed, some being fixed already without their knowledge, some being unreproducible, some without enough information to be corrected, etc. If you can help by managing and updating the list of outstanding bugs, you will be gladly welcome. And you will receive an even happier welcome if you provide a patch.

How do I create a SSH key?

SSH makes use of two keys: a private key and a public key. You should keep the private key secret at all times and only place it on machines over which you have direct control. Public, shared, and community machines are not suitable environments to store SSH private keys. Take action to help prevent theft of your SSH private key data. Setting a password on your SSH private key will help reduce the risks involved with private key theft.

Generate a key pair for each major location you work from. This helps to reduce the impact when your key gets stolen. When someone obtains access to your private key, your key can be abused in attempts to compromise KDE servers. Well known open source projects have been compromised this way in the past, YOU must help us to make sure that this doesn't happen with KDE servers as well. For that reason it is important to notify sysadmin (at) kde (dot) org immediately when you notice that someone may have had access to your private key for example when a computer on which it was stored has been hacked or infected with a virus, worm or trojan.

If you choose to make a backup of your SSH private key data, please ensure that any such backup is stored in a secure manner as well.

For the practical part, the following command can be used to generate a SSH private/public key pair with ssh-keygen -t dsa This will create a private key as ~/.ssh/id_dsa and a public key as ~/.ssh/id_dsa.pub.

There are times when you may want to use a key of a different name to the default, perhaps to use separate keys for different projects. To let SSH know which key you want to use for KDE.org, you can keep a list of servers and their corresponding keys in ~/.ssh/config. For example,

Host svn.kde.org 
IdentityFile ~/.ssh/id_dsa_kde

In order to use SSH to access KDE servers you need to send your public key to sysadmin (at) kde (dot) org.

How can I monitor changes made by others?

The kde-commits mailinglist carries automatic notifications for all changes made in the KDE repositories. The KDE-Commits mailinglist is very high traffic. An alternative is CommitFilter which allows you to get notification for only those areas that interest you.