Getting Started/Using Project Neon to contribute to KDE: Difference between revisions

From KDE TechBase
(→‎Contact the Team: not sure code /code is the right way to handle this!)
(update to new syntaxhighlighter)
Line 13: Line 13:
To use Project Neon, add the following PPA (Personal Package Archive) to your <tt>sources.list</tt> using your preferred method:
To use Project Neon, add the following PPA (Personal Package Archive) to your <tt>sources.list</tt> using your preferred method:


<code bash>
<syntaxhighlight lang="bash">
sudo add-apt-repository ppa:neon/ppa
sudo add-apt-repository ppa:neon/ppa
</code>
</syntaxhighlight>
or
or
<code bash>
<pre>
# Project neon nightly KDE4 build
# Project neon nightly KDE4 build
deb http://ppa.launchpad.net/neon/ppa/ubuntu maverick main
deb http://ppa.launchpad.net/neon/ppa/ubuntu maverick main
Line 23: Line 23:
#above repository is PGP signed, refer to below link for getting PGP key
#above repository is PGP signed, refer to below link for getting PGP key
https://launchpad.net/~neon/+archive/ppa
https://launchpad.net/~neon/+archive/ppa
</code>
</pre>


After that, you can simply install the nightly package of whichever modules you want to work on. The Packages are named project-neon-<git/svn module name>.
After that, you can simply install the nightly package of whichever modules you want to work on. The Packages are named project-neon-<git/svn module name>.
Line 29: Line 29:
You can install all of the packages or just the ones you are interested in, depending on what you want to use them for. For example if you want to install the KDE Workspace with the extra plasmoids, you would install the <tt>project-neon-kdeplasma-addons</tt> and <tt>project-neon-session</tt> so you get KDM support for Project Neon.
You can install all of the packages or just the ones you are interested in, depending on what you want to use them for. For example if you want to install the KDE Workspace with the extra plasmoids, you would install the <tt>project-neon-kdeplasma-addons</tt> and <tt>project-neon-session</tt> so you get KDM support for Project Neon.


<code bash>
<syntaxhighlight lang="bash">
sudo apt-get install project-neon-kdeplasma-addons project-neon-session
sudo apt-get install project-neon-kdeplasma-addons project-neon-session
</code>
</syntaxhighlight>


If you are only interested in application development in another module, you can install just the module package.
If you are only interested in application development in another module, you can install just the module package.


<code bash>
<syntaxhighlight lang="bash">
sudo apt-get install project-neon-kdepim project-neon-common
sudo apt-get install project-neon-kdepim project-neon-common
</code>
</syntaxhighlight>


That command will also install the <tt>kdelibs</tt>, <tt>kdepimlibs</tt> and other dependencies too. In your regular (stable) KDE session you can then run the nightly version of your chosen application after setting up the environment.
That command will also install the <tt>kdelibs</tt>, <tt>kdepimlibs</tt> and other dependencies too. In your regular (stable) KDE session you can then run the nightly version of your chosen application after setting up the environment.


<code bash>
<syntaxhighlight lang="bash">
. /opt/project-neon/share/project-neon/environment.rc
. /opt/project-neon/share/project-neon/environment.rc
kmail
kmail
</code>
</syntaxhighlight>


Instead of sourcing the settings by hand every time, you could add this to your .bashrc:
Instead of sourcing the settings by hand every time, you could add this to your .bashrc:


<code bash>
<syntaxhighlight lang="bash">
switchtonightly ()
switchtonightly ()
{
{
   . /opt/project-neon/share/project-neon/environment.rc
   . /opt/project-neon/share/project-neon/environment.rc
}
}
</code>
</syntaxhighlight>


or use <tt>neon-env</tt> (see below), but you can't run non-Project Neon apps when you use neon-env.
or use <tt>neon-env</tt> (see below), but you can't run non-Project Neon apps when you use neon-env.
Line 99: Line 99:
Debugging Symbols:
Debugging Symbols:
The debugging symbols for every package are in it's corresponding -dbg package, so to install the debugging symbols for kdelibs you can use
The debugging symbols for every package are in it's corresponding -dbg package, so to install the debugging symbols for kdelibs you can use
<code bash>
<syntaxhighlight lang="bash">
sudo apt-get install project-neon-kdelibs-dbg
sudo apt-get install project-neon-kdelibs-dbg
</code>
</syntaxhighlight>


If you are already using a nightly package of the module you want to develop for, you should remove that, and checkout the development version. For example:
If you are already using a nightly package of the module you want to develop for, you should remove that, and checkout the development version. For example:


