- Delete old Vite+Svelte frontend - Initialize new SvelteKit project with TypeScript - Configure Tailwind CSS v4 + DaisyUI - Implement JWT authentication with auto-refresh - Create login page with form validation (Zod) - Add protected route guards - Update Docker configuration for single-stage build - Add E2E tests with Playwright (6/11 passing) - Fix Svelte 5 reactivity with $state() runes Known issues: - 5 E2E tests failing (timing/async issues) - Token refresh implementation needs debugging - Validation error display timing
19 lines
665 B
JavaScript
19 lines
665 B
JavaScript
import { buildCharacterArbitrary } from './_internals/builders/CharacterArbitraryBuilder.js';
|
|
import { indexToPrintableIndexMapper, indexToPrintableIndexUnmapper } from './_internals/mappers/IndexToPrintableIndex.js';
|
|
const gapSize = 0xdfff + 1 - 0xd800;
|
|
function unicodeMapper(v) {
|
|
if (v < 0xd800)
|
|
return indexToPrintableIndexMapper(v);
|
|
return v + gapSize;
|
|
}
|
|
function unicodeUnmapper(v) {
|
|
if (v < 0xd800)
|
|
return indexToPrintableIndexUnmapper(v);
|
|
if (v <= 0xdfff)
|
|
return -1;
|
|
return v - gapSize;
|
|
}
|
|
export function unicode() {
|
|
return buildCharacterArbitrary(0x0000, 0xffff - gapSize, unicodeMapper, unicodeUnmapper);
|
|
}
|