2024-10-29 12:22:10 +00:00
|
|
|
const chalk = require('chalk');
|
|
|
|
|
2023-06-22 14:21:42 +00:00
|
|
|
const fs = require('node:fs');
|
|
|
|
const path = require('node:path');
|
2021-05-22 18:48:38 +00:00
|
|
|
|
|
|
|
const check = process.argv.includes('--check');
|
|
|
|
|
|
|
|
function findAllHeaders (basePath) {
|
|
|
|
const allFiles = fs.readdirSync(basePath);
|
|
|
|
const toReturn = [];
|
|
|
|
for (const file of allFiles) {
|
|
|
|
const absPath = path.resolve(basePath, file);
|
|
|
|
if (fs.statSync(absPath).isDirectory()) {
|
|
|
|
toReturn.push(...findAllHeaders(absPath));
|
|
|
|
} else {
|
|
|
|
toReturn.push(absPath);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return toReturn;
|
|
|
|
}
|
|
|
|
|
2024-10-29 12:22:10 +00:00
|
|
|
const diff = (array1, array2) => {
|
|
|
|
const set1 = new Set(array1);
|
|
|
|
const set2 = new Set(array2);
|
|
|
|
|
|
|
|
const added = array1.filter(item => !set2.has(item));
|
|
|
|
const removed = array2.filter(item => !set1.has(item));
|
|
|
|
|
|
|
|
console.log(chalk.white.bgGreen.bold('Files Added:'));
|
|
|
|
added.forEach(item => console.log(chalk.green.bold(`+ ${item}`)));
|
|
|
|
|
|
|
|
console.log(chalk.white.bgRed.bold('Files Removed:'));
|
|
|
|
removed.forEach(item => console.log(chalk.red.bold(`- ${item}`)));
|
|
|
|
};
|
|
|
|
|
|
|
|
const parseHeaders = (name, content) => {
|
|
|
|
const pattern = new RegExp(`${name}_headers\\s*=\\s*\\[(.*?)\\]`, 's');
|
|
|
|
const headers = content.match(pattern);
|
|
|
|
if (!headers) return [];
|
|
|
|
return headers[1].split(',')
|
|
|
|
.map(item => item.trim().replace(/"/g, ''))
|
|
|
|
.filter(item => item.length > 0);
|
|
|
|
};
|
|
|
|
|
2021-05-22 18:48:38 +00:00
|
|
|
for (const folder of ['libc++', 'libc++abi']) {
|
|
|
|
const prettyName = folder.replace(/\+/g, 'x');
|
|
|
|
|
2023-08-15 15:49:41 +00:00
|
|
|
const libcxxIncludeDir = path.resolve(__dirname, '..', '..', 'third_party', folder, 'src', 'include');
|
|
|
|
const gclientPath = `third_party/${folder}/src/include`;
|
2021-05-22 18:48:38 +00:00
|
|
|
|
|
|
|
const headers = findAllHeaders(libcxxIncludeDir).map(absPath => path.relative(path.resolve(__dirname, '../..', gclientPath), absPath));
|
|
|
|
|
2024-10-29 12:22:10 +00:00
|
|
|
const newHeaders = headers.map(f => `//${path.posix.join(gclientPath, f)}`);
|
2021-05-22 18:48:38 +00:00
|
|
|
const content = `${prettyName}_headers = [
|
2024-10-29 12:22:10 +00:00
|
|
|
${newHeaders.map(h => `"${h}"`).join(',\n ')},
|
2021-05-22 18:48:38 +00:00
|
|
|
]
|
|
|
|
|
2023-08-15 15:49:41 +00:00
|
|
|
${prettyName}_licenses = [ "//third_party/${folder}/src/LICENSE.TXT" ]
|
2021-05-22 18:48:38 +00:00
|
|
|
`;
|
|
|
|
|
2024-10-29 12:22:10 +00:00
|
|
|
const file = `filenames.${prettyName}.gni`;
|
|
|
|
const filenamesPath = path.resolve(__dirname, '..', file);
|
2021-05-22 18:48:38 +00:00
|
|
|
|
|
|
|
if (check) {
|
|
|
|
const currentContent = fs.readFileSync(filenamesPath, 'utf8');
|
|
|
|
if (currentContent !== content) {
|
2024-10-29 12:22:10 +00:00
|
|
|
const currentHeaders = parseHeaders(prettyName, currentContent);
|
|
|
|
|
|
|
|
console.error(chalk.bold(`${file} contents are not up to date:\n`));
|
|
|
|
diff(currentHeaders, newHeaders);
|
|
|
|
console.error(chalk.bold(`\nRun node gen-libc++-filenames.js to regenerate ${file}`));
|
|
|
|
process.exit(1);
|
2021-05-22 18:48:38 +00:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
console.log(filenamesPath);
|
|
|
|
fs.writeFileSync(filenamesPath, content);
|
|
|
|
}
|
|
|
|
}
|