- ✅ Ticket 1.1: Estructura Clean Architecture en backend - ✅ Ticket 1.2: Schemas Zod compartidos - ✅ Ticket 1.3: Refactorización drugs.ts (1362 → 8 archivos modulares) - ✅ Ticket 1.4: Refactorización procedures.ts (3583 → 6 archivos modulares) - ✅ Ticket 1.5: Eliminación de duplicidades (~50 líneas) Cambios principales: - Creada estructura Clean Architecture en backend/src/ - Schemas Zod compartidos en backend/src/shared/schemas/ - Refactorización modular de drugs y procedures - Utilidades genéricas en src/utils/ (filter, validation) - Eliminados scripts obsoletos y documentación antigua - Corregidos errores: QueryClient, import test-error-handling - Build verificado y funcionando correctamente
64 lines
1.5 KiB
JavaScript
64 lines
1.5 KiB
JavaScript
/**
|
|
* @import {Effects, State, TokenType} from 'micromark-util-types'
|
|
*/
|
|
|
|
import { markdownSpace } from 'micromark-util-character';
|
|
|
|
// To do: implement `spaceOrTab`, `spaceOrTabMinMax`, `spaceOrTabWithOptions`.
|
|
|
|
/**
|
|
* Parse spaces and tabs.
|
|
*
|
|
* There is no `nok` parameter:
|
|
*
|
|
* * spaces in markdown are often optional, in which case this factory can be
|
|
* used and `ok` will be switched to whether spaces were found or not
|
|
* * one line ending or space can be detected with `markdownSpace(code)` right
|
|
* before using `factorySpace`
|
|
*
|
|
* ###### Examples
|
|
*
|
|
* Where `␉` represents a tab (plus how much it expands) and `␠` represents a
|
|
* single space.
|
|
*
|
|
* ```markdown
|
|
* ␉
|
|
* ␠␠␠␠
|
|
* ␉␠
|
|
* ```
|
|
*
|
|
* @param {Effects} effects
|
|
* Context.
|
|
* @param {State} ok
|
|
* State switched to when successful.
|
|
* @param {TokenType} type
|
|
* Type (`' \t'`).
|
|
* @param {number | undefined} [max=Infinity]
|
|
* Max (exclusive).
|
|
* @returns {State}
|
|
* Start state.
|
|
*/
|
|
export function factorySpace(effects, ok, type, max) {
|
|
const limit = max ? max - 1 : Number.POSITIVE_INFINITY;
|
|
let size = 0;
|
|
return start;
|
|
|
|
/** @type {State} */
|
|
function start(code) {
|
|
if (markdownSpace(code)) {
|
|
effects.enter(type);
|
|
return prefix(code);
|
|
}
|
|
return ok(code);
|
|
}
|
|
|
|
/** @type {State} */
|
|
function prefix(code) {
|
|
if (markdownSpace(code) && size++ < limit) {
|
|
effects.consume(code);
|
|
return prefix;
|
|
}
|
|
effects.exit(type);
|
|
return ok(code);
|
|
}
|
|
} |