當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript Readable.pipe方法代碼示例

本文整理匯總了TypeScript中stream.Readable.pipe方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript Readable.pipe方法的具體用法?TypeScript Readable.pipe怎麽用?TypeScript Readable.pipe使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在stream.Readable的用法示例。


在下文中一共展示了Readable.pipe方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: function

export default async function (
  stream: Readable,
  result: ScrapeResult,
  next: Next
): Promise<ScrapeResult> {
  const { url } = result

  if (result.encodingFormat !== 'text/html') {
    return next(stream)
  }

  const [parsed] = await Promise.all([
    parseHtml(stream.pipe(new PassThrough()), url),
    next(stream.pipe(new PassThrough()))
  ])

  const { twitter, html, icons, dublincore, applinks, sailthru, alternate } = parsed

  const [jsonld, rdfa, microdata] = await Promise.all([
    parsed.jsonld ? Jsonld.expand(parsed.jsonld, { base: url }).catch(() => undefined) : undefined,
    parsed.rdfa ? Jsonld.expand(parsed.rdfa, { base: url }).catch(() => undefined) : undefined,
    parsed.microdata ? Jsonld.expand(parsed.microdata, { base: url }).catch(() => undefined) : undefined
  ])

  return Object.assign(result, {
    jsonld,
    rdfa,
    microdata,
    twitter,
    html,
    icons,
    dublincore,
    applinks,
    sailthru,
    alternate
  })
}
開發者ID:blakeembrey,項目名稱:node-scrappy,代碼行數:37,代碼來源:html.ts

示例2: mkdirp

	return mkdirp(targetDirName, void 0, token).then(() => new Promise((c, e) => {
		if (token.isCancellationRequested) {
			return;
		}

		try {
			istream = createWriteStream(targetFileName, { mode });
			istream.once('close', () => c(null));
			istream.once('error', e);
			stream.once('error', e);
			stream.pipe(istream);
		} catch (error) {
			e(error);
		}
	}));
開發者ID:ramesius,項目名稱:vscode,代碼行數:15,代碼來源:zip.ts

示例3: createWriteStream

	return Promise.resolve(mkdirp(targetDirName, undefined, token)).then(() => new Promise<void>((c, e) => {
		if (token.isCancellationRequested) {
			return;
		}

		try {
			istream = createWriteStream(targetFileName, { mode });
			istream.once('close', () => c());
			istream.once('error', e);
			stream.once('error', e);
			stream.pipe(istream);
		} catch (error) {
			e(error);
		}
	}));
開發者ID:joelday,項目名稱:vscode,代碼行數:15,代碼來源:zip.ts

示例4: lint

    lint(html: string): Promise<Issue[]> {

        var parser: SAXParser = new SAXParser({ locationInfo: true });
        var parseState: ParseState = new ParseState(this.scopes, this.voids);
        var stream: Readable = new Readable();

        parseState.initPreRules(parser);

        let rules = this.rules;

        rules.forEach((rule) => {
            rule.init(parser, parseState);
        });

        parseState.initPostRules(parser);

        stream.push(html);
        stream.push(null);
        var work = stream.pipe(parser);

        var completed = new Promise<void>(function (resolve, reject) {
            work.on("end", () => {
                parseState.finalise();
                resolve();
            });
        });

        var ruleTasks = [];

        rules.forEach((rule) => {
            let task = completed.then(() => {
                return rule.finalise();
            });
            ruleTasks.push(task);
        });

        return Promise.all(ruleTasks).then(results => {

            var all = new Array<Issue>();

            results.forEach(parts => {
                all = all.concat(parts);
            });

            return all;
        });
    }
開發者ID:gitter-badger,項目名稱:template-lint,代碼行數:47,代碼來源:linter.ts

示例5: lint

  lint(html: string | Stream, path?: string): Promise<Issue[]> {
    var parser = this.parserBuilder.build();
    parser.init(this.rules, this.ast, path);

    if (typeof (html) === 'string') {
      var stream: Readable = new Readable();
      stream.push(html);
      stream.push(null);
      stream.pipe(parser);
    } else if (this.isStream(html)) {
      html.pipe(parser);
    }
    else {
      throw new Error("html isn't pipeable");
    }

    var completed = new Promise<void>(function (resolve, reject) {
      parser.on("end", () => {
        parser.finalise();
        resolve();
      });
    });

    var ruleTasks = [];

    this.rules.forEach((rule) => {
      let task = completed.then(() => {
        return rule.finalise(this.ast.root);
      });
      ruleTasks.push(task);
    });

    return Promise.all(ruleTasks).then(results => {

      var all = new Array<Issue>();

      results.forEach(parts => {
        all = all.concat(parts);
      });

      all = all.sort((a, b) => (a.line - b.line) * 1000 + (a.column - b.column));

      return all;
    });
  }
開發者ID:MeirionHughes,項目名稱:template-lint,代碼行數:45,代碼來源:linter.ts

