Bug 203059

Summary: Add Swift modulemap for WebKit Private APIs
Product: WebKit Reporter: Dean Jackson <dino>
Component: New BugsAssignee: Dean Jackson <dino>
Status: RESOLVED FIXED    
Severity: Normal CC: aroben, eric.carlson, ews-watchlist, glenn, jer.noble, philipj, sergio, thorton, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Attachments:
Description Flags
Patch
none
Patch
none
Patch
none
Patch
none
Patch
none
WIP - does not compile ews-feeder: commit-queue-

Dean Jackson
Reported 2019-10-16 15:36:29 PDT
Add Swift modulemap for WebKit Private APIs
Attachments
Patch (4.55 KB, patch)
2019-10-16 15:39 PDT, Dean Jackson
no flags
Patch (20.96 KB, patch)
2021-02-23 17:16 PST, Dean Jackson
no flags
Patch (29.02 KB, patch)
2021-02-24 15:21 PST, Dean Jackson
no flags
Patch (30.35 KB, patch)
2021-02-24 15:24 PST, Dean Jackson
no flags
Patch (29.96 KB, patch)
2021-02-26 10:58 PST, Dean Jackson
no flags
WIP - does not compile (31.24 KB, patch)
2021-03-29 13:33 PDT, Dean Jackson
ews-feeder: commit-queue-
Dean Jackson
Comment 1 2019-10-16 15:39:50 PDT
Tim Horton
Comment 2 2019-10-16 15:42:00 PDT
Comment on attachment 381125 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=381125&action=review > Source/WebKit/Shared/API/Cocoa/WebKitPrivate.h:28 > +#import <WebKit/WKPreferencesPrivate.h> This is still hilariously incomplete. Should we just add everything?
Dean Jackson
Comment 3 2019-10-16 15:47:56 PDT
Comment on attachment 381125 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=381125&action=review >> Source/WebKit/Shared/API/Cocoa/WebKitPrivate.h:28 >> +#import <WebKit/WKPreferencesPrivate.h> > > This is still hilariously incomplete. Should we just add everything? Will do separately. (even though it is a bit of a cheat that this patch is doing the single one I care about right now)
Radar WebKit Bug Importer
Comment 4 2019-10-16 15:49:39 PDT
Dean Jackson
Comment 5 2019-10-16 15:49:57 PDT
Dean Jackson
Comment 6 2021-02-23 12:08:11 PST
This got rolled out almost immediately. Time to try it again.
Dean Jackson
Comment 7 2021-02-23 17:16:40 PST
Tim Horton
Comment 8 2021-02-23 17:35:21 PST
Comment on attachment 421377 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=421377&action=review > Source/WebKit/Shared/API/Cocoa/WebKit.h:2 > + * Copyright (C) 2014-2021 Apple Inc. All rights reserved. I think this file needs a .in extension or something now? > Source/WebKit/Shared/API/Cocoa/WebKitPrivate.h:2 > + * Copyright (C) 2014-2021 Apple Inc. All rights reserved. Ditto
Adam Roben (:aroben)
Comment 9 2021-02-24 11:56:30 PST
Comment on attachment 421377 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=421377&action=review > Source/WebKit/Scripts/generate-umbrella-header.py:1 > +#!/usr/bin/python Does this file need a license too? (Maybe even the module maps?)
Dean Jackson
Comment 10 2021-02-24 14:23:27 PST
Comment on attachment 421377 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=421377&action=review >> Source/WebKit/Scripts/generate-umbrella-header.py:1 >> +#!/usr/bin/python > > Does this file need a license too? (Maybe even the module maps?) The existing module maps did not. But yes, this should.
Dean Jackson
Comment 11 2021-02-24 15:21:28 PST
Dean Jackson
Comment 12 2021-02-24 15:24:44 PST
Alexey Proskuryakov
Comment 13 2021-02-24 15:28:16 PST
Is Python code here tested with both Python 2 and Python 3?
Dean Jackson
Comment 14 2021-02-25 14:24:47 PST
(In reply to Alexey Proskuryakov from comment #13) > Is Python code here tested with both Python 2 and Python 3? Yes.
Dean Jackson
Comment 15 2021-02-25 14:25:31 PST
These failures are because the bot needs a clean build.
Alexey Proskuryakov
Comment 16 2021-02-25 14:38:42 PST
Is there a way to not require a clean build? We are way conditioned to allowing ourselves that, but it's never correct behavior.
Dean Jackson
Comment 17 2021-02-25 15:17:03 PST
(In reply to Alexey Proskuryakov from comment #16) > Is there a way to not require a clean build? We are way conditioned to > allowing ourselves that, but it's never correct behavior. Are you asking me? I have no idea why TAPI fails on a non-clean bot build, so no, I don't know how to stop requiring it. Truitt tickled the mac bots, which shows that a clean build succeeds.
Alexey Proskuryakov
Comment 18 2021-02-25 15:29:04 PST
Comment on attachment 421471 [details] Patch It helps to know that it was an InstallAPI failure. Generally speaking, we cannot do much to fix incremental builds when API/SPI headers get renamed, and an old version is still present in the file system due to incremental nature of the build. We could and maybe should get into the habit of adding scripts to clean those up, but we haven't yet. This patch makes NSURLDownloadSPI.h non-private, which appears unacceptable given its name. So InstallAPI inadvertently pointed out a real problem for once.
Alexey Proskuryakov
Comment 19 2021-02-25 15:31:02 PST
If I'm missing something and it is acceptable, please fell encourage to r? again.
Alexey Proskuryakov
Comment 20 2021-02-25 15:36:39 PST
> This patch makes NSURLDownloadSPI.h non-private, which appears unacceptable > given its name. Not given its name, but given that WebDownload.h is private, and imports it.
Adam Roben (:aroben)
Comment 21 2021-02-25 19:20:36 PST
Comment on attachment 421471 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=421471&action=review > Source/WebKitLegacy/WebKitLegacy.xcodeproj/project.pbxproj:-690 > - E1531BD82187B954002E3F81 /* NSURLDownloadSPI.h in Headers */ = {isa = PBXBuildFile; fileRef = E1531BD72187B8F2002E3F81 /* NSURLDownloadSPI.h */; settings = {ATTRIBUTES = (Private, ); }; }; Looks like we need to undo this change since WebDownload.h imports this header and WebDownload.h is a private header.
Dean Jackson
Comment 22 2021-02-26 10:58:43 PST
Dean Jackson
Comment 23 2021-02-26 10:59:39 PST
The problem is that if you import the system NSURLDownload you'll get a clash if you then import NSURLDownloadSPI. TestWebKitAPI hits this. This new patch adds the same guards that WebDownload does, so it shouldn't cause a clash if you include the umbrella.
Adam Roben (:aroben)
Comment 24 2021-02-26 11:01:09 PST
Comment on attachment 421677 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=421677&action=review There are bunch of modularization-related warnings we could enable too: -Watimport-in-framework-header -Wframework-include-private-from-public -Wincomplete-framework-module-declaration -Wincomplete-umbrella -Wnon-modular-include-in-framework-module -Wnon-modular-include-in-module -Wquoted-include-in-framework-header > Source/WebKit/WebKit.xcodeproj/xcshareddata/xcschemes/WebKit.xcscheme:34 > - buildConfiguration = "Release" > + buildConfiguration = "Debug" You probably didn't leave to mean this change in.
Dean Jackson
Comment 25 2021-03-29 12:51:50 PDT
-Watimport-in-framework-header No config equivalent -Wframework-include-private-from-public CLANG_WARN_FRAMEWORK_INCLUDE_PRIVATE_FROM_PUBLIC=YES -Wincomplete-framework-module-declaration No config equivalent -Wincomplete-umbrella No config equivalent -Wnon-modular-include-in-framework-module CLANG_ALLOW_NON_MODULAR_INCLUDES_IN_FRAMEWORK_MODULES=NO (this is the default) -Wnon-modular-include-in-module No config equivalen -Wquoted-include-in-framework-header CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER=YES
Dean Jackson
Comment 26 2021-03-29 13:23:55 PDT
This is going to take a bit of cleanup in JSC and WebCore. For example WebKit's APICustomHeaderFields.h includes WebCore's CustomHeaderFields.h which has a quoted include.
Dean Jackson
Comment 27 2021-03-29 13:33:24 PDT
Created attachment 424572 [details] WIP - does not compile
Ian Anderson
Comment 28 2022-12-14 23:16:13 PST
EWS
Comment 29 2023-03-23 13:51:23 PDT
Committed 262032@main (db17513feb3f): <https://commits.webkit.org/262032@main> Reviewed commits have been landed. Closing PR #7674 and removing active labels.
Note You need to log in before you can comment on or make changes to this bug.