@@ -1256,10 +1256,10 @@ index 0000000000000000000000000000000000000000..af9cbada10203b387fb9732b346583b1
1256
1256
+ }
1257
1257
diff --git a/filenames.json b/filenames.json
1258
1258
new file mode 100644
1259
- index 0000000000000000000000000000000000000000..1a9cba024f1762b0dfe31da92213b51e112101ec
1259
+ index 0000000000000000000000000000000000000000..fd42e2a5e6163ff70db0f716d2f9a32f13cdf668
1260
1260
--- /dev/null
1261
1261
+++ b/filenames.json
1262
- @@ -0,0 +1,739 @@
1262
+ @@ -0,0 +1,734 @@
1263
1263
+ // This file is automatically generated by generate_gn_filenames_json.py
1264
1264
+ // DO NOT EDIT
1265
1265
+ {
@@ -1292,7 +1292,7 @@ index 0000000000000000000000000000000000000000..1a9cba024f1762b0dfe31da92213b51e
1292
1292
+ ]
1293
1293
+ },
1294
1294
+ {
1295
- + "dest_dir": "include/node//",
1295
+ + "dest_dir": "include/node/. /",
1296
1296
+ "files": [
1297
1297
+ "//v8/include/v8-array-buffer.h",
1298
1298
+ "//v8/include/v8-callbacks.h",
@@ -1346,19 +1346,20 @@ index 0000000000000000000000000000000000000000..1a9cba024f1762b0dfe31da92213b51e
1346
1346
+ "//v8/include/v8-wasm.h",
1347
1347
+ "//v8/include/v8-weak-callback-info.h",
1348
1348
+ "//v8/include/v8.h",
1349
- + "//v8/include/v8config.h"
1349
+ + "//v8/include/v8config.h",
1350
+ + "deps/uv/include/uv.h"
1350
1351
+ ]
1351
1352
+ },
1352
1353
+ {
1353
- + "dest_dir": "include/node// libplatform/",
1354
+ + "dest_dir": "include/node/libplatform/",
1354
1355
+ "files": [
1355
1356
+ "//v8/include/libplatform/libplatform-export.h",
1356
1357
+ "//v8/include/libplatform/libplatform.h",
1357
1358
+ "//v8/include/libplatform/v8-tracing.h"
1358
1359
+ ]
1359
1360
+ },
1360
1361
+ {
1361
- + "dest_dir": "include/node// cppgc/",
1362
+ + "dest_dir": "include/node/cppgc/",
1362
1363
+ "files": [
1363
1364
+ "//v8/include/cppgc/allocation.h",
1364
1365
+ "//v8/include/cppgc/common.h",
@@ -1391,7 +1392,7 @@ index 0000000000000000000000000000000000000000..1a9cba024f1762b0dfe31da92213b51e
1391
1392
+ ]
1392
1393
+ },
1393
1394
+ {
1394
- + "dest_dir": "include/node// cppgc/internal/",
1395
+ + "dest_dir": "include/node/cppgc/internal/",
1395
1396
+ "files": [
1396
1397
+ "//v8/include/cppgc/internal/api-constants.h",
1397
1398
+ "//v8/include/cppgc/internal/atomic-entry-flag.h",
@@ -1410,13 +1411,7 @@ index 0000000000000000000000000000000000000000..1a9cba024f1762b0dfe31da92213b51e
1410
1411
+ ]
1411
1412
+ },
1412
1413
+ {
1413
- + "dest_dir": "include/node//",
1414
- + "files": [
1415
- + "deps/uv/include/uv.h"
1416
- + ]
1417
- + },
1418
- + {
1419
- + "dest_dir": "include/node//uv/",
1414
+ + "dest_dir": "include/node/uv/",
1420
1415
+ "files": [
1421
1416
+ "deps/uv/include/uv/aix.h",
1422
1417
+ "deps/uv/include/uv/bsd.h",
@@ -1891,7 +1886,7 @@ index 0000000000000000000000000000000000000000..1a9cba024f1762b0dfe31da92213b51e
1891
1886
+ "src/dataqueue/queue.h",
1892
1887
+ "src/debug_utils.h",
1893
1888
+ "src/debug_utils-inl.h",
1894
- + "src/embeded_data .h",
1889
+ + "src/embedded_data .h",
1895
1890
+ "src/encoding_binding.h",
1896
1891
+ "src/env_properties.h",
1897
1892
+ "src/env.h",
@@ -2243,10 +2238,10 @@ index 75a7f3dd89e096d13ad7d70ed29d301cd56315b5..9a20a275fbe5df9f384b7b1d1d26806e
2243
2238
// bootstrap scripts, whose source are bundled into the binary as static data.
2244
2239
diff --git a/tools/generate_gn_filenames_json.py b/tools/generate_gn_filenames_json.py
2245
2240
new file mode 100755
2246
- index 0000000000000000000000000000000000000000..7848ddb1841b6d4f36e9376c73564eb4ff6d7c08
2241
+ index 0000000000000000000000000000000000000000..37c16859003e61636fe2f1a4040b1e904c472d0b
2247
2242
--- /dev/null
2248
2243
+++ b/tools/generate_gn_filenames_json.py
2249
- @@ -0,0 +1,90 @@
2244
+ @@ -0,0 +1,117 @@
2250
2245
+ #!/usr/bin/env python3
2251
2246
+ import json
2252
2247
+ import os
@@ -2276,6 +2271,14 @@ index 0000000000000000000000000000000000000000..7848ddb1841b6d4f36e9376c73564eb4
2276
2271
+ // DO NOT EDIT
2277
2272
+ '''.lstrip()
2278
2273
+
2274
+ + SRC_DIR = os.path.abspath(os.path.join(__file__, '..', '..', '..', '..'))
2275
+ +
2276
+ + def get_out_dir():
2277
+ + out_dir = 'Testing'
2278
+ + override = os.environ.get('ELECTRON_OUT_DIR')
2279
+ + if override is not None:
2280
+ + out_dir = override
2281
+ + return os.path.join(SRC_DIR, 'out', out_dir)
2279
2282
+
2280
2283
+ if __name__ == '__main__':
2281
2284
+ node_root_dir = os.path.dirname(os.path.dirname(__file__))
@@ -2294,18 +2297,25 @@ index 0000000000000000000000000000000000000000..7848ddb1841b6d4f36e9376c73564eb4
2294
2297
+ }
2295
2298
+
2296
2299
+ def filter_v8_files(files):
2297
- + if any(f.startswith('deps/v8/') for f in files):
2298
- + files = [f.replace('deps/v8/', '../../v8/', 1) if f.endswith('js') else f.replace('deps/v8/', '//v8/') for f in files]
2299
- +
2300
- + if any(f == '<@(node_builtin_shareable_builtins)' for f in files):
2301
- + files.remove('<@(node_builtin_shareable_builtins)')
2300
+ + v8_files = [f for f in files if f.startswith('deps/v8/')]
2301
+ + other_files = [f for f in files if not f.startswith('deps/v8/')]
2302
+ +
2303
+ + for i, f in enumerate(v8_files):
2304
+ + if not f.startswith('deps/v8/tools'):
2305
+ + if f.endswith('js'):
2306
+ + v8_files[i] = f.replace('deps/v8/', '../../v8/', 1)
2307
+ + else:
2308
+ + v8_files[i] = f.replace('deps/v8/', '//v8/')
2309
+ +
2310
+ + if any(f == '<@(node_builtin_shareable_builtins)' for f in other_files):
2311
+ + other_files.remove('<@(node_builtin_shareable_builtins)')
2302
2312
+ shared_builtins = ['deps/cjs-module-lexer/lexer.js', 'deps/cjs-module-lexer/dist/lexer.js', 'deps/undici/undici.js']
2303
- + files .extend(shared_builtins)
2313
+ + other_files .extend(shared_builtins)
2304
2314
+
2305
- + return files
2315
+ + return v8_files + other_files
2306
2316
+
2307
2317
+ def filter_fs_files(files):
2308
- + return [f for f in files if f.startswith('lib/internal/fs/')] + ['lib/fs.js']
2318
+ + return [f for f in files if f.startswith('lib/internal/fs/')] + ['lib/fs.js'] + ['lib/fs/promises.js']
2309
2319
+
2310
2320
+ lib_files = SearchFiles('lib', 'js')
2311
2321
+ out['library_files'] = filter_v8_files(lib_files)
@@ -2322,17 +2332,29 @@ index 0000000000000000000000000000000000000000..7848ddb1841b6d4f36e9376c73564eb4
2322
2332
+ out['node_sources'] += filter_v8_files(blocklisted_sources)
2323
2333
+
2324
2334
+ out['headers'] = []
2325
- + def add_headers(files, dest_dir):
2335
+ + def add_headers(options, files, dest_dir):
2326
2336
+ if 'src/node.h' in files:
2327
2337
+ files = [f for f in files if f.endswith('.h') and f != 'src/node_version.h']
2328
2338
+ elif any(f.startswith('../../v8/') for f in files):
2329
2339
+ files = [f.replace('../../v8/', '//v8/', 1) for f in files]
2330
2340
+ if files:
2331
- + hs = {'files': sorted(files), 'dest_dir': dest_dir}
2332
- + out['headers'].append(hs)
2333
- +
2334
- + install.variables = {'node_shared_libuv': 'false'}
2335
- + install.headers(add_headers)
2341
+ + dir_index = next((i for i, d in enumerate(out['headers']) if d['dest_dir'] == dest_dir), -1)
2342
+ + if (dir_index != -1):
2343
+ + out['headers'][dir_index]['files'] += sorted(files)
2344
+ + else:
2345
+ + hs = {'files': sorted(files), 'dest_dir': dest_dir}
2346
+ + out['headers'].append(hs)
2347
+ +
2348
+ + config_gypi_path = os.path.join(get_out_dir(), 'gen', 'config.gypi')
2349
+ + root_gen_dir = os.path.join(node_root_dir, 'out', 'Release', 'gen')
2350
+ +
2351
+ + options = install.parse_options(['install', '--v8-dir', '../../v8', '--config-gypi-path', config_gypi_path, '--headers-only'])
2352
+ + options.variables['node_use_openssl'] = 'false'
2353
+ + options.variables['node_shared_libuv'] = 'false'
2354
+ + # We generate zlib headers in Electron's BUILD.gn.
2355
+ + options.variables['node_shared_zlib'] = ''
2356
+ +
2357
+ + install.headers(options, add_headers)
2336
2358
+ with open(os.path.join(node_root_dir, 'filenames.json'), 'w') as f:
2337
2359
+ f.write(FILENAMES_JSON_HEADER)
2338
2360
+ f.write(json.dumps(out, sort_keys=True, indent=2, separators=(',', ': ')))
@@ -2363,18 +2385,27 @@ index 0000000000000000000000000000000000000000..9be3ac447f9a4dde23fefc26e0b922b4
2363
2385
+ transformed_f.write(transformed_contents)
2364
2386
+
2365
2387
diff --git a/tools/install.py b/tools/install.py
2366
- index b132c7bf26c02886a7ab341a1973bf449744ba0f..171b383a4b6c2528d11dd5f89a6837fd071bcf4b 100755
2388
+ index b132c7bf26c02886a7ab341a1973bf449744ba0f..757e3e60a7be01fac55c5fbb010dbbae00b1bfca 100755
2367
2389
--- a/tools/install.py
2368
2390
+++ b/tools/install.py
2369
- @@ -284,6 +284,7 @@ def headers(options, action):
2391
+ @@ -264,6 +264,7 @@ def headers(options, action):
2392
+ 'include/v8-forward.h',
2393
+ 'include/v8-function-callback.h',
2394
+ 'include/v8-function.h',
2395
+ + 'include/v8-handle-base.h',
2396
+ 'include/v8-initialization.h',
2397
+ 'include/v8-internal.h',
2398
+ 'include/v8-isolate.h',
2399
+ @@ -284,6 +285,8 @@ def headers(options, action):
2370
2400
'include/v8-promise.h',
2371
2401
'include/v8-proxy.h',
2372
2402
'include/v8-regexp.h',
2373
2403
+ "include/v8-sandbox.h",
2404
+ + "include/v8-source-location.h",
2374
2405
'include/v8-script.h',
2375
2406
'include/v8-snapshot.h',
2376
2407
'include/v8-statistics.h',
2377
- @@ -390,7 +391 ,7 @@ def parse_options(args):
2408
+ @@ -390,7 +393 ,7 @@ def parse_options(args):
2378
2409
parser.add_argument('--build-dir', help='the location of built binaries',
2379
2410
default='out/Release')
2380
2411
parser.add_argument('--v8-dir', help='the location of V8',
0 commit comments