0
0
mirror of https://github.com/twbs/bootstrap.git synced 2025-01-07 00:46:15 +01:00
Bootstrap/build/change-version.js

111 lines
2.7 KiB
JavaScript
Raw Normal View History

#!/usr/bin/env node
/*!
* Script to update version number references in the project.
* Copyright 2017-2021 The Bootstrap Authors
* Copyright 2017-2021 Twitter, Inc.
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
*/
'use strict'
2017-09-26 14:14:52 +02:00
const fs = require('fs')
const path = require('path')
const sh = require('shelljs')
sh.config.fatal = true
// Blame TC39... https://github.com/benjamingr/RegExp.escape/issues/37
2017-12-16 13:00:38 +01:00
function regExpQuote(string) {
2020-05-08 18:19:14 +02:00
return string.replace(/[$()*+.?[\\\]^{|}-]/g, '\\$&')
2017-12-16 13:00:38 +01:00
}
function regExpQuoteReplacement(string) {
2020-05-08 18:19:14 +02:00
return string.replace(/\$/g, '$$')
2017-12-16 13:00:38 +01:00
}
2017-09-26 14:14:52 +02:00
const DRY_RUN = false
function walkAsync(directory, excludedDirectories, fileCallback, errback) {
if (excludedDirectories.has(path.parse(directory).base)) {
return
}
2020-06-12 20:50:30 +02:00
2017-09-26 14:14:52 +02:00
fs.readdir(directory, (err, names) => {
if (err) {
errback(err)
return
}
2020-06-12 20:50:30 +02:00
names.forEach(name => {
2017-09-26 14:14:52 +02:00
const filepath = path.join(directory, name)
fs.lstat(filepath, (err, stats) => {
if (err) {
process.nextTick(errback, err)
return
}
2020-06-12 20:50:30 +02:00
2017-12-16 13:00:38 +01:00
if (stats.isDirectory()) {
process.nextTick(walkAsync, filepath, excludedDirectories, fileCallback, errback)
2017-12-16 13:00:38 +01:00
} else if (stats.isFile()) {
process.nextTick(fileCallback, filepath)
}
})
})
})
}
function replaceRecursively(directory, excludedDirectories, allowedExtensions, original, replacement) {
2017-12-16 13:00:38 +01:00
original = new RegExp(regExpQuote(original), 'g')
replacement = regExpQuoteReplacement(replacement)
2020-06-12 20:50:30 +02:00
const updateFile = DRY_RUN ? filepath => {
if (allowedExtensions.has(path.parse(filepath).ext)) {
2017-12-16 13:00:38 +01:00
console.log(`FILE: ${filepath}`)
} else {
console.log(`EXCLUDED:${filepath}`)
}
2020-06-12 20:50:30 +02:00
} : filepath => {
if (allowedExtensions.has(path.parse(filepath).ext)) {
2017-12-16 13:00:38 +01:00
sh.sed('-i', original, replacement, filepath)
}
}
2020-06-12 20:50:30 +02:00
walkAsync(directory, excludedDirectories, updateFile, err => {
console.error('ERROR while traversing directory!:')
console.error(err)
process.exit(1)
})
}
function main(args) {
if (args.length !== 2) {
console.error('USAGE: change-version old_version new_version')
console.error('Got arguments:', args)
process.exit(1)
}
2020-06-12 20:50:30 +02:00
2017-09-26 14:14:52 +02:00
const oldVersion = args[0]
const newVersion = args[1]
const EXCLUDED_DIRS = new Set([
'.git',
'_gh_pages',
'node_modules',
'resources'
])
2017-09-26 14:14:52 +02:00
const INCLUDED_EXTENSIONS = new Set([
// This extension whitelist is how we avoid modifying binary files
'',
'.css',
'.html',
'.js',
'.json',
'.md',
'.scss',
'.txt',
'.yml'
])
replaceRecursively('.', EXCLUDED_DIRS, INCLUDED_EXTENSIONS, oldVersion, newVersion)
}
main(process.argv.slice(2))