Bug 862986 - Part 2: Migrate PROGRAM from Makefile.in to moz.build. r=gps

This commit is contained in:
Brian O'Keefe 2013-04-30 20:46:10 -04:00
parent 41e401f326
commit 7422d5ac7b
77 changed files with 134 additions and 69 deletions

View File

@ -18,11 +18,6 @@ DEFINES += -DENABLE_MARIONETTE=1
endif
ifndef LIBXUL_SDK
ifneq ($(GAIADIR),)
PROGRAM=$(MOZ_APP_NAME)-bin$(BIN_SUFFIX)
else
PROGRAM=$(MOZ_APP_NAME)$(BIN_SUFFIX)
endif
CPPSRCS = nsBrowserApp.cpp

View File

@ -4,3 +4,8 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
if not CONFIG['LIBXUL_SDK']:
if CONFIG['GAIADIR']:
PROGRAM = CONFIG['MOZ_APP_NAME'] + "-bin"
else:
PROGRAM = CONFIG['MOZ_APP_NAME']

View File

@ -11,8 +11,6 @@ include $(DEPTH)/config/autoconf.mk
GAIA_PATH := gaia/profile
PROGRAM = $(MOZ_APP_NAME)$(BIN_SUFFIX)
ifeq ($(OS_ARCH),WINNT)
CPPSRCS = run-b2g.cpp
DEFINES += \

View File

@ -4,3 +4,5 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
PROGRAM = CONFIG['MOZ_APP_NAME']

View File

@ -43,8 +43,6 @@ endif #} LIBXUL_SDK
# Build a binary bootstrapping with XRE_main
PROGRAM = $(MOZ_APP_NAME)$(BIN_SUFFIX)
CPPSRCS = nsBrowserApp.cpp
LOCAL_INCLUDES += \

View File

@ -5,3 +5,6 @@
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
DIRS += ['profile/extensions']
PROGRAM = CONFIG['MOZ_APP_NAME']

View File

@ -16,7 +16,6 @@ include $(topsrcdir)/config/config.mk
# We want this exe in dist/bin
DIST_SUBDIR =
PROGRAM = CommandExecuteHandler$(BIN_SUFFIX)
DIST_PROGRAM = CommandExecuteHandler$(BIN_SUFFIX)
# Don't link against mozglue.dll

View File

@ -4,3 +4,4 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
PROGRAM = 'CommandExecuteHandler'

View File

@ -15,8 +15,6 @@ include $(topsrcdir)/config/config.mk
DIST_SUBDIR = metro/install
PROGRAM = linktool$(BIN_SUFFIX)
CPPSRCS = linktool.cpp
OS_LIBS = \

View File

@ -4,3 +4,5 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
PROGRAM = 'linktool'

View File

@ -23,8 +23,6 @@ include $(topsrcdir)/config/config.mk
# We want this exe in dist/bin
DIST_SUBDIR =
PROGRAM = metrotestharness$(BIN_SUFFIX)
CPPSRCS = \
metrotestharness.cpp \
$(NULL)

View File

@ -4,3 +4,5 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
PROGRAM = 'metrotestharness'

View File

@ -13,7 +13,6 @@ NO_PROFILE_GUIDED_OPTIMIZE = 1
ifdef ENABLE_TESTS
PROGRAM = crashinject$(BIN_SUFFIX)
USE_STATIC_LIBS = 1
CPPSRCS = crashinject.cpp

View File

@ -9,3 +9,5 @@ if CONFIG['_MSC_VER'] and CONFIG['OS_TEST'] != 'x86_64':
TEST_DIRS += ['crashinjectdll']
if CONFIG['ENABLE_TESTS']:
PROGRAM = 'crashinject'

View File

@ -15,8 +15,6 @@ CPPSRCS = \
PluginHangUIChild.cpp \
$(NULL)
PROGRAM = plugin-hang-ui$(BIN_SUFFIX)
OS_LIBS = $(call EXPAND_LIBNAME,comctl32)
RCINCLUDE = HangUIDlg.rc

View File

@ -4,3 +4,5 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
PROGRAM = 'plugin-hang-ui'

View File

@ -36,7 +36,6 @@ include $(DEPTH)/config/autoconf.mk
XPI_NAME = winembed
PROGRAM = winEmbed$(BIN_SUFFIX)
RESFILE = winEmbed.res
CPPSRCS = \

View File

