From 2dfaa480dec547b67a7a1b0a209374349fea235b Mon Sep 17 00:00:00 2001 From: cjihrig Date: Sun, 2 Dec 2018 12:25:39 -0500 Subject: [PATCH] dns: simplify dns.promises warning logic dns.promises is lazy loaded. Instead of using a seaparate Boolean flag to track whether or not it has been loaded, just inspect the state of the lazy loaded module itself. PR-URL: https://github.com/nodejs/node/pull/24788 Reviewed-By: Anto Aravinth Reviewed-By: Weijia Wang Reviewed-By: Masashi Hirano Reviewed-By: Jeremiah Senkpiel --- lib/dns.js | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/lib/dns.js b/lib/dns.js index ac3f6d6f0ec725..f68409f2ee6743 100644 --- a/lib/dns.js +++ b/lib/dns.js @@ -50,8 +50,7 @@ const { const dnsException = errors.dnsException; -let promisesWarn = true; -let promises; // Lazy loaded +let promises = null; // Lazy loaded function onlookup(err, addresses) { if (err) { @@ -269,7 +268,7 @@ function defaultResolverSetServers(servers) { setDefaultResolver(resolver); bindDefaultResolver(module.exports, Resolver.prototype); - if (promises !== undefined) + if (promises !== null) bindDefaultResolver(promises, promises.Resolver.prototype); } @@ -318,10 +317,9 @@ Object.defineProperties(module.exports, { configurable: true, enumerable: false, get() { - if (promisesWarn) { + if (promises === null) { promises = require('internal/dns/promises'); promises.setServers = defaultResolverSetServers; - promisesWarn = false; process.emitWarning('The dns.promises API is experimental', 'ExperimentalWarning'); }