mirror of
https://github.com/status-im/react-native.git
synced 2025-02-21 13:48:13 +00:00
Summary: Fixes lots of ESLint warnings. Many of them where in PR #20877 by janicduplessis which requested to split the linting fixes from configuration and package changes. I solved only the issues that I was most certain about but I would love to get hands on all of them with a little bit of input. Pull Request resolved: https://github.com/facebook/react-native/pull/22062 Differential Revision: D12889447 Pulled By: TheSavior fbshipit-source-id: 35f7a08104a5b859c860afdde4af2b32c0685c50
39 lines
1020 B
JavaScript
39 lines
1020 B
JavaScript
/**
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*
|
|
* @format
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
/**
|
|
* Try executing a function n times recursively.
|
|
* Return 0 the first time it succeeds
|
|
* Return code of the last failed commands if not more retries left
|
|
* @funcToRetry - function that gets retried
|
|
* @retriesLeft - number of retries to execute funcToRetry
|
|
* @onEveryError - func to execute if funcToRetry returns non 0
|
|
*/
|
|
function tryExecNTimes(funcToRetry, retriesLeft, onEveryError) {
|
|
const exitCode = funcToRetry();
|
|
if (exitCode === 0) {
|
|
return exitCode;
|
|
} else {
|
|
if (onEveryError) {
|
|
onEveryError();
|
|
}
|
|
retriesLeft--;
|
|
console.warn(`Command failed, ${retriesLeft} retries left`);
|
|
if (retriesLeft === 0) {
|
|
return exitCode;
|
|
} else {
|
|
return tryExecNTimes(funcToRetry, retriesLeft, onEveryError);
|
|
}
|
|
}
|
|
}
|
|
|
|
module.exports = tryExecNTimes;
|