mirror of
https://github.com/chirimen-oh/node-web-gpio.git
synced 2025-01-18 16:08:00 +00:00
replace with eslint to biome for linting
This commit is contained in:
parent
24518181c6
commit
8ce22e2be1
3 changed files with 182 additions and 796 deletions
33
index.ts
33
index.ts
|
@ -31,6 +31,7 @@ const Uint16Max = 65535;
|
||||||
function parseUint16(parseString: string) {
|
function parseUint16(parseString: string) {
|
||||||
const n = Number.parseInt(parseString, 10);
|
const n = Number.parseInt(parseString, 10);
|
||||||
if (0 <= n && n <= Uint16Max) return n;
|
if (0 <= n && n <= Uint16Max) return n;
|
||||||
|
// biome-ignore lint/style/noUselessElse:
|
||||||
else throw new RangeError(`Must be between 0 and ${Uint16Max}.`);
|
else throw new RangeError(`Must be between 0 and ${Uint16Max}.`);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -62,6 +63,7 @@ interface GPIOChangeEvent {
|
||||||
*/
|
*/
|
||||||
interface GPIOChangeEventHandler {
|
interface GPIOChangeEventHandler {
|
||||||
/** イベント */
|
/** イベント */
|
||||||
|
// biome-ignore lint/style/useShorthandFunctionType:
|
||||||
(event: GPIOChangeEvent): void;
|
(event: GPIOChangeEvent): void;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -82,10 +84,11 @@ export class GPIOAccess extends EventEmitter {
|
||||||
super();
|
super();
|
||||||
|
|
||||||
this._ports = ports == null ? new GPIOPortMap() : ports;
|
this._ports = ports == null ? new GPIOPortMap() : ports;
|
||||||
|
// biome-ignore lint/complexity/noForEach:
|
||||||
this._ports.forEach((port) =>
|
this._ports.forEach((port) =>
|
||||||
port.on('change', (event) => {
|
port.on('change', (event) => {
|
||||||
this.emit('change', event);
|
this.emit('change', event);
|
||||||
})
|
}),
|
||||||
);
|
);
|
||||||
|
|
||||||
this.on('change', (event: GPIOChangeEvent): void => {
|
this.on('change', (event: GPIOChangeEvent): void => {
|
||||||
|
@ -109,8 +112,8 @@ export class GPIOAccess extends EventEmitter {
|
||||||
async unexportAll(): Promise<void> {
|
async unexportAll(): Promise<void> {
|
||||||
await Promise.all(
|
await Promise.all(
|
||||||
[...this.ports.values()].map((port) =>
|
[...this.ports.values()].map((port) =>
|
||||||
port.exported ? port.unexport() : undefined
|
port.exported ? port.unexport() : undefined,
|
||||||
)
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -224,22 +227,23 @@ export class GPIOPort extends EventEmitter {
|
||||||
if (!this.exported) {
|
if (!this.exported) {
|
||||||
await fs.writeFile(
|
await fs.writeFile(
|
||||||
path.join(SysfsGPIOPath, 'export'),
|
path.join(SysfsGPIOPath, 'export'),
|
||||||
String(this.portNumber)
|
String(this.portNumber),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
await fs.writeFile(
|
await fs.writeFile(
|
||||||
path.join(SysfsGPIOPath, this.portName, 'direction'),
|
path.join(SysfsGPIOPath, this.portName, 'direction'),
|
||||||
direction
|
direction,
|
||||||
);
|
);
|
||||||
if (direction === 'in') {
|
if (direction === 'in') {
|
||||||
this._timeout = setInterval(
|
this._timeout = setInterval(
|
||||||
// eslint-disable-next-line
|
// eslint-disable-next-line
|
||||||
this.read.bind(this),
|
this.read.bind(this),
|
||||||
this._pollingInterval
|
this._pollingInterval,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
// biome-ignore lint/suspicious/noExplicitAny:
|
||||||
} catch (error: any) {
|
} catch (error: any) {
|
||||||
if (this._exportRetry == 0) {
|
if (this._exportRetry === 0) {
|
||||||
await sleep(100);
|
await sleep(100);
|
||||||
console.warn('May be the first time port access. Retry..');
|
console.warn('May be the first time port access. Retry..');
|
||||||
++this._exportRetry;
|
++this._exportRetry;
|
||||||
|
@ -264,8 +268,9 @@ export class GPIOPort extends EventEmitter {
|
||||||
try {
|
try {
|
||||||
await fs.writeFile(
|
await fs.writeFile(
|
||||||
path.join(SysfsGPIOPath, 'unexport'),
|
path.join(SysfsGPIOPath, 'unexport'),
|
||||||
String(this.portNumber)
|
String(this.portNumber),
|
||||||
);
|
);
|
||||||
|
// biome-ignore lint/suspicious/noExplicitAny:
|
||||||
} catch (error: any) {
|
} catch (error: any) {
|
||||||
throw new OperationError(error);
|
throw new OperationError(error);
|
||||||
}
|
}
|
||||||
|
@ -280,13 +285,13 @@ export class GPIOPort extends EventEmitter {
|
||||||
async read(): Promise<GPIOValue> {
|
async read(): Promise<GPIOValue> {
|
||||||
if (!(this.exported && this.direction === 'in')) {
|
if (!(this.exported && this.direction === 'in')) {
|
||||||
throw new InvalidAccessError(
|
throw new InvalidAccessError(
|
||||||
`The exported must be true and value of direction must be "in".`
|
`The exported must be true and value of direction must be "in".`,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const buffer = await fs.readFile(
|
const buffer = await fs.readFile(
|
||||||
path.join(SysfsGPIOPath, this.portName, 'value')
|
path.join(SysfsGPIOPath, this.portName, 'value'),
|
||||||
);
|
);
|
||||||
|
|
||||||
const value = parseUint16(buffer.toString()) as GPIOValue;
|
const value = parseUint16(buffer.toString()) as GPIOValue;
|
||||||
|
@ -297,6 +302,7 @@ export class GPIOPort extends EventEmitter {
|
||||||
}
|
}
|
||||||
|
|
||||||
return value;
|
return value;
|
||||||
|
// biome-ignore lint/suspicious/noExplicitAny:
|
||||||
} catch (error: any) {
|
} catch (error: any) {
|
||||||
throw new OperationError(error);
|
throw new OperationError(error);
|
||||||
}
|
}
|
||||||
|
@ -309,15 +315,16 @@ export class GPIOPort extends EventEmitter {
|
||||||
async write(value: GPIOValue): Promise<void> {
|
async write(value: GPIOValue): Promise<void> {
|
||||||
if (!(this.exported && this.direction === 'out')) {
|
if (!(this.exported && this.direction === 'out')) {
|
||||||
throw new InvalidAccessError(
|
throw new InvalidAccessError(
|
||||||
`The exported must be true and value of direction must be "out".`
|
`The exported must be true and value of direction must be "out".`,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
await fs.writeFile(
|
await fs.writeFile(
|
||||||
path.join(SysfsGPIOPath, this.portName, 'value'),
|
path.join(SysfsGPIOPath, this.portName, 'value'),
|
||||||
parseUint16(value.toString()).toString()
|
parseUint16(value.toString()).toString(),
|
||||||
);
|
);
|
||||||
|
// biome-ignore lint/suspicious/noExplicitAny:
|
||||||
} catch (error: any) {
|
} catch (error: any) {
|
||||||
throw new OperationError(error);
|
throw new OperationError(error);
|
||||||
}
|
}
|
||||||
|
@ -359,7 +366,7 @@ export async function requestGPIOAccess(): Promise<GPIOAccess> {
|
||||||
[...Array(GPIOPortMapSizeMax).keys()].map((portNumber) => [
|
[...Array(GPIOPortMapSizeMax).keys()].map((portNumber) => [
|
||||||
portNumber,
|
portNumber,
|
||||||
new GPIOPort(portNumber),
|
new GPIOPort(portNumber),
|
||||||
])
|
]),
|
||||||
);
|
);
|
||||||
|
|
||||||
return new GPIOAccess(ports);
|
return new GPIOAccess(ports);
|
||||||
|
|
|
@ -14,10 +14,8 @@
|
||||||
"author": "Kohei Watanabe <kou029w@gmail.com>",
|
"author": "Kohei Watanabe <kou029w@gmail.com>",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
|
"@biomejs/biome": "^1.9.3",
|
||||||
"@types/node": "^22.7.4",
|
"@types/node": "^22.7.4",
|
||||||
"@typescript-eslint/eslint-plugin": "^8.8.0",
|
|
||||||
"@typescript-eslint/parser": "^8.8.0",
|
|
||||||
"eslint": "^9.11.1",
|
|
||||||
"husky": "^9.1.6",
|
"husky": "^9.1.6",
|
||||||
"lint-staged": "^15.2.10",
|
"lint-staged": "^15.2.10",
|
||||||
"prettier": "^3.3.3",
|
"prettier": "^3.3.3",
|
||||||
|
@ -26,7 +24,7 @@
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"build": "tsc",
|
"build": "tsc",
|
||||||
"lint": "eslint index.ts",
|
"lint": "biome lint index.ts",
|
||||||
"prepare": "husky install && rm -rf dist && npm run build",
|
"prepare": "husky install && rm -rf dist && npm run build",
|
||||||
"precommit": "lint-staged",
|
"precommit": "lint-staged",
|
||||||
"docs": "npm run remove:docs && npm run typedoc -- --options typedoc.json --exclude '**/*.spec.ts' ./ README.md",
|
"docs": "npm run remove:docs && npm run typedoc -- --options typedoc.json --exclude '**/*.spec.ts' ./ README.md",
|
||||||
|
|
Loading…
Add table
Reference in a new issue