summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorUlf Samuelsson <ulf.samuelsson@atmel.com>2007-10-31 06:35:06 +0000
committerUlf Samuelsson <ulf.samuelsson@atmel.com>2007-10-31 06:35:06 +0000
commitd359c6611dc9232392c0545de6a783b4cff4e895 (patch)
tree80b68ab530b9d6547eaacd46544c04fabe09c2d8
parentc2f4774694e99914acc53d876fe91353b7c9b2a1 (diff)
downloadbuildroot-novena-d359c6611dc9232392c0545de6a783b4cff4e895.tar.gz
buildroot-novena-d359c6611dc9232392c0545de6a783b4cff4e895.zip
Add libogg media container package for vorbis
-rw-r--r--package/Config.in1
-rw-r--r--package/libogg/Config.in13
-rw-r--r--package/libogg/libogg.mk85
3 files changed, 99 insertions, 0 deletions
diff --git a/package/Config.in b/package/Config.in
index edd18aeb1..a4b5c15dd 100644
--- a/package/Config.in
+++ b/package/Config.in
@@ -273,6 +273,7 @@ source "package/asterisk/Config.in"
source "package/aumix/Config.in"
source "package/libid3tag/Config.in"
source "package/libmad/Config.in"
+source "package/libogg/Config.in"
source "package/libsndfile/Config.in"
source "package/libvorbis/Config.in"
source "package/madplay/Config.in"
diff --git a/package/libogg/Config.in b/package/libogg/Config.in
new file mode 100644
index 000000000..09c56895c
--- /dev/null
+++ b/package/libogg/Config.in
@@ -0,0 +1,13 @@
+config BR2_PACKAGE_LIBOGG
+ bool "libogg"
+ default n
+ help
+ Ogg is the name of Xiph.org's container format for audio, video, and metadata
+
+config BR2_PACKAGE_LIBOGG_HEADERS
+ bool "libogg target headers"
+ default n
+ depends on BR2_PACKAGE_LIBOGG
+ help
+ Add target headers for the Ogg open source container format
+ - Not yet implemented
diff --git a/package/libogg/libogg.mk b/package/libogg/libogg.mk
new file mode 100644
index 000000000..461adab83
--- /dev/null
+++ b/package/libogg/libogg.mk
@@ -0,0 +1,85 @@
+#############################################################
+#
+# libogg
+#
+#############################################################
+LIBOGG_VERSION:=1.1.3
+LIBOGG_NAME:=libogg-$(LIBOGG_VERSION)
+LIBOGG_SOURCE:=$(LIBOGG_NAME).tar.gz
+LIBOGG_SITE:=http://downloads.xiph.org/releases/ogg/$(LIBOGG-SOURCE)
+LIBOGG_DIR:=$(BUILD_DIR)/libogg-$(LIBOGG_VERSION)
+LIBOGG_BINARY:=libogg
+LIBOGG_TARGET_BINARY:=usr/lib/libogg
+LIBOGG_CAT:=$(ZCAT)
+
+$(DL_DIR)/$(LIBOGG_SOURCE):
+ $(WGET) -P $(DL_DIR) $(LIBOGG_SITE)/$(LIBOGG_SOURCE)
+
+$(LIBOGG_DIR)/.source: $(DL_DIR)/$(LIBOGG_SOURCE)
+ $(LIBOGG_CAT) $(DL_DIR)/$(LIBOGG_SOURCE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) -
+ touch $@
+
+$(LIBOGG_DIR)/.configured: $(LIBOGG_DIR)/.source
+ (cd $(LIBOGG_DIR); rm -rf config.cache; \
+ $(TARGET_CONFIGURE_ARGS) \
+ $(TARGET_CONFIGURE_OPTS) \
+ CFLAGS="$(TARGET_CFLAGS)" \
+ PKG_CONFIG_PATH="$(STAGING_DIR)/lib/pkconfig:$(STAGING_DIR)/usr/lib/pkgconfig" \
+ PKG_CONFIG="$(STAGING_DIR)/usr/bin/pkg-config" \
+ PKG_CONFIG_SYSROOT=$(STAGING_DIR) \
+ ./configure \
+ --target=$(GNU_TARGET_NAME) \
+ --host=$(GNU_TARGET_NAME) \
+ --build=$(GNU_HOST_NAME) \
+ --prefix=/usr \
+ --sysconfdir=/etc \
+ --enable-shared \
+ --enable-static \
+ --disable-oggtest \
+ $(DISABLE_NLS) \
+ )
+ touch $@
+
+$(LIBOGG_DIR)/.libs: $(LIBOGG_DIR)/.configured
+ $(MAKE) CC=$(TARGET_CC) -C $(LIBOGG_DIR)
+ touch $@
+
+$(TARGET_DIR)/usr/lib/libogg.so: $(LIBOGG_DIR)/.libs
+ $(MAKE) prefix=$(TARGET_DIR)/usr -C $(LIBOGG_DIR) install
+ifneq ($(strip $(BR2_HAVE_MANPAGES)),y)
+ rm -rf $(TARGET_DIR)/usr/share/doc/$(LIBOGG_NAME)
+endif
+ touch $@
+
+$(TARGET_DIR)/usr/lib/libogg.a: $(TARGET_DIR)/usr/lib/libogg.so
+ cp -dpf $(LIBOGG_DIR)/lib/libogg.a $(TARGET_DIR)/usr/lib/
+ touch $@
+
+libogg-header: $(TARGET_DIR)/usr/lib/libogg.a
+ mkdir -p $(TARGET_DIR)/usr/include/ogg
+ cp -dpf $(LIBOGG_DIR)/include/ogg/*.h \
+ $(TARGET_DIR)/usr/include/ogg
+
+libogg: uclibc pkgconfig $(TARGET_DIR)/usr/lib/libogg.so
+
+libogg-source: $(DL_DIR)/$(LIBOGG_SOURCE)
+
+libogg-clean:
+ $(MAKE) prefix=$(STAGING_DIR)/usr -C $(LIBOGG_DIR) uninstall
+ -$(MAKE) -C $(LIBOGG_DIR) clean
+
+libogg-dirclean:
+ rm -rf $(LIBOGG_DIR)
+
+############################################################
+#
+# Toplevel Makefile options
+#
+############################################################
+ifeq ($(strip $(BR2_PACKAGE_LIBOGG)),y)
+TARGETS+=libogg
+endif
+
+ifeq ($(strip $(BR2_PACKAGE_LIBOGG_HEADERS)),y)
+TARGETS+=libogg-header
+endif