From 48281ecfcdae6f1fd75ad25dce0eafd395a20ee7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Juan=20Jos=C3=A9=20Arboleda?= Date: Thu, 22 Jul 2021 16:16:50 -0500 Subject: [PATCH] doc: add code examples to `Writable.destroy()` and `Writable.destroyed` PR-URL: https://github.com/nodejs/node/pull/39491 Reviewed-By: James M Snell --- doc/api/stream.md | 39 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) diff --git a/doc/api/stream.md b/doc/api/stream.md index 3af13addda1bb8..03a4deffd7c8d9 100644 --- a/doc/api/stream.md +++ b/doc/api/stream.md @@ -401,6 +401,35 @@ This is a destructive and immediate way to destroy a stream. Previous calls to Use `end()` instead of destroy if data should flush before close, or wait for the `'drain'` event before destroying the stream. +```cjs +const { Writable } = require('stream'); + +const myStream = new Writable(); + +const fooErr = new Error('foo error'); +myStream.destroy(fooErr); +myStream.on('error', (fooErr) => console.error(fooErr.message)); // foo error +``` + +```cjs +const { Writable } = require('stream'); + +const myStream = new Writable(); + +myStream.destroy(); +myStream.on('error', function wontHappen() {}); +``` + +```cjs +const { Writable } = require('stream'); + +const myStream = new Writable(); +myStream.destroy(); + +myStream.write('foo', (error) => console.error(error.code)); +// ERR_STREAM_DESTROYED +``` + Once `destroy()` has been called any further calls will be a no-op and no further errors except from `_destroy()` may be emitted as `'error'`. @@ -416,6 +445,16 @@ added: v8.0.0 Is `true` after [`writable.destroy()`][writable-destroy] has been called. +```cjs +const { Writable } = require('stream'); + +const myStream = new Writable(); + +console.log(myStream.destroyed); // false +myStream.destroy(); +console.log(myStream.destroyed); // true +``` + ##### `writable.end([chunk[, encoding]][, callback])`