Jump to content

User:Donnguyen: Difference between revisions

From KDE Community Wiki
Donnguyen (talk | contribs)
Donnguyen (talk | contribs)
 
(48 intermediate revisions by the same user not shown)
Line 1: Line 1:
= Building KDE/Plasma 5 on Ubuntu 14.04 LTS =
==Projects==
{{Warning|Since this guide uses packages from Xenial and PPA's, this may cause instability to your system
===Dolphin===
}}
[https://www.kde.org/applications/system/dolphin/development Dolphin - Development Information]
The aim of this guide is to help you build KDE Plasma 5 for development and/or use. I decided to write a guide specifically for Ubuntu 14.04 because it can be tricky to resolve all of the build dependencies and problems specific to this system
{{Note|These instructions are valid as of 2 Sep 2016, which will build Plasma 5.7.90 and KDE Frameworks 5.25.0. }}
Since you will be building out of the master branch, dependencies may change after this guide is written.  I will try to update this guide to cover any new dependencies.


Most of the instructions in this guide can be cut and pasted. A few steps will require you to edit some files or interact with a GUI.
[https://docs.kde.org/trunk5/en/applications/dolphin/ Dolpin Handbook]


{{Note|Following the instructions in this guide will install Qt to /opt/Qt5.7.0 and kde to /opt/kde-5.
[https://github.com/KDE/dolphin Dolphin github]
}}
{{Warning|2=Important|1=Building software is not a simple task.  If you simply wish to try out Plasma 5, I recommend you look at other methods
}}


== Install a recent version of cmake ==
==Guides I've Written==
You will need to install a more recent version of cmake to build.
[[Guidelines_and_HOWTOs/Build_from_source/Plasma 5 on Ubuntu 14.04 LTS|How to build KDE/Plasma 5 on Ubuntu 14.04 LTS]]
{{Input|1=<nowiki>
sudo apt-get install build-essential
wget https://cmake.org/files/v3.6/cmake-3.6.1.tar.gz
tar -zxvf cmake-3.6.1.tar.gz
cd cmake-3.6.1/
./configure
make
sudo apt-get install checkinstall
sudo checkinstall
</nowiki>}}


== Upgrade libwayland-dev and network-manager from PPA's ==
[[/Building_and_using_Qt5GStreamer_on_Windows|Building and using Qt5GStreamer on Windows]]
Upgrade libwayland-dev and related dependencies:
{{Input|1=<nowiki>sudo add-apt-repository ppa:xorg-edgers/ppa
sudo apt-get update  
sudo apt-get install libwayland-dev
</nowiki>}}
Upgrade network-manager and related dependencies:
{{Input|1=<nowiki>sudo add-apt-repository ppa:9v-shaun-42/networkmanager 
sudo apt-get update
sudo apt-get install network-manager
</nowiki>}}
{{Tip|You may lose network connection after this step.  Reboot to fix.}}


== Install Qt 5.7.0 using Qt offline installer ==
==Videos I've Made==
Download and install Qt 5.7.0 to the default location /opt/Qt5.7.0
[https://www.youtube.com/watch?v=28Jjf5Ak6Q0 Touchscreen gestures in Linux using Touchegg]
{{Input|1=<nowiki>wget http://download.qt.io/official_releases/qt/5.7/5.7.0/qt-opensource-linux-x64-5.7.0.run
sudo ./qt-opensource-linux-x64-5.7.0.run</nowiki>}}
Choose default options and include "Sources" option
{{Note|On my computer it appears to be stuck at 4%(dialog box doesn't respond), but it installs just fine if I wait.}}


== Install some build dependencies ==
==KDE==
[irc://irc.kde.org/kde-devel <nowiki>#kde-devel</nowiki>]


{{Input|1=<nowiki>sudo apt-get build-dep kde-workspace qtbase5-dev</nowiki>}}
https://git.reviewboard.kde.org/dashboard/


== Build Qtwebkit ==
===https://bugs.kde.org/===
[https://bugs.kde.org/buglist.cgi?bug_status=CONFIRMED&order=changeddate%20DESC%2Cbug_id%20DESC&product=dolphin&query_format=advanced Confirmed dolphin bugs]
Install dependencies for building Qtwebkit:
{{Input|1=<nowiki>sudo apt-get install flex bison gperf libicu-dev libxslt-dev ruby</nowiki>}}
Install git:
{{Input|1=<nowiki>sudo apt-get install git</nowiki>}}
Clone and build qtwebkit:
{{Input|1=<nowiki>git clone git://code.qt.io/qt/qtwebkit.git --branch 5.7.0
mkdir qtwebkit-build
cd qtwebkit-build
/opt/Qt5.7.0/5.7/gcc_64/bin/qmake ../qtwebkit
make
sudo make install
</nowiki>}}


== Setup kdesrc-build and .kdesrc-buildrc ==
[https://bugs.kde.org/buglist.cgi?bug_status=UNCONFIRMED&bug_status=CONFIRMED&bug_status=ASSIGNED&bug_status=REOPENED&email2=don78colorado&emailassigned_to2=1&emailcc2=1&emailreporter2=1&emailtype2=substring&query_format=advanced Bugs related to me]
kdesrc-build needs xml-parser-perl so install it with the following command:
{{Input|1=<nowiki>sudo apt-get install libxml-parser-perl</nowiki>}}


Most of this section is taken from https://community.kde.org/Guidelines_and_HOWTOs/Build_from_source and copied here for your convenience.  Be sure to set qtdir and kdedir as directed at the end of this section.


=== Git remote prefix ===
https://identity.kde.org/
Let's setup a "kde:" prefix for git commands. Add the following text to your ~/.gitconfig:
<syntaxhighlight lang="ini">
[url "git://anongit.kde.org/"]
  insteadOf = kde:
[url "ssh://[email protected]/"]
  pushInsteadOf = kde:
</syntaxhighlight>


=== Install kdesrc-build ===
https://lxr.kde.org
''kdesrc-build'' is,  a user-space package manager, it is used to compile KDE-related projects from source and installs them into a designated directory.


Follow the given steps to set up kdesrc-build to install KDevelop into our $HOME directory:
https://phabricator.kde.org/
<pre>
mkdir ~/kdesrc 
cd ~/kdesrc 
git clone kde:kdesrc-build 
cd kdesrc-build 
cp kdesrc-buildrc-kf5-sample ~/.kdesrc-buildrc


# Install a symlink of kdesrc-build to a location in PATH
[https://quickgit.kde.org/ KDE QuickGit]
mkdir ~/bin 
ln -s $PWD/kdesrc-build ~/bin 
export PATH=~/bin:$PATH
</pre>


You will need to append the line <pre>export PATH=~/bin:$PATH</pre> to <pre>~/.bashrc</pre> so kdesrc-build is available in PATH whenever you open a terminal.
[https://github.com/kde/ KDE GitHub]


[https://www.kde.org/standards/kxmlgui/1.0/kxmlgui.xsd KXMLGUI XSD]


'''Configure kdesrc-build
==Links==
'''
===Development===
edit<pre>~/.kdesrc-buildrc</pre> 
[[Get_Involved/development]]
Replace <pre>/path/to/kdesrc-build/kf5-qt5-build-include</pre> with <pre>~/kdesrc/kdesrc-build/kf5-qt5-build-include</pre> in ~/.kdesrc-buildrc file


Add <pre>ignore-kde-structure true</pre> and <pre>make-options -jN</pre> to the global section in ~/.kdesrc-buildrc
[[Guidelines_and_HOWTOs/Using_Qt_Creator]]
<pre>
global 
  ...
  ignore-kde-structure true
  make-options -j5 # NOTE: 5 is the number of jobs, this should usually be (number-of-cpu-cores + 1)
  #stop-on-failure        true        # Stop kdesrc-build
  ...
end global 
</pre>


Set qtdir to output of <code>qmake –v</code> minus the lib
[[Policies/Commit_Policy]]
    kdedir /opt/kde-5 # Where to install KF5-based software
    qtdir /opt/Qt5.7.0/5.7/gcc_64    # Where to find Qt5
{{Remember|Make sure you have write access to the directory specified by kdedir!}}
===Setup work around for baloo compilation error ===
Add the following to ~/.kdesrc-buildrc to work around the compilation error with baloo:
  options baloo
      cmake-options -DCMAKE_CXX_FLAGS="-lc"
  end options


== Build plasma-desktop ==
[[Guidelines_and_HOWTOs/UnitTests]]
Install dependencies to build plasma-desktop:
{{Input|1=<nowiki>sudo apt-get build-dep polkit-qt-1
sudo apt-get install libgif-dev libnm-glib-dev "^libxcb.*" libx11-xcb-dev libglu1-mesa-dev libxrender-dev libxi-dev libattr1-dev liblmdb-dev libxapian-dev
</nowiki>}}
Download and install some packages from Xenial:
{{Input|1=<nowiki>mkdir extra-deb
cd extra-deb
wget http://mirrors.kernel.org/ubuntu/pool/main/libx/libxkbcommon/libxkbcommon-dev_0.5.0-1ubuntu2_amd64.deb
wget http://mirrors.kernel.org/ubuntu/pool/main/libx/libxkbcommon/libxkbcommon0_0.5.0-1ubuntu2_amd64.deb
wget http://mirrors.kernel.org/ubuntu/pool/main/libe/libepoxy/libepoxy-dev_1.3.1-1_amd64.deb
wget http://mirrors.kernel.org/ubuntu/pool/main/libe/libepoxy/libepoxy0_1.3.1-1_amd64.deb
dpkg -i *.deb
</nowiki>}}
Finally, we can build plasma-desktop:
{{Input|1=<nowiki>kdesrc-build --include-dependencies plasma-desktop</nowiki>}}


== Build some extra applications ==
===Learning===
You may want to build some base applications and can do so with:
https://techbase.kde.org/Development/Tutorials
{{Input|1=<nowiki>
kdesrc-build applications
</nowiki>}}
You can use kdesrc-build to build other applications. For example, to build kdevelop:
{{Input|1=<nowiki>
kdesrc-build --include-dependencies kdevelop
</nowiki>}}


===API===
https://api.kde.org/frameworks/kxmlgui/html/classKXmlGuiWindow.html


== Set up environment to run plasma 5 ==
http://doc.qt.io/qt-5/qobject.html
Follow this guide to test your plasma 5 build: https://community.kde.org/Guidelines_and_HOWTOs/Build_from_source/Test_plasma
 
===Qt===
[http://doc.qt.io/qt-5/qtexamplesandtutorials.html Qt Examples And Tutorials]
 
[http://doc.qt.io/ Qt Documentation]
 
===Git===
 
[[Infrastructure/Git/Recipes]]
 
[[Sysadmin/GitKdeOrgManual]]
 
[[Infrastructure/Git]]
 
[[Frameworks/Git_Workflow]]
 
[[Infrastructure/Git/Simple_Workflow]]
 
===cmake===
https://cmake.org/cmake/help/v3.6/manual/cmake-commands.7.html
 
https://api.kde.org/ecm/manual/ecm-modules.7.html
 
==Test Section==
Under User:donnguyen (outdated, just for testing) - [[/How to build KDE/Plasma 5 on Ubuntu 14.04 LTS|How to build KDE/Plasma 5 on Ubuntu 14.04 LTS]]
 
[[/first with prepending slash|Desc with slash]] - Creates it under here
 
[[first without prepending slash|Desc with no slash]] - Creates it at root
 
Testing "/Test new link" - [[/Test new link|Test new link]]
 
Testing "Special:myLanguage" - [[Special:myLanguage/Guidelines_and_HOWTOs/Build_from_source/Plasma 5 on Ubuntu 14.04 LTS|How to build KDE/Plasma 5 on Ubuntu 14.04 LTS]]

Latest revision as of 21:22, 17 April 2017