blob: 619065a780782d6f07985ae12d85a94b13a6f2e9 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
# Apply patches to source code
#
# Copyright (C) 2012 Patrick McDermott
#
# This file is part of opkbuild.
#
# opkbuild is free software: you can redistribute it and/or modify it
# under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# opkbuild is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with opkbuild. If not, see <http://www.gnu.org/licenses/>.
. "${LIBDATADIR}/libopkbuild.shso.1"
main()
{
ob_set_text_domain 'opkbuild'
ob_init_package '..' || exit 1
ob_parse_package_metadata -c '.opkbuild.cache' || exit 1
apply_patches
}
apply_patches()
{
applied='false'
if [ -d '../patches' ] && [ -d 'src' ]; then
# Iterate over patches ordered alphabetically by name.
# POSIX.1-2008 says that the results of a pathname expansion shall be
# "sorted according to the collating sequence in effect in the current
# locale". So for consistent results, we first set a standard locale.
orig_lang="${LANG}"
LANG='POSIX'
for patch in '../patches/'*; do
[ -f "${patch}" ] || continue
LANG="${orig_lang}"
patch="${patch#../patches/}"
ob_info "$(ob_get_msg 'applying_patch')" "${patch}"
cd src
patch -N -p 1 -u -i "../../patches/${patch}" || \
ob_error "$(ob_get_msg 'cant_apply_patch')" "${patch}"
cd ..
applied='true'
done
LANG="${orig_lang}"
fi
${applied} || ob_info "$(ob_get_msg 'no_patches')"
}
main "${@}"
|