docdir := $(sharedir)/doc
mandir := $(sharedir)/man
-moz_include_dir := \
- $(shell pkg-config --variable=prefix mozilla-gtkmozembed)/include/mozilla
-moz_lib_dir := \
- $(shell pkg-config --variable=prefix mozilla-gtkmozembed)/lib/mozilla
+# Prefer XULRunner to the old Mozilla
+ifeq ($(shell pkg-config --exists xulrunner-gtkmozembed && echo yes),yes)
+ mozilla := xulrunner
+else
+ mozilla := mozilla
+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_version := \
$(shell sed 's/\#define MOZILLA_VERSION "\(.*\)"/\1/; t; d' \
CFLAGS := -ansi -Wall -Wunused -Wno-unused-parameter
CPPFLAGS := -D_REENTRANT
CXXFLAGS := -ansi -Wall -Wunused
-LDFLAGS := -lpthread $(shell pkg-config --libs gtkmm-2.0 mozilla-gtkmozembed) \
+LDFLAGS := -lpthread \
+ $(shell pkg-config --libs gtkmm-2.0 $(mozilla)-gtkmozembed) \
-Wl,-rpath -Wl,$(moz_lib_dir) -lexpat
ifdef NDEBUG
.objs/browser_widget.% : CPPFLAGS += -DMOZ_LIB_DIR='"$(moz_lib_dir)"'
.objs/videolink.% \
- : CPPFLAGS += -DVIDEOLINK_SHARE_DIR='"$(sharedir)/videolink"' \
- -DMOZ_VERSION_MAJOR=$(moz_version_major) \
- -DMOZ_VERSION_MINOR=$(moz_version_minor) \
- -DMOZ_VERSION_PATCHLEVEL=$(moz_version_patchlevel)
+ : CPPFLAGS += -DVIDEOLINK_SHARE_DIR='"$(sharedir)/videolink"'
.objs/browser_widget.% .objs/generate_dvd.% .objs/pixbufs.% \
.objs/temp_file.% .objs/vob_list.% .objs/videolink.% \
: CPPFLAGS += $(shell pkg-config --cflags gtkmm-2.0)
-.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)
+.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)
# 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.% \
: CXXFLAGS += -Wno-non-virtual-dtor
# These dig a bit deeper into Mozilla
-.objs/link_iterator.% .objs/style_sheets.% .objs/videolink.% \
- : CPPFLAGS += $(addprefix -I$(moz_include_dir)/, \
- content docshell dom gfx layout necko webshell widget)
-
-.objs/null_prompt_service.% : CPPFLAGS += -I$(moz_include_dir)/uconv
-
-.objs/%.d : %.cpp .objs/.created
- $(CXX) $(CXXFLAGS) $(CPPFLAGS) -MM -MF $@ $<
+.objs/link_iterator.% .objs/null_prompt_service.% .objs/style_sheets.% \
+.objs/videolink.% \
+ : CPPFLAGS += $(addprefix -I$(moz_include_dir)/, \
+ content docshell dom gfx 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)
-.objs/%.d : %.c .objs/.created
- $(CC) $(CFLAGS) $(CPPFLAGS) -MM -MF $@ $<
+.objs/%.d : .objs/.created
+ touch $@
.objs/%.o : %.cpp .objs/.created
- $(CXX) $(CXXFLAGS) $(CPPFLAGS) -o $@ -c $<
+ $(CXX) $(CXXFLAGS) $(CPPFLAGS) -o $@ -MD -MF .objs/$*.d -c $<
.objs/%.o : %.c .objs/.created
- $(CC) $(CFLAGS) $(CPPFLAGS) -o $@ -c $<
+ $(CC) $(CFLAGS) $(CPPFLAGS) -o $@ -MD -MF .objs/$*.d -c $<
%/.created :
mkdir -p $*