使用したい非常に便利なソフトウェア パッケージ ( libdc1394 ) がありますが、いくつかの変更が必要であり、sourceforge プロジェクトの所有者は夏の間休暇を取っている可能性があります。プロジェクトをフォークした場合、homebrew に変更した数式を提供させるにはどうすればよいですか? 私はオープンソースソフトウェアにかなり慣れていません。
また、homebrew は現在、既存のプロジェクトのバイナリ ボトルを提供しています。フォークされたライブラリからこれらのバイナリ ボトルを作成するには、homebrew でビルド自体を実行できますか?それとも、さまざまな OSX 10.X システム用のバイナリを生成するためにコンパイルする必要がありますか? 私が尋ねる理由は、既存のライブラリの ./configure が私のシステムにあらゆる種類の問題を引き起こすからです (ただし、誰かのシステムでは動作するはずです)。
セラーの場所はここに /usr/local/Cellar/libdc1394/2.2.2
あり、バイナリはここにあります: /usr/local/Cellar/libdc1394/2.2.2/lib
;
コンテンツ: libdc1394.22.dylib, libdc1394.dylib, libdc1394.a, pkgconfig
バイナリを含む、キャッシュ内の注いだボトルの場所:
/Library/Caches/Homebrew/libdc1394-2.2.2.mavericks.bottle.tar.gz
以下は、既存の自作式である Ruby スクリプト ( /usr/local/Library/Formula/libdc1394.rb
) です。
require "formula"
class Libdc1394 < Formula
homepage "http://damien.douxchamps.net/ieee1394/libdc1394/"
url "https://downloads.sourceforge.net/project/libdc1394/libdc1394-2/2.2.2/libdc1394-2.2.2.tar.gz"
sha1 "13958c3cd0709565b5e4a9012dcf2a9b710264e2"
bottle do
cellar :any
sha1 "063e3babff63f462de1b7d053690ae3f0e250bcb" => :mavericks
sha1 "52d23eb6514dfc5c9aa554bade7dac92deefec70" => :mountain_lion
sha1 "9f703002e33433885f3f2cb9e4a4006585282a01" => :lion
end
depends_on "sdl"
# fix issue due to bug in OSX Firewire stack
# libdc1394 author comments here:
# http://permalink.gmane.org/gmane.comp.multimedia.libdc1394.devel/517
patch :DATA
def install
system "./configure", "--disable-dependency-tracking",
"--prefix=#{prefix}",
"--disable-examples",
"--disable-sdltest"
system "make install"
end
end
__END__
diff --git a/dc1394/macosx/capture.c b/dc1394/macosx/capture.c
index c7c71f2..8959535 100644
--- a/dc1394/macosx/capture.c
+++ b/dc1394/macosx/capture.c
@@ -150,7 +150,7 @@ callback (buffer_info * buffer, NuDCLRef dcl)
for (i = 0; i < buffer->num_dcls; i++) {
int packet_size = capture->frames[buffer->i].packet_size;
- if ((buffer->pkts[i].status & 0x1F) != 0x11) {
+ if (buffer->pkts[i].status && (buffer->pkts[i].status & 0x1F) != 0x11) {
dc1394_log_warning ("packet %d had error status %x",
i, buffer->pkts[i].status);
corrupt = 1;