@ -6,3 +6,5 @@
MODULE = 'winEmbed'
PROGRAM = 'winEmbed'

View File

@ -10,8 +10,6 @@ VPATH = @srcdir@
include $(DEPTH)/config/autoconf.mk
PROGRAM = ucgendat
CSRCS = ucgendat.c
# XXX need configure test

View File

@ -6,3 +6,5 @@
MODULE = 'ucgendat'
PROGRAM = 'ucgendat'

View File

@ -9,8 +9,6 @@ VPATH = @srcdir@
include $(DEPTH)/config/autoconf.mk
PROGRAM = $(MOZ_CHILD_PROCESS_NAME)
ifneq ($(dir $(PROGRAM)),./)
GENERATED_DIRS = $(dir $(PROGRAM))
endif

View File

@ -6,3 +6,5 @@
MODULE = 'ipc'
PROGRAM = CONFIG['MOZ_CHILD_PROCESS_NAME']

View File

@ -9,8 +9,6 @@ VPATH = @srcdir@
include $(DEPTH)/config/autoconf.mk
PROGRAM = $(MODULE)$(BIN_SUFFIX)
NSDISTMODE = copy
LOCAL_INCLUDES += -I$(topsrcdir)/toolkit/xre

View File

@ -6,3 +6,5 @@
MODULE = 'ipdlunittest'
PROGRAM = 'ipdlunittest'

View File

@ -11,7 +11,6 @@ VPATH = @srcdir@ @srcdir@/tests
include $(DEPTH)/config/autoconf.mk
PROGRAM = gdb-tests$(BIN_SUFFIX)
CPPSRCS = \
gdb-tests.cpp \
test-jsid.cpp \

View File

@ -4,3 +4,5 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
PROGRAM = 'gdb-tests'

View File

@ -11,8 +11,6 @@ VPATH = @srcdir@
include $(DEPTH)/config/autoconf.mk
PROGRAM = jsapi-tests$(BIN_SUFFIX)
CPPSRCS = \
tests.cpp \
selfTest.cpp \

View File

@ -4,3 +4,5 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
PROGRAM = 'jsapi-tests'

View File

@ -11,7 +11,6 @@ VPATH = @srcdir@
include $(DEPTH)/config/autoconf.mk
PROGRAM = $(JS_SHELL_NAME)$(BIN_SUFFIX)
CPPSRCS = \
js.cpp \
jsoptparse.cpp \

View File

@ -4,3 +4,5 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
PROGRAM = CONFIG['JS_SHELL_NAME']

View File

@ -10,7 +10,6 @@ VPATH = @srcdir@
include $(DEPTH)/config/autoconf.mk
PROGRAM = xpcshell$(BIN_SUFFIX)
SDK_BINARY = $(PROGRAM)
CPPSRCS = xpcshell.cpp

View File

@ -6,3 +6,5 @@
MODULE = 'xpcshell'
PROGRAM = 'xpcshell'

View File

@ -16,7 +16,6 @@ DIST_FILES = recommended-addons.json
ifndef LIBXUL_SDK
ifneq (Android,$(OS_TARGET))
PROGRAM=$(MOZ_APP_NAME)$(BIN_SUFFIX)
LOCAL_INCLUDES += -I$(topsrcdir)/toolkit/xre
LOCAL_INCLUDES += -I$(topsrcdir)/xpcom/base

View File

@ -4,3 +4,6 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
if not CONFIG['LIBXUL_SDK']:
if CONFIG['OS_TARGET'] != 'Android':
PROGRAM = CONFIG['MOZ_APP_NAME']

View File

@ -20,10 +20,6 @@ endif
# Mozilla distribution.
HOST_PROGRAM = mar$(HOST_BIN_SUFFIX)
ifdef MOZ_ENABLE_SIGNMAR
PROGRAM = signmar$(BIN_SUFFIX)
endif
# Don't link the against libmozglue because we don't need it.
MOZ_GLUE_LDFLAGS =
MOZ_GLUE_PROGRAM_LDFLAGS =

View File

@ -6,3 +6,5 @@
MODULE = 'mar'
if CONFIG['MOZ_ENABLE_SIGNMAR']:
PROGRAM = 'signmar'

View File

@ -11,8 +11,6 @@ FAIL_ON_WARNINGS := 1
include $(DEPTH)/config/autoconf.mk
PROGRAM = TestStreamConv$(BIN_SUFFIX)
CPPSRCS = \
Converters.cpp \
TestStreamConv.cpp \

