port select python and config error
Mark Brethen
mark.brethen at gmail.com
Sun Oct 28 21:50:35 UTC 2018
brethen-air:~ marbre$ port select --summary
Warning: port definitions are more than two weeks old, consider updating them by running 'port selfupdate'.
Name Selected Options
==== ======== =======
clang none mp-clang-6.0 none
cython none cython36 none
gcc none mp-gcc7 none
ipython py34-ipython none
llvm none mp-llvm-3.4 mp-llvm-6.0 none
mpi none mpich-mp-fortran none
nosetests none nosetests36 none
pip pip34 none
py-sympy py36-sympy py36-sympy none
python python27 python26-apple python27 python27-apple python36 none
python2 python27 python26-apple python27 python27-apple none
python3 python36 python36 none
wxWidgets none wxWidgets-3.0 none
With macports python 2.7 it’s a different error:
:info:build /opt/local/Library/Frameworks/Python.framework/Versions/2.7/Resources/Python.app/Contents/MacOS/Python: can't open file 'setup.py': [Errno 2] No such file or directory
:info:build Command failed: cd "/opt/local/var/macports/build/_Users_marbre_ports_math_reduce/libreduce/work/Reduce-svn4765-src/generic/libreduce/x86_64-mac_10.12_sierra-darwin16.7.0" && /opt/local/Library/Frameworks/Python.framework/Versions/2.7/bin/python2.7 setup.py --no-user-cfg build
:info:build Exit code: 2
:error:build Failed to build libreduce: command execution failed
:debug:build Error code: CHILDSTATUS 96796 2
:debug:build Backtrace: command execution failed
:debug:build while executing
:debug:build "system {*}$notty {*}$nice $fullcmdstring"
:debug:build invoked from within
:debug:build "command_exec build"
:debug:build (procedure "portbuild::build_main" line 8)
:debug:build invoked from within
:debug:build "$procedure $targetname"
:error:build See /opt/local/var/macports/logs/_Users_marbre_ports_math_reduce/libreduce/main.log for details.
-------------- next part --------------
A non-text attachment was scrubbed...
Name: main.log
Type: application/octet-stream
Size: 111213 bytes
Desc: not available
URL: <http://lists.macports.org/pipermail/macports-dev/attachments/20181028/5e1a1b3d/attachment-0001.obj>
-------------- next part --------------
Mark Brethen
mark.brethen at gmail.com
> On Oct 28, 2018, at 4:25 PM, Ryan Schmidt <ryandesign at macports.org> wrote:
>
>
>
> On Oct 28, 2018, at 16:08, Mark Brethen wrote:
>
>> Quite by accident I have discovered a flaw with my libreduce port as regards to "port select —set python". I had not set a default python version before I built the reduce libraries, unaware it was using apple's system python 2.7 to build. However, when I set a python version using port select —set python and add the python group, libreduce fails at configure. There is a file ‘ac_python_devel.m4’ in the source directory that is throwing the error (see attached). I’m not sure why builds with apple’s python and not macports.
>>
>> <main.log><ac_python_devel.m4>
>
> Which version of python did you select?
>
> The error shown in your log is:
>
> :info:configure checking for python... /opt/local/bin/python
> :info:configure checking for a version of Python >= '2.1.0'... File "<string>", line 1
> :info:configure import sys, string; ver = string.split(sys.version)[0]; print ver >= '2.1.0'
> :info:configure ^
> :info:configure SyntaxError: invalid syntax
> :info:configure no
>
> If I pass that code to MacPorts python2.7 it works fine. If I pass it to MacPorts python3.5 it shows an invalid syntax error, because it is: python3 changed the syntax of the print command. It's now a function, not a language construct, so parentheses need to be used.
>
> In addition, string.split is gone in python3.
>
> Code that works with both python2 and python3 is:
>
> import sys, string; ver = sys.version.split()[0]; print(ver >= '2.1.0')
>
> You might suggest that to the developers of this software.
>
> Using a string comparison operator on version numbers is probably wrong too.
>
> If the configure script's code wasn't compatible with python3, who knows if the rest of the project's python code is. If it's not, easiest to just force the port to use /usr/bin/python. Setting "configure.python /usr/bin/python" might do that.
>
More information about the macports-dev
mailing list