class OpenZwave < Formula desc "Library for selected Z-Wave PC controllers" homepage "http://www.openzwave.com" url "http://old.openzwave.com/downloads/openzwave-1.2.919.tar.gz" sha256 "473229f3dd3d6b260e6584b17e5c5f2e09e61805f89763f486a9f7aa2b4181ba" bottle do sha256 "ee97a2cce9fed3f63fb917e09e448f35815eff5120ebae16711777be4796d5c0" => :high_sierra sha256 "68502b64e9fb7031f9fc5fe4fa7e6714fd5e5ab93d467169e7e47e90c322ff64" => :sierra sha256 "4bf1d8a8ba3fcf4ee39df9bfe09017d3a432047e5e6bf0dce6f6e612ad174b95" => :el_capitan sha256 "9ceb267d8fb564daefb535f65ac71f426535f7552b9feffcb3638793f0c40810" => :yosemite sha256 "753eb6cb76dd0c170c1e84285a702fb9fb49c76aa8d59970ecea2160938f0bba" => :mavericks sha256 "be2b4c51703ee93865a6c755a4394b6271eb599ea98a7431b54d090276a0e9f7" => :mountain_lion end # Patch to build a .dylib instead of a .so # This patch has been merged upstream and can be removed after the next release: # https://code.google.com/p/open-zwave/source/detail?r=954 patch :DATA def install ENV["BUILD"] = "release" ENV["PREFIX"] = prefix system "make", "install" end test do (testpath/"test.cpp").write <<~EOS #include #include "Options.h" int main() { OpenZWave::Options::Create("", "", ""); return 0; } EOS system ENV.cxx, "-o", "test", "-I", prefix/"include/openzwave", "-L#{lib}", "-lopenzwave", "test.cpp" system "./test" end end __END__ diff --git a/cpp/build/Makefile b/cpp/build/Makefile index 24df4f5..b064029 100644 --- a/cpp/build/Makefile +++ b/cpp/build/Makefile @@ -23,16 +23,24 @@ top_srcdir := $(abspath $(dir $(lastword $(MAKEFILE_LIST)))../../) include $(top_srcdir)/cpp/build/support.mk +#Mac prefers a dylib, not a so +ifeq ($(UNAME),Darwin) +SHARED_LIB_NAME=libopenzwave-$(VERSION).dylib +SHARED_LIB_UNVERSIONED=libopenzwave.dylib +else +SHARED_LIB_NAME=libopenzwave.so.$(VERSION) +SHARED_LIB_UNVERSIONED=libopenzwave.so +endif #if we are on a Mac, add these flags and libs to the compile and link phases ifeq ($(UNAME),Darwin) CFLAGS += -c -DDARWIN -arch i386 -arch x86_64 -LDFLAGS += -arch i386 -arch x86_64 +LDFLAGS += -arch i386 -arch x86_64 -dynamiclib LIBS += -framework IOKit -framework CoreFoundation -arch i386 -arch x86_64 else ifeq ($(UNAME),FreeBSD) CFLAGS += -I/usr/local/include else -LDFLAGS += -Wl,-soname,libopenzwave.so.$(VERSION) +LDFLAGS += -shared -Wl,-soname,$(SHARED_LIB_NAME) LIBS += -ludev endif @@ -74,10 +82,10 @@ indep := $(notdir $(filter-out $(top_srcdir)/cpp/src/vers.cpp, $(wildcard $(top_ aes := $(notdir $(wildcard $(top_srcdir)/cpp/src/aes/*.c)) -default: $(LIBDIR)/libopenzwave.a $(LIBDIR)/libopenzwave.so.$(VERSION) +default: $(LIBDIR)/libopenzwave.a $(LIBDIR)/$(SHARED_LIB_NAME) clean: - @rm -rf $(DEPDIR) $(OBJDIR) $(LIBDIR)/libopenzwave.so* $(LIBDIR)/libopenzwave.a $(top_builddir)/libopenzwave.pc $(top_builddir)/docs/api $(top_builddir)/Doxyfile + @rm -rf $(DEPDIR) $(OBJDIR) $(LIBDIR)/libopenzwave.so* $(LIBDIR)/libopenzwave-*.dylib $(LIBDIR)/libopenzwave.a $(top_builddir)/libopenzwave.pc $(top_builddir)/docs/api $(top_builddir)/Doxyfile -include $(patsubst %.cpp,$(DEPDIR)/%.d,$(tinyxml)) @@ -110,7 +118,7 @@ $(LIBDIR)/libopenzwave.a: $(patsubst %.cpp,$(OBJDIR)/%.o,$(tinyxml)) \ @$(AR) $@ $+ @$(RANLIB) $@ -$(LIBDIR)/libopenzwave.so.$(VERSION): $(patsubst %.cpp,$(OBJDIR)/%.o,$(tinyxml)) \ +$(LIBDIR)/$(SHARED_LIB_NAME): $(patsubst %.cpp,$(OBJDIR)/%.o,$(tinyxml)) \ $(patsubst %.c,$(OBJDIR)/%.o,$(hidapi)) \ $(patsubst %.c,$(OBJDIR)/%.o,$(aes)) \ $(patsubst %.cpp,$(OBJDIR)/%.o,$(cclasses)) \ @@ -120,7 +128,7 @@ $(LIBDIR)/libopenzwave.so.$(VERSION): $(patsubst %.cpp,$(OBJDIR)/%.o,$(tinyxml)) $(OBJDIR)/vers.o @echo "Linking Shared Library" - @$(LD) $(LDFLAGS) -shared -o $@ $+ $(LIBS) - @ln -sf libopenzwave.so.$(VERSION) $(LIBDIR)/libopenzwave.so + @$(LD) $(LDFLAGS) -o $@ $+ $(LIBS) + @ln -sf $(SHARED_LIB_NAME) $(LIBDIR)/$(SHARED_LIB_UNVERSIONED) ifeq ($(PKGCONFIG),) $(top_builddir)/libopenzwave.pc: $(top_srcdir)/cpp/build/libopenzwave.pc.in @@ -155,10 +163,10 @@ doc: $(top_builddir)/Doxyfile @cd $(top_builddir); $(DOXYGEN) endif -install: $(LIBDIR)/libopenzwave.so.$(VERSION) doc $(top_builddir)/libopenzwave.pc +install: $(LIBDIR)/$(SHARED_LIB_NAME) doc $(top_builddir)/libopenzwave.pc install -d $(DESTDIR)/$(instlibdir)/ - cp $(LIBDIR)/libopenzwave.so.$(VERSION) $(DESTDIR)/$(instlibdir)/libopenzwave.so.$(VERSION) - ln -sf libopenzwave.so.$(VERSION) $(DESTDIR)/$(instlibdir)/libopenzwave.so + cp $(LIBDIR)/$(SHARED_LIB_NAME) $(DESTDIR)/$(instlibdir)/$(SHARED_LIB_NAME) + ln -sf $(SHARED_LIB_NAME) $(DESTDIR)/$(instlibdir)/$(SHARED_LIB_UNVERSIONED) install -d $(DESTDIR)/$(includedir) install -m 0644 $(top_srcdir)/cpp/src/*.h $(DESTDIR)/$(includedir) install -d $(DESTDIR)/$(includedir)/command_classes/ diff --git a/cpp/examples/MinOZW/Makefile b/cpp/examples/MinOZW/Makefile index 0f1fd50..3805a39 100644 --- a/cpp/examples/MinOZW/Makefile +++ b/cpp/examples/MinOZW/Makefile @@ -19,7 +19,7 @@ top_srcdir := $(abspath $(dir $(lastword $(MAKEFILE_LIST)))../../../) INCLUDES := -I $(top_srcdir)/cpp/src -I $(top_srcdir)/cpp/tinyxml/ -I $(top_srcdir)/cpp/hidapi/hidapi/ -LIBS = $(wildcard $(LIBDIR)/*.so $(top_builddir)/*.so $(top_builddir)/cpp/build/*.so ) +LIBS = $(wildcard $(LIBDIR)/*.so $(LIBDIR)/*.dylib $(top_builddir)/*.so $(top_builddir)/*.dylib $(top_builddir)/cpp/build/*.so $(top_builddir)/cpp/build/*.dylib ) LIBSDIR = $(abspath $(dir $(firstword $(LIBS)))) minozwsrc := $(notdir $(wildcard $(top_srcdir)/cpp/examples/MinOZW/*.cpp)) VPATH := $(top_srcdir)/cpp/examples/MinOZW