<code bash>
<pre>
# Remove the packaged nightly version
# Remove the packaged nightly version
sudo apt-get purge project-neon-kdepim
sudo apt-get purge project-neon-kdepim
Line 125: Line 125:
# and install it to the prefix /opt/project-neon/
# and install it to the prefix /opt/project-neon/
neonmake
neonmake
</code>
</pre>


Note that you should usually checkout a module from KDE, not an application. Most modules contain libraries shared within the module and which are necessary to build the applications in the module.
Note that you should usually checkout a module from KDE, not an application. Most modules contain libraries shared within the module and which are necessary to build the applications in the module.
Line 136: Line 136:
The Project Neon nightly packages include English language strings only. Translated packages are not available. However, if you are translating KDE applications, you can install the translations from KDE SVN in your normal workflow.
The Project Neon nightly packages include English language strings only. Translated packages are not available. However, if you are translating KDE applications, you can install the translations from KDE SVN in your normal workflow.


<code bash>
<syntaxhighlight lang="bash">
cd ~
cd ~
cd Translations
cd Translations
Line 152: Line 152:
neon-env
neon-env
neonmake
neonmake
</code>
</syntaxhighlight>


After building the translations it is possible to either change the language in system settings, or run applications in another language using the environment variable <tt>KDE_LANG</tt>.
After building the translations it is possible to either change the language in system settings, or run applications in another language using the environment variable <tt>KDE_LANG</tt>.


<code bash>
<syntaxhighlight lang="bash">
switchtonightly # or neon-env
switchtonightly # or neon-env
KDE_LANG=de kmail
KDE_LANG=de kmail
</code>
</syntaxhighlight>


exit the shell to reset the settings.
exit the shell to reset the settings.
Line 177: Line 177:
Here is a shortcut to get all available modules from the PPA:
Here is a shortcut to get all available modules from the PPA:


<code bash>
<syntaxhighlight lang="bash">
sudo apt-get install project-neon-all
sudo apt-get install project-neon-all
</code>
</syntaxhighlight>