View File

@ -6,3 +6,5 @@
MODULE = 'TestStreamConv'
PROGRAM = 'TestStreamConv'

View File

@ -16,6 +16,7 @@ from ..frontend.data import (
SandboxDerived,
VariablePassthru,
Exports,
Program,
XpcshellManifests,
)
from ..util import FileAvoidWrite
@ -214,6 +215,9 @@ class RecursiveMakeBackend(BuildBackend):
elif isinstance(obj, Exports):
self._process_exports(obj.exports, backend_file)
elif isinstance(obj, Program):
self._process_program(obj.program, backend_file)
elif isinstance(obj, XpcshellManifests):
self._process_xpcshell_manifests(obj.xpcshell_manifests, backend_file)
@ -325,5 +329,8 @@ class RecursiveMakeBackend(BuildBackend):
self._process_exports(children[subdir], backend_file,
namespace=namespace + subdir)
def _process_program(self, program, backend_file):
backend_file.write('PROGRAM = %s\n' % program)
def _process_xpcshell_manifests(self, manifest, backend_file, namespace=""):
backend_file.write('XPCSHELL_TESTS += %s\n' % os.path.dirname(manifest))

View File

@ -149,6 +149,24 @@ class Exports(SandboxDerived):
SandboxDerived.__init__(self, sandbox)
self.exports = exports
class Program(SandboxDerived):
"""Sandbox container object for PROGRAM, which is a unicode string.
This class handles automatically appending BIN_SUFFIX to the PROGRAM value.
If BIN_SUFFIX is not defined, PROGRAM is unchanged.
Otherwise, if PROGRAM ends in BIN_SUFFIX, it is unchanged
Otherwise, BIN_SUFFIX is appended to PROGRAM
"""
__slots__ = ('program')
def __init__(self, sandbox, program, bin_suffix):
SandboxDerived.__init__(self, sandbox)
bin_suffix = bin_suffix or ''
if not program.endswith(bin_suffix):
program += bin_suffix
self.program = program
class XpcshellManifests(SandboxDerived):
"""Build object container for XPCSHELL_TESTS_MANIFESTS (was: XPCSHELL_TESTS).

View File

@ -167,6 +167,14 @@ VARIABLES = {
EXPORTS.mozilla.dom += ['bar.h']
"""),
'PROGRAM' : (unicode, "",
"""Compiled executable name.
If the configuration token 'BIN_SUFFIX' is set, its value will be
automatically appended to PROGRAM. If PROGRAM already ends with
BIN_SUFFIX, PROGRAM will remain unchanged.
"""),
# IDL Generation.
'XPIDL_SOURCES': (list, [],
"""XPCOM Interface Definition Files (xpidl).

View File

@ -0,0 +1,4 @@
# Any copyright is dedicated to the Public Domain.
# http://creativecommons.org/publicdomain/zero/1.0/
PROGRAM = 'test_program'

View File

@ -15,6 +15,7 @@ from mozbuild.frontend.data import (
ReaderSummary,
VariablePassthru,
Exports,
Program,
XpcshellManifests,
)
from mozbuild.frontend.emitter import TreeMetadataEmitter
@ -31,6 +32,7 @@ class TestEmitterBasic(unittest.TestCase):
def reader(self, name):
config = MockConfig(os.path.join(data_path, name))
config.substs['ENABLE_TESTS'] = '1'
config.substs['BIN_SUFFIX'] = '.prog'
return BuildReader(config)
@ -170,6 +172,17 @@ class TestEmitterBasic(unittest.TestCase):
overwrite = exports._children['overwrite']
self.assertEqual(overwrite.get_strings(), ['new.h'])
def test_program(self):
reader = self.reader('program')
objs = self.read_topsrcdir(reader)
self.assertEqual(len(objs), 2)
self.assertIsInstance(objs[0], DirectoryTraversal)
self.assertIsInstance(objs[1], Program)
program = objs[1].program
self.assertEqual(program, 'test_program.prog')
def test_xpcshell_manifests(self):
reader = self.reader('xpcshell_manifests')
objs = self.read_topsrcdir(reader)

View File

@ -10,8 +10,6 @@ VPATH = @srcdir@
include $(DEPTH)/config/autoconf.mk
PROGRAM = rdfcat$(BIN_SUFFIX)
CPPSRCS = rdfcat.cpp
LIBS = \

View File

@ -4,3 +4,5 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
PROGRAM = 'rdfcat'

View File

@ -10,7 +10,6 @@ VPATH = @srcdir@
include $(DEPTH)/config/autoconf.mk
PROGRAM = rdfpoll$(BIN_SUFFIX)
CPPSRCS = rdfpoll.cpp

View File

@ -4,3 +4,5 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
PROGRAM = 'rdfpoll'

View File

@ -10,8 +10,6 @@ VPATH = @srcdir@
include $(DEPTH)/config/autoconf.mk
PROGRAM = triplescat$(BIN_SUFFIX)
CPPSRCS = triplescat.cpp
LIBS = \

View File

@ -4,3 +4,5 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
PROGRAM = 'triplescat'

View File

@ -14,8 +14,6 @@ include $(DEPTH)/config/autoconf.mk
# wrappers
STL_FLAGS =
PROGRAM = ssltunnel$(BIN_SUFFIX)
CPPSRCS = ssltunnel.cpp
LIBS = \

View File

@ -4,3 +4,5 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
PROGRAM = 'ssltunnel'

View File

@ -12,7 +12,6 @@ include $(DEPTH)/config/autoconf.mk
ifeq ($(MOZ_WIDGET_TOOLKIT),gtk2)
ifdef MOZ_X11
PROGRAM = screentopng
CPPSRCS = gdk-screenshot.cpp
LOCAL_INCLUDES = $(MOZ_GTK2_CFLAGS)
OS_LIBS = $(MOZ_GTK2_LIBS) $(XSS_LIBS)
@ -22,7 +21,6 @@ endif # GTK2
ifeq ($(MOZ_WIDGET_TOOLKIT),windows)
PROGRAM = screenshot$(BIN_SUFFIX)
CPPSRCS = win32-screenshot.cpp
OS_LIBS += $(call EXPAND_LIBNAME,gdiplus)
MOZ_GLUE_PROGRAM_LDFLAGS =

View File

@ -4,3 +4,7 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
if CONFIG['MOZ_WIDGET_TOOLKIT'] == 'gtk2' and CONFIG['MOZ_X11']:
PROGRAM = 'screentopng'
elif CONFIG['MOZ_WIDGET_TOOLKIT'] == 'windows':
PROGRAM = 'screenshot'

View File

@ -21,7 +21,6 @@ CPPSRCS = \
# For debugging purposes only
#DEFINES += -DDISABLE_UPDATER_AUTHENTICODE_CHECK
PROGRAM = maintenanceservice$(BIN_SUFFIX)
DIST_PROGRAM = maintenanceservice$(BIN_SUFFIX)
# Don't link the maintenanceservice against mozglue.dll. See bug 687139 and

View File

@ -4,3 +4,5 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
PROGRAM = 'maintenanceservice'

View File

@ -16,7 +16,6 @@ include $(DEPTH)/config/autoconf.mk
STL_FLAGS =
ifneq ($(OS_TARGET),Android)
PROGRAM = crashreporter$(BIN_SUFFIX)
DIST_PROGRAM = crashreporter$(BIN_SUFFIX)
# Don't link the updater against libmozglue.

View File

@ -6,6 +6,8 @@
MODULE = 'crashreporter'
if CONFIG['OS_TARGET'] != 'Android':
PROGRAM = 'crashreporter'
# The xpcshell test case here verifies that the CA certificate list
if CONFIG['MOZ_WIDGET_TOOLKIT'] == 'gtk2' and CONFIG['MOZ_PLATFORM_MAEMO']:
XPCSHELL_TESTS_MANIFESTS += ['maemo-unit/xpcshell.ini']

View File

@ -22,8 +22,6 @@ CPPSRCS += \
$(NULL)
endif
PROGRAM = updater$(BIN_SUFFIX)
# Don't link the updater against libmozglue. See bug 687139
MOZ_GLUE_LDFLAGS =
MOZ_GLUE_PROGRAM_LDFLAGS =

View File

@ -4,3 +4,5 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
PROGRAM = 'updater'

View File

@ -11,8 +11,6 @@ VPATH = @srcdir@
include $(DEPTH)/config/autoconf.mk
PROGRAM = jprof
CPPSRCS = \
bfd.cpp \
coff.cpp \

View File

@ -5,3 +5,6 @@
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
DIRS += ['stub']
PROGRAM = 'jprof'

View File

@ -30,7 +30,6 @@ EXTRACSRCS = tmreader.c
EXTRACPPSRCS = adreader.cpp
ifndef MOZ_PROFILE_GENERATE
PROGRAM = spacetrace$(BIN_SUFFIX)
PROGCSRCS = \
spacetrace.c \

View File

@ -4,3 +4,5 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
if not CONFIG['MOZ_PROFILE_GENERATE']:
PROGRAM = 'spacetrace'

View File

@ -11,8 +11,6 @@ FAIL_ON_WARNINGS := 1
include $(DEPTH)/config/autoconf.mk
# Build a binary bootstrapping with XRE_main
PROGRAM = webapprt-stub
CPPSRCS = webapprt.cpp
LOCAL_INCLUDES += \

View File

@ -4,3 +4,5 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
PROGRAM = 'webapprt-stub'

View File

@ -13,8 +13,6 @@ include $(DEPTH)/config/autoconf.mk
# shouldn't get 755 perms need $(IFLAGS1) for either way of calling nsinstall.
NSDISTMODE = copy
PROGRAM = webapprt-stub$(BIN_SUFFIX)
CMMSRCS = webapprt.mm
# Don't create a dependency on mozglue, which is impossible (difficult?)

View File

@ -4,3 +4,5 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
PROGRAM = 'webapprt-stub'

View File

@ -10,8 +10,6 @@ VPATH = @srcdir@
include $(DEPTH)/config/autoconf.mk
# Build a binary bootstrapping with XRE_main
PROGRAM = webapprt-stub$(BIN_SUFFIX)
CPPSRCS = webapprt.cpp
# Statically link against the CRT

View File

@ -4,3 +4,5 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
PROGRAM = 'webapprt-stub'

View File

@ -28,8 +28,6 @@ EXTRA_DSO_LDOPTS = \
$(MOZ_COMPONENT_LIBS) \
$(NULL)
PROGRAM = mozilla-xremote-client$(BIN_SUFFIX)
PROGCPPSRCS = \
mozilla-xremote-client.cpp \
XRemoteClient.cpp \

View File

@ -6,3 +6,5 @@
MODULE = 'xremoteclient'
PROGRAM = 'mozilla-xremote-client'

View File

@ -15,8 +15,6 @@ GARBAGE += $(addprefix $(DIST)/bin/defaults/pref/,xulrunner.js)
DEFINES += -DAB_CD=$(AB_CD)
PROGRAM = xulrunner$(BIN_SUFFIX)
DEFINES += -DXULRUNNER_PROGNAME=\"xulrunner\"
ifdef TARGET_XPCOM_ABI

View File

@ -5,3 +5,6 @@
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
DIRS += ['profile']
PROGRAM = 'xulrunner'

View File

@ -16,12 +16,6 @@ MOZ_GLUE_LDFLAGS =
CPPSRCS = nsXULStub.cpp
# The value of XULRUNNER_STUB_NAME is generated by configure to allow XULRunner
# apps to override it using the --with-xulrunner-stub-name=<appname> argument.
# If this configure argument is not present then the default name is 'xulrunner'
# for Mac OS X and 'xulrunner-stub' for all other platforms.
PROGRAM = $(XULRUNNER_STUB_NAME)$(BIN_SUFFIX)
LOCAL_INCLUDES = \
-I$(topsrcdir)/xpcom/build \
-I$(topsrcdir)/xpcom/base \

View File

@ -6,3 +6,9 @@
MODULE = 'xulrunner'
# The value of XULRUNNER_STUB_NAME is generated by configure to allow XULRunner
# apps to override it using the --with-xulrunner-stub-name=<appname> argument.
# If this configure argument is not present then the default name is 'xulrunner'
# for Mac OS X and 'xulrunner-stub' for all other platforms.
PROGRAM = CONFIG['XULRUNNER_STUB_NAME']

View File

@ -11,7 +11,6 @@ include $(DEPTH)/config/autoconf.mk
ifeq ($(OS_ARCH),WINNT)
CPPSRCS = redit.cpp
PROGRAM = redit$(BIN_SUFFIX)
SDK_BINARY = \
$(PROGRAM) \

View File

@ -6,3 +6,5 @@
MODULE = 'redit'
if CONFIG['OS_ARCH'] == 'WINNT':
PROGRAM = 'redit'