Skip to content

Useful variables for recipes

Schrijvers Luc edited this page Jun 17, 2024 · 37 revisions

For a list of all variables and where to use them, check Haikuporter Guidelines and Haikuporter Build-Recipes

License

Some sources ship with licenses not provided by default in Haiku, when they do you have to put them together with your recipe

create a `licenses` directory next to your `recipe`
copy the existing license from source to the licenses directory
rename the license appropriate and add this to your recipe in LICENSES=""

$portVersion

For a non standard $portversion like this: 1.5.4~pl02 you need to adjust the SOURCE_URI and sometimes the SOURCE_DIR:

`SOURCE_URI="https://www.gnu.org/software/xorriso/xorriso-${portVersion/\~/.}.tar.gz"`

SOURCE_DIR = xorriso-1.5.4 then:

SOURCE_DIR="xorriso-${portVersion/\~pl02/}"

A bit more complex for slunkcrypt-2022_04_24.recipe, we need to change the _ to - in the recipe, the archive doesn't provide a top-levell directory so we need to leave SOURCE_DIR empty, gitLabDir and SLUNKCRYPT_VERSION are custom variables:

gitLabDir="da63740f538e552708ae712bcc157142"
SLUNKCRYPT_VERSION=`echo $portVersion | sed 's/\_/-/g'`
SOURCE_URI="$HOMEPAGE/uploads/$gitLabDir/slunkcrypt.$SLUNKCRYPT_VERSION.source.tar.gz"
CHECKSUM_SHA256="599be4f4a6767992731a671d534fdaa74919dc8c83a8204b0f92439b90f7b658"
SOURCE_DIR=""

Or to replace a . with a _ like in opencascade-7.7.0.recipe:

SOURCE_URI="https://git.dev.opencascade.org/gitweb/?p=occt.git;a=snapshot;h=refs/tags/V${portVersion//./_};sf=tgz"

$commandBinDir and $commandSuffix

On x86_gcc2 if primary doesn't build (!x86_gcc2) then move binaries to $prefix/bin instead of $binDir ($prefix/bin/x86) needs the adjustment in BUILD() and PROVIDES too:

# On x86_gcc2 we don't want to install the commands in bin/<arch>/, but in bin/.
commandBinDir=$binDir
commandSuffix=$secondaryArchSuffix
if [ "$targetArchitecture" = x86_gcc2 ]; then
	commandSuffix=
	commandBinDir=$prefix/bin
fi

PROVIDES="
	projectx$secondaryArchSuffix
	cmd:projectx$commandSuffix
	"

BUILD()
	runConfigure --omit-dirs binDir ./configure \
		--bindir=$commandBinDir

for cmake:

BUILD()
	cmake -B build -S . \
	$cmakeDirArgs \
	-DCMAKE_INSTALL_BINDIR=$commandBinDir

