chrome-devtools-frontend
Version:
Chrome DevTools UI
68 lines (56 loc) • 1.99 kB
text/typescript
// Copyright 2013 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import * as Common from '../../core/common/common.js';
import {ChunkedFileReader, type ChunkedReader} from './FileUtils.js';
export class TempFile {
#lastBlob: Blob|null;
constructor() {
this.#lastBlob = null;
}
write(pieces: Array<string|Blob>): void {
if (this.#lastBlob) {
pieces.unshift(this.#lastBlob);
}
this.#lastBlob = new Blob(pieces, {type: 'text/plain'});
}
read(): Promise<string|null> {
return this.readRange();
}
size(): number {
return this.#lastBlob ? this.#lastBlob.size : 0;
}
async readRange(startOffset?: number, endOffset?: number): Promise<string|null> {
if (!this.#lastBlob) {
Common.Console.Console.instance().error('Attempt to read a temp file that was never written');
return '';
}
const blob = typeof startOffset === 'number' || typeof endOffset === 'number' ?
this.#lastBlob.slice((startOffset as number), (endOffset as number)) :
this.#lastBlob;
const reader = new FileReader();
try {
await new Promise((resolve, reject) => {
reader.onloadend = resolve;
reader.onerror = reject;
reader.readAsText(blob);
});
} catch (error) {
Common.Console.Console.instance().error('Failed to read from temp file: ' + error.message);
}
return reader.result as string | null;
}
async copyToOutputStream(
outputStream: Common.StringOutputStream.OutputStream,
progress?: ((arg0: ChunkedReader) => void)): Promise<DOMError|null> {
if (!this.#lastBlob) {
void outputStream.close();
return null;
}
const reader = new ChunkedFileReader((this.#lastBlob as File), 10 * 1000 * 1000, progress);
return await reader.read(outputStream).then(success => success ? null : reader.error());
}
remove(): void {
this.#lastBlob = null;
}
}