mirror of
https://github.com/coder/code-server.git
synced 2026-02-05 14:27:08 -06:00
* Replace evaluations with proxies and messages * Return proxies synchronously Otherwise events can be lost. * Ensure events cannot be missed * Refactor remaining fills * Use more up-to-date version of util For callbackify. * Wait for dispose to come back before removing This prevents issues with the "done" event not always being the last event fired. For example a socket might close and then end, but only if the caller called end. * Remove old node-pty tests * Fix emitting events twice on duplex streams * Preserve environment when spawning processes * Throw a better error if the proxy doesn't exist * Remove rimraf dependency from ide * Update net.Server.listening * Use exit event instead of killed Doesn't look like killed is even a thing. * Add response timeout to server * Fix trash * Require node-pty & spdlog after they get unpackaged This fixes an error when running in the binary. * Fix errors in down emitter preventing reconnecting * Fix disposing proxies when nothing listens to "error" event * Refactor event tests to use jest.fn() * Reject proxy call when disconnected Otherwise it'll wait for the timeout which is a waste of time since we already know the connection is dead. * Use nbin for binary packaging * Remove additional module requires * Attempt to remove require for local bootstrap-fork * Externalize fsevents
47 lines
2.0 KiB
TypeScript
47 lines
2.0 KiB
TypeScript
/// <reference path="../../../../../lib/vscode/src/typings/spdlog.d.ts" />
|
|
import { EventEmitter } from "events";
|
|
import * as spdlog from "spdlog";
|
|
import { ServerProxy } from "../../common/proxy";
|
|
|
|
export class RotatingLoggerProxy implements ServerProxy {
|
|
private readonly emitter = new EventEmitter();
|
|
|
|
public constructor(private readonly logger: spdlog.RotatingLogger) {}
|
|
|
|
public async trace (message: string): Promise<void> { this.logger.trace(message); }
|
|
public async debug (message: string): Promise<void> { this.logger.debug(message); }
|
|
public async info (message: string): Promise<void> { this.logger.info(message); }
|
|
public async warn (message: string): Promise<void> { this.logger.warn(message); }
|
|
public async error (message: string): Promise<void> { this.logger.error(message); }
|
|
public async critical (message: string): Promise<void> { this.logger.critical(message); }
|
|
public async setLevel (level: number): Promise<void> { this.logger.setLevel(level); }
|
|
public async clearFormatters (): Promise<void> { this.logger.clearFormatters(); }
|
|
public async flush (): Promise<void> { this.logger.flush(); }
|
|
public async drop (): Promise<void> { this.logger.drop(); }
|
|
|
|
public async onDone(cb: () => void): Promise<void> {
|
|
this.emitter.on("dispose", cb);
|
|
}
|
|
|
|
public async dispose(): Promise<void> {
|
|
this.flush();
|
|
this.emitter.emit("dispose");
|
|
this.emitter.removeAllListeners();
|
|
}
|
|
|
|
// tslint:disable-next-line no-any
|
|
public async onEvent(_cb: (event: string, ...args: any[]) => void): Promise<void> {
|
|
// No events.
|
|
}
|
|
}
|
|
|
|
export class SpdlogModuleProxy {
|
|
public async createLogger(name: string, filePath: string, fileSize: number, fileCount: number): Promise<RotatingLoggerProxy> {
|
|
return new RotatingLoggerProxy(new (require("spdlog") as typeof import("spdlog")).RotatingLogger(name, filePath, fileSize, fileCount));
|
|
}
|
|
|
|
public async setAsyncMode(bufferSize: number, flushInterval: number): Promise<void> {
|
|
require("spdlog").setAsyncMode(bufferSize, flushInterval);
|
|
}
|
|
}
|