Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(269)

Issue 2000483002: Clean up V8 bindings template code (Closed)

Created:
4 years, 7 months ago by iclelland
Modified:
4 years, 7 months ago
Reviewers:
haraken, chasej, Yuki
CC:
chromium-reviews, blink-reviews, blink-reviews-bindings_chromium.org
Base URL:
https://chromium.googlesource.com/chromium/src.git@master
Target Ref:
refs/pending/heads/master
Project:
chromium
Visibility:
Public.

Description

Clean up V8 bindings template code This patch makes some of the V8 bindings templates a bit cleaner. Specifically: - Uses custom filters for the attribute list to duplicating complicated logic between for loops in the template and extra booleans defined in python. - Adds a unique_by filter to simplify the uniqueness logic in the templates. - Makes consistent use of the 'runtime_enabled' filter. - Combines for/endfor and if/endif tags into single for-if/endfor tags. - Makes use of the jinja2 'groupby' filter to clarify the complex logic for collecting and grouping runtime features by name. It has a couple of visible side effects; mostly removing some extra generated blank lines, and removing an unneeded extra brace pair in v8_dictionary.cpp (and adjusting indentation appropriately). The text expectations have been updated to match. TBR=chasej@chromium.org Committed: https://crrev.com/b96196730f9ca3f02a60c3e59b58b61bf5c50def Cr-Commit-Position: refs/heads/master@{#395067}

Patch Set 1 #

Unified diffs Side-by-side diffs Delta from patch set Stats (+546 lines, -637 lines) Patch
M third_party/WebKit/Source/bindings/scripts/code_generator_v8.py View 2 chunks +4 lines, -1 line 0 comments Download
M third_party/WebKit/Source/bindings/scripts/v8_attributes.py View 2 chunks +30 lines, -0 lines 0 comments Download
M third_party/WebKit/Source/bindings/scripts/v8_interface.py View 1 chunk +0 lines, -19 lines 0 comments Download
M third_party/WebKit/Source/bindings/scripts/v8_utilities.py View 1 chunk +11 lines, -0 lines 0 comments Download
M third_party/WebKit/Source/bindings/templates/dictionary_v8.cpp View 1 chunk +35 lines, -39 lines 0 comments Download
M third_party/WebKit/Source/bindings/templates/interface_base.cpp View 7 chunks +12 lines, -41 lines 0 comments Download
M third_party/WebKit/Source/bindings/tests/results/core/V8TestDictionary.cpp View 2 chunks +384 lines, -446 lines 0 comments Download
M third_party/WebKit/Source/bindings/tests/results/core/V8TestDictionaryDerived.cpp View 1 chunk +45 lines, -53 lines 0 comments Download
M third_party/WebKit/Source/bindings/tests/results/core/V8TestInterface.cpp View 1 chunk +1 line, -1 line 0 comments Download
M third_party/WebKit/Source/bindings/tests/results/core/V8TestInterfaceConstructor.cpp View 1 chunk +0 lines, -1 line 0 comments Download
M third_party/WebKit/Source/bindings/tests/results/core/V8TestInterfaceConstructor2.cpp View 1 chunk +0 lines, -1 line 0 comments Download
M third_party/WebKit/Source/bindings/tests/results/core/V8TestInterfaceConstructor3.cpp View 1 chunk +0 lines, -1 line 0 comments Download
M third_party/WebKit/Source/bindings/tests/results/core/V8TestInterfaceConstructor4.cpp View 1 chunk +0 lines, -1 line 0 comments Download
M third_party/WebKit/Source/bindings/tests/results/core/V8TestInterfaceCustomConstructor.cpp View 1 chunk +0 lines, -1 line 0 comments Download
M third_party/WebKit/Source/bindings/tests/results/core/V8TestInterfaceEmpty.cpp View 1 chunk +0 lines, -1 line 0 comments Download
M third_party/WebKit/Source/bindings/tests/results/core/V8TestInterfaceEventInit.cpp View 1 chunk +11 lines, -13 lines 0 comments Download
M third_party/WebKit/Source/bindings/tests/results/core/V8TestInterfaceEventTarget.cpp View 1 chunk +0 lines, -1 line 0 comments Download
M third_party/WebKit/Source/bindings/tests/results/core/V8TestInterfaceNamedConstructor2.cpp View 1 chunk +0 lines, -1 line 0 comments Download
M third_party/WebKit/Source/bindings/tests/results/core/V8TestPermissiveDictionary.cpp View 1 chunk +11 lines, -13 lines 0 comments Download
M third_party/WebKit/Source/bindings/tests/results/core/V8TestSpecialOperationsNotEnumerable.cpp View 1 chunk +0 lines, -1 line 0 comments Download
M third_party/WebKit/Source/bindings/tests/results/modules/V8TestInterface5.cpp View 1 chunk +1 line, -1 line 0 comments Download
M third_party/WebKit/Source/bindings/tests/results/modules/V8TestInterfacePartial.cpp View 1 chunk +1 line, -1 line 0 comments Download

Messages

Total messages: 15 (8 generated)
iclelland
haraken, PTAL, thanks! chasej, FYI There was a lot of logic written directly in the ...
4 years, 7 months ago (2016-05-20 04:26:48 UTC) #2
haraken
This looks like a nice refactoring. LGTM.
4 years, 7 months ago (2016-05-20 04:43:37 UTC) #3
Yuki
LGTM!!
4 years, 7 months ago (2016-05-20 06:10:10 UTC) #5
commit-bot: I haz the power
CQ is trying da patch. Follow status at https://chromium-cq-status.appspot.com/patch-status/2000483002/1 View timeline at https://chromium-cq-status.appspot.com/patch-timeline/2000483002/1
4 years, 7 months ago (2016-05-20 12:47:18 UTC) #7
commit-bot: I haz the power
CQ is trying da patch. Follow status at https://chromium-cq-status.appspot.com/patch-status/2000483002/1 View timeline at https://chromium-cq-status.appspot.com/patch-timeline/2000483002/1
4 years, 7 months ago (2016-05-20 12:48:48 UTC) #11
commit-bot: I haz the power
Committed patchset #1 (id:1)
4 years, 7 months ago (2016-05-20 13:48:23 UTC) #13
commit-bot: I haz the power
4 years, 7 months ago (2016-05-20 13:49:35 UTC) #15
Message was sent while issue was closed.
Patchset 1 (id:??) landed as
https://crrev.com/b96196730f9ca3f02a60c3e59b58b61bf5c50def
Cr-Commit-Position: refs/heads/master@{#395067}

Powered by Google App Engine
This is Rietveld 408576698