无法更新Macports(使用Mac OS X Mavericks)


149

将Mac OS X升级到最新版本的Mavericks之后,我尝试自我更新Macports,但失败了:

$ sudo port -v selfupdate
--->  Updating MacPorts base sources using rsync
receiving file list ... done

sent 36 bytes  received 69 bytes  210.00 bytes/sec
total size is 4925440  speedup is 46908.95
receiving file list ... done

sent 36 bytes  received 76 bytes  74.67 bytes/sec
total size is 512  speedup is 4.57
MacPorts base version 2.2.0 installed,
MacPorts base version 2.2.1 downloaded.
--->  Updating the ports tree
Synchronizing local ports tree from rsync://rsync.macports.org/release/tarballs/ports.tar
receiving file list ... done

sent 36 bytes  received 70 bytes  70.67 bytes/sec
total size is 57702400  speedup is 544362.26
receiving file list ... done

sent 36 bytes  received 77 bytes  75.33 bytes/sec
total size is 512  speedup is 4.53
receiving file list ... rsync: change_dir "tarballs/PortIndex_darwin_13_i386" (in release) failed: No such file or directory (2)
done

sent 4 bytes  received 9 bytes  26.00 bytes/sec
total size is 0  speedup is 0.00
rsync error: some files could not be transferred (code 23) at /SourceCache/rsync/rsync-42/rsync/main.c(1400) [receiver=2.6.9]
Command failed: /usr/bin/rsync -rtzv --delete-after rsync://rsync.macports.org/release/tarballs/PortIndex_darwin_13_i386/PortIndex /opt/local/var/macports/sources/rsync.macports.org/release/tarballs
Exit code: 23
--->  MacPorts base is outdated, installing new version 2.2.1
Installing new MacPorts release in /opt/local as root:admin; permissions 0755; Tcl-Package in /Library/Tcl

checking build system type... x86_64-apple-darwin13.0.0
checking host system type... x86_64-apple-darwin13.0.0
checking target system type... x86_64-apple-darwin13.0.0
checking MacPorts version... 2.2.1
checking for sw_vers... /usr/bin/sw_vers
checking for defaults... /usr/bin/defaults
checking for xcode-select... /usr/bin/xcode-select
checking Mac OS X version... 10.9
checking Xcode location... /Applications/Xcode.app/Contents/Developer
checking Xcode version... 5.0.1
checking for gcc... /usr/bin/cc
checking whether the C compiler works... yes
checking for C compiler default output file name... a.out
checking for suffix of executables...
<snip>
checking CommonCrypto/CommonDigest.h presence... yes
checking for CommonCrypto/CommonDigest.h... yes
checking for readline in -lreadline... yes
checking whether rl_username_completion_function is declared... no
checking whether rl_filename_completion_function is declared... yes
checking whether rl_completion_matches is declared... yes
checking whether username_completion_function is declared... yes
checking whether filename_completion_function is declared... yes
checking whether completion_matches is declared... yes
checking for Tcl configuration... configure: error: Can't find Tcl configuration definitions
Command failed: cd /opt/local/var/macports/sources/rsync.macports.org/release/tarballs/base && CC=/usr/bin/cc OBJC=/usr/bin/cc ./configure --prefix=/opt/local --with-tclpackage=/Library/Tcl --with-install-user=root --with-install-group=admin --with-directory-mode=0755 --enable-readline && make SELFUPDATING=1 && make install SELFUPDATING=1
Exit code: 1
Error: Error installing new MacPorts base: command execution failed
To report a bug, follow the instructions in the guide:
    http://guide.macports.org/#project.tickets
Error: /opt/local/bin/port: port selfupdate failed: Error installing new MacPorts base: command execution failed
$

如果我只是尝试升级特定端口,它也会失败:

$ sudo port upgrade emacsapp
Password:
Warning: port definitions are more than two weeks old, consider updating them by running 'port selfupdate'.
Error: emacsapp is not installed
$ sudo port search emacs
Password:
Warning: port definitions are more than two weeks old, consider updating them by running 'port selfupdate'.
$ sudo port upgrade emacs-app
Warning: port definitions are more than two weeks old, consider updating them by running 'port selfupdate'.
--->  Fetching archive for gperf
--->  Attempting to fetch gperf-3.0.4_2.darwin_13.x86_64.tbz2 from http://packages.macports.org/gperf
--->  Attempting to fetch gperf-3.0.4_2.darwin_13.x86_64.tbz2 from http://lil.fr.packages.macports.org/gperf
--->  Attempting to fetch gperf-3.0.4_2.darwin_13.x86_64.tbz2 from http://mse.uk.packages.macports.org/sites/packages.macports.org/gperf
--->  Fetching distfiles for gperf
--->  Attempting to fetch gperf-3.0.4.tar.gz from http://ykf.ca.distfiles.macports.org/MacPorts/mpdistfiles/gperf
--->  Verifying checksums for gperf
--->  Extracting gperf
Error: org.macports.extract for port gperf returned: command execution failed
Please see the log file for port gperf for details:
    /opt/local/var/macports/logs/_opt_local_var_macports_sources_rsync.macports.org_release_tarballs_ports_devel_gperf/gperf/main.log
Error: Problem while installing gperf
To report a bug, follow the instructions in the guide:
    http://guide.macports.org/#project.tickets
$

任何想法

  • 是否由OS X Mavericks和Macports之间的不兼容引起的?
  • 如何解决?

编辑:

我尝试了另一台计算机将其从10.8.5升级到10.9,然后尝试对macports进行自我更新,但此操作不再起作用,但给出了另一个错误:

$ sudo port -v selfupdate
--->  Updating MacPorts base sources using rsync
receiving file list ... done
base.tar

sent 13396 bytes  received 10355 bytes  15834.00 bytes/sec
total size is 4925440  speedup is 207.38
receiving file list ... done
base.tar.rmd160

sent 64 bytes  received 635 bytes  1398.00 bytes/sec
total size is 512  speedup is 0.73
MacPorts base version 2.2.1 installed,
MacPorts base version 2.2.1 downloaded.
--->  Updating the ports tree
Synchronizing local ports tree from file:///opt/local/var/macports/sources/svn.macports.org/trunk/dports/
svn: E155036: Please see the 'svn upgrade' command
svn: E155036: Working copy '/opt/local/var/macports/sources/svn.macports.org/trunk/dports' is too old (format 10, created by Subversion 1.6)
Command failed: /usr/bin/svn update --non-interactive /opt/local/var/macports/sources/svn.macports.org/trunk/dports
Exit code: 1
Error: Synchronization of the local ports tree failed doing an svn update
Error: Couldn't sync the ports tree: Synchronization of 1 source(s) failed
To report a bug, follow the instructions in the guide:
    http://guide.macports.org/#project.tickets
Error: /opt/local/bin/port: port selfupdate failed: Couldn't sync the ports tree: Synchronization of 1 source(s) failed


很好的建议-对我
有用-lynxoid

Answers:


282

首先安装“命令行工具”:

sudo xcode-select --install

(有时需要通过“ sudo xcodebuild -license”明确同意许可)

然后升级端口:

sudo port -v selfupdate

36
还可能值得注意的是,您应该通过执行以下操作来同意条款和条件:sudo xcodebuild -license。执行步骤,然后输入“同意”,然后按Enter。
astromax 2013年

5
如果不执行此操作,则在运行selfupdate时,某些端口将失败。
astromax 2013年

8
至少对我而言,无需许可即可弹出许可协议。
PaulSkinner

那几乎钉住了它。谢谢!!
Edson Medina

2
自2014年4月26日起。这些命令不再起作用。也许应该从developer.apple.com/downloads/index.action#下载“用于OS X Mavericks的命令行工具” 并进行安装。
qazwsx 2014年

37