The application [http://ariya.blogspot.com/2008/06/creating-fancy-screenshots-with.html screenie] is provided since Kubuntu 8.10 as <tt>screenie-qt</tt>.
The application [http://ariya.blogspot.com/2008/06/creating-fancy-screenshots-with.html screenie] is provided since Kubuntu 8.10 as <tt>screenie-qt</tt>.


<code bash>
<syntaxhighlight lang="bash">
sudo apt-get install screenie-qt
sudo apt-get install screenie-qt
</code>
</syntaxhighlight>


== Contact the Team ==
== Contact the Team ==

Revision as of 20:05, 29 June 2011


Getting_Started/Using_Project_Neon_to_contribute_to_KDE


Project Neon is a nightly build of the latest KDE trunk. It is an easy way for new contributors to KDE to get started without having to build the entire KDE-SVN tree and maintain the checkout. Additionally, dependencies are automatically handled and updated. This is suitable for new developers, translators, usability designers, documenters, promoters, bug triagers etc. This process makes the steps detailed on this page.

However, for developers, it may at some point become necessary to build more components from SVN as you become more involved in the project. The kdesrc-build script is an easy way to build all or parts of KDE SVN.

Requirements

Project neon always requires the latest stable Kubuntu release or development release. Previous versions of Kubuntu are not supported.

Installing Project Neon

To use Project Neon, add the following PPA (Personal Package Archive) to your sources.list using your preferred method:

sudo add-apt-repository ppa:neon/ppa

or

# Project neon nightly KDE4 build
deb http://ppa.launchpad.net/neon/ppa/ubuntu maverick main

#above repository is PGP signed, refer to below link for getting PGP key
https://launchpad.net/~neon/+archive/ppa

After that, you can simply install the nightly package of whichever modules you want to work on. The Packages are named project-neon-<git/svn module name>.

You can install all of the packages or just the ones you are interested in, depending on what you want to use them for. For example if you want to install the KDE Workspace with the extra plasmoids, you would install the project-neon-kdeplasma-addons and project-neon-session so you get KDM support for Project Neon.

sudo apt-get install project-neon-kdeplasma-addons project-neon-session

If you are only interested in application development in another module, you can install just the module package.

sudo apt-get install project-neon-kdepim project-neon-common

That command will also install the kdelibs, kdepimlibs and other dependencies too. In your regular (stable) KDE session you can then run the nightly version of your chosen application after setting up the environment.

. /opt/project-neon/share/project-neon/environment.rc
kmail

Instead of sourcing the settings by hand every time, you could add this to your .bashrc:

switchtonightly ()
{
  . /opt/project-neon/share/project-neon/environment.rc
}

or use neon-env (see below), but you can't run non-Project Neon apps when you use neon-env.

You'll need to close the terminal session for the settings to be undone.

This will correctly use the nightly version of libraries instead of using the stable versions, so no other changes are necessary to your library path etc.

Note that settings for applications that you run from project neon do not conflict with your regular application settings and data. .project-neon-kde/ is used instead of .kde/

Using Project Neon for development

If you are joining one of the development teams in KDE, you will need a real SVN/GIT checkout in order to contribute your code back to the project and create patches easily.

Some extra tools are provided for this purpose in the package project-neon-utils:

NOTE: both neon-cmake and neonmake require neon-env to be run first!

neon-env - sets up the necessary environment settings for project neon builds and opens a subshell.

neon-cmake - cmake wrapper with neon environment settings for cmake, same synopsis as cmake and passes arguments to cmake

neonmake - convenience script which will create a build folder, configure the source, build it and install it in /opt/project-neon/ so you can test your changes.

neon-clean - This script will reset all changes you did to /opt/project-neon after installing the packages. Since this script reinstalls the packages it might require a working internet connection.

neonbuild - pbuilder/pdebuild wrapper to rebuild a neon package in a chroot. Takes the same options as pbuilder. If no pbuidler action is given pdebuild is run instead.


You can change the cmake and make options used by setting these variables in ~/.neonrc:

NEON_CMAKE_OPTS="" Here you can add additional cmake options that should be used together with the default neon options.

NEON_CMAKE_OVERRIDE="" If you set this variable cmake will ignore the default neon options and only use the ones in NEON_CMAKE_OVERRIDE.

NEON_MAKE_OVERRIDE="" If you set this variable make in neonmake will only use your options. By default make uses '-j CPUs+1'


Debugging Symbols: The debugging symbols for every package are in it's corresponding -dbg package, so to install the debugging symbols for kdelibs you can use

sudo apt-get install project-neon-kdelibs-dbg

If you are already using a nightly package of the module you want to develop for, you should remove that, and checkout the development version. For example:

# Remove the packaged nightly version
sudo apt-get purge project-neon-kdepim

# Add below Project Neon source code repository to sources.list if you didn't use add-apt-repository
deb-src http://ppa.launchpad.net/neon/ppa/ubuntu maverick main

# Get the dependencies for building kdepim
sudo apt-get build-dep project-neon-kdepim
cd ~
# You may choose to do your development in a different folder.
cd Development
# Gets the latest version of the kdepim module.
git clone git://anongit.kde.org/kdepim
cd kdepim
# Set up neon environment
neon-env
# Shortcut provided by Project Neon to make the module
# and install it to the prefix /opt/project-neon/
neonmake

Note that you should usually checkout a module from KDE, not an application. Most modules contain libraries shared within the module and which are necessary to build the applications in the module.

Also note that when using apt-get build-dep it will always get all build-depends, so watch out that it doesn't install a component you want to build yourself as that would overwrite your changes should you install the packages after installing your build.


Using Project Neon for translation

The Project Neon nightly packages include English language strings only. Translated packages are not available. However, if you are translating KDE applications, you can install the translations from KDE SVN in your normal workflow.

cd ~
cd Translations
# The -N switch checks out only the top level directory from svn.
svn co -N svn://anonsvn.kde.org/home/kde/trunk/l10n-kde4
cd l10n-kde4
# scripts necessary to build translations.
svn up scripts
# Get the German translations
svn up de
# Generate the build files for the German language pack - if you get a message
# that revpath couldn't be found you need to install the xutils-dev package
./scripts/autogen.sh de
cd de
neon-env
neonmake

After building the translations it is possible to either change the language in system settings, or run applications in another language using the environment variable KDE_LANG.

switchtonightly # or neon-env
KDE_LANG=de kmail

exit the shell to reset the settings.

Using Project Neon for documentation

The Project Neon nightly source packages include the official KDE User Documentation in English.

TODO: How to build user docs from SVN.

Using Project Neon for promotion

If you are creating screenshots or screencasts of the latest version of KDE, project Neon is a simple and fast way of getting a default KDE4 session.

The KDE Promotion team recommends using the default background, theme, icons etc when preparing official promotional materials (unless the feature you are showing is related to configuring KDE artwork). Project Neon uses the default artwork that comes with KDE4, so it is useful for creating promo materials.

Here is a shortcut to get all available modules from the PPA:

sudo apt-get install project-neon-all

The application screenie is provided since Kubuntu 8.10 as screenie-qt.

sudo apt-get install screenie-qt

Contact the Team

You can reach the Project Neon team on IRC in #project-neon on irc.freenode.net by mail at [email protected] or you can ask a question on launchpad

If you think there is a bug in our packaging of the provided software you can file a bug on launchpad

Team page in the Kubuntu Wiki