AuroraForEach/forEach.js
2021-10-07 17:28:16 +01:00

122 lines
4.1 KiB
JavaScript

const fs = require("fs")
const n = 100
const subn = 10
const kMacroParamLimit = 127
function forN(n, cb) {
for (var i = 0; i < n; i++) {
cb(i)
}
}
function genArray(n) {
return [...Array(n).keys()]
}
function formatNJoin(n, start, join) {
return start + genArray(n).join(join)
}
function formatNJoinReverse(n, start, join) {
return start + genArray(n).reverse().join(join)
}
function formatNJoinReverseSuffix(n, start, join, suffix) {
return start + genArray(n).reverse().join(suffix + join) + suffix
}
function formatNJoinReverse(n, start, join) {
return start + genArray(n).reverse().join(join)
}
function formatNParamPattern(n, join) {
return formatNJoin(n, join, ", " + join)
}
function formatNParamPatternReverse(n, join) {
return formatNJoinReverse(n, join, ", " + join)
}
function formatNParamPatternReverseSuffix(n, join, suffix) {
return formatNJoinReverseSuffix(n, join, ", " + join, suffix)
}
var textBuffer = ""
textBuffer +=
`/**
* X-Macro alternative. Defines AU_FOR_EACH_N(expandable, ...args*N)
* Autogenerated by forEach.js; do not modify"
*/
#define AU_FE_EXPAND(exp) exp
#define AU_FE_ERROR(exp) ERROR. CHECK PARAMETER COUNT. DID YOU FORGET A COMMA?
`
forN(subn, function(subN) {
if (!subN) return
var suffix = subN != 1 ? "_" + (subN): ""
var subNMulNCapped = Math.min(kMacroParamLimit - 3, n * subN)
var ignoreList = {}
var ignoreListFirst = {}
forN(subNMulNCapped, function(i) {
if (i == 0) {
textBuffer += `#define AU_FE_0${suffix}(prefix) \n`
ignoreListFirst[`AU_FE_0_FIRST${suffix}`] = true
return
}
var X = formatNParamPattern(subN, "X")
var iM1 = i - 1
var iM1Translated = i - subN
if (subN == 1) {
textBuffer += `#define AU_FE_${i}${suffix}(prefix, ${X}, ...) prefix(${X}) AU_FE_EXPAND(AU_FE_${iM1}${suffix}(prefix, __VA_ARGS__))\n`
} else if (i % subN == 0) {
if (i == subN) {
textBuffer += `#define AU_FE_${i}${suffix}(prefix, ${X}) prefix(${X}) AU_FE_EXPAND(AU_FE_${iM1Translated}${suffix}(prefix))\n`
} else {
textBuffer += `#define AU_FE_${i}${suffix}(prefix, ${X}, ...) prefix(${X}) AU_FE_EXPAND(AU_FE_${iM1Translated}${suffix}(prefix, __VA_ARGS__))\n`
}
} else {
ignoreList[`AU_FE_${i}${suffix}`] = true
}
var I2 = i + 1
if (i < subN) {
ignoreListFirst[`AU_FE_${i}_FIRST${suffix}`] = true
} else if ((i % (subN) == 0)) {
if (i == subN) {
textBuffer += `#define AU_FE_${I2}_FIRST${suffix}(first, prefix, ${X}) first(${X}) AU_FE_EXPAND(AU_FE_${iM1Translated}${suffix}(prefix))\n`
} else {
textBuffer += `#define AU_FE_${I2}_FIRST${suffix}(first, prefix, ${X}, ...) first(${X}) AU_FE_EXPAND(AU_FE_${iM1Translated}${suffix}(prefix, __VA_ARGS__))\n`
}
} else {
ignoreListFirst[`AU_FE_${I2}_FIRST${suffix}`] = true
}
})
var getMacroParams = formatNParamPattern(subNMulNCapped, "_")
textBuffer += `#define AU_GET_MACRO${suffix}(${getMacroParams}, NAME,...) NAME\n`
var params = formatNParamPatternReverseSuffix(subNMulNCapped, "AU_FE_", suffix)
var params2 = formatNParamPatternReverseSuffix(subNMulNCapped, "AU_FE_", "_FIRST" + suffix)
params = params.split(", ").map((str) => { return ignoreList[str] ? "AU_FE_ERROR" : str}).join(", ")
params2 = params2.split(", ").map((str) => { return ignoreListFirst[str] ? "AU_FE_ERROR" : str}).join(", ")
textBuffer += `#define AU_FOR_EACH${suffix}(action, ...) AU_FE_EXPAND(AU_GET_MACRO${suffix}(_whydoweneedthis, __VA_ARGS__, ${params})(action,__VA_ARGS__))\n`
textBuffer += `#define AU_FOR_EACH_FIRST${suffix}(action, ...) AU_FE_EXPAND(AU_GET_MACRO${suffix}(_whydoweneedthis, __VA_ARGS__, ${params2})(action,__VA_ARGS__))`
textBuffer += "\n\n"
})
fs.writeFileSync("./Include/AuroraForEach.hpp", textBuffer)