occam-verify-cli 1.0.16 → 1.0.18

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -49,8 +49,13 @@ function createReleaseContext(dependency, dependentNames, context, callback) {
49
49
  callback(error, success);
50
50
  return;
51
51
  }
52
- var releaseContextFromDependency = context.releaseContextFromDependency, dependencyString = dependency.asString();
53
- log.debug("Creating the '".concat(releaseName, "' context given the '").concat(dependencyString, "' dependency..."));
52
+ var releaseContextFromDependency = context.releaseContextFromDependency, dependencyString = dependency.asString(), dependentNamesLength = dependentNames.length;
53
+ if (dependentNamesLength === 0) {
54
+ log.info("Creating the '".concat(releaseName, "' context..."));
55
+ } else {
56
+ var lastDependentName = last(dependentNames), dependentName = lastDependentName; ///
57
+ log.info("Creating the '".concat(releaseName, "' context given the '").concat(dependentName, "' dependant's '").concat(dependencyString, "' dependency..."));
58
+ }
54
59
  releaseContextFromDependency(dependency, context, function(error, releaseContext) {
55
60
  if (error) {
56
61
  callback(error);
@@ -69,7 +74,6 @@ function createReleaseContext(dependency, dependentNames, context, callback) {
69
74
  return;
70
75
  }
71
76
  releaseContextMap[releaseName] = releaseContext;
72
- log.info("...created the '".concat(releaseName, "' context."));
73
77
  createDependencyReleaseContexts(dependency, releaseContext, dependentNames, context, function(error, success) {
74
78
  if (error) {
75
79
  callback(error);
@@ -80,6 +84,7 @@ function createReleaseContext(dependency, dependentNames, context, callback) {
80
84
  callback(error, success);
81
85
  return;
82
86
  }
87
+ log.debug("...created the '".concat(releaseName, "' context."));
83
88
  callback(error, success);
84
89
  });
85
90
  }, context);
@@ -94,9 +99,9 @@ function initialiseReleaseContext(dependency, context) {
94
99
  if (!releaseContextInitialised) {
95
100
  initialiseDependencyReleaseContexts(dependency, releaseContext, context);
96
101
  var log1 = context.log, releaseContexts = retrieveReleaseContexts(releaseContext, releaseContextMap);
97
- log1.debug("Initialising the '".concat(dependencyName, "' context..."));
102
+ log1.info("Initialising the '".concat(dependencyName, "' context..."));
98
103
  releaseContext.initialise(releaseContexts);
99
- log1.info("...initialised the '".concat(dependencyName, "' context."));
104
+ log1.debug("...initialised the '".concat(dependencyName, "' context."));
100
105
  }
101
106
  }
102
107
  }
@@ -199,4 +204,4 @@ function initialiseDependencyReleaseContexts(dependency, releaseContext, context
199
204
  });
200
205
  }
201
206
 
