@aws-cdk/core
Version:
AWS Cloud Development Kit Core Library
91 lines • 11.8 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.DefaultTokenResolver = exports.StringConcat = void 0;
const encoding_1 = require("./private/encoding");
const token_map_1 = require("./private/token-map");
/**
* Converts all fragments to strings and concats those.
*
* Drops 'undefined's.
*/
class StringConcat {
/**
* Join the fragment on the left and on the right.
*/
join(left, right) {
if (left === undefined) {
return right !== undefined ? `${right}` : undefined;
}
if (right === undefined) {
return `${left}`;
}
return `${left}${right}`;
}
}
exports.StringConcat = StringConcat;
/**
* (experimental) Default resolver implementation.
*
* @experimental
*/
class DefaultTokenResolver {
/**
* @experimental
*/
constructor(concat) {
this.concat = concat;
}
/**
* (experimental) Default Token resolution.
*
* Resolve the Token, recurse into whatever it returns,
* then finally post-process it.
*
* @experimental
*/
resolveToken(t, context, postProcessor) {
try {
let resolved = t.resolve(context);
// The token might have returned more values that need resolving, recurse
resolved = context.resolve(resolved);
resolved = postProcessor.postProcess(resolved, context);
return resolved;
}
catch (e) {
let message = `Resolution error: ${e.message}.`;
if (t.creationStack && t.creationStack.length > 0) {
message += `\nObject creation stack:\n at ${t.creationStack.join('\n at ')}`;
}
e.message = message;
throw e;
}
}
/**
* (experimental) Resolve string fragments to Tokens.
*
* @experimental
*/
resolveString(fragments, context) {
return fragments.mapTokens({ mapToken: context.resolve }).join(this.concat);
}
/**
* (experimental) Resolve a tokenized list.
*
* @experimental
*/
resolveList(xs, context) {
// Must be a singleton list token, because concatenation is not allowed.
if (xs.length !== 1) {
throw new Error(`Cannot add elements to list token, got: ${xs}`);
}
const str = encoding_1.TokenString.forListToken(xs[0]);
const tokenMap = token_map_1.TokenMap.instance();
const fragments = str.split(tokenMap.lookupToken.bind(tokenMap));
if (fragments.length !== 1) {
throw new Error(`Cannot concatenate strings in a tokenized string array, got: ${xs[0]}`);
}
return fragments.mapTokens({ mapToken: context.resolve }).firstValue;
}
}
exports.DefaultTokenResolver = DefaultTokenResolver;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resolvable.js","sourceRoot":"","sources":["resolvable.ts"],"names":[],"mappings":";;;AACA,iDAAiD;AACjD,mDAA+C;;;;;;AA0G/C,MAAa,YAAY;;;;IAChB,IAAI,CAAC,IAAqB,EAAE,KAAsB;QACvD,IAAI,IAAI,KAAK,SAAS,EAAE;YAAE,OAAO,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,GAAG,KAAK,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;SAAE;QAChF,IAAI,KAAK,KAAK,SAAS,EAAE;YAAE,OAAO,GAAG,IAAI,EAAE,CAAC;SAAE;QAC9C,OAAO,GAAG,IAAI,GAAG,KAAK,EAAE,CAAC;IAC3B,CAAC;CACF;AAND,oCAMC;;;;;;AAOD,MAAa,oBAAoB;;;;IAC/B,YAA6B,MAA6B;QAA7B,WAAM,GAAN,MAAM,CAAuB;IAC1D,CAAC;;;;;;;;;IAQM,YAAY,CAAC,CAAc,EAAE,OAAwB,EAAE,aAA6B;QACzF,IAAI;YACF,IAAI,QAAQ,GAAG,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;YAElC,yEAAyE;YACzE,QAAQ,GAAG,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YACrC,QAAQ,GAAG,aAAa,CAAC,WAAW,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;YACxD,OAAO,QAAQ,CAAC;SACjB;QAAC,OAAO,CAAC,EAAE;YACV,IAAI,OAAO,GAAG,qBAAqB,CAAC,CAAC,OAAO,GAAG,CAAC;YAChD,IAAI,CAAC,CAAC,aAAa,IAAI,CAAC,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;gBACjD,OAAO,IAAI,kCAAkC,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC;aAChF;YAED,CAAC,CAAC,OAAO,GAAG,OAAO,CAAC;YACpB,MAAM,CAAC,CAAC;SACT;IACH,CAAC;;;;;;IAKM,aAAa,CAAC,SAAmC,EAAE,OAAwB;QAChF,OAAO,SAAS,CAAC,SAAS,CAAC,EAAE,QAAQ,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC9E,CAAC;;;;;;IAEM,WAAW,CAAC,EAAY,EAAE,OAAwB;QACvD,wEAAwE;QACxE,IAAI,EAAE,CAAC,MAAM,KAAK,CAAC,EAAE;YACnB,MAAM,IAAI,KAAK,CAAC,2CAA2C,EAAE,EAAE,CAAC,CAAC;SAClE;QAED,MAAM,GAAG,GAAG,sBAAW,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5C,MAAM,QAAQ,GAAG,oBAAQ,CAAC,QAAQ,EAAE,CAAC;QACrC,MAAM,SAAS,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;QACjE,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE;YAC1B,MAAM,IAAI,KAAK,CAAC,gEAAgE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;SAC1F;QAED,OAAO,SAAS,CAAC,SAAS,CAAC,EAAE,QAAQ,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,UAAU,CAAC;IACvE,CAAC;CACF;AAnDD,oDAmDC","sourcesContent":["import { IConstruct } from './construct-compat';\nimport { TokenString } from './private/encoding';\nimport { TokenMap } from './private/token-map';\nimport { TokenizedStringFragments } from './string-fragments';\n\n                                                \nexport interface IResolveContext {\n                                                                   \n  readonly scope: IConstruct;\n\n                                                                                            \n  readonly preparing: boolean;\n\n                                        \n  resolve(x: any): any;\n\n                                                                                          \n  registerPostProcessor(postProcessor: IPostProcessor): void;\n}\n\n                                                                                                                            \nexport interface IResolvable {\n                                                                                                                                                                                               \n  readonly creationStack: string[];\n\n                                                             \n  resolve(context: IResolveContext): any;\n\n                                                                                                                                \n  toString(): string;\n}\n\n                                                                                                          \nexport interface IPostProcessor {\n                                                                                                    \n  postProcess(input: any, context: IResolveContext): any;\n}\n\n                                \nexport interface ITokenResolver {\n                                       \n  resolveToken(t: IResolvable, context: IResolveContext, postProcessor: IPostProcessor): any;\n\n                                                                                                             \n  resolveString(s: TokenizedStringFragments, context: IResolveContext): any;\n\n                                         \n  resolveList(l: string[], context: IResolveContext): any;\n}\n\n                                                                                                                                                                 \nexport interface IFragmentConcatenator {\n                                                               \n  join(left: any | undefined, right: any | undefined): any;\n}\n\n                                                                                        \nexport class StringConcat implements IFragmentConcatenator {\n  public join(left: any | undefined, right: any | undefined): any {\n    if (left === undefined) { return right !== undefined ? `${right}` : undefined; }\n    if (right === undefined) { return `${left}`; }\n    return `${left}${right}`;\n  }\n}\n\n                                                              \nexport class DefaultTokenResolver implements ITokenResolver {\n  constructor(private readonly concat: IFragmentConcatenator) {\n  }\n\n                                                                                                                                           \n  public resolveToken(t: IResolvable, context: IResolveContext, postProcessor: IPostProcessor) {\n    try {\n      let resolved = t.resolve(context);\n\n      // The token might have returned more values that need resolving, recurse\n      resolved = context.resolve(resolved);\n      resolved = postProcessor.postProcess(resolved, context);\n      return resolved;\n    } catch (e) {\n      let message = `Resolution error: ${e.message}.`;\n      if (t.creationStack && t.creationStack.length > 0) {\n        message += `\\nObject creation stack:\\n  at ${t.creationStack.join('\\n  at ')}`;\n      }\n\n      e.message = message;\n      throw e;\n    }\n  }\n\n                                                   \n  public resolveString(fragments: TokenizedStringFragments, context: IResolveContext) {\n    return fragments.mapTokens({ mapToken: context.resolve }).join(this.concat);\n  }\n\n  public resolveList(xs: string[], context: IResolveContext) {\n    // Must be a singleton list token, because concatenation is not allowed.\n    if (xs.length !== 1) {\n      throw new Error(`Cannot add elements to list token, got: ${xs}`);\n    }\n\n    const str = TokenString.forListToken(xs[0]);\n    const tokenMap = TokenMap.instance();\n    const fragments = str.split(tokenMap.lookupToken.bind(tokenMap));\n    if (fragments.length !== 1) {\n      throw new Error(`Cannot concatenate strings in a tokenized string array, got: ${xs[0]}`);\n    }\n\n    return fragments.mapTokens({ mapToken: context.resolve }).firstValue;\n  }\n}\n"]}