| @@ -1,79 +1,80 @@ | | | @@ -1,79 +1,80 @@ |
1 | # $NetBSD: extension.mk,v 1.44 2016/05/20 16:37:27 wiz Exp $ | | 1 | # $NetBSD: extension.mk,v 1.45 2016/05/21 05:22:40 richard Exp $ |
2 | | | 2 | |
3 | .include "../../lang/python/pyversion.mk" | | 3 | .include "../../lang/python/pyversion.mk" |
4 | | | 4 | |
5 | # Packages that are a non-egg distutils extension should set | | 5 | # Packages that are a non-egg distutils extension should set |
6 | # PYDISTUTILSPKG=YES and include this mk file. | | 6 | # PYDISTUTILSPKG=YES and include this mk file. |
7 | | | 7 | |
8 | # This mk fragment is included to handle packages that create | | 8 | # This mk fragment is included to handle packages that create |
9 | # extensions to python, which by definition are those that place files | | 9 | # extensions to python, which by definition are those that place files |
10 | # in ${PYSITELIB}. Extensions can be implemented via setuptools as | | 10 | # in ${PYSITELIB}. Extensions can be implemented via setuptools as |
11 | # eggs (see egg.mk), via distutils (confusing, with an egg-info file, | | 11 | # eggs (see egg.mk), via distutils (confusing, with an egg-info file, |
12 | # even though they are not eggs), or via more ad hocs methods. | | 12 | # even though they are not eggs), or via more ad hocs methods. |
13 | | | 13 | |
14 | .if defined(PYDISTUTILSPKG) | | 14 | .if defined(PYDISTUTILSPKG) |
15 | .include "../../mk/bsd.prefs.mk" | | 15 | .include "../../mk/bsd.prefs.mk" |
16 | | | 16 | |
17 | PYSETUP?= setup.py | | 17 | PYSETUP?= setup.py |
18 | PYSETUPBUILDTARGET?= build | | 18 | PYSETUPBUILDTARGET?= build |
19 | PYSETUPBUILDARGS?= #empty | | 19 | PYSETUPBUILDARGS?= #empty |
20 | PYSETUPARGS?= #empty | | 20 | PYSETUPARGS?= #empty |
21 | PYSETUPINSTALLARGS?= #empty | | 21 | PYSETUPINSTALLARGS?= #empty |
22 | PYSETUPOPTARGS?= -c -O1 | | 22 | PYSETUPOPTARGS?= -c -O1 |
23 | _PYSETUPINSTALLARGS= ${PYSETUPINSTALLARGS} ${PYSETUPOPTARGS} ${_PYSETUPTOOLSINSTALLARGS} | | 23 | _PYSETUPINSTALLARGS= ${PYSETUPINSTALLARGS} ${PYSETUPOPTARGS} ${_PYSETUPTOOLSINSTALLARGS} |
24 | _PYSETUPINSTALLARGS+= --root=${DESTDIR:Q} | | 24 | _PYSETUPINSTALLARGS+= --root=${DESTDIR:Q} |
25 | PY_PATCHPLIST?= yes | | 25 | PY_PATCHPLIST?= yes |
26 | PYSETUPINSTALLARGS?= #empty | | 26 | PYSETUPINSTALLARGS?= #empty |
27 | PYSETUPTESTTARGET?= test | | 27 | PYSETUPTESTTARGET?= test |
28 | PYSETUPTESTARGS?= #empty | | 28 | PYSETUPTESTARGS?= #empty |
29 | PYSETUPSUBDIR?= #empty | | 29 | PYSETUPSUBDIR?= #empty |
30 | | | 30 | |
31 | pre-patch: fixup-python-writeable-source | | 31 | post-install: fixup-python-writeable-source |
32 | .PHONY: fixup-python-writeable-source | | 32 | .PHONY: fixup-python-writeable-source |
33 | fixup-python-writeable-source: | | 33 | fixup-python-writeable-source: |
34 | ${FIND} ${WRKSRC} -type f -exec ${CHMOD} go-w {} \; | | 34 | ${FIND} ${DESTDIR} -type f \( -perm -g+w -o -perm -o+w \) \ |
| | | 35 | -exec ${CHMOD} go-w '{}' + |
35 | | | 36 | |
36 | do-build: | | 37 | do-build: |
37 | (cd ${WRKSRC}/${PYSETUPSUBDIR} && ${SETENV} ${MAKE_ENV} ${PYTHONBIN} \ | | 38 | (cd ${WRKSRC}/${PYSETUPSUBDIR} && ${SETENV} ${MAKE_ENV} ${PYTHONBIN} \ |
38 | ${PYSETUP} ${PYSETUPARGS} ${PYSETUPBUILDTARGET} ${PYSETUPBUILDARGS}) | | 39 | ${PYSETUP} ${PYSETUPARGS} ${PYSETUPBUILDTARGET} ${PYSETUPBUILDARGS}) |
39 | | | 40 | |
40 | do-install: | | 41 | do-install: |
41 | (cd ${WRKSRC}/${PYSETUPSUBDIR} && ${SETENV} ${INSTALL_ENV} ${MAKE_ENV} \ | | 42 | (cd ${WRKSRC}/${PYSETUPSUBDIR} && ${SETENV} ${INSTALL_ENV} ${MAKE_ENV} \ |
42 | ${PYTHONBIN} ${PYSETUP} ${PYSETUPARGS} "install" ${_PYSETUPINSTALLARGS}) | | 43 | ${PYTHONBIN} ${PYSETUP} ${PYSETUPARGS} "install" ${_PYSETUPINSTALLARGS}) |
43 | .if !target(do-test) && !(defined(TEST_TARGET) && !empty(TEST_TARGET)) | | 44 | .if !target(do-test) && !(defined(TEST_TARGET) && !empty(TEST_TARGET)) |
44 | do-test: | | 45 | do-test: |
45 | (cd ${WRKSRC}/${PYSETUPSUBDIR} && ${SETENV} ${MAKE_ENV} ${PYTHONBIN} \ | | 46 | (cd ${WRKSRC}/${PYSETUPSUBDIR} && ${SETENV} ${MAKE_ENV} ${PYTHONBIN} \ |
46 | ${PYSETUP} ${PYSETUPARGS} ${PYSETUPTESTTARGET} ${PYSETUPTESTARGS}) | | 47 | ${PYSETUP} ${PYSETUPARGS} ${PYSETUPTESTTARGET} ${PYSETUPTESTARGS}) |
47 | .endif | | 48 | .endif |
48 | | | 49 | |
49 | .endif | | 50 | .endif |
50 | | | 51 | |
51 | # PY_NO_EGG suppress the installation of the egg info file (and | | 52 | # PY_NO_EGG suppress the installation of the egg info file (and |
52 | # therefore its inclusion in the package). Python practice is be to | | 53 | # therefore its inclusion in the package). Python practice is be to |
53 | # use these files to let 'require' verify that python distributions | | 54 | # use these files to let 'require' verify that python distributions |
54 | # are present, and therefore the default value of PY_NO_EGG=yes causes | | 55 | # are present, and therefore the default value of PY_NO_EGG=yes causes |
55 | # pkgsrc not to conform to python norms. The reason for this behavior | | 56 | # pkgsrc not to conform to python norms. The reason for this behavior |
56 | # appears to be that creating egg info files was new in Python 2.5. | | 57 | # appears to be that creating egg info files was new in Python 2.5. |
57 | PY_NO_EGG?= yes | | 58 | PY_NO_EGG?= yes |
58 | .if !empty(PY_NO_EGG:M[yY][eE][sS]) | | 59 | .if !empty(PY_NO_EGG:M[yY][eE][sS]) |
59 | # see python*/patches/patch-av | | 60 | # see python*/patches/patch-av |
60 | INSTALL_ENV+= PKGSRC_PYTHON_NO_EGG=defined | | 61 | INSTALL_ENV+= PKGSRC_PYTHON_NO_EGG=defined |
61 | .endif | | 62 | .endif |
62 | | | 63 | |
63 | .if defined(PY_PATCHPLIST) | | 64 | .if defined(PY_PATCHPLIST) |
64 | PLIST_SUBST+= PYINC=${PYINC} PYLIB=${PYLIB} PYSITELIB=${PYSITELIB} | | 65 | PLIST_SUBST+= PYINC=${PYINC} PYLIB=${PYLIB} PYSITELIB=${PYSITELIB} |
65 | .endif | | 66 | .endif |
66 | | | 67 | |
67 | # prepare Python>=3.2 bytecode file location change | | 68 | # prepare Python>=3.2 bytecode file location change |
68 | # http://www.python.org/dev/peps/pep-3147/ | | 69 | # http://www.python.org/dev/peps/pep-3147/ |
69 | .if empty(_PYTHON_VERSION:M2?) | | 70 | .if empty(_PYTHON_VERSION:M2?) |
70 | PY_PEP3147?= yes | | 71 | PY_PEP3147?= yes |
71 | .endif | | 72 | .endif |
72 | .if defined(PY_PEP3147) && !empty(PY_PEP3147:M[yY][eE][sS]) | | 73 | .if defined(PY_PEP3147) && !empty(PY_PEP3147:M[yY][eE][sS]) |
73 | PLIST_AWK+= -f ${PKGSRCDIR}/lang/python/plist-python.awk | | 74 | PLIST_AWK+= -f ${PKGSRCDIR}/lang/python/plist-python.awk |
74 | PLIST_AWK_ENV+= PYVERS="${PYVERSSUFFIX:S/.//}" | | 75 | PLIST_AWK_ENV+= PYVERS="${PYVERSSUFFIX:S/.//}" |
75 | PRINT_PLIST_AWK+= /^[^@]/ && /[^\/]+\.py[co]$$/ { | | 76 | PRINT_PLIST_AWK+= /^[^@]/ && /[^\/]+\.py[co]$$/ { |
76 | PRINT_PLIST_AWK+= gsub(/__pycache__\//, "") | | 77 | PRINT_PLIST_AWK+= gsub(/__pycache__\//, "") |
77 | PRINT_PLIST_AWK+= gsub(/opt-1\.pyc$$/, "pyo") | | 78 | PRINT_PLIST_AWK+= gsub(/opt-1\.pyc$$/, "pyo") |
78 | PRINT_PLIST_AWK+= gsub(/\.cpython-${_PYTHON_VERSION}/, "")} | | 79 | PRINT_PLIST_AWK+= gsub(/\.cpython-${_PYTHON_VERSION}/, "")} |
79 | .endif | | 80 | .endif |