202
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/releaseContext.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\n\nconst { last } = arrayUtilities;\n\nfunction createReleaseContext(dependency, dependentNames, context, callback) {\n  const { log, releaseContextMap } = context,\n        dependencyName = dependency.getName(),\n        releaseName = dependencyName, ///\n        releaseContext = releaseContextMap[releaseName] || null;\n\n  if (releaseContext !== null) {\n    const error = null,\n          releaseMatchesDependency = checkReleaseMatchesDependency(releaseContext, dependency, dependentNames, context);\n\n    let success;\n\n    if (releaseMatchesDependency) {\n      log.debug(`Already created the '${releaseName}' context.`);\n\n      success = true;\n    } else {\n      success = false;\n    }\n\n    callback(error, success);\n\n    return;\n  }\n\n  const { releaseContextFromDependency } = context,\n        dependencyString = dependency.asString();\n\n  log.debug(`Creating the '${releaseName}' context given the '${dependencyString}' dependency...`);\n\n  releaseContextFromDependency(dependency, context, (error, releaseContext) => {\n    if (error) {\n      callback(error);\n\n      return;\n    }\n\n    const releaseContextCreated = checkReleaseContextCreated(releaseContext, dependency, context);\n\n    if (!releaseContextCreated) {\n      const error = null,\n            success = false;\n\n      callback(error, success);\n\n      return;\n    }\n\n    const releaseMatchesDependency = checkReleaseMatchesDependency(releaseContext, dependency, dependentNames, context);\n\n    if (!releaseMatchesDependency) {\n      const error = null,\n            success = false;\n\n      callback(error, success);\n\n      return;\n    }\n\n    releaseContextMap[releaseName] = releaseContext;\n\n    log.info(`...created the '${releaseName}' context.`);\n\n    createDependencyReleaseContexts(dependency, releaseContext, dependentNames, context, (error, success) => {\n      if (error) {\n        callback(error);\n\n        return;\n      }\n\n      if (!success) {\n        log.warning(`...unable to create the '${releaseName}' context.`);\n\n        callback(error, success);\n\n        return;\n      }\n\n      callback(error, success);\n    });\n  }, context);\n}\n\nfunction initialiseReleaseContext(dependency, context) {\n  const { releaseContextMap } = context,\n        dependencyName = dependency.getName(),\n        releaseName = dependencyName, ///\n        releaseContext = releaseContextMap[releaseName] || null;\n\n  if (releaseContext === null) {\n    const { log } = context;\n\n    log.warning(`Unable to initialise the '${dependencyName}' context because it has not been created.`);\n  } else {\n    const releaseContextInitialised = releaseContext.isInitialised();\n\n    if (!releaseContextInitialised) {\n      initialiseDependencyReleaseContexts(dependency, releaseContext, context);\n\n      const { log } = context,\n            releaseContexts = retrieveReleaseContexts(releaseContext, releaseContextMap);\n\n      log.debug(`Initialising the '${dependencyName}' context...`);\n\n      releaseContext.initialise(releaseContexts);\n\n      log.info(`...initialised the '${dependencyName}' context.`);\n    }\n  }\n}\n\nexport default {\n  createReleaseContext,\n  initialiseReleaseContext\n};\n\nfunction retrieveReleaseContexts(releaseContext, releaseContextMap) {\n  const releaseContexts = [],\n        remainingReleaseContext = releaseContext,  ///\n        remainingReleaseContexts = [\n          remainingReleaseContext\n        ];\n\n  let remainingReleaseContextsLength = remainingReleaseContexts.length;\n\n  while (remainingReleaseContextsLength > 0) {\n    const remainingReleaseContext = remainingReleaseContexts.shift(),\n          releaseContext = remainingReleaseContext;  ///\n\n    releaseContexts.push(releaseContext);\n\n    const dependencies = releaseContext.getDependencies();\n\n    dependencies.forEachDependency((dependency) => {\n      const dependencyName = dependency.getName(),\n            releaseName = dependencyName, ///\n            releaseContext = releaseContextMap[releaseName],\n            releaseContextsIncludesReleaseContext = releaseContexts.includes(releaseContext),\n            remainingReleaseContextsIncludesReleaseContext = remainingReleaseContexts.includes(releaseContext);\n\n      if (!releaseContextsIncludesReleaseContext && !remainingReleaseContextsIncludesReleaseContext) {\n        const remainingReleaseContext = releaseContext; ///\n\n        remainingReleaseContexts.push(remainingReleaseContext);\n      }\n    });\n\n    remainingReleaseContextsLength = remainingReleaseContexts.length;\n  }\n\n  return releaseContexts;\n}\n\nfunction checkReleaseContextCreated(releaseContext, dependency, context) {\n  const releaseContextCreated = (releaseContext !== null);\n\n  if (!releaseContextCreated) {\n    const { log } = context,\n          dependencyName = dependency.getName(),\n          releaseName = dependencyName; ///\n\n    log.warning(`The '${releaseName}' context could not be created. Perhaps the 'meta.json' file is missing or invalid. Or there could be a dependency mismatch.`);\n  }\n\n  return releaseContextCreated;\n}\n\nfunction checkCyclicDependencyExists(dependency, dependentNames, context) {\n  const dependencyName = dependency.getName(),\n        dependentNamesIncludesDependencyName = dependentNames.includes(dependencyName),\n        cyclicDependencyExists = dependentNamesIncludesDependencyName;  ///\n\n  if (cyclicDependencyExists) {\n    const { log } = context,\n          firstDependentName = first(dependentNames),\n          dependencyNames = [  ///\n            ...dependentNames,\n            firstDependentName\n          ],\n          dependencyNamesString = dependencyNames.join(`' -> '`);\n\n    log.warning(`There is a cyclic dependency: '${dependencyNamesString}'.`);\n  }\n\n  return cyclicDependencyExists;\n}\n\nfunction checkReleaseMatchesDependency(releaseContext, dependency, dependentNames, context) {\n  let releaseMatchesDependency = true;\n\n  const entries = releaseContext.getEntries(),\n        shortenedVersion = dependency.getShortedVersion();\n\n  if (shortenedVersion !== null) {\n    const entriesMatchShortenedVersion = entries.matchShortenedVersion(shortenedVersion);\n\n    if (!entriesMatchShortenedVersion) {\n      const { log } = context,\n            version = releaseContext.getVersion(),\n            lastDependentName = last(dependentNames),\n            dependentName = lastDependentName,  ///\n            versionString = version.toString(),\n            dependencyString = dependency.asString();\n\n      log.warning(`Version mismatch: The '${dependentName}' dependent requires the '${dependencyString}' dependency but a context with version '${versionString}' was provided.`);\n\n      releaseMatchesDependency = false;\n    }\n  }\n\n  return releaseMatchesDependency;\n}\n\nfunction createDependencyReleaseContexts(dependency, releaseContext, dependentNames, context, callback) {\n  const dependencyName = dependency.getName(),\n        dependencies = releaseContext.getDependencies();\n\n  dependentNames = [ ...dependentNames, dependencyName ];  ///\n\n  dependencies.asynchronousForEachDependency((dependency, next, done) => {\n    const cyclicDependencyExists = checkCyclicDependencyExists(dependency, dependentNames);\n\n    if (cyclicDependencyExists) {\n      const error = null,\n            success = false;\n\n      callback(error, success);\n\n      callback = null;\n\n      done();\n\n      return;\n    }\n\n    createReleaseContext(dependency, dependentNames, context, (error, success) => {\n      if (error) {\n        callback(error);\n\n        callback = null;\n\n        done();\n\n        return;\n      }\n\n      if (!success) {\n        callback(error, success);\n\n        callback = null;\n\n        done();\n\n        return;\n      }\n\n      next();\n    });\n  }, done);\n\n  function done() {\n    if (callback !== null) {\n      const error = null,\n            success = true;\n\n      callback(error, success);\n    }\n  }\n}\n\nfunction initialiseDependencyReleaseContexts(dependency, releaseContext, context) {\n  const dependencies = releaseContext.getDependencies();\n\n  dependencies.forEachDependency((dependency) => {  ///\n    initialiseReleaseContext(dependency, context);\n  });\n}\n"],"names":["last","arrayUtilities","createReleaseContext","dependency","dependentNames","context","callback","log","releaseContextMap","dependencyName","getName","releaseName","releaseContext","error","releaseMatchesDependency","checkReleaseMatchesDependency","success","debug","releaseContextFromDependency","dependencyString","asString","releaseContextCreated","checkReleaseContextCreated","info","createDependencyReleaseContexts","warning","initialiseReleaseContext","releaseContextInitialised","isInitialised","initialiseDependencyReleaseContexts","releaseContexts","retrieveReleaseContexts","initialise","remainingReleaseContext","remainingReleaseContexts","remainingReleaseContextsLength","length","shift","push","dependencies","getDependencies","forEachDependency","releaseContextsIncludesReleaseContext","includes","remainingReleaseContextsIncludesReleaseContext","checkCyclicDependencyExists","dependentNamesIncludesDependencyName","cyclicDependencyExists","firstDependentName","first","dependencyNames","dependencyNamesString","join","entries","getEntries","shortenedVersion","getShortedVersion","entriesMatchShortenedVersion","matchShortenedVersion","version","getVersion","lastDependentName","dependentName","versionString","toString","asynchronousForEachDependency","next","done"],"mappings":"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"}
207
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/releaseContext.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\n\nconst { last } = arrayUtilities;\n\nfunction createReleaseContext(dependency, dependentNames, context, callback) {\n  const { log, releaseContextMap } = context,\n        dependencyName = dependency.getName(),\n        releaseName = dependencyName, ///\n        releaseContext = releaseContextMap[releaseName] || null;\n\n  if (releaseContext !== null) {\n    const error = null,\n          releaseMatchesDependency = checkReleaseMatchesDependency(releaseContext, dependency, dependentNames, context);\n\n    let success;\n\n    if (releaseMatchesDependency) {\n      log.debug(`Already created the '${releaseName}' context.`);\n\n      success = true;\n    } else {\n      success = false;\n    }\n\n    callback(error, success);\n\n    return;\n  }\n\n  const { releaseContextFromDependency } = context,\n        dependencyString = dependency.asString(),\n        dependentNamesLength = dependentNames.length;\n\n  if (dependentNamesLength === 0) {\n    log.info(`Creating the '${releaseName}' context...`);\n  } else {\n    const lastDependentName = last(dependentNames),\n          dependentName = lastDependentName;  ///\n\n    log.info(`Creating the '${releaseName}' context given the '${dependentName}' dependant's '${dependencyString}' dependency...`);\n  }\n\n  releaseContextFromDependency(dependency, context, (error, releaseContext) => {\n    if (error) {\n      callback(error);\n\n      return;\n    }\n\n    const releaseContextCreated = checkReleaseContextCreated(releaseContext, dependency, context);\n\n    if (!releaseContextCreated) {\n      const error = null,\n            success = false;\n\n      callback(error, success);\n\n      return;\n    }\n\n    const releaseMatchesDependency = checkReleaseMatchesDependency(releaseContext, dependency, dependentNames, context);\n\n    if (!releaseMatchesDependency) {\n      const error = null,\n            success = false;\n\n      callback(error, success);\n\n      return;\n    }\n\n    releaseContextMap[releaseName] = releaseContext;\n\n    createDependencyReleaseContexts(dependency, releaseContext, dependentNames, context, (error, success) => {\n      if (error) {\n        callback(error);\n\n        return;\n      }\n\n      if (!success) {\n        log.warning(`...unable to create the '${releaseName}' context.`);\n\n        callback(error, success);\n\n        return;\n      }\n\n      log.debug(`...created the '${releaseName}' context.`);\n\n      callback(error, success);\n    });\n  }, context);\n}\n\nfunction initialiseReleaseContext(dependency, context) {\n  const { releaseContextMap } = context,\n        dependencyName = dependency.getName(),\n        releaseName = dependencyName, ///\n        releaseContext = releaseContextMap[releaseName] || null;\n\n  if (releaseContext === null) {\n    const { log } = context;\n\n    log.warning(`Unable to initialise the '${dependencyName}' context because it has not been created.`);\n  } else {\n    const releaseContextInitialised = releaseContext.isInitialised();\n\n    if (!releaseContextInitialised) {\n      initialiseDependencyReleaseContexts(dependency, releaseContext, context);\n\n      const { log } = context,\n            releaseContexts = retrieveReleaseContexts(releaseContext, releaseContextMap);\n\n      log.info(`Initialising the '${dependencyName}' context...`);\n\n      releaseContext.initialise(releaseContexts);\n\n      log.debug(`...initialised the '${dependencyName}' context.`);\n    }\n  }\n}\n\nexport default {\n  createReleaseContext,\n  initialiseReleaseContext\n};\n\nfunction retrieveReleaseContexts(releaseContext, releaseContextMap) {\n  const releaseContexts = [],\n        remainingReleaseContext = releaseContext,  ///\n        remainingReleaseContexts = [\n          remainingReleaseContext\n        ];\n\n  let remainingReleaseContextsLength = remainingReleaseContexts.length;\n\n  while (remainingReleaseContextsLength > 0) {\n    const remainingReleaseContext = remainingReleaseContexts.shift(),\n          releaseContext = remainingReleaseContext;  ///\n\n    releaseContexts.push(releaseContext);\n\n    const dependencies = releaseContext.getDependencies();\n\n    dependencies.forEachDependency((dependency) => {\n      const dependencyName = dependency.getName(),\n            releaseName = dependencyName, ///\n            releaseContext = releaseContextMap[releaseName],\n            releaseContextsIncludesReleaseContext = releaseContexts.includes(releaseContext),\n            remainingReleaseContextsIncludesReleaseContext = remainingReleaseContexts.includes(releaseContext);\n\n      if (!releaseContextsIncludesReleaseContext && !remainingReleaseContextsIncludesReleaseContext) {\n        const remainingReleaseContext = releaseContext; ///\n\n        remainingReleaseContexts.push(remainingReleaseContext);\n      }\n    });\n\n    remainingReleaseContextsLength = remainingReleaseContexts.length;\n  }\n\n  return releaseContexts;\n}\n\nfunction checkReleaseContextCreated(releaseContext, dependency, context) {\n  const releaseContextCreated = (releaseContext !== null);\n\n  if (!releaseContextCreated) {\n    const { log } = context,\n          dependencyName = dependency.getName(),\n          releaseName = dependencyName; ///\n\n    log.warning(`The '${releaseName}' context could not be created. Perhaps the 'meta.json' file is missing or invalid. Or there could be a dependency mismatch.`);\n  }\n\n  return releaseContextCreated;\n}\n\nfunction checkCyclicDependencyExists(dependency, dependentNames, context) {\n  const dependencyName = dependency.getName(),\n        dependentNamesIncludesDependencyName = dependentNames.includes(dependencyName),\n        cyclicDependencyExists = dependentNamesIncludesDependencyName;  ///\n\n  if (cyclicDependencyExists) {\n    const { log } = context,\n          firstDependentName = first(dependentNames),\n          dependencyNames = [  ///\n            ...dependentNames,\n            firstDependentName\n          ],\n          dependencyNamesString = dependencyNames.join(`' -> '`);\n\n    log.warning(`There is a cyclic dependency: '${dependencyNamesString}'.`);\n  }\n\n  return cyclicDependencyExists;\n}\n\nfunction checkReleaseMatchesDependency(releaseContext, dependency, dependentNames, context) {\n  let releaseMatchesDependency = true;\n\n  const entries = releaseContext.getEntries(),\n        shortenedVersion = dependency.getShortedVersion();\n\n  if (shortenedVersion !== null) {\n    const entriesMatchShortenedVersion = entries.matchShortenedVersion(shortenedVersion);\n\n    if (!entriesMatchShortenedVersion) {\n      const { log } = context,\n            version = releaseContext.getVersion(),\n            lastDependentName = last(dependentNames),\n            dependentName = lastDependentName,  ///\n            versionString = version.toString(),\n            dependencyString = dependency.asString();\n\n      log.warning(`Version mismatch: The '${dependentName}' dependent requires the '${dependencyString}' dependency but a context with version '${versionString}' was provided.`);\n\n      releaseMatchesDependency = false;\n    }\n  }\n\n  return releaseMatchesDependency;\n}\n\nfunction createDependencyReleaseContexts(dependency, releaseContext, dependentNames, context, callback) {\n  const dependencyName = dependency.getName(),\n        dependencies = releaseContext.getDependencies();\n\n  dependentNames = [ ...dependentNames, dependencyName ];  ///\n\n  dependencies.asynchronousForEachDependency((dependency, next, done) => {\n    const cyclicDependencyExists = checkCyclicDependencyExists(dependency, dependentNames);\n\n    if (cyclicDependencyExists) {\n      const error = null,\n            success = false;\n\n      callback(error, success);\n\n      callback = null;\n\n      done();\n\n      return;\n    }\n\n    createReleaseContext(dependency, dependentNames, context, (error, success) => {\n      if (error) {\n        callback(error);\n\n        callback = null;\n\n        done();\n\n        return;\n      }\n\n      if (!success) {\n        callback(error, success);\n\n        callback = null;\n\n        done();\n\n        return;\n      }\n\n      next();\n    });\n  }, done);\n\n  function done() {\n    if (callback !== null) {\n      const error = null,\n            success = true;\n\n      callback(error, success);\n    }\n  }\n}\n\nfunction initialiseDependencyReleaseContexts(dependency, releaseContext, context) {\n  const dependencies = releaseContext.getDependencies();\n\n  dependencies.forEachDependency((dependency) => {  ///\n    initialiseReleaseContext(dependency, context);\n  });\n}\n"],"names":["last","arrayUtilities","createReleaseContext","dependency","dependentNames","context","callback","log","releaseContextMap","dependencyName","getName","releaseName","releaseContext","error","releaseMatchesDependency","checkReleaseMatchesDependency","success","debug","releaseContextFromDependency","dependencyString","asString","dependentNamesLength","length","info","lastDependentName","dependentName","releaseContextCreated","checkReleaseContextCreated","createDependencyReleaseContexts","warning","initialiseReleaseContext","releaseContextInitialised","isInitialised","initialiseDependencyReleaseContexts","releaseContexts","retrieveReleaseContexts","initialise","remainingReleaseContext","remainingReleaseContexts","remainingReleaseContextsLength","shift","push","dependencies","getDependencies","forEachDependency","releaseContextsIncludesReleaseContext","includes","remainingReleaseContextsIncludesReleaseContext","checkCyclicDependencyExists","dependentNamesIncludesDependencyName","cyclicDependencyExists","firstDependentName","first","dependencyNames","dependencyNamesString","join","entries","getEntries","shortenedVersion","getShortedVersion","entriesMatchShortenedVersion","matchShortenedVersion","version","getVersion","versionString","toString","asynchronousForEachDependency","next","done"],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "occam-verify-cli",
3
3
  "author": "James Smith",
4
- "version": "1.0.16",
4
+ "version": "1.0.18",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/occam-verify-cli",
7
7
  "description": "Occam's Verifier",
@@ -30,9 +30,17 @@ function createReleaseContext(dependency, dependentNames, context, callback) {
30
30
  }
31
31
 
32
32
  const { releaseContextFromDependency } = context,
33
- dependencyString = dependency.asString();
33
+ dependencyString = dependency.asString(),
34
+ dependentNamesLength = dependentNames.length;
34
35
 
35
- log.debug(`Creating the '${releaseName}' context given the '${dependencyString}' dependency...`);
36
+ if (dependentNamesLength === 0) {
37
+ log.info(`Creating the '${releaseName}' context...`);
38
+ } else {
39
+ const lastDependentName = last(dependentNames),
40
+ dependentName = lastDependentName; ///
41
+
42
+ log.info(`Creating the '${releaseName}' context given the '${dependentName}' dependant's '${dependencyString}' dependency...`);
43
+ }
36
44
 
37
45
  releaseContextFromDependency(dependency, context, (error, releaseContext) => {
38
46
  if (error) {
@@ -65,8 +73,6 @@ function createReleaseContext(dependency, dependentNames, context, callback) {
65
73
 
66
74
  releaseContextMap[releaseName] = releaseContext;
67
75
 
68
- log.info(`...created the '${releaseName}' context.`);
69
-
70
76
  createDependencyReleaseContexts(dependency, releaseContext, dependentNames, context, (error, success) => {
71
77
  if (error) {
72
78
  callback(error);
@@ -82,6 +88,8 @@ function createReleaseContext(dependency, dependentNames, context, callback) {
82
88
  return;
83
89
  }
84
90
 
91
+ log.debug(`...created the '${releaseName}' context.`);
92
+
85
93
  callback(error, success);
86
94
  });
87
95
  }, context);
@@ -106,11 +114,11 @@ function initialiseReleaseContext(dependency, context) {
106
114
  const { log } = context,
107
115
  releaseContexts = retrieveReleaseContexts(releaseContext, releaseContextMap);
108
116
 
109
- log.debug(`Initialising the '${dependencyName}' context...`);
117
+ log.info(`Initialising the '${dependencyName}' context...`);
110
118
 
111
119
  releaseContext.initialise(releaseContexts);
112
120
 
113
- log.info(`...initialised the '${dependencyName}' context.`);
121
+ log.debug(`...initialised the '${dependencyName}' context.`);
114
122
  }
115
123
  }
116
124
  }