をここに私はGoogleのI/O(警告で「!ファイヤーセール」の連続展開のデモのために書いたコードの一部です。これは、私は、次のような何かを行うことができ、私のクラウド機能のコード内で続い)特にエラー処理の場合には、読みやすくしているのawait /非同期
import * as fs from 'fs';
import * as os from 'os';
import * as path from 'path';
let tempy = require('tempy'); // No .d.ts
function rmFileAsync(file: string) {
return new Promise((resolve, reject) => {
fs.unlink(file, (err) => {
if (err) {
reject(err);
} else {
resolve();
}
})
})
}
function statAsync(file: string): Promise<fs.Stats> {
return new Promise((resolve, reject) => {
fs.stat(file, (err, stat) => {
if (err) {
reject(err);
} else {
resolve(stat);
}
})
})
}
async function rmrfAsync(dir: string) {
// Note: I should have written this to be async too
let files = fs.readdirSync(dir);
return Promise.all(_.map(files, async (file) => {
file = path.join(dir, file);
let stat = await statAsync(file);
if (stat.isFile()) {
return rmFileAsync(file);
}
return rmrfAsync(file);
}));
}
を使用することができます:
export let myFunction = functions.myTrigger.onEvent(async event => {
// If I want to be extra aggressive to handle any timeouts/failures and
// clean up before execution:
try {
await rmrfAsync(os.tmpdir());
} catch (err) {
console.log('Failed to clean temp directory. Deploy may fail.', err);
}
// In an async function we can use try/finally to ensure code runs
// without changing the error status of the function.
try {
// Gets a new directory under /tmp so we're guaranteed to have a
// clean slate.
let dir = tempy.directory();
// ... do stuff ...
} finally {
await rmrfAsync(dir);
}
}
'fs.rmdir'は約束を返しますか?既存のコードでどのように使用できますか? –
また、アクセスできますか、私の一時ディレクトリを見ることができますか? –
os.tmpdirは通常のディレクトリです。あなたはそれを読んだり、削除したりすることができます。非同期に対処したくない場合は、 'fs.rmdirSync'を呼び出すことができます。それ以外の場合は、古いCallback APIをPromise APIに変換するために以下のような単純な使い方があります。 –