示例6: unwrapBody

        let requestHandler = (req : Request, response : Response) => {
            let args = endpoint.params.map(x => req.params[x]);

            args = args.concat(endpoint.query.map(x => req.query[x]));
            args = args.concat(endpoint.headers.map(x => req.get(x)));

            let body = unwrapBody(req.body);

            if(body) {
                args.push(body);
            }

            let handler = target[endpoint.handler];

            let result;

            try {
                result = handler.apply(target, args);
            } catch(error) {
                let wrappedError = wrapErrorBody(error); //TODO: this error handler should be configurable
                console.error('Request Error: ' + JSON.stringify(wrappedError));
                response.status(500).send(wrappedError);
                return;
            }


            if(isPromise(result)) {

                let promise : Promise<any> = result;
                promise.then(x => response.send(x))
                       .catch(error => {
                           let wrappedError = wrapErrorBody(error); //TODO: this error handler should be configurable
                           console.error('Request Error: ' + JSON.stringify(wrappedError));
                           response.status(500).send(wrappedError);
                       });

            } else if(isReadableStream(result)) {

                let readableStream : Readable = result;
                readableStream.pipe(response);

            } else {
                response.send(result);
            }
        };
開發者ID:mserranom,項目名稱:lean-ci,代碼行數:45,代碼來源:express_decorators.ts

示例7: catch

        const logStreamInLogger = (
          stream: ReadableStream | null,
          loggerLevel: Level,
        ) => {
          if (!stream) return;
          stream.pipe(split()).on('data', (line: string) => {
            if (line.length === 0) return;
            if (line.startsWith('{') && line.endsWith('}')) {
              try {
                const json: object = JSON.parse(line);
                logger.log('', json, loggerLevel);
                return;
              } catch (err) {}
            }

            outputLogger.log(line, undefined, loggerLevel);
          });
        };
開發者ID:christophehurpeau,項目名稱:springbokjs-daemon,代碼行數:18,代碼來源:index.ts

示例8: it

        it('should throw if input is streamed', (done: Function) => {
            const transform = new PboTransformStream().on('error', (err: Error) => {
                expect(err).to.be.an('Error');
                expect(err.message).to.equal('Streaming input is not supported');
                done();
            });

            const emitter = new Readable({
                objectMode: true,
                read: () => {
                    const file = new File({ contents: new Duplex() });
                    emitter.push(file);
                    emitter.push(null);
                }
            });

            emitter.pipe(transform);
        });
開發者ID:winseros,項目名稱:gulp-armapbo-plugin,代碼行數:18,代碼來源:pboTransformStream.spec.ts

示例9: coalesce

        exportSchemaToFile: ({ pubsub, file, schema }: any) => {
            const sql = `SELECT c.TABLE_NAME, c.TABLE_SCHEMA, '' AS TABLE_TEXT, t.TABLE_TYPE, c.COLUMN_NAME, coalesce(pgd.description, '') AS COLUMN_TEXT, c.DATA_TYPE, coalesce(c.NUMERIC_PRECISION, c.CHARACTER_MAXIMUM_LENGTH) LENGTH, c.NUMERIC_SCALE 
            FROM information_schema.tables t
            join information_schema.columns c on t.table_schema=c.table_schema and t.table_name=c.table_name
            join pg_catalog.pg_statio_all_tables pt on pt.schemaname=t.table_schema and pt.relname=t.table_name
            left outer join pg_catalog.pg_description pgd on pgd.objoid=pt.relid and pgd.objsubid=c.ordinal_position
            where t.table_schema=$1
            order by c.TABLE_NAME, c.ORDINAL_POSITION
            `
            const handleError = err => pubsub.emit('export-error', err)
            const stream = new Readable({ objectMode: true })
            stream._read = () => {
                // noop
            }
            client.query(
                {
                    text: sql,
                    values: [schema],
                    rowMode: 'array',
                },
                (err, result) => {
                    if (err) {
                        handleError(err)
                    } else {
                        result.rows.map(row => stream.push(row))
                        stream.push(null)
                    }
                }
            )

            return stream
                .pipe(createGroupTablesTransform(pubsub))
                .on('error', handleError)
                .pipe(JSONStream.stringify())
                .on('error', handleError)
                .on('end', () => console.log('end json stringify'))
                .pipe(createWriteStream(file))
                .on('end', () => console.log('end write'))
                .on('error', handleError)
        },
開發者ID:jakobrun,項目名稱:gandalf,代碼行數:40,代碼來源:pgConnector.ts

示例10: Promise

    return new Promise((resolve, reject) => {
      try {
        const [nsPath, dataPath, metaPath] = this.getPaths(ns, key)

        ensurePath(nsPath)

        let headers = {}
        if (opts && opts.headers) {
          headers = { ...headers, ...opts.headers }
        }

        const stream = fs.createWriteStream(dataPath)
        value.pipe(stream)

        fs.writeFileSync(metaPath, JSON.stringify(headers), "utf8")

        resolve(true)
      } catch (err) {
        log.warn("[FileSystemBlobStore] set error", err)
        reject(err)
      }
    })
開發者ID:dianpeng,項目名稱:fly,代碼行數:22,代碼來源:fs_blob_store.ts


注:本文中的stream.Readable.pipe方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。