prefix := /usr/local
-moz_include_dir := \
- $(shell pkg-config --variable=prefix mozilla-gtkmozembed)/include/mozilla
-moz_lib_dir := \
- $(shell pkg-config --variable=prefix mozilla-gtkmozembed)/lib/mozilla
+bindir := $(prefix)/bin
+sharedir := $(prefix)/share
+docdir := $(sharedir)/doc
+mandir := $(sharedir)/man
+
+ifeq ($(shell pkg-config --atleast-version 1.9 mozilla-gtkmozembed-embedding && echo yes),yes)
+ moz_name := xulrunner-1.9
+ moz_pc := mozilla-gtkmozembed-embedding
+ moz_cppflags_extra := $(shell pkg-config --cflags xulrunner-nspr)
+ moz_unstable_cppflags_extra :=
+ moz_ldflags_extra :=
+else
+ ifeq ($(shell pkg-config --exists xulrunner-gtkmozembed && echo yes),yes)
+ moz_name := xulrunner
+ moz_pc := xulrunner-gtkmozembed
+ else
+ moz_name := mozilla
+ moz_pc := mozilla-gtkmozembed
+ endif
+ moz_unstable_cppflags_extra = \
+ $(addprefix -I$(moz_include_dir)/, \
+ content docshell dom gfx imglib2 layout locale necko uconv webshell widget) \
+ -DMOZILLA_INTERNAL_API
+ moz_ldflags_extra = -Wl,-rpath,$(moz_lib_dir)
+endif
+
+moz_prefix := $(shell pkg-config --variable=prefix $(moz_pc))
+moz_include_dir := $(shell pkg-config --variable=includedir $(moz_pc))
+moz_lib_dir := $(moz_prefix)/lib/$(moz_name)
-CFLAGS := -Wall
+moz_version := $(shell pkg-config --modversion $(moz_pc))
+moz_version_major := $(word 1,$(subst ., ,$(moz_version)))
+moz_version_minor := $(word 2,$(subst ., ,$(moz_version)))
+
+CFLAGS := -ansi -Wall -Wunused -Wno-unused-parameter
CPPFLAGS := -D_REENTRANT
-CXXFLAGS := -Wall
-LDFLAGS := -lpthread $(shell pkg-config --libs gtkmm-2.0 mozilla-gtkmozembed) \
- -Wl,-rpath -Wl,$(moz_lib_dir)
+CXXFLAGS := -ansi -Wall -Wunused
+LDFLAGS := -lpthread \
+ $(shell pkg-config --libs gtkmm-2.4 $(moz_pc)) \
+ $(moz_ldflags_extra) -lexpat
ifdef NDEBUG
CPPFLAGS += -DNDEBUG
endif
cxxsources := \
- auto_proc.cpp browserwidget.cpp childiterator.cpp framebuffer.cpp \
- linkiterator.cpp pixbufs.cpp stylesheets.cpp webdvd.cpp xpcom_support.cpp
+ auto_proc.cpp browser_widget.cpp child_iterator.cpp \
+ event_state_manager.cpp generate_dvd.cpp link_iterator.cpp \
+ null_prompt_service.cpp pixbufs.cpp style_sheets.cpp temp_file.cpp \
+ video.cpp vob_list.cpp videolink.cpp warp_pointer.cpp \
+ x_frame_buffer.cpp xml_utils.cpp xpcom_support.cpp
csources := jquant2.c
-webdvd : $(cxxsources:.cpp=.o) $(csources:.c=.o)
- $(CXX) $(LDFLAGS) -o $@ $^
+sources_using_gtkmm := \
+ browser_widget.cpp generate_dvd.cpp pixbufs.cpp temp_file.cpp \
+ vob_list.cpp videolink.cpp warp_pointer.cpp
+sources_using_moz := \
+ browser_widget.cpp child_iterator.cpp event_state_manager.cpp \
+ link_iterator.cpp null_prompt_service.cpp style_sheets.cpp \
+ videolink.cpp xpcom_support.cpp
+sources_using_moz_unstable := \
+ browser_widget.cpp event_state_manager.cpp link_iterator.cpp \
+ null_prompt_service.cpp style_sheets.cpp videolink.cpp
-clean :
- rm -f webdvd *.d *.o *~ .\#* *.orig *.rej svn-commit*.tmp *.dvdauthor *.png *.vob *.spumux
+videolink : $(cxxsources:%.cpp=.objs/%.o) $(csources:%.c=.objs/%.o)
+ $(CXX) $^ $(LDFLAGS) -o $@
-distclean : clean
- rm -rf .svn
+clean :
+ rm -rf .objs
+ rm -f videolink *~ .\#* *.orig *.rej svn-commit*.tmp
install :
- mkdir -p -m 755 $(prefix)/bin $(prefix)/lib/webdvd
- install -m 755 -s webdvd $(prefix)/bin
- install -m 644 webdvd.css $(prefix)/lib/webdvd
+ mkdir -p -m 755 $(DESTDIR)$(bindir)
+ install -m 755 -s videolink $(DESTDIR)$(bindir)
+ mkdir -p -m 755 $(DESTDIR)$(docdir)/videolink
+ gzip -c9 README >$(DESTDIR)$(docdir)/videolink/README.gz
+ gzip -c9 ChangeLog >$(DESTDIR)$(docdir)/videolink/ChangeLog.gz
+ chmod 644 $(DESTDIR)$(docdir)/videolink/*.gz
+ mkdir -p -m 755 $(DESTDIR)$(mandir)/man1
+ gzip -c9 videolink.1 >$(DESTDIR)$(mandir)/man1/videolink.1.gz
+ chmod 644 $(DESTDIR)$(mandir)/man1/videolink.1.gz
+ mkdir -p -m 755 $(DESTDIR)$(sharedir)/videolink
+ install -m 644 *.css $(DESTDIR)$(sharedir)/videolink
+
+.PHONY : clean install
-.PHONY : clean distclean install
+.objs/browser_widget.% : CPPFLAGS += -DMOZ_LIB_DIR='"$(moz_lib_dir)"'
-browserwidget.% : CPPFLAGS += -DMOZ_LIB_DIR='"$(moz_lib_dir)"'
+.objs/videolink.% \
+ : CPPFLAGS += -DVIDEOLINK_SHARE_DIR='"$(sharedir)/videolink"'
-webdvd.% \
- : CPPFLAGS += -DWEBDVD_LIB_DIR='"$(prefix)/lib/webdvd"'
+$(sources_using_gtkmm:%.cpp=.objs/%.o) \
+ : CPPFLAGS += $(shell pkg-config --cflags gtkmm-2.4)
-browserwidget.% pixbufs.% webdvd.% \
- : CPPFLAGS += $(shell pkg-config --cflags gtkmm-2.0)
+$(sources_using_moz:%.cpp=.objs/%.o) \
+ : CPPFLAGS += $(shell pkg-config --cflags $(moz_pc)) $(moz_cppflags_extra)
+# Non-virtual destructors are fine in XPCOM interface classes since
+# instances are only ever called by the Release function which is virtual.
+$(sources_using_moz:%.cpp=.objs/%.o) : CXXFLAGS += -Wno-non-virtual-dtor
-browserwidget.% childiterator.o linkiterator.% stylesheets.% webdvd.% \
-xpcom_support.% \
- : CPPFLAGS += $(shell pkg-config --cflags mozilla-gtkmozembed)
+$(sources_using_moz_unstable:%.cpp=.objs/%.o) \
+ : CPPFLAGS += $(moz_unstable_cppflags_extra) \
+ -DMOZ_VERSION_MAJOR=$(moz_version_major) \
+ -DMOZ_VERSION_MINOR=$(moz_version_minor)
-# These dig a bit deeper into Mozilla
-linkiterator.% stylesheets.% webdvd.% \
- : CPPFLAGS += $(addprefix -I$(moz_include_dir)/, \
- content docshell dom gfx layout necko webshell widget)
+.objs/%.d : .objs/.created
+ touch $@
-%.d : %.cpp
- $(CXX) $(CXXFLAGS) $(CPPFLAGS) -MM -MF $@ $<
+.objs/%.o : %.cpp .objs/.created
+ $(CXX) $(CXXFLAGS) $(CPPFLAGS) -o $@ -MD -MF .objs/$*.d -c $<
-%.d : %.c
- $(CC) $(CFLAGS) $(CPPFLAGS) -MM -MF $@ $<
+.objs/%.o : %.c .objs/.created
+ $(CC) $(CFLAGS) $(CPPFLAGS) -o $@ -MD -MF .objs/$*.d -c $<
+
+%/.created :
+ mkdir -p $*
+ touch $@
ifneq ($(MAKECMDGOALS),clean)
- include $(cxxsources:.cpp=.d) $(csources:.c=.d)
+ include $(cxxsources:%.cpp=.objs/%.d) $(csources:%.c=.objs/%.d)
endif
-# Temporary rule for testing output files.
-
-%.vob : %_back.png %.spumux %_links.png
- pngtopnm $*_back.png \
- | ppmtoy4m -v0 -n 1 -F 25:1 -A 59:54 -I p -S 420_mpeg2 \
- | mpeg2enc -v0 -f 8 -a 2 -o /dev/stdout \
- | mplex -v0 -f 8 -o /dev/stdout /dev/stdin \
- | spumux -v0 -m dvd $*.spumux > $@
+.PRECIOUS : %/.created