# Prefer XULRunner to the old Mozilla
ifeq ($(shell pkg-config --exists xulrunner-gtkmozembed && echo yes),yes)
- mozilla := xulrunner
+ moz_name := xulrunner
+ moz_pc := xulrunner-gtkmozembed
else
- mozilla := mozilla
+ moz_name := mozilla
+ moz_pc := mozilla-gtkmozembed
endif
-moz_prefix := $(shell pkg-config --variable=prefix $(mozilla)-gtkmozembed)
-moz_include_dir := $(moz_prefix)/include/$(mozilla)
-moz_lib_dir := $(moz_prefix)/lib/$(mozilla)
+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)
-moz_version := \
- $(shell sed 's/\#define MOZILLA_VERSION "\(.*\)"/\1/; t; d' \
- < $(moz_include_dir)/mozilla-config.h)
+moz_version := $(shell pkg-config --modversion $(moz_pc))
moz_version_major := $(word 1,$(subst ., ,$(moz_version)))
moz_version_minor := $(word 2,$(subst ., ,$(moz_version)))
-moz_version_patchlevel := $(word 3,$(subst ., ,$(moz_version)))
CFLAGS := -ansi -Wall -Wunused -Wno-unused-parameter
CPPFLAGS := -D_REENTRANT
CXXFLAGS := -ansi -Wall -Wunused
-LDFLAGS := -lpthread \
- $(shell pkg-config --libs gtkmm-2.4 $(mozilla)-gtkmozembed) \
+LDFLAGS := -lpthread \
+ $(shell pkg-config --libs gtkmm-2.4 $(moz_pc)) \
-Wl,-rpath -Wl,$(moz_lib_dir) -lexpat
ifdef NDEBUG
x_frame_buffer.cpp xml_utils.cpp xpcom_support.cpp
csources := jquant2.c
+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 link_iterator.cpp \
+ null_prompt_service.cpp style_sheets.cpp videolink.cpp xpcom_support.cpp
+sources_using_moz_unstable := \
+ link_iterator.cpp null_prompt_service.cpp style_sheets.cpp videolink.cpp
+
videolink : $(cxxsources:%.cpp=.objs/%.o) $(csources:%.c=.objs/%.o)
$(CXX) $(LDFLAGS) -o $@ $^
.objs/videolink.% \
: CPPFLAGS += -DVIDEOLINK_SHARE_DIR='"$(sharedir)/videolink"'
-.objs/browser_widget.% .objs/generate_dvd.% .objs/pixbufs.% \
-.objs/temp_file.% .objs/vob_list.% .objs/videolink.% .objs/warp_pointer.% \
+$(sources_using_gtkmm:%.cpp=.objs/%.o) \
: CPPFLAGS += $(shell pkg-config --cflags gtkmm-2.4)
-.objs/browser_widget.% .objs/child_iterator.% .objs/link_iterator.% \
-.objs/null_prompt_service.% .objs/style_sheets.% .objs/videolink.% \
-.objs/xpcom_support.% \
- : CPPFLAGS += $(shell pkg-config --cflags $(mozilla)-gtkmozembed)
+$(sources_using_moz:%.cpp=.objs/%.o) \
+ : CPPFLAGS += $(shell pkg-config --cflags $(moz_pc))
# Non-virtual destructors are fine in XPCOM interface classes since
# instances are only ever called by the Release function which is virtual.
-.objs/browser_widget.% .objs/child_iterator.% .objs/link_iterator.% \
-.objs/null_prompt_service.% .objs/style_sheets.% .objs/videolink.% \
-.objs/xpcom_support.% \
- : CXXFLAGS += -Wno-non-virtual-dtor
-
-# These dig a bit deeper into Mozilla
-.objs/link_iterator.% .objs/null_prompt_service.% .objs/style_sheets.% \
-.objs/videolink.% \
+$(sources_using_moz:%.cpp=.objs/%.o) : CXXFLAGS += -Wno-non-virtual-dtor
+
+$(sources_using_moz_unstable:%.cpp=.objs/%.o) \
: CPPFLAGS += $(addprefix -I$(moz_include_dir)/, \
- content docshell dom gfx layout locale necko uconv \
- webshell widget) \
+ content docshell dom gfx imglib2 layout locale \
+ necko uconv webshell widget) \
-DMOZILLA_INTERNAL_API \
-DMOZ_VERSION_MAJOR=$(moz_version_major) \
- -DMOZ_VERSION_MINOR=$(moz_version_minor) \
- -DMOZ_VERSION_PATCHLEVEL=$(moz_version_patchlevel)
+ -DMOZ_VERSION_MINOR=$(moz_version_minor)
.objs/%.d : .objs/.created
touch $@