X-Git-Url: https://git.saurik.com/apple/javascriptcore.git/blobdiff_plain/9dae56ea45a0f5f8136a5c93d6f3a7f99399ca73..refs/heads/master:/DerivedSources.make?ds=sidebyside diff --git a/DerivedSources.make b/DerivedSources.make index 4b33682..677f4ce 100644 --- a/DerivedSources.make +++ b/DerivedSources.make @@ -1,17 +1,17 @@ -# Copyright (C) 2006, 2007, 2008, 2009 Apple Inc. All rights reserved. +# Copyright (C) 2006, 2007, 2008, 2009, 2011, 2013, 2015 Apple Inc. All rights reserved. # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions # are met: # # 1. Redistributions of source code must retain the above copyright -# notice, this list of conditions and the following disclaimer. +# notice, this list of conditions and the following disclaimer. # 2. Redistributions in binary form must reproduce the above copyright # notice, this list of conditions and the following disclaimer in the -# documentation and/or other materials provided with the distribution. -# 3. Neither the name of Apple Computer, Inc. ("Apple") nor the names of +# documentation and/or other materials provided with the distribution. +# 3. Neither the name of Apple Inc. ("Apple") nor the names of # its contributors may be used to endorse or promote products derived -# from this software without specific prior written permission. +# from this software without specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED @@ -27,49 +27,176 @@ VPATH = \ $(JavaScriptCore) \ $(JavaScriptCore)/parser \ - $(JavaScriptCore)/pcre \ - $(JavaScriptCore)/docs \ $(JavaScriptCore)/runtime \ - $(JavaScriptCore)/interpreter \ - $(JavaScriptCore)/jit \ + $(JavaScriptCore)/interpreter \ + $(JavaScriptCore)/jit \ + $(JavaScriptCore)/builtins \ # .PHONY : all all : \ - ArrayPrototype.lut.h \ - chartables.c \ + ArrayConstructor.lut.h \ + ArrayIteratorPrototype.lut.h \ + BooleanPrototype.lut.h \ + DateConstructor.lut.h \ DatePrototype.lut.h \ - Grammar.cpp \ + ErrorPrototype.lut.h \ + JSDataViewPrototype.lut.h \ + JSONObject.lut.h \ + JSGlobalObject.lut.h \ + JSPromisePrototype.lut.h \ + JSPromiseConstructor.lut.h \ + KeywordLookup.h \ Lexer.lut.h \ - MathObject.lut.h \ NumberConstructor.lut.h \ + NumberPrototype.lut.h \ + ObjectConstructor.lut.h \ RegExpConstructor.lut.h \ - RegExpObject.lut.h \ - StringPrototype.lut.h \ - docs/bytecode.html \ + RegExpPrototype.lut.h \ + RegExpJitTables.h \ + StringConstructor.lut.h \ + StringIteratorPrototype.lut.h \ + SymbolConstructor.lut.h \ + SymbolPrototype.lut.h \ + udis86_itab.h \ + Bytecodes.h \ + InitBytecodes.asm \ + JSCBuiltins \ # +# builtin functions +.PHONY: JSCBuiltins + +PYTHON = python +PERL = perl + +ifeq ($(OS),Windows_NT) + DELETE = cmd //C del +else + DELETE = rm -f +endif +# -------- + +JSCBuiltins: $(JavaScriptCore)/generate-js-builtins JSCBuiltins.h JSCBuiltins.cpp +JSCBuiltins.h: $(JavaScriptCore)/generate-js-builtins $(JavaScriptCore)/builtins + $(PYTHON) $(JavaScriptCore)/generate-js-builtins --input-directory $(JavaScriptCore)/builtins --output $@ + +JSCBuiltins.cpp: JSCBuiltins.h + # lookup tables for classes %.lut.h: create_hash_table %.cpp - $^ -i > $@ + $(PERL) $^ -i > $@ Lexer.lut.h: create_hash_table Keywords.table - $^ > $@ + $(PERL) $^ > $@ + +# character tables for Yarr + +RegExpJitTables.h: create_regex_tables + $(PYTHON) $^ > $@ + +KeywordLookup.h: KeywordLookupGenerator.py Keywords.table + $(PYTHON) $^ > $@ + +# udis86 instruction tables + +udis86_itab.h: $(JavaScriptCore)/disassembler/udis86/itab.py $(JavaScriptCore)/disassembler/udis86/optable.xml + $(PYTHON) $(JavaScriptCore)/disassembler/udis86/itab.py $(JavaScriptCore)/disassembler/udis86/optable.xml + +# Bytecode files + +Bytecodes.h: $(JavaScriptCore)/generate-bytecode-files $(JavaScriptCore)/bytecode/BytecodeList.json + $(PYTHON) $(JavaScriptCore)/generate-bytecode-files --bytecodes_h Bytecodes.h $(JavaScriptCore)/bytecode/BytecodeList.json + +InitBytecodes.asm: $(JavaScriptCore)/generate-bytecode-files $(JavaScriptCore)/bytecode/BytecodeList.json + $(PYTHON) $(JavaScriptCore)/generate-bytecode-files --init_bytecodes_asm InitBytecodes.asm $(JavaScriptCore)/bytecode/BytecodeList.json + +# Inspector interfaces + +INSPECTOR_DOMAINS = \ + $(JavaScriptCore)/inspector/protocol/ApplicationCache.json \ + $(JavaScriptCore)/inspector/protocol/CSS.json \ + $(JavaScriptCore)/inspector/protocol/Console.json \ + $(JavaScriptCore)/inspector/protocol/DOM.json \ + $(JavaScriptCore)/inspector/protocol/DOMDebugger.json \ + $(JavaScriptCore)/inspector/protocol/DOMStorage.json \ + $(JavaScriptCore)/inspector/protocol/Database.json \ + $(JavaScriptCore)/inspector/protocol/Debugger.json \ + $(JavaScriptCore)/inspector/protocol/GenericTypes.json \ + $(JavaScriptCore)/inspector/protocol/Inspector.json \ + $(JavaScriptCore)/inspector/protocol/LayerTree.json \ + $(JavaScriptCore)/inspector/protocol/Network.json \ + $(JavaScriptCore)/inspector/protocol/OverlayTypes.json \ + $(JavaScriptCore)/inspector/protocol/Page.json \ + $(JavaScriptCore)/inspector/protocol/Runtime.json \ + $(JavaScriptCore)/inspector/protocol/Timeline.json \ + $(JavaScriptCore)/inspector/protocol/Worker.json \ +# -# JavaScript language grammar +ifeq ($(findstring ENABLE_INDEXED_DATABASE,$(FEATURE_DEFINES)), ENABLE_INDEXED_DATABASE) + INSPECTOR_DOMAINS := $(INSPECTOR_DOMAINS) $(JavaScriptCore)/inspector/protocol/IndexedDB.json +endif -Grammar.cpp: Grammar.y - bison -d -p jscyy $< -o $@ > bison_out.txt 2>&1 - perl -p -e 'END { if ($$conflict) { unlink "Grammar.cpp"; die; } } $$conflict ||= /conflict/' < bison_out.txt - touch Grammar.cpp.h - touch Grammar.hpp - cat Grammar.cpp.h Grammar.hpp > Grammar.h - rm -f Grammar.cpp.h Grammar.hpp bison_out.txt +ifeq ($(findstring ENABLE_WEB_REPLAY,$(FEATURE_DEFINES)), ENABLE_WEB_REPLAY) + INSPECTOR_DOMAINS := $(INSPECTOR_DOMAINS) $(JavaScriptCore)/inspector/protocol/Replay.json +endif -# character tables for PCRE +INSPECTOR_GENERATOR_SCRIPTS = \ + $(JavaScriptCore)/inspector/scripts/codegen/__init__.py \ + $(JavaScriptCore)/inspector/scripts/codegen/cpp_generator_templates.py \ + $(JavaScriptCore)/inspector/scripts/codegen/cpp_generator.py \ + $(JavaScriptCore)/inspector/scripts/codegen/generate_cpp_backend_dispatcher_header.py \ + $(JavaScriptCore)/inspector/scripts/codegen/generate_cpp_backend_dispatcher_implementation.py \ + $(JavaScriptCore)/inspector/scripts/codegen/generate_cpp_frontend_dispatcher_header.py \ + $(JavaScriptCore)/inspector/scripts/codegen/generate_cpp_frontend_dispatcher_implementation.py \ + $(JavaScriptCore)/inspector/scripts/codegen/generate_cpp_protocol_types_header.py \ + $(JavaScriptCore)/inspector/scripts/codegen/generate_cpp_protocol_types_implementation.py \ + $(JavaScriptCore)/inspector/scripts/codegen/generate_js_backend_commands.py \ + $(JavaScriptCore)/inspector/scripts/codegen/generator_templates.py \ + $(JavaScriptCore)/inspector/scripts/codegen/generator.py \ + $(JavaScriptCore)/inspector/scripts/codegen/models.py \ + $(JavaScriptCore)/inspector/scripts/generate-combined-inspector-json.py \ + $(JavaScriptCore)/inspector/scripts/generate-inspector-protocol-bindings.py \ +# + +all : \ + CombinedDomains.json \ + InspectorFrontendDispatchers.h \ + InjectedScriptSource.h \ +# + +# The combined JSON file depends on the actual set of domains and their file contents, so that +# adding, modifying, or removing domains will trigger regeneration of inspector files. + +.PHONY: force +EnabledInspectorDomains : $(JavaScriptCore)/UpdateContents.py force + $(PYTHON) $(JavaScriptCore)/UpdateContents.py '$(INSPECTOR_DOMAINS)' $@ + +CombinedDomains.json : inspector/scripts/generate-combined-inspector-json.py $(INSPECTOR_DOMAINS) EnabledInspectorDomains + $(PYTHON) $(JavaScriptCore)/inspector/scripts/generate-combined-inspector-json.py $(INSPECTOR_DOMAINS) > ./CombinedDomains.json + +# Inspector Backend Dispatchers, Frontend Dispatchers, Type Builders +InspectorFrontendDispatchers.h : CombinedDomains.json $(INSPECTOR_GENERATOR_SCRIPTS) + $(PYTHON) $(JavaScriptCore)/inspector/scripts/generate-inspector-protocol-bindings.py --framework JavaScriptCore --outputDir . ./CombinedDomains.json + +InjectedScriptSource.h : inspector/InjectedScriptSource.js $(JavaScriptCore)/inspector/scripts/jsmin.py $(JavaScriptCore)/inspector/scripts/xxd.pl + echo "//# sourceURL=__WebInspectorInjectedScript__" > ./InjectedScriptSource.min.js + $(PYTHON) $(JavaScriptCore)/inspector/scripts/jsmin.py < $(JavaScriptCore)/inspector/InjectedScriptSource.js >> ./InjectedScriptSource.min.js + $(PERL) $(JavaScriptCore)/inspector/scripts/xxd.pl InjectedScriptSource_js ./InjectedScriptSource.min.js InjectedScriptSource.h + $(DELETE) InjectedScriptSource.min.js + +# Web Replay inputs generator + +INPUT_GENERATOR_SCRIPTS = \ + $(JavaScriptCore)/replay/scripts/CodeGeneratorReplayInputs.py \ + $(JavaScriptCore)/replay/scripts/CodeGeneratorReplayInputsTemplates.py \ +# + +INPUT_GENERATOR_SPECIFICATIONS = \ + $(JavaScriptCore)/replay/JSInputs.json \ +# -chartables.c : dftables - $^ $@ +all : JSReplayInputs.h -docs/bytecode.html: make-bytecode-docs.pl Interpreter.cpp - perl $^ $@ +JSReplayInputs.h : $(INPUT_GENERATOR_SPECIFICATIONS) $(INPUT_GENERATOR_SCRIPTS) + $(PYTHON) $(JavaScriptCore)/replay/scripts/CodeGeneratorReplayInputs.py --outputDir . --framework JavaScriptCore $(INPUT_GENERATOR_SPECIFICATIONS)