- web/: Vue 3 + Vite + UnoCSS + Pinia, dark tactical theme (amber/#0d1117) - AppNav, ListingCard, SearchView with filters/sort, composables (useSnipeMode, useKonamiCode, useMotion), Pinia search store - Steal shimmer, auction countdown, Snipe Mode easter egg all native in Vue - docker/web/: nginx + multi-stage Dockerfile (node build → nginx serve) - compose.yml: api (8510) + web (8509) services - Dockerfile CMD updated to uvicorn for upcoming FastAPI layer - Clean build: 0 TS errors, 380 modules
33 lines
750 B
JavaScript
33 lines
750 B
JavaScript
import { Comment } from '../../tokenizer/index.js';
|
|
|
|
const ASTERISK = 0x002A; // U+002A ASTERISK (*)
|
|
const SOLIDUS = 0x002F; // U+002F SOLIDUS (/)
|
|
|
|
|
|
export const name = 'Comment';
|
|
export const structure = {
|
|
value: String
|
|
};
|
|
|
|
export function parse() {
|
|
const start = this.tokenStart;
|
|
let end = this.tokenEnd;
|
|
|
|
this.eat(Comment);
|
|
|
|
if ((end - start + 2) >= 2 &&
|
|
this.charCodeAt(end - 2) === ASTERISK &&
|
|
this.charCodeAt(end - 1) === SOLIDUS) {
|
|
end -= 2;
|
|
}
|
|
|
|
return {
|
|
type: 'Comment',
|
|
loc: this.getLocation(start, this.tokenStart),
|
|
value: this.substring(start + 2, end)
|
|
};
|
|
}
|
|
|
|
export function generate(node) {
|
|
this.token(Comment, '/*' + node.value + '*/');
|
|
}
|