const crypto = require('crypto') const fs = require('fs') const path = require('path') // Fallback to blow away old cache keys const HASH_VERSION = 1 // Base files to hash const filesToHash = [ path.resolve(__dirname, '../DEPS'), path.resolve(__dirname, '../yarn.lock'), path.resolve(__dirname, '../script/external-binaries.json'), path.resolve(__dirname, '../script/sysroots.json') ] const addAllFiles = (dir) => { for (const child of fs.readdirSync(dir).sort()) { const childPath = path.resolve(dir, child) if (fs.statSync(childPath).isDirectory()) { addAllFiles(childPath) } else { filesToHash.push(childPath) } } } // Add all patch files to the hash addAllFiles(path.resolve(__dirname, '../patches')) // Create Hash const hasher = crypto.createHash('SHA256') hasher.update(`HASH_VERSION:${HASH_VERSION}`) for (const file of filesToHash) { hasher.update(fs.readFileSync(file)) } // Add the GCLIENT_EXTRA_ARGS variable to the hash const extraArgs = process.env.GCLIENT_EXTRA_ARGS || 'no_extra_args' hasher.update(extraArgs) const effectivePlatform = extraArgs.includes('host_os=mac') ? 'darwin' : process.platform // Write the hash to disk fs.writeFileSync(path.resolve(__dirname, '../.depshash'), hasher.digest('hex')) let targetContent = `${effectivePlatform}\n${process.env.TARGET_ARCH}\n${process.env.GN_CONFIG}\n${undefined}\n${process.env.GN_EXTRA_ARGS}\n${process.env.GN_BUILDFLAG_ARGS}` const argsDir = path.resolve(__dirname, '../build/args') for (const argFile of fs.readdirSync(argsDir).sort()) { targetContent += `\n${argFile}--${crypto.createHash('SHA1').update(fs.readFileSync(path.resolve(argsDir, argFile))).digest('hex')}` } fs.writeFileSync(path.resolve(__dirname, '../.depshash-target'), targetContent)