2021-12-04 - Sorry the Gramps wiki is currently being upgraded to a newer software version. Please check back after the 2021-12-08. We apologize for the inconvenience.

Changes

Jump to: navigation, search

Debian

1,543 bytes removed, 27 May
add language box
{{languages|Debian}}= For version 4.0 x and newer =
'''Testing .debs can be found in http://sourceforge.net/projects/gramps/files/Unstable/''' {{man menu|Gramps 4 moves moved to setuptool/distutils installer.}}
==Dependency==
* debian stuff
sudo apt-get install devscripts dpkg-dev fakeroot debhelper libgconf2dh-devlinktree
* [https://github.com/astraw/stdeb stdeb], which produces Debian source packages from Python packages via a new distutils command, sdist_dsc. Automatic defaults are provided for the Debian package, but many aspects of the resulting package can be customized. An additional command, bdist_deb, creates a Debian binary package, a .deb file. The debianize command builds a debian/ directory directly alongside your setup.py.
sudo apt-get install python-stdeb python-all # or python3-all
==Build==
 
'''For testing only''': you can get this experimental 'python-gramps' package under [http://sourceforge.net/projects/gramps/files/Unstable/ '''UNSTABLE'''] section.
 
There is a problem with ''usr/share/pyshared/gramps/gen/utils/resource-path'' file, need to use an environment variable: '''GRAMPS_RESOURCES'''.
$ GRAMPS_RESOURCES=/usr/share gramps
 
or you need to customize ''[http://svn.code.sf.net/p/gramps/code/branches/maintenance/gramps40/setup.py setup.py]'' before building your package!
eg,
resource_file = os.path.join(os.path.dirname(__file__), 'gramps', 'gen',
'utils', 'resource-path')
with io.open(resource_file, 'w', encoding='utf-8',
errors='strict') as fp:
- path = os.path.abspath(os.path.join(self.install_data, 'share'))
+ path = os.path.join('/usr', 'share'))
*'''WARNING'''
** The launcher under ''/usr/bin/gramps'' is using the '''same path''' for current stable release and this testing version. '''Backup your launcher''' if you want to install both versions. Translations might be also overwritten, you have been warned...
** You need at least version '''3.3.2''' of python-gobject for Gramps '''4.0x'''.
** You cannot use greater version than '''2.28''' of python-gobject for Gramps '''3.4.x'''.
These options are set into ''/debian'' folder.
cd debian
export DEBEMAIL='[email protected]'
export DEBFULLNAME='Your name'
cd .. dch -v 4.0.0-alpha5-r21758 "New upstream for unstable release (r21758)Gramps 4.0.0"
dpkg-buildpackage -rfakeroot
===via Distutils===
source Samples :  * https://github.com/astraw/stdeb/blob/master/stdeb/command/* https://github.com/kelvan/gotoVienna/blob/master/bdist_hdeb.py ==Test== $ lintian gramps_4.0.1-2_all.deb W: gramps: old-fsf-address-in-copyright-file W: gramps: extra-license-file usr/share/doc/gramps/COPYING.gz W: gramps: package-contains-upstream-install-documentation usr/share/doc/gramps/INSTALL W: gramps: extra-license-file usr/share/doc/gramps/LICENSE.gz W: gramps: menu-icon-missing usr/share/pixmaps/gramps.xpm ==webapp package==
Sample for creating a debian harmattan (MeeGo 1.2) binary * How to include Makefile into deb package:?
<code>import os import stdebsetup.util as util from shutil import copy from stdeb.command.sdist_dsc import sdist_dscpy:
from distutils- package_data_webapp = ['webapp/*.core import Commandsql', 'webapp/grampsdb/sql/*.sql'] + package_data_webapp = ['webapp/*.sql', 'webapp/Makefile', 'webapp/grampsdb/sql/*.sql']
__all__ = ['bdist_hdeb']* Depends on python-django, python-sqlite
class bdist_hdeb(Command)Control: description = 'distutils command to create debian harmattan binary package'
# [http Package://wiki.meego.com/Aegis_Policies aegis], UAC, [httpspython-gramps-webapp Architecture://developer.gnome.org/goa/stable/ UOA], [httpall Depends://developer.ubuntu.com/resources/technologies/online python-accounts/ GOA]django, etc ... user_options = [ ("aegis python-manifest="sqlite, None ${misc:Depends}, 'aegis manifest to use') ] boolean_options = [] ${python:Depends}
def initialize_options (self)Rules: self.aegis_manifest = None
def finalize_options (self): pass #!/usr/bin/make -f
def run(self): # generate Uncomment this to turn on verbose mode.dsc source pkg self.run_command('sdist_dsc') export DH_VERBOSE=1 export DH_OPTIONS=-v
# execute system command and read output (execute and read output of find cmd) dsc_tree = 'deb_dist' target_dir = None for entry in os.listdir(dsc_tree): fulldir = os.path.join(dsc_tree,entry) if os.path.isdir(fulldir): if target_dir is not None %: raise ValueError('more than one directory in deb_dist. ' 'Unsure which is source directory') else: target_dir = fulldir if target_dir is None: raise ValueError('could not find debian source directory') # inject custom logic to dh_builddeb (build digsigsums before and add aegis manifest after) DEBNAME = self.distribution.get_name()+'_'+self.distribution.get_version()+'*_all.deb' rules = open(target_dir+'/debian/rules', 'a') rules.write('override_dh_builddeb:\n\tpython ../../digsigsums.py '+self.distribution.get_name()+\ '\n\tdh_builddeb') if self.aegis_manifest is not None: # MeeGo 1.2 rules.write('\n\tar q ../'+DEBNAME+' _aegis') rules.write('\n\n') rules.close() dh [email protected] --with python2
# make aegis manifest avaiable to debian/rules Override auto test because upstream do not use the standard unittest discover # MeeGo 1.2 if self.aegis_manifest is not None override_dh_auto_test: copy(self.aegis_manifest, target_dir+'/_aegis') # define system command to execute (gen .deb binary pkg) syscmd = ['dpkg-buildpackage','-rfakeroot','-uc','-b']
util # Override of auto_build override_dh_auto_build: python setup.process_command(syscmd,cwd=target_dir)</code>py --server build
source # Override of auto_install to remove information from package override_dh_auto_install: https://github #dh_auto_install python setup.com/kelvan/gotoViennapy --server install --root=debian/blob/master/bdist_hdeb.pypython-gramps-webapp --install-layout=deb
# Make css style sheets and templates non-executable override_dh_fixperms: dh_fixperms chmod a-x $(CURDIR)/debian/python-gramps-webapp/usr/share/gramps/css/Web_*.css chmod a-x $(CURDIR)/debian/python-gramps-webapp/usr/share/gramps/templates/*.html  # Avoid compressing COPYING file so that it can appear in the "About" dialog override_dh_compress: #dh_compress -X COPYING * python 3 Control: X-Python3-Version: >= 3.2  Package: python3-gramps-webapp Architecture: all Depends: python3-django, python3-sqlite, ${misc:Depends}, ${python3:Depends} Rules:  #!/usr/bin/make -f  # Uncomment this to turn on verbose mode. export DH_VERBOSE=1 export DH_OPTIONS=webapp -v  %: dh [email protected] --with python3  # Override auto test because upstream do not use the standard unittest discover override_dh_auto_test:  # Override of auto_build override_dh_auto_build: python3 setup.py --server build  # Override of auto_install to remove information from package override_dh_auto_install: #dh_auto_install python3 setup.py --server install --root=debian/python3-gramps-webapp --install-layout=deb
* webapp returns a syntax error on post install script: cannot compile modules # Make css style sheets and templates non-executable SyntaxErroroverride_dh_fixperms: dh_fixperms chmod a-x $('invalid syntax', ('CURDIR)/debian/python3-gramps-webapp/usr/libshare/python2gramps/css/Web_*.7css chmod a-x $(CURDIR)/distdebian/python3-packagesgramps-webapp/usr/share/gramps/webapptemplates/init_gramps.py', 30, 21, 'from *.grampsdb models import models as dj\n')) * How to include Makefile into deb package?html
* Depends on python # Avoid compressing COPYING file so that it can appear in the "About" dialog override_dh_compress: #dh_compress -django 1.3, python-sqlite, grampsX COPYING
==qml package==
*Depends on python-pyside, gramps
= For version 3.4 and before=Instructions on creating the Debian package for Ubuntu = * Check out the necessary version; for example, to build the <tt>.deb</tt> package file for UbuntuGRAMPS {{version}}, you'll want to run: git clone http://git.code.sf.net/p/gramps/source Gramps git checkout v{{version}} -b {{version}}
* Ensure you have a working build environment
* For Ubuntu 7.04 or 7.10, install these tools:
sudo apt-get install devscripts dpkg-dev fakeroot debhelper libgconf2-dev
* For Ubuntu 8.04, install these tools:
sudo apt-get install devscripts dpkg-dev fakeroot debhelper libgconf2-dev python-xml
* For Ubuntu 12.04 install these tools:
sudo apt-get install devscripts dpkg-dev fakeroot debhelper libgconf2-dev
* Check out the necessary version; for example, to build the <tt>.deb</tt> file for GRAMPS version 3.4.3, you'll want to run:
mkdir ~/gramps
cd ~/gramps
svn co https://svn.code.sf.net/p/gramps/code/tags/gramps-3.4.3/
* Confirm that sudo apt-get install devscripts dpkg-dev fakeroot debhelper libgconf2-dev, everything builds:
./autogen.sh
make
* Create the Changelog files:
svn2cl --reparagraph --include-rev --authors=src/data/authors.xml
cd po
svn2cl --reparagraph --include-rev --authors=../src/data/authors.xml
cd ..
* Create the <tt>.deb</tt> package:
cd debian
export DEBEMAIL='[email protected]'
export DEBFULLNAME='Stephane Charette'
cd ..
dch -v 3.4.3-3 "New upstream release, include two patches"
dpkg-buildpackage -rfakeroot
: Remember to modify '''<tt>DEBEMAIL</tt>''' and '''<tt>DEBFULLNAME</tt>''' to reflect your e-mail and name.
git log v{{version}}.. --pretty --numstat --summary --no-merges | git2cl > ChangeLog git log v{{version}}.. --pretty --numstat --summary --no-merges -- po/* Release .po | git2cl > po/ChangeLog Using the <tt>.debChangelog</tt> files: cd .. ls *.deb: Note the '''generated with <tt>gramps_3.4.3-3_all.debgit2cl</tt>''' file, which needs to be uploaded to  Modify <tt>ftp://upload.sourceforgeMANIFEST.net/incoming/in</tt>. + include ChangeLog + include po/ChangeLog
* The details on how things are going to be packaged into deb files, what are the dependencies, the pre- and post- install and removal scripts etc are under <tt>debian/</tt> directory. Please refer to the [http://www.debian.org/doc/maint-guide/ Debian New Maintainers' Guide] for further details.
[[Category:Developers/Packaging]]
1,425
edits

Navigation menu