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 2013年

回答:


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 2013年

それはほとんどそれを釘付けにします。ありがとう!!
Edson Medina

2
2014年4月26日現在。これらのコマンドは機能しなくなりました。「OS X Mavericksのコマンドラインツール」をdeveloper.apple.com/downloads/index.action#からダウンロードてインストールする必要があります。
qazwsx 14

37

同様の質問に答えました。Tclフレームワークの場所が変更され、既存のMacPortsインフラストラクチャが破壊されました。Mavericksの2.2.1インストーラは、ここから入手できるようになりまし。インストールされているポートのリストを作成し、インストール/opt/local前に削除することを検討してください。とにかくすべてを「更新」する必要があるでしょう。


6
2.2.1をインストールすると、すべてが再び機能し始めました。何も削除する必要はありませんでした。ポインターありがとうございます。
Alex Polkhovsky 2013年

こっちも一緒。これが正解です。はい、多くの人はコマンドラインツールをインストールしませんが、最初のトレースが示すように、ここでは明らかに問題ではありません。
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コマンドを実行し、他のポートをインストールできるようになりました。

私が見たエラーは以下でした、ヨソフィアが指摘したのと同じ問題のようです:

$ 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の回答にコメントし(申し訳ありませんが、SO n00bはまだ許可されていません)、アップグレードの経験を共有したいと思いました...本当に新しい回答ではありませんが、うまくいけばいくつかの有用な情報です。

上記のようにMavericks MacPortsインストーラーをダウンロードしてインストールしました(ただし、@ King Julianが提案したように/ optを削除せず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

問題はMacportsとTclフレームワークの場所にあり、Xcodeがインストールされた後のパスにあるようです。ここで、Mavericks用のMacportsの新しいバージョンをインストールすることをお勧めします:http : //www.macports.org/install.php


0

Mountain Lionでこの問題が発生しましたが、実際には古いXCodeパスを調べているMacPortsに関係していました(ベータ版を含むいくつかのバージョンがインストールされていました)。-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

そしてそれはそれを修正しました。

私はこの有用なページから手掛かりを得ました。

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.