回答了类似的问题。Tcl框架的位置已更改,从而破坏了现有的MacPorts基础结构。2.2.1安装程序小牛队已经成为可用在这里。列出您已安装的端口,并/opt/local在安装前考虑删除。无论如何,您可能都需要“更新”所有内容。


6
安装了2.2.1,一切又重新开始工作。不必删除任何东西。谢谢你的指点。
Alex Polkhovsky

同样在这里。这是正确的答案。是的,很多人没有安装命令行工具,但这显然不是问题所在,如提供的第一个跟踪所示。
PatchyFog

这确实是正确的,幸运的是我很快在其他地方的其他误导性问题之后找到了这个答案。谢谢。
沸腾的仙境2013年

macosx没有预装tcl,对吗?
Maysam Torabi 2014年

3

您可能会不同意XCode许可证。如果xcode-install无法解决问题,则可以运行以下命令以同意Xcode许可证。 sudo xcodebuild -license



2

我遇到过同样的问题。我假设您以前安装了Xcode命令行实用程序。只需启动XCODE并完成配置即可。现在重新运行port命令,它应该可以正常工作。


1

我遇到了selfupdate错误,并通过从http://www.macports.org/install.php全新安装MacPorts解决了该问题。现在,我可以正常运行selfupdate命令并安装其他端口。

我看到的错误在下面,似乎与Yo Sophia指出的问题相同:

$ sudo port selfupdate
Password:
--->  Updating MacPorts base sources using rsync
MacPorts base version 2.1.3 installed,
MacPorts base version 2.2.1 downloaded.
--->  Updating the ports tree
--->  MacPorts base is outdated, installing new version 2.2.1
Installing new MacPorts release in /opt/local as root:admin; permissions 0755; Tcl-Package in /Library/Tcl

Error: /opt/local/bin/port: port selfupdate failed: Error installing new MacPorts base: command execution failed

0

我主要想评论@Brett的上述回答(很抱歉,仍然不允许n00b),并分享我的升级经验……并不是真正的新答案,但希望能提供一些有用的信息。

我如上所述下载并安装了Mavericks MacPorts安装程序,(但是没有删除/ opt,如@King Julian所做的那样self update,这很好,然后upgrade outdated似乎正在卸载并重新安装所有端口,并显示一条消息:

Warning: Deactivate forced.  Proceeding despite dependencies.

在每一个。幸运的是,我制作了etcapache2 / conf dirs 的副本,因此当它最终完成时应该能够恢复我的配置... 30分钟左右后,它抛出了错误

Unable to open port: extra characters after close-quote

所以我又做了self update一次,upgrade outdated似乎又跑了...

这样看起来就可以完成(无论如何,LAMP都可以正常工作)-从头开始重新启动可能更快,但是请确保至少有几个小时的备用时间(并连接到电源;)

抱歉,如果信息过多,但希望对您有所帮助!



0

我在Mountain Lion上遇到了这个问题,实际上是与MacPorts查看旧的XCode路径有关的(我安装了多个版本,包括Beta)。我使用-d选项运行并检查了/opt/local/var/macports/sources/rsync.macports.org/release/base中的config.log文件,它报告了一些错误:

--- snip ---
...
configure:3331: checking for C compiler version
configure:3340: gcc --version >&5
Configured with: --prefix=/Applications/Xcode5-DP3.app/Contents/Developer/usr --with-gxx-include-dir=/usr/include/c++/4.2.1
xcrun: Error: could not stat active Xcode path '/Applications/Xcode5-DP3.app/Contents/Developer'. (No such file or directory)
configure:3351: $? = 0
configure:3340: gcc -v >&5
Configured with: --prefix=/Applications/Xcode5-DP3.app/Contents/Developer/usr --with-gxx-include-dir=/usr/include/c++/4.2.1
xcrun: Error: could not stat active Xcode path '/Applications/Xcode5-DP3.app/Contents/Developer'. (No such file or directory)
...
--- snip ---

所以我给了它正确的路径:

sudo xcode-select -switch /Applications/Xcode.app/Contents/Developer

并固定了它。

我从这个有用的页面中得到了线索。

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.