[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]

Re: [scl.org] Question about generating RPMs that depend on SCLs (like python27)



Next error:

extracting debug info from /rpmbuild/BUILDROOT/assimilation-cma-0.1.4-0.30.x86_64/usr/sbin/nanoprobe
1376 blocks
+ /usr/lib/rpm/check-buildroot
+ /usr/lib/rpm/brp-scl-compress '%{_scl_root}'
+ /usr/lib/rpm/redhat/brp-strip /usr/bin/strip
+ /usr/lib/rpm/redhat/brp-strip-comment-note /usr/bin/strip /usr/bin/objdump
+ /usr/lib/rpm/redhat/brp-strip-static-archive /usr/bin/strip
+ scl enable %scl '/usr/lib/rpm/redhat/brp-python-bytecompile-with-scl-python /usr/bin/python 1 %{_scl_root}'
Unable to open /etc/scl/prefixes/%scl!
error: Bad exit status from /var/tmp/rpm-tmp.eqUbD6 (%install)
    Bad exit status from /var/tmp/rpm-tmp.eqUbD6 (%install)

I'm guessing need to define %scl.

It looks to me like these macros expect that you're *defining* a package, not using one. Good thing I don't need more than one, or I'd be in a world of hurt (which is how it feels now anyway).


On 07/18/2014 11:10 AM, Alan Robertson wrote:
On 07/16/2014 02:30 AM, Bohuslav Kabrda wrote:
That's correct. The problem here is, I think, that the package places it's files into sitearch of the SCL, but it's not actually an SCL package. One of the results of having it as non-SCL package means, that %scl_package_override() function, present in the python27-build subpackage doesn't get invoked. This function looks like this (you need to 's/@scl@/python27/'):

# override __os_install_post for this collection
# the python27_os_install_post macro is defined in macros.python2.python27 in python27-python-devel
# the name is intentionally hardcoded to always provide the same name
%scl_package_override() %{expand:%{? scl@_os_install_post:%global __os_install_post % scl@_os_install_post}
%global __python_requires % scl@_python_requires
%global __python_provides % scl@_python_provides
This looks like it has a typo in it.

If @scl@ is python27, then

    %global __python_requires % scl@_python_requires
becomes
    %global __python_requires python27_python_requires
and
    %global __python_provides % scl@_python_provides
becomes
    %global __python_provides python27_python_provides

Why is the original spelled with two underscores ("__python_requires") but the replacement name ("python27_python_requires") only has one underscore?

This seems a bit inconsistent...  It looks correct, but inconsistent...


I see that the python27_python_requires macro is defined in /etc/rpm/macros.python2.python27. I see that __python_requires is defined in the file /usr/lib/rpm/macros.
The definition of python27_python_requires is:
%python27_python_provides /usr/lib/rpm/pythondeps-scl.sh --provides %{?scl_prefix} %python27_python_requires /usr/lib/rpm/pythondeps-scl.sh --requires %{?scl_prefix}

So, it expects you to set scl_prefix. I set it to "python27-" From what I can see in the macro definitions, that's what I expect it would want.

Well, at least now I get different problems!

+ install -p -D -m0755 /rpmbuild/BUILDROOT/assimilation-cma-0.1.4-0.30.x86_64/etc/init.d/cma /rpmbuild/BUILDROOT/assimilation-cma-0.1.4-0.30.x86_64/etc/rc.d/init.d/assimilation-cma + install -p -D -m0755 /rpmbuild/BUILDROOT/assimilation-cma-0.1.4-0.30.x86_64/etc/init.d/nanoprobe /rpmbuild/BUILDROOT/assimilation-cma-0.1.4-0.30.x86_64/etc/rc.d/init.d/assimilation-nanoprobe + rm -f /rpmbuild/BUILDROOT/assimilation-cma-0.1.4-0.30.x86_64/etc/init.d/cma /rpmbuild/BUILDROOT/assimilation-cma-0.1.4-0.30.x86_64/etc/init.d/nanoprobe + mkdir -p /rpmbuild/BUILDROOT/assimilation-cma-0.1.4-0.30.x86_64/var/run/assimilation + mkdir -p /rpmbuild/BUILDROOT/assimilation-cma-0.1.4-0.30.x86_64/var/run/nanoprobe + mkdir -p /rpmbuild/BUILDROOT/assimilation-cma-0.1.4-0.30.x86_64/usr/lib64 + mkdir -p /rpmbuild/BUILDROOT/assimilation-cma-0.1.4-0.30.x86_64/opt/rh/python27/root//usr/lib64/python2.7/site-packages/assimilation/testcode
+ /usr/lib/rpm/brp-scl-compress '%{_scl_root}'
/var/tmp/rpm-tmp.uQBlOW: line 59: /usr/lib/rpm/brp-scl-compress: No such file or directory
error: Bad exit status from /var/tmp/rpm-tmp.uQBlOW (%install)
    Bad exit status from /var/tmp/rpm-tmp.uQBlOW (%install)

Looks like that should come from scl-utils-build...



--
    Alan Robertson <alanr unix sh> - @OSSAlanR

"Openness is the foundation and preservative of friendship...  Let me claim from you at all times your undisguised opinions." - William Wilberforce


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]