当前位置: 首页>>代码示例>>TypeScript>>正文


TypeScript NameUtils.parseClusterName方法代码示例

本文整理汇总了TypeScript中core/naming.NameUtils.parseClusterName方法的典型用法代码示例。如果您正苦于以下问题:TypeScript NameUtils.parseClusterName方法的具体用法?TypeScript NameUtils.parseClusterName怎么用?TypeScript NameUtils.parseClusterName使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在core/naming.NameUtils的用法示例。


在下文中一共展示了NameUtils.parseClusterName方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的TypeScript代码示例。

示例1: getMatchingRule

  public getMatchingRule(
    account: string,
    location: string,
    clusterName: string,
    rules: IClusterMatchRule[],
  ): IClusterMatchRule {
    if (!rules || !rules.length) {
      return null;
    }
    const nameParts = NameUtils.parseClusterName(clusterName);

    const matchedRules = rules
      .filter(r => {
        const ruleAccount = r.account || '';
        const ruleLocation = r.location || '';
        const ruleStack = r.stack || '';
        const ruleDetail = r.detail || '';
        const stack = nameParts.stack || '';
        const detail = nameParts.freeFormDetails || '';
        return (
          ('*' === ruleAccount || account === ruleAccount) &&
          ('*' === ruleLocation || location === ruleLocation) &&
          ('*' === ruleStack || stack === ruleStack) &&
          ('*' === ruleDetail || detail === ruleDetail)
        );
      })
      .sort((a, b) => {
        if (a.account !== b.account) {
          return a.account === '*' ? 1 : -1;
        }
        if (a.location !== b.location) {
          return a.location === '*' ? 1 : -1;
        }
        if (a.stack !== b.stack) {
          return a.stack === '*' ? 1 : -1;
        }
        if (a.detail !== b.detail) {
          return a.detail === '*' ? 1 : -1;
        }
        return a.priority - b.priority;
      });

    return matchedRules.length ? matchedRules[0] : null;
  }
开发者ID:emjburns,项目名称:deck,代码行数:44,代码来源:ClusterRuleMatcher.ts


注:本文中的core/naming.NameUtils.parseClusterName方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。