Note, this is for autotools when using runConfigure and $cmakeDirArgs for cmake (providing it's using GNUInstallDirs (cmake))

for meson actually not needed, --bindir always defaults to $prefix/bin (but you can change that if you want to install the binary in $binDir):

BUILD()
	meson build --buildtype=release \
		--bindir=$bindir

Provide binaries only for primary architecture:

On 32bit we can provide binaries for both archtectures (x86_gcc2 and x86). Sometimes we only want to provide them for primary architecture only, then we can use this between PROVIDES and REQUIRES:

# we only want the binaries for primary architecture
if [ -z "$secondaryArchSuffix" ]; then
PROVIDES="$PROVIDES
	cmd:id3convert
	cmd:id3cp
	cmd:id3info
	cmd:id3tag
	"
fi

And in INSTALL (after make install):

# we only want the binaries for primary architecture
if [ -n "$secondaryArchSuffix" ]; then
	rm -rf $binDir
fi

Check SONAME version for a library:

readelf -d /system/lib/libgit2.so.1.5.0 | grep SONAME

$libVersion and $libVersionCompat

If libraries provide sonames declare them here and in PROVIDES="":

libVersion="0.1.1"
libVersionCompat="$libVersion compat >= ${libVersion%%.*}"

PROVIDES="
	fribidi$secondaryArchSuffix = $portVersion
	lib:libfribidi$secondaryArchSuffix = $libVersionCompat
	"

In packages with multiple libraries and different sonames you could use a bit more complex variant:

libcdioLibs="
	libcdio
	libcdioxx
	libiso9660
	libiso9660xx
	libudf
	"
libcdioVersion=18.0.0
libcdioxxVersion=1.0.0
libiso9660Version=11.0.0
libiso9660xxVersion=0.0.0
libudfVersion=0.0.0
for i in lib $libcdioLibs; do
	eval "${i}VersionCompat=\"\$${i}Version compat >= \${${i}Version%%.*}\""
done

PROVIDES="
	libcdio$secondaryArchSuffix = $portVersion
	lib:libcdio$secondaryArchSuffix = $libcdioVersionCompat
	lib:libcdio++$secondaryArchSuffix = $libcdioxxVersionCompat
	lib:libiso9660$secondaryArchSuffix = $libiso9660VersionCompat
	lib:libiso9660++$secondaryArchSuffix = $libiso9660xxVersionCompat
	lib:libudf$secondaryArchSuffix = $libudfVersionCompat
	"

If $libVersion is the same as $portVersion (eg breeze_icons6-6.8.0.recipe)

libVersion="$portVersion"

If $libVersion is not the same as $portVersion (eg breeze_icons6-6.8.0~rc1.recipe)

libVersion="${portVersion/\~rc1/}"

Skip command provided in both PRIMARY and SECONDARY ARCHITECTURE

If a package builds for both gcc2 and gcc8 you might want to skip the commands for SECONDARY_ARCHITECTURE="":

if [ -z "$secondaryArchSuffix" ]; then
	PROVIDES="$PROVIDES
		cmd:cdda_player = $portVersion
		cmd:cd_drive = $portVersion
		cmd:cd_info = $portVersion
		cmd:cd_read = $portVersion
		cmd:iso_info = $portVersion
		cmd:iso_read = $portVersion
		cmd:mmc_tool = $portVersion
		"
fi

Also needs adjusting in INSTALL():

INSTALL()
	if [ -z "$secondaryArchSuffix" ]; then
		packageEntries tools \
			"$commandBinDir"
	fi


	if [ -n "$secondaryArchSuffix" ]; then
		rm -rf "$documentationDir" "$binDir"
	fi

Tools sub package PROVIDES_TOOLS=""

Sometimes you want the tools (commands in a subpackage, use $commandSuffix or $secondaryArchSuffix as needed:

PROVIDES_tools="
	fribidi${secondaryArchSuffix}_tools = $portVersion
	cmd:fribidi$commandSuffix = $portVersion
	"
REQUIRES_tools="
	fribidi$secondaryArchSuffix == $portVersion base
	"

Also needs adjustment in INSTALL(), use $commandBinDir or $binDir where needed

packageEntries tools \
	"$commandBinDir"

defineDebugInfoPackage

Check in Terminal with readelf -S $libname | grep debug for debug info If they are provided move them into a debug package:

defineDebugInfoPackage roaraudio$secondaryArchSuffix \
	$libDir/libroar.so.$libVersion \
	$commandBinDir/roarbidir

defineDebugInfoPackage libde265$secondaryArchSuffix \
	$libDir/libde265.so.$libVersion \
	"$(getPackagePrefix tools)"/bin/acceleration_speed \

Add pkgconfig file

Sometimes ports don't provide pkgconfig files, these can be added to the INSTALL() part:

# Add pkgconfig file
mkdir -p $developLibDir/pkgconfig
cat > $developLibDir/pkgconfig/libargon2.pc << EOF
bindir=$prefix/bin
exec_prefix=$prefix
libdir=$libDir
includedir=$includeDir

Name: libargon2
Description: $SUMMARY
Version: $portVersion
Libs: -L$developLibDir -largon2
Cflags: -I$includeDir
EOF

fixPkgconfig

Sometimes fixPkgconfig alters the paths for the pkgconfig files, this is a fix for those:

INSTALL()
	# fixPkgconfig
	if [ -n "$secondaryArchSuffix" ]; then
		sed -i 's,\/headers/x86,\/headers/x86/sunpinyin-2.0,g' \
			$prefix/$relativeDevelopLibDir/pkgconfig/sunpinyin-2.0.pc
	else
		sed -i 's,\/headers,\/headers/sunpinyin-2.0,g' \
			$prefix/$relativeDevelopLibDir/pkgconfig/sunpinyin-2.0.pc
	fi

Or:

fixPkgconfig strict
sed -e 's,^includedir=\(.*\)include,includedir=${prefix}/'${relativeIncludeDir}',' \
	-i $developLibDir/pkgconfig/libinstpatch-1.0.pc

Some more information on using sed: https://www.geeksforgeeks.org/sed-command-in-linux-unix-with-examples/

fixCMake

Sometimes cmake configuration files hardcode there headers path to "/include", to fix this you could use:

sed -i 's,\/include,/'${relativeIncludeDir}',g' \
	$libDir/cmake/QXmppQt5/QXmpp.cmake

Or:

if [ -n "$secondaryArchSuffix" ]; then
sed -e 's|_IMPORT_PREFIX}/include|_IMPORT_PREFIX}/develop/headers/x86|' -i \
	$libDir/cmake/tvision/tvision-config.cmake
else
sed -e 's|_IMPORT_PREFIX}/include|_IMPORT_PREFIX}/develop/headers|' -i \
	$libDir/cmake/tvision/tvision-config.cmake
fi

Remove multiple libtool files in one go in INSTALL()

find "$libDir" -name '*.la' -delete

Post-install script

If you need to do some post install actions you can do this in a post-install script that will be executed when the package is installed

ADDITIONAL_FILES="fontconfig-reload-cache.sh"

POST_INSTALL_SCRIPTS="$relativePostInstallDir/fontconfig-reload-cache.sh"

mkdir -p $postInstallDir
cp -f $portDir/additional-files/fontconfig-reload-cache.sh $postInstallDir

In the script you can do a check if fc-cache is available and if so reload the fontconfig's chache (save this file as fontconfig-reload-cache.sh in additional-files):

#!sh

command -v fc-cache && fc-cache -f

finddir

If you need to point to a certain path, check finddir -l for available paths:

$(finddir B_SYSTEM_DEVELOP_DIRECTORY)/lib$secondaryArchSubDir

This points to /boot/system/develop/lib/x86 (secondary architecture on 32bit)

Add icon and application information

You can open your applications with FileTypes and get additional information like version number ... For resource vector_icon information you can create a new icon or edit a provided svg icon in Icon-O-Matic and export the icon as *.rdef file. Edit the *.rdef.in file in your port directory next to the recipes, below some information what's needed:

additional-files/mednaffe.rdef.in

resource app_flags B_SINGLE_LAUNCH;

resource app_version {
	major  = @MAJOR@,
	middle = @MIDDLE@,
	minor  = @MINOR@,

	variety = B_APPV_FINAL,
	internal = 0,

	short_info = "@APP_NAME@",
	long_info = "@LONG_INFO@"
};

resource app_signature "@APP_SIGNATURE@";

resource vector_icon {
	$"6E63696604020112020000003B1906BDCE9B00000049D2014B20D10000FFFF00"
	$"00020106020000003DEC56BDEC5100000049E13F480189008FB1DCFF3465A403"
	$"204A870200120239F37D3E5955BE595539F37D4465034BBA6100FFFFFFFF0004"
	$"0606FF07CB4FC6F1CB4FC6F1CB4FC9ABBF2DCBE1C5E1CBE1B879CBE1B30AC6F1"
	$"B30AC9ABB30AC437BF2DC201B879C201C5E1C201CB4FC6F1CB4FC437CB4FC6F1"
	$"C6F10606FF07C9F0BF59C9F0BF59C9F0C530BF5EC9EBC534C9EBB987C9EBB4CB"
	$"BF59B4CBC530B4CBB983BF5EB4C7B987B4C7C534B4C7C9F0BF59C9F0B983C9F0"
	$"BF59BF590606FF07C9F0BF59C9F0BF59C9F0C530BF5EC9EBC534C9EBB987C9EB"
	$"B4CBBF59B4CBC530B4CBB983BF5EB4C7B987B4C7C534B4C7C9F0BF59C9F0B983"
	$"C9F0BF59BF590606FF07C95BBF59C95BBF59C95BC4DDBF5EC956C4E2C956B9D9"
	$"C956B560BF59B560C4DDB560B9D5BF5EB55CB9D9B55CC4E2B55CC95BBF59C95B"
	$"B9D5C95BBF59BF59040A000100000A010101000A0201021001178100040A0301"
	$"03100117810004"
};

In the recipe (games-emulation/mednaffe-0.9.2.recipe)

ADDITIONAL_FILES="mednaffe.rdef.in"

And this in INSTALL section after the actual make install (or simular)

local MAJOR="`echo "$portVersion" | cut -d. -f1`"
local MIDDLE="`echo "$portVersion" | cut -d. -f2`"
local MINOR="`echo "$portVersion" | cut -d. -f3`"
local APP_NAME="Mednaffe"
local LONG_INFO="$SUMMARY"
local APP_SIGNATURE="application/x-vnd.mednaffe"
sed \
	-e "s|@MAJOR@|$MAJOR|" \
	-e "s|@MIDDLE@|$MIDDLE|" \
	-e "s|@MINOR@|$MINOR|" \
	-e "s|@LONG_INFO@|$LONG_INFO|" \
	-e "s|@APP_NAME@|$APP_NAME|" \
	-e "s|@APP_SIGNATURE@|$APP_SIGNATURE|" \
	$portDir/additional-files/mednaffe.rdef.in > mednaffe.rdef

addResourcesToBinaries mednaffe.rdef $appsDir/Mednaffe

In cases where you checked out a git commit and end up with a recipe named: *~git.recipe, you need to cut off the ~git part for the portVersion:

local MINOR="`echo "$portVersion" | cut -d. -f3 | cut -d~ -f1`"

Rename rdef to rsrc (usefull sometimes for scripts that can't use rdef files)

# Installing extra-attribs
rc frogatto.rdef

settype -t application/x-vnd.Be-elfexecutable $appsDir/Frogatto4
resattr -o $appsDir/Frogatto4 frogatto.rsrc

addAppDeskbarSymLink

If you need to add a link in the Deskbar

addAppDeskbarSymlink $appsDir/Mednaffe

or

addAppDeskbarSymlink $prefix/bin/solarus-launcher Solarus

or

addAppDeskbarSymlink $commandBindDir/MAME

for a link in the Preferences menu:

addPreferencesDeskbarSymlink $prefix/bin/tuxpaint-config "Tux Paint Config"

Patching

Sometimes you need to change some small things in the source files, will try to put some things up here. If you use PATCH put them up before BUILD.

For python: some python scripts tend to start with #!/usr/bin/python, but in our case we want this to be python3

PATCH()
{
	sed -i 's,\/usr/bin/env python,\/bin/env python3,g' ginsh/*.py
	sed -i 's,\/usr/bin/env python,\/bin/env python3,g' scripts/*.py
}

Target architectures

If you need a local variable that is only needed for a specific architecture you could use something like this

local yearArg
if [ $targetArchitecture = x86_gcc2 ]; then
	yearArg="--disable-year2038"
fi

In this case you pass the variable to configure

runConfigure --omit-dirs binDir ./configure --bindir=$commandBinDir \
	--disable-nls \
	--disable-gcc-warnings \
	LDFLAGS="-lnetwork" CFLAGS="-D_BSD_SOURCE" \
	FORCE_UNSAFE_CONFIGURE=1 \
	$yearArg

KDE and reuse tool

reuse is a python tool to understand how your project is licensed. It's not packaged so let's (for now) use pip to install and test this in the recipe.

In TEST_REQUIRES put:

TEST_REQUIRES="
	cmd:python3
	cmd:pip3
	"

Then in TEST() put (test case example):

TEST()
{
	pip3 install --user reuse
	export LIBRARY_PATH="$sourceDir/build/bin${LIBRARY_PATH:+:$LIBRARY_PATH}"
	ctest --test-dir build --output-on-failure
	pip3 uninstall reuse -y
}