forked from mikael-lovqvist/fa2json
Compare commits
3 Commits
448e27ed8e
...
331d9bd357
| Author | SHA1 | Date | |
|---|---|---|---|
| 331d9bd357 | |||
| 068d6963a1 | |||
| d2171d59a6 |
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@@ -0,0 +1 @@
|
||||
build/
|
||||
9
Makefile
9
Makefile
@@ -1,7 +1,9 @@
|
||||
SHELL := /bin/bash
|
||||
CC := cc
|
||||
CFLAGS := -Wall -O2
|
||||
TARGET := fa2json
|
||||
MKDIR := mkdir
|
||||
CFLAGS := -Wall -Werror -Os
|
||||
BUILD_DIR := build
|
||||
TARGET := $(BUILD_DIR)/fa2json
|
||||
SRCS := fs-watcher.c json-writer.c
|
||||
|
||||
.PHONY: all test dev clean
|
||||
@@ -9,6 +11,7 @@ SRCS := fs-watcher.c json-writer.c
|
||||
all: $(TARGET)
|
||||
|
||||
$(TARGET): $(SRCS)
|
||||
$(MKDIR) -p $(BUILD_DIR)
|
||||
$(CC) $(CFLAGS) -o $@ $^
|
||||
|
||||
test: $(TARGET)
|
||||
@@ -18,4 +21,4 @@ dev: $(TARGET)
|
||||
node test/dev.mjs $(ARGS)
|
||||
|
||||
clean:
|
||||
rm -f $(TARGET)
|
||||
rm -rf $(BUILD_DIR)
|
||||
|
||||
@@ -58,7 +58,7 @@ static void handle_events(int fafd, int mount_fd) {
|
||||
clock_gettime(CLOCK_MONOTONIC, &mono);
|
||||
clock_gettime(CLOCK_REALTIME, &wall);
|
||||
|
||||
fprintf(stdout, "{\"ts\": [%i, %i, %i, %i]", wall.tv_sec, wall.tv_nsec, mono.tv_sec, mono.tv_nsec);
|
||||
fprintf(stdout, "{\"ts\": [%li, %li, %li, %li]", wall.tv_sec, wall.tv_nsec, mono.tv_sec, mono.tv_nsec);
|
||||
|
||||
char *ptr = (char *)(metadata + 1);
|
||||
char *end = (char *)metadata + metadata->event_len;
|
||||
@@ -98,7 +98,7 @@ static void handle_events(int fafd, int mount_fd) {
|
||||
}
|
||||
|
||||
if (entry_index++) { fprintf(stdout, ", "); }
|
||||
fprintf(stdout, ", \"mask\": %i}\n", metadata->mask);
|
||||
fprintf(stdout, ", \"mask\": %lli}\n", metadata->mask);
|
||||
|
||||
metadata = FAN_EVENT_NEXT(metadata, size);
|
||||
|
||||
|
||||
@@ -1,34 +1,31 @@
|
||||
import { execSync, spawn } from 'node:child_process';
|
||||
import { mkdtempSync, mkdirSync } from 'node:fs';
|
||||
import { tmpdir } from 'node:os';
|
||||
import { execFileSync, spawn } from 'node:child_process';
|
||||
import { join } from 'node:path';
|
||||
|
||||
const FA2JSON = new URL('../../fa2json', import.meta.url).pathname;
|
||||
const FA2JSON = new URL('../../build/fa2json', import.meta.url).pathname;
|
||||
|
||||
export async function setup() {
|
||||
// Create image file and format
|
||||
const img = execSync('mktemp /tmp/fa2json-test-XXXXXX.img').toString().trim();
|
||||
execSync(`truncate -s 10M ${img}`);
|
||||
execSync(`mkfs.ext4 -q ${img}`);
|
||||
const img = execFileSync('mktemp', ['/tmp/fa2json-test-XXXXXX.img']).toString().trim();
|
||||
execFileSync('truncate', ['-s', '10M', img]);
|
||||
execFileSync('mkfs.ext4', ['-q', img]);
|
||||
|
||||
// Create mount point and mount
|
||||
const mnt = execSync('mktemp -d /tmp/fa2json-mnt-XXXXXX').toString().trim();
|
||||
execSync(`sudo mount ${img} ${mnt}`);
|
||||
const mnt = execFileSync('mktemp', ['-d', '/tmp/fa2json-mnt-XXXXXX']).toString().trim();
|
||||
execFileSync('sudo', ['mount', img, mnt]);
|
||||
|
||||
// Hand ownership to current user, then sync before fa2json starts
|
||||
execSync(`sudo chown ${process.getuid()} ${mnt}`);
|
||||
execSync('sync');
|
||||
execFileSync('sudo', ['chown', String(process.getuid()), mnt]);
|
||||
execFileSync('sync');
|
||||
|
||||
async function teardown() {
|
||||
try { execSync(`sudo umount ${mnt}`); } catch {}
|
||||
try { execSync(`rm -f ${img}`); } catch {}
|
||||
try { execSync(`rmdir ${mnt}`); } catch {}
|
||||
try { execFileSync('sudo', ['umount', mnt]); } catch {}
|
||||
try { execFileSync('rm', ['-f', img]); } catch {}
|
||||
try { execFileSync('rmdir', [mnt]); } catch {}
|
||||
}
|
||||
|
||||
return { img, mnt, teardown };
|
||||
}
|
||||
|
||||
export function spawnFa2json(mnt) {
|
||||
const proc = spawn('sudo', [FA2JSON, mnt], { stdio: ['ignore', 'pipe', 'inherit'] });
|
||||
return proc;
|
||||
return spawn('sudo', [FA2JSON, mnt], { stdio: ['ignore', 'pipe', 'inherit'] });
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user