diff options
| author | Johns <johns98@gmx.net> | 2013-02-12 18:36:38 +0100 |
|---|---|---|
| committer | Johns <johns98@gmx.net> | 2013-02-12 18:36:38 +0100 |
| commit | c9f78fc40c174dabb94592eec8e3515da27e5003 (patch) | |
| tree | 80cd303cfdb31819d1d3601faca830cf38884450 | |
| parent | ee78297e6e6ea8a11df476f1fa688f8d4718ba66 (diff) | |
| download | vdr-plugin-play-c9f78fc40c174dabb94592eec8e3515da27e5003.tar.gz vdr-plugin-play-c9f78fc40c174dabb94592eec8e3515da27e5003.tar.bz2 | |
New Makefile for vdr >=1.7.36.
| -rw-r--r-- | Makefile | 185 | ||||
| -rw-r--r-- | Makefile-pre1.7.36 | 5 |
2 files changed, 189 insertions, 1 deletions
diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..e7a6706 --- /dev/null +++ b/Makefile @@ -0,0 +1,185 @@ +# +# Makefile for a Video Disk Recorder plugin +# +# $Id$ + +# The official name of this plugin. +# This name will be used in the '-P...' option of VDR to load the plugin. +# By default the main source file also carries this name. + +PLUGIN = play + +### Configuration (edit this for your needs) + + # support avfs a virtual file system +AVFS ?= $(shell test -x /usr/bin/avfs-config && echo 1) + # use ffmpeg libswscale +SWCALE ?= $(shell pkg-config --exists libswscale && echo 1) + # support png images +PNG ?= $(shell pkg-config --exists libpng && echo 1) + # support jpg images +JPG ?= $(shell test -r /usr/include/jpeglib.h && echo 1) + +CONFIG := # -DDEBUG # uncomment to build DEBUG + +ifeq ($(AVFS),1) +CONFIG += -DUSE_AVFS +_CFLAGS += $(shell /usr/bin/avfs-config --cflags) +LIBS += $(shell /usr/bin/avfs-config --libs) +endif +ifeq ($(SWSCALE),1) +CONFIG += -DUSE_SWSCALE +_CFLAGS += $(shell pkg-config --cflags libswscale) +LIBS += $(shell pkg-config --libs libswscale) +endif +ifeq ($(PNG),1) +CONFIG += -DUSE_PNG +_CFLAGS += $(shell pkg-config --cflags libpng) +LIBS += $(shell pkg-config --libs libpng) +endif +ifeq ($(JPG),1) +CONFIG += -DUSE_JPG +_CFLAGS += -I/usr/include +LIBS += -Ljpeg +endif + +_CFLAGS += $(shell pkg-config --cflags xcb xcb-image xcb-keysyms xcb-icccm) +LIBS += -lrt $(shell pkg-config --libs xcb xcb-image xcb-keysyms xcb-icccm) + +### The version number of this plugin (taken from the main source file): + +VERSION = $(shell grep 'static const char \*const VERSION *=' $(PLUGIN).cpp | awk '{ print $$7 }' | sed -e 's/[";]//g') +GIT_REV = $(shell git describe --always 2>/dev/null) + +### The directory environment: + +# Use package data if installed...otherwise assume we're under the VDR source directory: +PKGCFG = $(if $(VDRDIR),$(shell pkg-config --variable=$(1) $(VDRDIR)/vdr.pc),$(shell pkg-config --variable=$(1) vdr || pkg-config --variable=$(1) ../../../vdr.pc)) +LIBDIR = $(call PKGCFG,libdir) +LOCDIR = $(call PKGCFG,locdir) +PLGCFG = $(call PKGCFG,plgcfg) +# +TMPDIR ?= /tmp + +### The compiler options: + +export CFLAGS = $(call PKGCFG,cflags) +export CXXFLAGS = $(call PKGCFG,cxxflags) + +ifeq ($(CFLAGS),) +$(error CFLAGS not set) +endif +ifeq ($(CXXFLAGS),) +$(error CXXFLAGS not set) +endif + +### The version number of VDR's plugin API: + +APIVERSION = $(call PKGCFG,apiversion) + +### Allow user defined options to overwrite defaults: + +-include $(PLGCFG) + +### The name of the distribution archive: + +ARCHIVE = $(PLUGIN)-$(VERSION) +PACKAGE = vdr-$(ARCHIVE) + +### The name of the shared object file: + +SOFILE = libvdr-$(PLUGIN).so + +### Includes and Defines (add further entries here): + +INCLUDES += + +DEFINES += -DPLUGIN_NAME_I18N='"$(PLUGIN)"' -D_GNU_SOURCE $(CONFIG) \ + $(if $(GIT_REV), -DGIT_REV='"$(GIT_REV)"') + +### Make it standard + +override CXXFLAGS += $(_CFLAGS) $(DEFINES) $(INCLUDES) \ + -g -W -Wall -Wextra -Winit-self -Werror=overloaded-virtual +override CFLAGS += $(_CFLAGS) $(DEFINES) $(INCLUDES) \ + -g -W -Wall -Wextra -Winit-self -Wdeclaration-after-statement + +### The object files (add further files here): + +OBJS = $(PLUGIN).o dia.o video.o readdir.o + +SRCS = $(wildcard $(OBJS:.o=.c)) $(PLUGIN).cpp + +### The main target: + +all: $(SOFILE) i18n + +### Dependencies: + +MAKEDEP = $(CXX) -MM -MG +DEPFILE = .dependencies +$(DEPFILE): Makefile + @$(MAKEDEP) $(CXXFLAGS) $(SRCS) > $@ + +-include $(DEPFILE) + +### Internationalization (I18N): + +PODIR = po +I18Npo = $(wildcard $(PODIR)/*.po) +I18Nmo = $(addsuffix .mo, $(foreach file, $(I18Npo), $(basename $(file)))) +I18Nmsgs = $(addprefix $(DESTDIR)$(LOCDIR)/, $(addsuffix /LC_MESSAGES/vdr-$(PLUGIN).mo, $(notdir $(foreach file, $(I18Npo), $(basename $(file)))))) +I18Npot = $(PODIR)/$(PLUGIN).pot + +%.mo: %.po + msgfmt -c -o $@ $< + +$(I18Npot): $(SRCS) + xgettext -C -cTRANSLATORS --no-wrap --no-location -k -ktr -ktrNOOP --package-name=vdr-$(PLUGIN) --package-version=$(VERSION) --msgid-bugs-address='<see README>' -o $@ `ls $^` + +%.po: $(I18Npot) + msgmerge -U --no-wrap --no-location --backup=none -q -N $@ $< + @touch $@ + +$(I18Nmsgs): $(DESTDIR)$(LOCDIR)/%/LC_MESSAGES/vdr-$(PLUGIN).mo: $(PODIR)/%.mo + install -D -m644 $< $@ + +.PHONY: i18n +i18n: $(I18Nmo) $(I18Npot) + +install-i18n: $(I18Nmsgs) + +### Targets: + +$(OBJS): Makefile + +$(SOFILE): $(OBJS) + $(CXX) $(CXXFLAGS) $(LDFLAGS) -shared $(OBJS) $(LIBS) -o $@ + +install-lib: $(SOFILE) + install -D $^ $(DESTDIR)$(LIBDIR)/$^.$(APIVERSION) + +install: install-lib install-i18n + +dist: $(I18Npo) clean + @-rm -rf $(TMPDIR)/$(ARCHIVE) + @mkdir $(TMPDIR)/$(ARCHIVE) + @cp -a * $(TMPDIR)/$(ARCHIVE) + @tar czf $(PACKAGE).tgz -C $(TMPDIR) $(ARCHIVE) + @-rm -rf $(TMPDIR)/$(ARCHIVE) + @echo Distribution package created as $(PACKAGE).tgz + +clean: + @-rm -f $(PODIR)/*.mo $(PODIR)/*.pot + @-rm -f $(OBJS) $(DEPFILE) *.so *.tgz core* *~ + +## Private Targets: + +HDRS= $(wildcard *.h) + +indent: + for i in $(SRCS) $(HDRS); do \ + indent $$i; \ + unexpand -a $$i | sed -e s/constconst/const/ > $$i.up; \ + mv $$i.up $$i; \ + done diff --git a/Makefile-pre1.7.36 b/Makefile-pre1.7.36 index 2194a6e..78cf533 100644 --- a/Makefile-pre1.7.36 +++ b/Makefile-pre1.7.36 @@ -25,6 +25,8 @@ CONFIG += $(shell test -x /usr/bin/avfs-config && echo "-DUSE_AVFS") CONFIG += $(shell pkg-config --exists libswscale && echo "-DUSE_SWSCALE") # autodetect: support png images CONFIG += $(shell pkg-config --exists libpng && echo "-DUSE_PNG") + # autodetect: support jpg images +CONFIG += $(shell test -r /usr/include/jpeglib.h && echo "-DUSE_JPG") ### The C++ compiler and options: @@ -81,7 +83,8 @@ _LIBS := $(shell pkg-config --libs xcb xcb-keysyms xcb-event xcb-icccm \ $(if $(findstring USE_AVFS,$(CONFIG)), `avfs-config --libs`) \ $(if $(findstring USE_SWSCALE,$(CONFIG)), \ `pkg-config --libs libswscale`) \ - $(if $(findstring USE_PNG,$(CONFIG)), `pkg-config --libs libpng`) + $(if $(findstring USE_PNG,$(CONFIG)), `pkg-config --libs libpng`) \ + $(if $(findstring USE_JPG,$(CONFIG)), -ljpeg) override LIBS += $(_LIBS) |
