@riotprompt/riotprompt 0.0.1 → 0.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/logger.js +4 -2
- package/dist/logger.js.map +1 -1
- package/dist/riotprompt.cjs +104 -102
- package/dist/riotprompt.cjs.map +1 -1
- package/package.json +16 -14
- package/vite.config.ts +2 -2
- package/dist/builder.cjs +0 -152
- package/dist/builder.cjs.map +0 -1
- package/dist/chat.cjs +0 -26
- package/dist/chat.cjs.map +0 -1
- package/dist/constants.cjs +0 -34
- package/dist/constants.cjs.map +0 -1
- package/dist/formatter.cjs +0 -139
- package/dist/formatter.cjs.map +0 -1
- package/dist/items/content.cjs +0 -14
- package/dist/items/content.cjs.map +0 -1
- package/dist/items/context.cjs +0 -13
- package/dist/items/context.cjs.map +0 -1
- package/dist/items/instruction.cjs +0 -13
- package/dist/items/instruction.cjs.map +0 -1
- package/dist/items/parameters.cjs +0 -53
- package/dist/items/parameters.cjs.map +0 -1
- package/dist/items/section.cjs +0 -120
- package/dist/items/section.cjs.map +0 -1
- package/dist/items/trait.cjs +0 -13
- package/dist/items/trait.cjs.map +0 -1
- package/dist/items/weighted.cjs +0 -27
- package/dist/items/weighted.cjs.map +0 -1
- package/dist/loader.cjs +0 -167
- package/dist/loader.cjs.map +0 -1
- package/dist/logger.cjs +0 -51
- package/dist/logger.cjs.map +0 -1
- package/dist/override.cjs +0 -109
- package/dist/override.cjs.map +0 -1
- package/dist/parse/markdown.cjs +0 -114
- package/dist/parse/markdown.cjs.map +0 -1
- package/dist/parse/text.cjs +0 -33
- package/dist/parse/text.cjs.map +0 -1
- package/dist/parser.cjs +0 -99
- package/dist/parser.cjs.map +0 -1
- package/dist/prompt.cjs +0 -15
- package/dist/prompt.cjs.map +0 -1
- package/dist/util/general.cjs +0 -52
- package/dist/util/general.cjs.map +0 -1
- package/dist/util/markdown.cjs +0 -115
- package/dist/util/markdown.cjs.map +0 -1
- package/dist/util/storage.cjs +0 -155
- package/dist/util/storage.cjs.map +0 -1
- package/dist/util/text.cjs +0 -42
- package/dist/util/text.cjs.map +0 -1
package/dist/riotprompt.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"riotprompt.cjs","sources":["../src/items/parameters.ts","../src/items/weighted.ts","../src/items/content.ts","../src/items/context.ts","../src/items/instruction.ts","../src/items/section.ts","../src/items/trait.ts","../src/prompt.ts","../src/constants.ts","../src/chat.ts","../src/logger.ts","../src/util/general.ts","../src/formatter.ts","../src/parse/markdown.ts","../src/parse/text.ts","../src/util/markdown.ts","../src/util/text.ts","../src/parser.ts","../src/util/storage.ts","../src/loader.ts","../src/override.ts","../src/builder.ts"],"sourcesContent":["import { z } from \"zod\";\n\nexport const ParametersSchema = z.record(z.string(), z.union([z.string(), z.number(), z.boolean(), z.array(z.union([z.string(), z.number(), z.boolean()]))]));\n\nexport type Parameters = z.infer<typeof ParametersSchema>;\n\nexport const create = (parameters: Parameters): Parameters => {\n return parameters;\n}\n\nexport const apply = (text: string, parameters?: Parameters): string => {\n if (!parameters) {\n return text;\n }\n\n // First, trim parameters keys to handle whitespace in placeholder names\n const trimmedParams: Record<string, any> = {};\n Object.keys(parameters).forEach(key => {\n trimmedParams[key.trim()] = parameters[key];\n });\n\n // Process all placeholders, preserving ones that don't have matching parameters\n return text.replace(/\\{\\{([^{}]+)\\}\\}/g, (match, p1) => {\n const paramKey = p1.trim();\n const parameter = trimmedParams[paramKey];\n\n if (parameter === undefined) {\n // Preserve the original placeholder if parameter doesn't exist\n return match;\n } else if (typeof parameter === 'string') {\n return parameter;\n } else if (typeof parameter === 'number') {\n return parameter.toString();\n } else if (typeof parameter === 'boolean') {\n return parameter.toString();\n } else if (Array.isArray(parameter)) {\n return parameter.join(', ');\n } else {\n return match;\n }\n });\n}","import { z } from \"zod\";\nimport { ParametersSchema, apply as applyParameters } from \"./parameters\";\n\nexport const WeightedSchema = z.object({\n text: z.string(),\n weight: z.number().optional(),\n});\n\nexport type Weighted = z.infer<typeof WeightedSchema>;\n\nexport const WeightedOptionsSchema = z.object({\n weight: z.number().optional(),\n parameters: ParametersSchema.optional(),\n});\n\nexport type WeightedOptions = z.infer<typeof WeightedOptionsSchema>;\n\n\nexport const create = <T extends Weighted>(\n text: string,\n options: Partial<WeightedOptions> = {}\n): T => {\n const weightedOptions = WeightedOptionsSchema.parse(options);\n const parameterizedText = applyParameters(text, weightedOptions.parameters);\n\n return {\n text: parameterizedText,\n weight: weightedOptions.weight,\n } as T;\n}","import { Weighted, WeightedOptions, WeightedOptionsSchema, create as createWeighted } from \"./weighted\";\n\n// Define Content as a type alias for Weighted\nexport type Content = Weighted;\n\n// Export create function\nexport const create = (text: string, options: Partial<WeightedOptions> = {}): Content => {\n const weightedOptions = WeightedOptionsSchema.parse(options);\n return createWeighted<Content>(text, weightedOptions);\n}\n\n","import { Weighted, WeightedOptions, WeightedOptionsSchema, create as createWeighted } from \"./weighted\";\n\nexport type Context = Weighted;\n\nexport const create = (text: string, options: Partial<WeightedOptions> = {}): Context => {\n const weightedOptions = WeightedOptionsSchema.parse(options);\n return createWeighted<Context>(text, weightedOptions);\n}\n\n","import { Weighted, WeightedOptions, WeightedOptionsSchema, create as createWeighted } from \"./weighted\";\n\nexport type Instruction = Weighted;\n\nexport const create = (text: string, options: Partial<WeightedOptions> = {}): Instruction => {\n const weightedOptions = WeightedOptionsSchema.parse(options);\n return createWeighted<Instruction>(text, weightedOptions);\n}","import { z } from \"zod\";\nimport { ParametersSchema } from \"./parameters\";\nimport { Weighted, WeightedOptions, WeightedOptionsSchema, create as createWeighted } from \"./weighted\";\n\nexport interface Section<T extends Weighted> {\n title?: string;\n items: (T | Section<T>)[];\n weight?: number;\n add: (\n item: T | T[] | Section<T> | Section<T>[] | string | string[],\n options?: Partial<WeightedOptions>\n ) => Section<T>;\n append: (\n item: T | T[] | Section<T> | Section<T>[] | string | string[],\n options?: Partial<WeightedOptions>\n ) => Section<T>;\n prepend: (\n item: T | T[] | Section<T> | Section<T>[] | string | string[],\n options?: Partial<WeightedOptions>\n ) => Section<T>;\n insert: (\n index: number,\n item: T | T[] | Section<T> | Section<T>[] | string | string[],\n options?: Partial<WeightedOptions>\n ) => Section<T>;\n replace: (\n index: number,\n item: T | Section<T> | string,\n options?: Partial<WeightedOptions>\n ) => Section<T>;\n remove: (index: number) => Section<T>;\n}\n\nexport const SectionOptionsSchema = z.object({\n title: z.string().optional(),\n weight: z.number().optional(),\n itemWeight: z.number().optional(),\n parameters: ParametersSchema.optional().default({}),\n});\n\nexport type SectionOptions = z.infer<typeof SectionOptionsSchema>;\n\nexport const isSection = (object: any): boolean => {\n return object !== undefined && object != null && typeof object === 'object' && 'items' in object;\n}\n\nexport const convertToSection = (\n object: any,\n options: Partial<SectionOptions> = {}\n): Section<Weighted> => {\n const sectionOptions = SectionOptionsSchema.parse(options);\n\n const weightedOptions = WeightedOptionsSchema.parse({\n ...sectionOptions,\n weight: sectionOptions.itemWeight,\n });\n\n if (isSection(object)) {\n const section = create({ ...sectionOptions, title: object.title });\n object.items.forEach((item: any) => {\n if (isSection(item)) {\n section.append(convertToSection(item, sectionOptions));\n } else {\n section.append(createWeighted(item.text, weightedOptions));\n }\n });\n return section;\n } else {\n throw new Error('Object is not a section');\n }\n}\n\nexport const create = <T extends Weighted>(\n options: Partial<SectionOptions> = {}\n): Section<T> => {\n const items: (T | Section<T>)[] = [];\n const sectionOptions = SectionOptionsSchema.parse(options);\n\n const sectionItemOptions = WeightedOptionsSchema.parse({\n ...sectionOptions,\n weight: sectionOptions.itemWeight,\n });\n\n const append = (item: T | T[] | Section<T> | Section<T>[] | string | string[], options: Partial<WeightedOptions> = {}): Section<T> => {\n let itemOptions: WeightedOptions = WeightedOptionsSchema.parse(options);\n itemOptions = { ...sectionItemOptions, ...itemOptions };\n\n if (Array.isArray(item)) {\n item.forEach((item) => {\n append(item);\n });\n } else {\n if (typeof item === 'string') {\n items.push(createWeighted<T>(item, itemOptions));\n } else {\n items.push(item);\n }\n }\n return section;\n }\n\n const prepend = (item: T | T[] | Section<T> | Section<T>[] | string | string[], options: Partial<WeightedOptions> = {}): Section<T> => {\n let itemOptions: WeightedOptions = WeightedOptionsSchema.parse(options);\n itemOptions = { ...sectionItemOptions, ...itemOptions };\n\n if (Array.isArray(item)) {\n item.forEach((item) => {\n prepend(item);\n });\n } else {\n if (typeof item === 'string') {\n items.unshift(createWeighted<T>(item, itemOptions));\n } else {\n items.unshift(item);\n }\n }\n return section;\n }\n\n const insert = (index: number, item: T | T[] | Section<T> | Section<T>[] | string | string[], options: Partial<WeightedOptions> = {}): Section<T> => {\n let itemOptions: WeightedOptions = WeightedOptionsSchema.parse(options);\n itemOptions = { ...sectionItemOptions, ...itemOptions };\n\n if (Array.isArray(item)) {\n item.forEach((item) => {\n insert(index, item);\n });\n } else {\n if (typeof item === 'string') {\n items.splice(index, 0, createWeighted<T>(item, itemOptions));\n } else {\n items.splice(index, 0, item);\n }\n }\n return section;\n }\n\n const remove = (index: number): Section<T> => {\n items.splice(index, 1);\n return section;\n }\n\n const replace = (index: number, item: T | Section<T> | string, options: Partial<WeightedOptions> = {}): Section<T> => {\n let itemOptions: WeightedOptions = WeightedOptionsSchema.parse(options);\n itemOptions = { ...sectionItemOptions, ...itemOptions };\n\n if (typeof item === 'string') {\n items[index] = createWeighted<T>(item, itemOptions);\n } else {\n items[index] = item;\n }\n return section;\n }\n\n const add = (item: T | T[] | Section<T> | Section<T>[] | string | string[], options: Partial<WeightedOptions> = {}): Section<T> => {\n let itemOptions: WeightedOptions = WeightedOptionsSchema.parse(options);\n itemOptions = { ...sectionItemOptions, ...itemOptions };\n\n return append(item, itemOptions);\n }\n\n const section: Section<T> = {\n title: sectionOptions.title,\n items,\n weight: sectionOptions.weight,\n add,\n append,\n prepend,\n insert,\n remove,\n replace,\n }\n\n return section;\n}\n\n\n","import { Weighted, WeightedOptions, WeightedOptionsSchema, create as createWeighted } from \"./weighted\";\n\nexport type Trait = Weighted;\n\nexport const create = (text: string, options: WeightedOptions = {}): Trait => {\n const weightedOptions = WeightedOptionsSchema.parse(options);\n return createWeighted<Trait>(text, weightedOptions);\n}","import { Content } from \"./items/content\";\nimport { Context } from \"./items/context\";\nimport { Instruction } from \"./items/instruction\";\nimport { Section } from \"./items/section\";\n\nexport interface Prompt {\n persona?: Section<Instruction>;\n instructions: Section<Instruction>;\n contents?: Section<Content>;\n contexts?: Section<Context>;\n}\n\nexport const create = ({\n persona,\n instructions,\n contents,\n contexts,\n}: {\n persona?: Section<Instruction>,\n instructions: Section<Instruction>,\n contents?: Section<Content>,\n contexts?: Section<Context>\n}): Prompt => {\n\n return {\n persona,\n instructions,\n contents,\n contexts,\n }\n}","import { SectionSeparator } from \"formatter\";\n\nimport { FormatOptions } from \"formatter\";\n\nexport const DEFAULT_CHARACTER_ENCODING = \"utf8\";\nexport const LIBRARY_NAME = \"riotprompt\";\n\nexport const DEFAULT_PERSONA_ROLE = \"developer\";\n\nexport const DEFAULT_INSTRUCTIONS_AREA_TITLE = \"Instructions\";\nexport const DEFAULT_CONTENTS_AREA_TITLE = \"Contents\";\nexport const DEFAULT_CONTEXT_AREA_TITLE = \"Context\";\n\nexport const DEFAULT_IGNORE_PATTERNS: string[] = [\n \"^\\\\..*\", // Hidden files (e.g., .git, .DS_Store)\n \"\\\\.(jpg|jpeg|png|gif|bmp|svg|webp|ico)$\", // Image files\n \"\\\\.(mp3|wav|ogg|aac|flac)$\", // Audio files\n \"\\\\.(mp4|mov|avi|mkv|webm)$\", // Video files\n \"\\\\.(pdf|doc|docx|xls|xlsx|ppt|pptx)$\", // Document files\n \"\\\\.(zip|tar|gz|rar|7z)$\" // Compressed files\n];\n\nexport const DEFAULT_SECTION_SEPARATOR: SectionSeparator = \"tag\";\nexport const DEFAULT_SECTION_INDENTATION = true;\nexport const DEFAULT_SECTION_TAG = \"section\";\nexport const DEFAULT_SECTION_TITLE_PROPERTY = \"title\";\n\nexport const DEFAULT_FORMAT_OPTIONS: FormatOptions = {\n sectionSeparator: DEFAULT_SECTION_SEPARATOR,\n sectionIndentation: DEFAULT_SECTION_INDENTATION,\n sectionTitleProperty: DEFAULT_SECTION_TITLE_PROPERTY,\n sectionDepth: 0,\n}\n","import { DEFAULT_PERSONA_ROLE } from \"./constants\";\n\nexport type Role = \"user\" | \"assistant\" | \"system\" | \"developer\";\n\nexport type Model = \"gpt-4o\" | \"gpt-4o-mini\" | \"o1-preview\" | \"o1-mini\" | \"o1\" | \"o3-mini\" | \"o1-pro\";\n\nexport interface Message {\n role: Role;\n content: string | string[];\n name?: string;\n}\n\nexport interface Request {\n messages: Message[];\n model: Model;\n\n addMessage(message: Message): void;\n}\n\nexport const getPersonaRole = (model: Model): Role => {\n if (model === \"gpt-4o\" || model === \"gpt-4o-mini\") {\n return \"system\";\n }\n return DEFAULT_PERSONA_ROLE;\n}\n\nexport const createRequest = (model: Model): Request => {\n const messages: Message[] = [];\n\n return {\n model,\n messages,\n addMessage: (message: Message) => {\n messages.push(message);\n }\n }\n}\n","/* eslint-disable no-console */\nimport { LIBRARY_NAME } from \"./constants\";\n\nexport interface Logger {\n name: string;\n debug: (message: string, ...args: any[]) => void;\n info: (message: string, ...args: any[]) => void;\n warn: (message: string, ...args: any[]) => void;\n error: (message: string, ...args: any[]) => void;\n verbose: (message: string, ...args: any[]) => void;\n silly: (message: string, ...args: any[]) => void;\n}\n\nexport const DEFAULT_LOGGER: Logger = {\n name: 'default',\n debug: (message: string, ...args: any[]) => console.debug(message, ...args),\n info: (message: string, ...args: any[]) => console.info(message, ...args),\n warn: (message: string, ...args: any[]) => console.warn(message, ...args),\n error: (message: string, ...args: any[]) => console.error(message, ...args),\n verbose: (message: string, ...args: any[]) => console.log(message, ...args),\n silly: (message: string, ...args: any[]) => console.log(message, ...args),\n}\n\nexport const wrapLogger = (toWrap: Logger, name?: string): Logger => {\n\n const requiredMethods: (keyof Logger)[] = ['debug', 'info', 'warn', 'error', 'verbose', 'silly'];\n const missingMethods = requiredMethods.filter(method => typeof toWrap[method] !== 'function');\n\n if (missingMethods.length > 0) {\n throw new Error(`Logger is missing required methods: ${missingMethods.join(', ')}`);\n }\n\n const log = (level: keyof Logger, message: string, ...args: any[]) => {\n message = `[${LIBRARY_NAME}] ${name ? `[${name}]` : ''}: ${message}`;\n\n if (level === 'debug') toWrap.debug(message, ...args);\n else if (level === 'info') toWrap.info(message, ...args);\n else if (level === 'warn') toWrap.warn(message, ...args);\n else if (level === 'error') toWrap.error(message, ...args);\n else if (level === 'verbose') toWrap.verbose(message, ...args);\n else if (level === 'silly') toWrap.silly(message, ...args);\n }\n\n return {\n name: 'wrapped',\n debug: (message: string, ...args: any[]) => log('debug', message, ...args),\n info: (message: string, ...args: any[]) => log('info', message, ...args),\n warn: (message: string, ...args: any[]) => log('warn', message, ...args),\n error: (message: string, ...args: any[]) => log('error', message, ...args),\n verbose: (message: string, ...args: any[]) => log('verbose', message, ...args),\n silly: (message: string, ...args: any[]) => log('silly', message, ...args),\n }\n}","export const clean = (obj: any) => {\n return Object.fromEntries(\n Object.entries(obj).filter(([_, v]) => v !== undefined)\n );\n}\n\n//Recursive implementation of jSON.stringify;\nexport const stringifyJSON = function (obj: any, visited: Set<any> = new Set()): string {\n const arrOfKeyVals: string[] = [];\n const arrVals: string[] = [];\n let objKeys: string[] = [];\n\n /*********CHECK FOR PRIMITIVE TYPES**********/\n if (typeof obj === 'number' || typeof obj === 'boolean' || obj === null)\n return '' + obj;\n else if (typeof obj === 'string')\n return '\"' + obj + '\"';\n\n /*********DETECT CIRCULAR REFERENCES**********/\n if (obj instanceof Object && visited.has(obj)) {\n return '\"(circular)\"';\n }\n\n /*********CHECK FOR ARRAY**********/\n else if (Array.isArray(obj)) {\n //check for empty array\n if (obj[0] === undefined)\n return '[]';\n else {\n // Add array to visited before processing its elements\n visited.add(obj);\n obj.forEach(function (el) {\n arrVals.push(stringifyJSON(el, visited));\n });\n return '[' + arrVals + ']';\n }\n }\n /*********CHECK FOR OBJECT**********/\n else if (obj instanceof Object) {\n // Add object to visited before processing its properties\n visited.add(obj);\n //get object keys\n objKeys = Object.keys(obj);\n //set key output;\n objKeys.forEach(function (key) {\n const keyOut = '\"' + key + '\":';\n const keyValOut = obj[key];\n //skip functions and undefined properties\n if (keyValOut instanceof Function || keyValOut === undefined)\n return; // Skip this entry entirely instead of pushing an empty string\n else if (typeof keyValOut === 'string')\n arrOfKeyVals.push(keyOut + '\"' + keyValOut + '\"');\n else if (typeof keyValOut === 'boolean' || typeof keyValOut === 'number' || keyValOut === null)\n arrOfKeyVals.push(keyOut + keyValOut);\n //check for nested objects, call recursively until no more objects\n else if (keyValOut instanceof Object) {\n arrOfKeyVals.push(keyOut + stringifyJSON(keyValOut, visited));\n }\n });\n return '{' + arrOfKeyVals + '}';\n }\n return '';\n};","import { Instruction } from \"riotprompt\";\nimport { z } from \"zod\";\nimport * as Chat from \"./chat\";\nimport { getPersonaRole, Message, Model } from \"./chat\";\nimport { DEFAULT_FORMAT_OPTIONS } from \"./constants\";\nimport { Section } from \"./items/section\";\nimport { Weighted } from \"./items/weighted\";\nimport { DEFAULT_LOGGER, wrapLogger } from \"./logger\";\nimport { Prompt } from \"./prompt\";\nimport { clean, stringifyJSON } from \"./util/general\";\n\nexport const SectionSeparatorSchema = z.enum([\"tag\", \"markdown\"]);\nexport const SectionTitlePropertySchema = z.enum([\"title\", \"name\"]);\n\nexport type SectionSeparator = z.infer<typeof SectionSeparatorSchema>;\nexport type SectionTitleProperty = z.infer<typeof SectionTitlePropertySchema>;\n\n\nexport const FormatOptionsSchema = z.object({\n sectionSeparator: SectionSeparatorSchema,\n sectionIndentation: z.boolean(),\n sectionTitleProperty: SectionTitlePropertySchema,\n sectionTitlePrefix: z.string().optional(),\n sectionTitleSeparator: z.string().optional(),\n sectionDepth: z.number().default(1),\n});\n\nexport type FormatOptions = z.infer<typeof FormatOptionsSchema>;\n\n\nexport const OptionSchema = z.object({\n logger: z.any().optional().default(DEFAULT_LOGGER),\n formatOptions: FormatOptionsSchema.partial().optional().default(DEFAULT_FORMAT_OPTIONS),\n});\n\nexport type Options = z.infer<typeof OptionSchema>;\n\nexport type OptionsParam = Partial<Options>;\n\nexport interface Instance {\n formatPersona: (model: Model, persona: Section<Instruction>) => Message;\n format: <T extends Weighted>(weightedText: T | Section<T>, sectionDepth?: number) => string;\n formatArray: <T extends Weighted>(items: (T | Section<T>)[], sectionDepth?: number) => string;\n formatPrompt: (model: Model, prompt: Prompt) => Chat.Request;\n}\n\n// Type guard to check if an object is a Section\nfunction isSection<T extends Weighted>(obj: T | Section<T>): obj is Section<T> {\n return obj && typeof obj === 'object' && 'items' in obj && Array.isArray((obj as Section<T>).items);\n}\n\n// Type guard to check if an object is a Section\nfunction isWeighted<T extends Weighted>(obj: T | Section<T>): obj is T {\n return obj && typeof obj === 'object' && 'text' in obj;\n}\n\n\nexport const create = (formatterOptions?: OptionsParam): Instance => {\n const options: Required<Options> = OptionSchema.parse(formatterOptions || {}) as Required<Options>;\n\n const logger = wrapLogger(options.logger, 'Formatter');\n\n let formatOptions: FormatOptions = DEFAULT_FORMAT_OPTIONS;\n if (options?.formatOptions) {\n formatOptions = {\n ...formatOptions,\n ...clean(options.formatOptions),\n };\n }\n\n const formatPersona = (model: Model, persona: Section<Instruction>): Message => {\n logger.silly(`Formatting persona`);\n if (persona) {\n const formattedPersona = formatSection(persona);\n\n return {\n role: getPersonaRole(model),\n content: `${formattedPersona}`,\n }\n } else {\n throw new Error(\"Persona is required\");\n }\n }\n\n const format = <T extends Weighted>(\n item: T | Section<T>,\n sectionDepth?: number,\n ): string => {\n logger.silly(`Formatting ${isSection(item) ? \"section\" : \"item\"} Item: %s`, stringifyJSON(item));\n const currentSectionDepth = sectionDepth ?? formatOptions.sectionDepth;\n logger.silly(`\\t\\tCurrent section depth: ${currentSectionDepth}`);\n\n let result: string = \"\";\n if (isSection(item)) {\n result = formatSection(item, currentSectionDepth + 1);\n } else if (isWeighted(item)) {\n result = item.text;\n } else {\n //If the item is neither a section nor a weighted item, it is empty.\n result = '';\n }\n return result;\n }\n\n const formatSection = <T extends Weighted>(section: Section<T>, sectionDepth?: number): string => {\n logger.silly(`Formatting section`);\n const currentSectionDepth = sectionDepth ?? formatOptions.sectionDepth;\n logger.silly(`\\t\\tCurrent section depth: ${currentSectionDepth}`);\n\n if (section) {\n const formattedItems = section.items.map(item => format(item, currentSectionDepth)).join(\"\\n\\n\");\n\n if (formatOptions.sectionSeparator === \"tag\") {\n return `<${section.title ?? \"section\"}>\\n${formattedItems}\\n</${section.title ?? \"section\"}>`;\n } else {\n // Default depth to 1 if not provided, resulting in H2 (##) matching the test case.\n const headingLevel = currentSectionDepth;\n const hashes = '#'.repeat(headingLevel);\n logger.silly(`\\t\\tHeading level: ${headingLevel}`);\n logger.silly(`\\t\\tSection title: ${section.title}`);\n return `${hashes} ${formatOptions.sectionTitlePrefix ? `${formatOptions.sectionTitlePrefix} ${formatOptions.sectionTitleSeparator} ` : \"\"}${section.title}\\n\\n${formattedItems}`;\n }\n } else {\n return '';\n }\n }\n\n // Helper function to format arrays of items or sections\n const formatArray = <T extends Weighted>(\n items: (T | Section<T>)[],\n sectionDepth?: number\n ): string => {\n logger.silly(`Formatting array`);\n const currentSectionDepth = sectionDepth ?? formatOptions.sectionDepth;\n return items.map(item => format(item, currentSectionDepth)).join(\"\\n\\n\");\n }\n\n const formatPrompt = (model: Model, prompt: Prompt): Chat.Request => {\n logger.silly('Formatting prompt');\n const chatRequest: Chat.Request = Chat.createRequest(model);\n\n if (prompt.persona) {\n [prompt.persona].forEach((persona: Section<Instruction>) => {\n chatRequest.addMessage(formatPersona(model, persona));\n });\n }\n\n let formattedAreas: string = formatSection(prompt.instructions) + '\\n\\n';\n\n if (prompt.contents) {\n formattedAreas += formatSection(prompt.contents) + '\\n\\n';\n }\n\n if (prompt.contexts) {\n formattedAreas += formatSection(prompt.contexts) + '\\n\\n';\n }\n\n chatRequest.addMessage({\n role: \"user\",\n content: formattedAreas,\n });\n\n return chatRequest;\n }\n\n return {\n formatPersona,\n format,\n formatPrompt,\n formatArray,\n }\n}\n","import { marked } from 'marked';\nimport { create as createSection, Section, SectionOptions, SectionOptionsSchema } from '../items/section';\nimport { create as createWeighted, Weighted, WeightedOptionsSchema } from '../items/weighted';\n\nexport const parseMarkdown = <T extends Weighted>(\n input: string | Buffer,\n options: Partial<SectionOptions> = {}\n): Section<T> => {\n\n let markdownContent;\n if (typeof input === 'string') {\n markdownContent = input;\n } else {\n markdownContent = input.toString();\n }\n\n const sectionOptions = SectionOptionsSchema.parse(options);\n\n // Use marked.lexer to get tokens without full parsing/rendering\n const tokens = marked.lexer(markdownContent);\n\n // Create the main section (with a Title from the options)\n const mainSection = createSection<T>(sectionOptions);\n\n // Track sections at each depth level\n const sectionStack: Section<T>[] = [mainSection];\n\n // Set if we've seen the first token\n let isFirstToken = true;\n\n // Set the item options\n const itemOptions = WeightedOptionsSchema.parse({\n ...sectionOptions,\n weight: sectionOptions.itemWeight,\n });\n\n for (const token of tokens) {\n switch (token.type) {\n case 'heading': {\n const depth = token.depth;\n\n // If this is the first token and it's a heading, use it as the main section title\n if (isFirstToken) {\n mainSection.title = token.text;\n isFirstToken = false;\n break;\n }\n\n isFirstToken = false;\n\n // Create a new section with this heading\n const newSection = createSection<T>({ ...sectionOptions, title: token.text });\n\n // Ensure the section stack has the right size based on this heading's depth\n // (e.g., a depth-2 heading should be added to the depth-1 section)\n // We need to ensure the stack length is exactly depth, not just less than or equal to depth\n while (sectionStack.length > depth && sectionStack.length > 1) {\n sectionStack.pop();\n }\n\n // Make sure we're at the right level for this heading\n // If we stay at the same heading level (e.g., two h2s in sequence),\n // we need to pop once more to get to the parent level\n if (sectionStack.length === depth && sectionStack.length > 1) {\n sectionStack.pop();\n }\n\n // Add new section to its parent\n const parentSection = sectionStack[sectionStack.length - 1];\n parentSection.add(newSection, itemOptions);\n\n // Push this section onto the stack\n sectionStack.push(newSection);\n break;\n }\n\n case 'paragraph': {\n isFirstToken = false;\n const instruction: T = createWeighted<T>(token.text, itemOptions);\n const currentSection = sectionStack[sectionStack.length - 1];\n currentSection.add(instruction, itemOptions);\n break;\n }\n\n case 'list': {\n isFirstToken = false;\n // Convert list items to instructions\n const listInstructionContent = token.items.map((item: any) => `- ${item.text}`).join('\\n');\n const listInstruction: T = createWeighted<T>(listInstructionContent, itemOptions);\n const currentSection = sectionStack[sectionStack.length - 1];\n currentSection.add(listInstruction, itemOptions);\n break;\n }\n\n case 'code': {\n isFirstToken = false;\n // Represent code blocks as instructions\n const codeInstruction: T = createWeighted<T>(`\\`\\`\\`${token.lang || ''}\\n${token.text}\\n\\`\\`\\``, itemOptions);\n const currentSection = sectionStack[sectionStack.length - 1];\n currentSection.add(codeInstruction, itemOptions);\n break;\n }\n\n case 'space':\n // Usually ignore space tokens between block elements\n break;\n\n default: {\n isFirstToken = false;\n // Treat other block tokens' text as instructions for robustness\n if ('text' in token && token.text) {\n const fallbackInstruction: T = createWeighted<T>(token.text, itemOptions);\n const currentSection = sectionStack[sectionStack.length - 1];\n currentSection.add(fallbackInstruction, itemOptions);\n }\n break;\n }\n }\n }\n return mainSection;\n}\n","import { create as createSection, Section, SectionOptions, SectionOptionsSchema } from '../items/section';\nimport { create as createWeighted, Weighted, WeightedOptionsSchema } from '../items/weighted';\n\nexport const parseText = <T extends Weighted>(\n input: string | Buffer,\n options: Partial<SectionOptions> = {}\n): Section<T> => {\n\n let text;\n if (typeof input === 'string') {\n text = input;\n } else {\n text = input.toString();\n }\n\n const sectionOptions = SectionOptionsSchema.parse(options);\n\n // Set the item options\n const itemOptions = WeightedOptionsSchema.parse({\n ...sectionOptions,\n weight: sectionOptions.itemWeight,\n });\n\n // Split the text on newlines\n const lines = text.split(/\\r?\\n/).filter(line => line.trim().length > 0);\n\n // Create the main section with the supplied title\n const mainSection = createSection<T>(sectionOptions);\n\n for (const line of lines) {\n const instruction: T = createWeighted<T>(line, itemOptions);\n mainSection.add(instruction, itemOptions);\n }\n\n return mainSection;\n}\n","import { DEFAULT_CHARACTER_ENCODING } from \"../constants\";\n\n// Heuristic to check for Markdown syntax. This is not a full parser.\n// It looks for common Markdown patterns.\nconst markdownRegex = /^(#+\\s|\\*\\s|-\\s|\\+\\s|>\\s|\\[.*\\]\\(.*\\)|```|~~~|---\\\\s*$)/m;\n\n/**\n * Inspects a string to see if it likely contains Markdown syntax.\n *\n * @param input The string or Buffer content to inspect.\n * @returns True if Markdown syntax is suspected, false otherwise.\n */\nexport function isMarkdown(input: string | Buffer): boolean {\n if (input == null) {\n return false;\n }\n // Convert Buffer to string if necessary\n const content = typeof input === 'string' ? input : input.toString(DEFAULT_CHARACTER_ENCODING);\n if (!content || content.trim() === '') {\n return false; // Empty string is not considered Markdown\n }\n\n // Check for common Markdown patterns in the entire content\n if (markdownRegex.test(content)) {\n return true;\n }\n\n // Fallback: Check for a high prevalence of Markdown-like list/header starters\n // or thematic breaks, or code blocks.\n // We'll consider up to the first ~2000 characters, roughly equivalent to the byte check.\n const effectiveContent = content.length > 2000 ? content.substring(0, 2000) : content;\n const lines = effectiveContent.split('\\n');\n let markdownFeatureCount = 0;\n const featurePatterns = [\n /^#+\\s+.+/, // Headers (e.g., # Heading)\n /^\\s*[*+-]\\s+.+/, // List items (e.g., * item, - item, + item)\n /^\\s*>\\s+.+/, // Blockquotes (e.g., > quote)\n /\\[.+\\]\\(.+\\)/, // Links (e.g., [text](url))\n /!\\[.+\\]\\(.+\\)/, // Images (e.g., )\n /`{1,3}[^`]+`{1,3}/, // Inline code (e.g., `code`) or code blocks (```code```)\n /^\\s*_{3,}\\s*$/, // Thematic breaks (e.g., ---, ***, ___)\n /^\\s*-{3,}\\s*$/,\n /^\\s*\\*{3,}\\s*$/\n ];\n\n for (const line of lines) {\n // Stop checking if we have already found enough features to be confident.\n // This is a small optimization for very long inputs that are clearly markdown early on.\n if (markdownFeatureCount >= 2 && lines.length > 10) { // Heuristic threshold\n const significantLineCountEarly = Math.min(lines.indexOf(line) + 1, 20);\n if (significantLineCountEarly > 0 && markdownFeatureCount / significantLineCountEarly > 0.1) {\n return true;\n }\n }\n\n for (const pattern of featurePatterns) {\n if (pattern.test(line.trim())) {\n markdownFeatureCount++;\n break; // Count each line only once\n }\n }\n }\n\n // If more than 5% of the first few lines (up to 20 lines or all lines if fewer)\n // show markdown features, or if there are at least 2 distinct features in short texts,\n // consider it Markdown.\n const significantLineCount = Math.min(lines.length, 20);\n if (significantLineCount > 0) {\n // Calculate the exact threshold percentage\n const thresholdPercentage = markdownFeatureCount / significantLineCount;\n\n // Check against the 5% threshold (0.05)\n // Using >= 0.05 exactly matches 5%, > 0.05 requires more than 5%\n if (thresholdPercentage >= 0.05 + 0.0001) { // Adding a small epsilon to ensure exactly 5% passes but just below fails\n return true;\n }\n\n // Other conditions for returning true\n if ((markdownFeatureCount >= 1 && significantLineCount <= 5) || markdownFeatureCount >= 2) {\n return true;\n }\n }\n\n return false;\n}\n\n// Example usage (optional, for testing):\n// function testIsMarkdownString() {\n// console.log('--- Testing isMarkdownString ---');\n// const markdown1 = '# Hello World\\\\nThis is a test.';\n// console.log(`Test 1 (Header): \"${markdown1.substring(0,10)}...\" -> ${isMarkdownString(markdown1)}`); // true\n\n// const markdown2 = '* Item 1\\\\n* Item 2';\n// console.log(`Test 2 (List): \"${markdown2.substring(0,10)}...\" -> ${isMarkdownString(markdown2)}`); // true\n\n// const markdown3 = '[Google](https://google.com)';\n// console.log(`Test 3 (Link): \"${markdown3.substring(0,15)}...\" -> ${isMarkdownString(markdown3)}`); // true\n\n// const markdown4 = '> This is a quote.';\n// console.log(`Test 4 (Blockquote): \"${markdown4.substring(0,10)}...\" -> ${isMarkdownString(markdown4)}`); // true\n\n// const markdown5 = '```javascript\\\\nconsole.log(\"hello\");\\\\n```';\n// console.log(`Test 5 (Code block): \"${markdown5.substring(0,15)}...\" -> ${isMarkdownString(markdown5)}`); // true\n\n// const text1 = 'This is a plain text string.';\n// console.log(`Test 6 (Plain text): \"${text1.substring(0,10)}...\" -> ${isMarkdownString(text1)}`); // false\n\n// const text2 = 'hello_world.this_is_a_test_string_with_underscores_but_not_markdown_thematic_break';\n// console.log(`Test 7 (Long non-markdown): \"${text2.substring(0,10)}...\" -> ${isMarkdownString(text2)}`); // false\n\n// const text3 = '<xml><tag>value</tag></xml>';\n// console.log(`Test 8 (XML): \"${text3.substring(0,10)}...\" -> ${isMarkdownString(text3)}`); // false\n\n// const shortMarkdown = '# H';\n// console.log(`Test 9 (Short Markdown): \"${shortMarkdown}\" -> ${isMarkdownString(shortMarkdown)}`); // true\n\n// const shortNonMarkdown = 'Hello';\n// console.log(`Test 10 (Short Non-Markdown): \"${shortNonMarkdown}\" -> ${isMarkdownString(shortNonMarkdown)}`); // false\n\n// const emptyString = '';\n// console.log(`Test 11 (Empty string): \"\" -> ${isMarkdownString(emptyString)}`); // false\n\n// const whitespaceString = ' \\t \\n ';\n// console.log(`Test 12 (Whitespace string): \"${whitespaceString.substring(0,5)}...\" -> ${isMarkdownString(whitespaceString)}`); // false\n\n// const markdownWithManyFeatures = `# Title\\\\n\\\\n* list\\\\n* list2\\\\n\\\\n> quote here\\\\n\\\\n\\`\\`\\`\\\\ncode\\\\n\\`\\`\\`\\\\n\\\\nnormal text paragraph with a [link](url).\\n---\\nAnother paragraph.\\nThis is just a test string to see how it performs with multiple markdown features present.\\nHello world this is a very long line that does not contain any markdown syntax at all, it is just plain text that goes on and on.\\n* Another list item\\n* And another one\\n# Another Header\\n## Subheader\\nThis is fun.\\nOkay I think this is enough.\\nFinal line.\\nAnother final line.\\nOne more for good measure.\\nOkay that should be enough lines to test the early exit.\\n`;\n// console.log(`Test 13 (Many Features): \"${markdownWithManyFeatures.substring(0,10)}...\" -> ${isMarkdownString(markdownWithManyFeatures)}`); // true\n\n// const htmlLike = '<div><p>Hello</p><ul><li>item</li></ul></div>';\n// console.log(`Test 14 (HTML-like): \"${htmlLike.substring(0,10)}...\" -> ${isMarkdownString(htmlLike)}`); // false\n\n// console.log('--- End Testing ---');\n// }\n\n// testIsMarkdownString();\n","import { DEFAULT_CHARACTER_ENCODING } from \"../constants\";\n\n// Returns true if the input is likely text, false if likely binary\nexport function isText(input: string | Buffer): boolean {\n let buf: Buffer;\n if (typeof input === 'string') {\n buf = Buffer.from(input, DEFAULT_CHARACTER_ENCODING);\n } else {\n buf = input;\n }\n\n // Empty buffers are considered text\n if (buf.length === 0) {\n return true;\n }\n\n // If the buffer contains null bytes, it's likely binary\n if (buf.includes(0)) {\n return false;\n }\n\n // For UTF-8 encoded text (including emoji and international characters),\n // convert to string first and check if there are non-printable characters\n const str = buf.toString(DEFAULT_CHARACTER_ENCODING);\n\n // Count the number of non-printable ASCII characters (excluding common whitespace)\n let nonPrintable = 0;\n const len = Math.min(str.length, 512); // Only check the first 512 characters for performance\n\n for (let i = 0; i < len; i++) {\n const charCode = str.charCodeAt(i);\n // Allow: tab (9), line feed (10), carriage return (13), printable ASCII (32-126)\n // Also allow all non-ASCII Unicode characters (charCode > 127)\n if (\n charCode !== 9 && charCode !== 10 && charCode !== 13 &&\n (charCode < 32 || (charCode > 126 && charCode < 128))\n ) {\n nonPrintable++;\n }\n }\n\n // If more than 10% of the checked characters are non-printable, consider it binary\n return nonPrintable / len < 0.1;\n}\n","import * as fs from 'fs/promises';\nimport * as path from 'path';\nimport { z } from 'zod';\nimport { ParametersSchema } from './items/parameters';\nimport { Section, SectionOptions, SectionOptionsSchema } from './items/section';\nimport { Weighted } from './items/weighted';\nimport { DEFAULT_LOGGER, wrapLogger } from './logger';\nimport { parseMarkdown } from './parse/markdown';\nimport { parseText } from './parse/text';\nimport { isMarkdown } from './util/markdown';\nimport { isText } from './util/text';\n\nconst OptionsSchema = z.object({\n logger: z.any().optional().default(DEFAULT_LOGGER),\n parameters: ParametersSchema.optional().default({}),\n});\n\nexport type Options = z.infer<typeof OptionsSchema>;\n\nexport type OptionsParam = Partial<Options>;\n\nexport interface Instance {\n parse: <T extends Weighted>(input: string | Buffer, options?: SectionOptions) => Section<T>;\n parseFile: <T extends Weighted>(filePath: string, options?: SectionOptions) => Promise<Section<T>>;\n}\n\nexport const create = (parserOptions?: OptionsParam): Instance => {\n const options: Required<Options> = OptionsSchema.parse(parserOptions || {}) as Required<Options>;\n const parameters = options.parameters;\n\n const logger = wrapLogger(options.logger, 'Parser');\n\n const loadOptions = (sectionOptions: Partial<SectionOptions> = {}): SectionOptions => {\n const currentOptions = SectionOptionsSchema.parse(sectionOptions);\n return {\n ...currentOptions,\n parameters: {\n ...parameters,\n ...currentOptions.parameters\n }\n }\n }\n\n const parseFile = async <T extends Weighted>(\n filePath: string,\n options: Partial<SectionOptions> = {}\n ): Promise<Section<T>> => {\n const currentOptions = loadOptions(options);\n try {\n const content = await fs.readFile(filePath, 'utf-8');\n // Only use the filename as title if no title was explicitly provided\n const fileName = path.basename(filePath, path.extname(filePath));\n return parse(content, {\n ...currentOptions,\n title: currentOptions?.title || fileName\n });\n } catch (error) {\n // Log the error or handle it appropriately\n logger.error(`Error reading or parsing file with marked at ${filePath}:`, error);\n throw new Error(`Failed to parse instructions from ${filePath}: ${error instanceof Error ? error.message : String(error)}`);\n }\n }\n\n /**\n * Reads Markdown content and parses it into a single Section.\n * \n * - If the content starts with a heading, that becomes the title of the returned Section\n * - If no heading at the start, creates a Section with no title\n * - Headers within the content create nested sections based on their depth\n * - All content is organized in a hierarchical structure based on heading levels\n *\n * @param content The content to parse\n * @returns A Section containing all content in a hierarchical structure\n */\n const parse = <T extends Weighted>(\n content: string | Buffer,\n options: Partial<SectionOptions> = {}\n ): Section<T> => {\n const currentOptions = loadOptions(options);\n\n let mainSection: Section<T>;\n if (isMarkdown(content)) {\n mainSection = parseMarkdown<T>(content, currentOptions);\n } else if (isText(content)) {\n mainSection = parseText<T>(content, currentOptions);\n } else {\n throw new Error(`Unsupported content supplied to parse, riotprompt currently only supports markdown and text`);\n }\n return mainSection;\n }\n\n return {\n parse,\n parseFile\n }\n}","// eslint-disable-next-line no-restricted-imports\nimport * as fs from 'fs';\nimport { glob } from 'glob';\nimport path from 'path';\nimport crypto from 'crypto';\n/**\n * This module exists to isolate filesystem operations from the rest of the codebase.\n * This makes testing easier by avoiding direct fs mocking in jest configuration.\n * \n * Additionally, abstracting storage operations allows for future flexibility - \n * this export utility may need to work with storage systems other than the local filesystem\n * (e.g. S3, Google Cloud Storage, etc).\n */\n\nexport interface Utility {\n exists: (path: string) => Promise<boolean>;\n isDirectory: (path: string) => Promise<boolean>;\n isFile: (path: string) => Promise<boolean>;\n isReadable: (path: string) => Promise<boolean>;\n isWritable: (path: string) => Promise<boolean>;\n isFileReadable: (path: string) => Promise<boolean>;\n isDirectoryWritable: (path: string) => Promise<boolean>;\n isDirectoryReadable: (path: string) => Promise<boolean>;\n createDirectory: (path: string) => Promise<void>;\n readFile: (path: string, encoding: string) => Promise<string>;\n readStream: (path: string) => Promise<fs.ReadStream>;\n writeFile: (path: string, data: string | Buffer, encoding: string) => Promise<void>;\n forEachFileIn: (directory: string, callback: (path: string) => Promise<void>, options?: { pattern: string, limit?: number }) => Promise<void>;\n hashFile: (path: string, length: number) => Promise<string>;\n listFiles: (directory: string) => Promise<string[]>;\n}\n\nexport const create = (params: { log?: (message: string, ...args: any[]) => void }): Utility => {\n\n // eslint-disable-next-line no-console\n const log = params.log || console.log;\n\n const exists = async (path: string): Promise<boolean> => {\n try {\n await fs.promises.stat(path);\n return true;\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n } catch (error: any) {\n return false;\n }\n }\n\n const isDirectory = async (path: string): Promise<boolean> => {\n const stats = await fs.promises.stat(path);\n if (!stats.isDirectory()) {\n log(`${path} is not a directory`);\n return false;\n }\n return true;\n }\n\n const isFile = async (path: string): Promise<boolean> => {\n const stats = await fs.promises.stat(path);\n if (!stats.isFile()) {\n log(`${path} is not a file`);\n return false;\n }\n return true;\n }\n\n const isReadable = async (path: string): Promise<boolean> => {\n try {\n await fs.promises.access(path, fs.constants.R_OK);\n } catch (error: any) {\n log(`${path} is not readable: %s %s`, error.message, error.stack);\n return false;\n }\n return true;\n }\n\n const isWritable = async (path: string): Promise<boolean> => {\n try {\n await fs.promises.access(path, fs.constants.W_OK);\n } catch (error: any) {\n log(`${path} is not writable: %s %s`, error.message, error.stack);\n return false;\n }\n return true;\n }\n\n const isFileReadable = async (path: string): Promise<boolean> => {\n return await exists(path) && await isFile(path) && await isReadable(path);\n }\n\n const isDirectoryWritable = async (path: string): Promise<boolean> => {\n return await exists(path) && await isDirectory(path) && await isWritable(path);\n }\n\n const isDirectoryReadable = async (path: string): Promise<boolean> => {\n return await exists(path) && await isDirectory(path) && await isReadable(path);\n }\n\n const createDirectory = async (path: string): Promise<void> => {\n try {\n await fs.promises.mkdir(path, { recursive: true });\n } catch (mkdirError: any) {\n throw new Error(`Failed to create output directory ${path}: ${mkdirError.message} ${mkdirError.stack}`);\n }\n }\n\n const readFile = async (path: string, encoding: string): Promise<string> => {\n return await fs.promises.readFile(path, { encoding: encoding as BufferEncoding });\n }\n\n const writeFile = async (path: string, data: string | Buffer, encoding: string): Promise<void> => {\n await fs.promises.writeFile(path, data, { encoding: encoding as BufferEncoding });\n }\n\n const forEachFileIn = async (\n directory: string,\n callback: (file: string) => Promise<void>,\n options: { pattern: string | string[], limit?: number } = { pattern: '*.*' },\n ): Promise<void> => {\n try {\n let filesProcessed = 0;\n const files = await glob(options.pattern, { cwd: directory, nodir: true });\n for (const file of files) {\n await callback(path.join(directory, file));\n filesProcessed++;\n if (options.limit && filesProcessed >= options.limit) {\n log(`Reached limit of ${options.limit} files, stopping`);\n break;\n }\n }\n } catch (err: any) {\n throw new Error(`Failed to glob pattern ${options.pattern} in ${directory}: ${err.message}`);\n }\n }\n\n const readStream = async (path: string): Promise<fs.ReadStream> => {\n return fs.createReadStream(path);\n }\n\n const hashFile = async (path: string, length: number): Promise<string> => {\n const file = await readFile(path, 'utf8');\n return crypto.createHash('sha256').update(file).digest('hex').slice(0, length);\n }\n\n const listFiles = async (directory: string): Promise<string[]> => {\n return await fs.promises.readdir(directory);\n }\n\n return {\n exists,\n isDirectory,\n isFile,\n isReadable,\n isWritable,\n isFileReadable,\n isDirectoryWritable,\n isDirectoryReadable,\n createDirectory,\n readFile,\n readStream,\n writeFile,\n forEachFileIn,\n hashFile,\n listFiles,\n };\n}","import path from \"path\";\nimport { z } from \"zod\";\nimport { DEFAULT_IGNORE_PATTERNS } from \"./constants\";\nimport { ParametersSchema } from \"./items/parameters\";\nimport { SectionOptions, SectionOptionsSchema } from \"./items/section\";\nimport { DEFAULT_LOGGER, wrapLogger } from \"./logger\";\nimport { Section, Weighted, createSection } from \"./riotprompt\";\nimport * as Storage from \"./util/storage\";\n\nconst OptionsSchema = z.object({\n logger: z.any().optional().default(DEFAULT_LOGGER),\n ignorePatterns: z.array(z.string()).optional().default(DEFAULT_IGNORE_PATTERNS),\n parameters: ParametersSchema.optional().default({}),\n});\n\nexport type Options = z.infer<typeof OptionsSchema>;\n\nexport type OptionsParam = Partial<Options>;\n\nexport interface Instance {\n load: <T extends Weighted>(contextDirectories?: string[], options?: SectionOptions) => Promise<Section<T>[]>;\n}\n\n/**\n * Extracts the first header from Markdown text\n * @param markdownText The Markdown text to parse\n * @returns The first header found in the Markdown or null if none is found\n */\nexport function extractFirstHeader(markdownText: string): string | null {\n // Regular expression to match Markdown headers (# Header, ## Header, etc.)\n const headerRegex = /^(#{1,6})\\s+(.+?)(?:\\n|$)/m;\n const match = markdownText.match(headerRegex);\n\n if (match && match[2]) {\n return match[2].trim();\n }\n\n return null;\n}\n\n/**\n * Removes the first header from Markdown text\n * @param markdownText The Markdown text to process\n * @returns The Markdown text without the first header\n */\nexport function removeFirstHeader(markdownText: string): string {\n // Regular expression to match Markdown headers (# Header, ## Header, etc.)\n const headerRegex = /^(#{1,6})\\s+(.+?)(?:\\n|$)/m;\n const match = markdownText.match(headerRegex);\n\n if (match) {\n return markdownText.replace(headerRegex, '').trim();\n }\n\n return markdownText;\n}\n\nexport const create = (loaderOptions?: OptionsParam): Instance => {\n const options: Required<Options> = OptionsSchema.parse(loaderOptions || {}) as Required<Options>;\n const parameters = options.parameters;\n\n const logger = wrapLogger(options.logger, 'Loader');\n const ignorePatterns = options.ignorePatterns;\n\n const loadOptions = (sectionOptions: Partial<SectionOptions> = {}): SectionOptions => {\n const currentOptions = SectionOptionsSchema.parse(sectionOptions);\n return {\n ...currentOptions,\n parameters: {\n ...parameters,\n ...currentOptions.parameters\n }\n }\n }\n\n /**\n * Loads context from the provided directories and returns instruction sections\n * \n * @param contextDirectories Directories containing context files\n * @returns Array of instruction sections loaded from context directories\n */\n const load = async<T extends Weighted>(\n contextDirectories: string[] = [],\n options: Partial<SectionOptions> = {}\n ): Promise<Section<T>[]> => {\n const sectionOptions = loadOptions(options);\n\n logger.debug(`Loading context from ${contextDirectories}`);\n const contextSections: Section<T>[] = [];\n\n if (!contextDirectories || contextDirectories.length === 0) {\n logger.debug(`No context directories provided, returning empty context`);\n return contextSections;\n }\n\n const storage = Storage.create({ log: logger.debug });\n\n // Add context sections from each directory\n for (const contextDir of contextDirectories) {\n try {\n const dirName = path.basename(contextDir);\n logger.debug(`Processing context directory ${dirName}`);\n let mainContextSection: Section<T>;\n\n // First check if there's a context.md file\n const contextFile = path.join(contextDir, 'context.md');\n\n if (await storage.exists(contextFile)) {\n logger.debug(`Found context.md file in ${contextDir}`);\n const mainContextContent = await storage.readFile(contextFile, 'utf8');\n // Extract the first header from the Markdown content\n const firstHeader = extractFirstHeader(mainContextContent);\n\n // Use the header from context.md as the section title, or fallback to directory name\n const sectionTitle = firstHeader || dirName;\n mainContextSection = createSection<T>({ ...sectionOptions, title: sectionTitle });\n\n // Add content without the header\n if (firstHeader) {\n mainContextSection.add(removeFirstHeader(mainContextContent), { ...sectionOptions });\n } else {\n mainContextSection.add(mainContextContent, { ...sectionOptions });\n }\n } else {\n // If no context.md exists, use directory name as title\n mainContextSection = createSection<T>({ ...sectionOptions, title: dirName });\n }\n\n // Get all other files in the directory\n const files = await storage.listFiles(contextDir);\n const ignorePatternsRegex = ignorePatterns.map(pattern => new RegExp(pattern, 'i'));\n\n const filteredFiles = files.filter(file =>\n !ignorePatternsRegex.some(regex => regex.test(file))\n );\n\n for (const file of filteredFiles) {\n // Skip the context.md file as it's already processed\n if (file === 'context.md') continue;\n\n logger.debug(`Processing file ${file} in ${contextDir}`);\n const filePath = path.join(contextDir, file);\n if (await storage.isFile(filePath)) {\n const fileContent = await storage.readFile(filePath, 'utf8');\n let sectionName = file;\n let contentToAdd = fileContent;\n\n // Extract header if it exists\n if (file.endsWith('.md')) {\n const fileHeader = extractFirstHeader(fileContent);\n if (fileHeader) {\n sectionName = fileHeader;\n // Remove the header from the content\n contentToAdd = removeFirstHeader(fileContent);\n }\n }\n\n // Create a subsection with the extracted name\n const fileSection = createSection<T>({ ...sectionOptions, title: sectionName });\n fileSection.add(contentToAdd, { ...sectionOptions });\n\n // Add this file section to the main context section\n mainContextSection.add(fileSection as unknown as T, { ...sectionOptions });\n }\n }\n\n contextSections.push(mainContextSection);\n } catch (error) {\n logger.error(`Error processing context directory ${contextDir}: ${error}`);\n }\n }\n\n return contextSections;\n }\n\n\n return {\n load\n }\n}\n","import path from 'path';\nimport { z } from 'zod';\nimport { ParametersSchema } from './items/parameters';\nimport { SectionOptions, SectionOptionsSchema } from './items/section';\nimport { DEFAULT_LOGGER, wrapLogger } from './logger';\nimport { Formatter, Parser, Section, Weighted } from './riotprompt';\nimport * as Storage from './util/storage';\n\nconst OptionsSchema = z.object({\n logger: z.any().optional().default(DEFAULT_LOGGER),\n configDir: z.string().default('./overrides'),\n overrides: z.boolean().default(false),\n parameters: ParametersSchema.optional().default({}),\n});\n\nexport type Options = z.infer<typeof OptionsSchema>;\n\nexport type OptionsParam = Partial<Options>;\n\nexport interface Instance {\n customize: <T extends Weighted>(overrideFile: string, section: Section<T>, sectionOptions?: SectionOptions) => Promise<Section<T>>;\n override: <T extends Weighted>(overrideFile: string, section: Section<T>, sectionOptions?: SectionOptions) =>\n Promise<{ override?: Section<T>, prepend?: Section<T>, append?: Section<T> }>;\n}\n\nexport const create = (overrideOptions: OptionsParam = {}): Instance => {\n const options: Required<Options> = OptionsSchema.parse(overrideOptions) as Required<Options>;\n\n const parameters = options.parameters;\n\n const logger = wrapLogger(options?.logger, 'Override');\n const storage = Storage.create({ log: logger.debug });\n\n const loadOptions = (sectionOptions: Partial<SectionOptions> = {}): SectionOptions => {\n const currentOptions = SectionOptionsSchema.parse(sectionOptions);\n return {\n ...currentOptions,\n parameters: {\n ...parameters,\n ...currentOptions.parameters\n }\n }\n }\n\n const override = async <T extends Weighted>(\n overrideFile: string,\n section: Section<T>,\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<{ override?: Section<T>, prepend?: Section<T>, append?: Section<T> }> => {\n const currentSectionOptions = loadOptions(sectionOptions);\n\n const baseFile = path.join(options.configDir, overrideFile);\n const preFile = baseFile.replace('.md', '-pre.md');\n const postFile = baseFile.replace('.md', '-post.md');\n\n const response: { override?: Section<T>, prepend?: Section<T>, append?: Section<T> } = {};\n\n if (await storage.exists(preFile)) {\n logger.silly('Found pre file %s', preFile);\n const parser = Parser.create({ logger });\n response.prepend = await parser.parseFile<T>(preFile, currentSectionOptions);\n }\n\n if (await storage.exists(postFile)) {\n logger.silly('Found post file %s', postFile);\n const parser = Parser.create({ logger });\n response.append = await parser.parseFile<T>(postFile, currentSectionOptions);\n }\n\n if (await storage.exists(baseFile)) {\n logger.silly('Found base file %s', baseFile);\n if (options.overrides) {\n logger.warn('WARNING: Core directives are being overwritten by custom configuration');\n const parser = Parser.create({ logger });\n response.override = await parser.parseFile<T>(baseFile, currentSectionOptions);\n } else {\n logger.error('ERROR: Core directives are being overwritten by custom configuration');\n throw new Error('Core directives are being overwritten by custom configuration, but overrides are not enabled. Please enable --overrides to use this feature.');\n }\n }\n\n return response;\n }\n\n const customize = async <T extends Weighted>(\n overrideFile: string,\n section: Section<T>,\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Section<T>> => {\n const currentSectionOptions = loadOptions(sectionOptions);\n\n const { overrideContent, prepend, append }: { overrideContent?: Section<T>, prepend?: Section<T>, append?: Section<T> } = await override(overrideFile, section, currentSectionOptions);\n let finalSection: Section<T> = section;\n\n if (overrideContent) {\n if (options.overrides) {\n logger.warn('Override found, replacing content from file %s', overrideContent);\n finalSection = overrideContent;\n } else {\n logger.error('ERROR: Core directives are being overwritten by custom configuration');\n throw new Error('Core directives are being overwritten by custom configuration, but overrides are not enabled. Please enable --overrides to use this feature.');\n }\n }\n\n if (prepend) {\n logger.silly('Prepend found, adding to content from file %s', prepend);\n finalSection = finalSection.prepend(prepend);\n }\n\n if (append) {\n logger.silly('Append found, adding to content from file %s', append);\n finalSection = finalSection.append(append);\n }\n\n const formatter = Formatter.create({ logger });\n logger.silly('Final section %s:\\n\\n%s\\n\\n', logger.name, formatter.format(finalSection));\n\n return finalSection;\n }\n\n return {\n override,\n customize,\n }\n}","import path from \"path\";\nimport { z } from \"zod\";\nimport { ParametersSchema } from \"./items/parameters\";\nimport { SectionOptions, SectionOptionsSchema } from \"./items/section\";\nimport { DEFAULT_LOGGER, wrapLogger } from \"./logger\";\nimport { Content, Context, createPrompt, createSection, Instruction, Loader, Override, Parser, Prompt, Section, Weighted } from \"./riotprompt\";\n\nconst OptionSchema = z.object({\n logger: z.any().optional().default(DEFAULT_LOGGER),\n basePath: z.string(),\n overridePath: z.string().optional().default(\"./\"),\n overrides: z.boolean().optional().default(false),\n parameters: ParametersSchema.optional().default({}),\n});\n\nexport type Options = z.infer<typeof OptionSchema>;\n\nexport type OptionsParam = Required<Pick<Options, 'basePath'>> & Partial<Omit<Options, 'basePath'>>;\n\nexport interface Instance {\n addPersonaPath(contentPath: string, sectionOptions?: Partial<SectionOptions>): Promise<Instance>;\n addContextPath(contentPath: string, sectionOptions?: Partial<SectionOptions>): Promise<Instance>;\n addInstructionPath(contentPath: string, sectionOptions?: Partial<SectionOptions>): Promise<Instance>;\n addContentPath(contentPath: string, sectionOptions?: Partial<SectionOptions>): Promise<Instance>;\n addContent(content: string, sectionOptions?: Partial<SectionOptions>): Promise<Instance>;\n addContext(context: string, sectionOptions?: Partial<SectionOptions>): Promise<Instance>;\n loadContext(contextDirectories: string[], sectionOptions?: Partial<SectionOptions>): Promise<Instance>;\n loadContent(contentDirectories: string[], sectionOptions?: Partial<SectionOptions>): Promise<Instance>;\n build(): Promise<Prompt>;\n}\n\nexport const create = (builderOptions: OptionsParam): Instance => {\n const options: Required<Options> = OptionSchema.parse(builderOptions) as Required<Options>;\n\n const logger = wrapLogger(options.logger, 'Builder');\n const parser = Parser.create({ logger });\n const override = Override.create({\n logger, configDir: options.overridePath || \"./\",\n overrides: options.overrides || false\n });\n const loader = Loader.create({ logger });\n\n const personaSection: Section<Instruction> = createSection({ title: \"Persona\" });\n const contextSection: Section<Context> = createSection({ title: \"Context\" });\n const instructionSection: Section<Instruction> = createSection({ title: \"Instruction\" });\n const contentSection: Section<Content> = createSection({ title: \"Content\" });\n const parameters = options.parameters;\n\n\n const instance: Partial<Instance> = {}\n\n const loadOptions = (sectionOptions: Partial<SectionOptions> = {}): SectionOptions => {\n const currentOptions = SectionOptionsSchema.parse(sectionOptions);\n return {\n ...currentOptions,\n parameters: {\n ...parameters,\n ...currentOptions.parameters\n }\n }\n }\n\n const loadDirectories = async <T extends Weighted>(\n directories: string[],\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Section<T>[]> => {\n const currentOptions = loadOptions(sectionOptions);\n logger.debug(\"Loading directories\", directories);\n const sections: Section<T>[] = await loader.load<T>(directories, currentOptions);\n return sections;\n }\n\n const loadContext = async (\n contextDirectories: string[],\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Instance> => {\n const currentOptions = loadOptions(sectionOptions);\n logger.debug('Loading context', contextDirectories);\n const context: Section<Context>[] = await loadDirectories<Context>(contextDirectories, currentOptions);\n contextSection.add(context);\n return instance as Instance;\n }\n instance.loadContext = loadContext;\n\n const loadContent = async (\n contentDirectories: string[],\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Instance> => {\n const currentOptions = loadOptions(sectionOptions);\n const content: Section<Content>[] = await loadDirectories<Content>(contentDirectories, currentOptions);\n contentSection.add(content);\n return instance as Instance;\n }\n instance.loadContent = loadContent;\n\n const loadPath = async <T extends Weighted>(\n contentPath: string,\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Section<T>> => {\n const currentOptions = loadOptions(sectionOptions);\n const defaultPath = path.join(options.basePath as string, contentPath);\n const section: Section<T> = await parser.parseFile<T>(defaultPath, currentOptions);\n const overrideSection = await override.customize<T>(contentPath, section, currentOptions);\n return overrideSection;\n }\n\n const addPersonaPath = async (\n contentPath: string,\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Instance> => {\n const currentOptions = loadOptions(sectionOptions);\n const persona: Section<Instruction> = await loadPath<Instruction>(contentPath, currentOptions);\n personaSection.add(persona);\n return instance as Instance;\n }\n instance.addPersonaPath = addPersonaPath;\n\n const addContextPath = async (\n contentPath: string,\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Instance> => {\n logger.debug(\"Adding context path\", contentPath);\n const currentOptions = loadOptions(sectionOptions);\n const context: Section<Context> = await loadPath<Context>(contentPath, currentOptions);\n contextSection.add(context);\n return instance as Instance;\n }\n instance.addContextPath = addContextPath;\n\n const addInstructionPath = async (\n contentPath: string,\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Instance> => {\n logger.debug(\"Adding instruction path\", contentPath);\n const currentOptions = loadOptions(sectionOptions);\n const instruction: Section<Instruction> = await loadPath<Instruction>(contentPath, currentOptions);\n instructionSection.add(instruction);\n return instance as Instance;\n }\n instance.addInstructionPath = addInstructionPath;\n\n const addContentPath = async (\n contentPath: string,\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Instance> => {\n logger.debug(\"Adding content path\", contentPath);\n const currentOptions = loadOptions(sectionOptions);\n const content: Section<Content> = await loadPath<Content>(contentPath, currentOptions);\n contentSection.add(content);\n return instance as Instance;\n }\n instance.addContentPath = addContentPath;\n\n const addContent = async (\n content: string | Buffer,\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Instance> => {\n logger.debug(\"Adding content\", typeof content);\n const currentOptions = loadOptions(sectionOptions);\n const parsedContentSection: Section<Content> = parser.parse<Content>(content, currentOptions);\n contentSection.add(parsedContentSection);\n return instance as Instance;\n }\n instance.addContent = addContent;\n\n const addContext = async (\n context: string | Buffer,\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Instance> => {\n logger.debug(\"Adding context\", typeof context);\n const currentOptions = loadOptions(sectionOptions);\n const parsedContextSection: Section<Context> = parser.parse<Context>(context, currentOptions);\n contextSection.add(parsedContextSection);\n return instance as Instance;\n }\n instance.addContext = addContext;\n\n const build = async () => {\n logger.debug(\"Building prompt\", {});\n const prompt = createPrompt({ persona: personaSection, contexts: contextSection, instructions: instructionSection, contents: contentSection });\n return prompt;\n }\n instance.build = build;\n\n return instance as Instance;\n}\n"],"names":["ParametersSchema","z","record","string","union","number","boolean","array","create","parameters","apply","text","trimmedParams","Object","keys","forEach","key","trim","replace","match","p1","paramKey","parameter","undefined","toString","Array","isArray","join","object","weight","optional","WeightedOptionsSchema","options","weightedOptions","parse","parameterizedText","applyParameters","createWeighted","SectionOptionsSchema","title","itemWeight","default","items","sectionOptions","sectionItemOptions","append","item","itemOptions","push","section","prepend","unshift","insert","index","splice","remove","add","persona","instructions","contents","contexts","DEFAULT_CHARACTER_ENCODING","LIBRARY_NAME","DEFAULT_PERSONA_ROLE","DEFAULT_IGNORE_PATTERNS","DEFAULT_SECTION_SEPARATOR","DEFAULT_SECTION_INDENTATION","DEFAULT_SECTION_TITLE_PROPERTY","DEFAULT_FORMAT_OPTIONS","sectionSeparator","sectionIndentation","sectionTitleProperty","sectionDepth","getPersonaRole","model","createRequest","messages","addMessage","message","DEFAULT_LOGGER","name","debug","args","console","info","warn","error","verbose","log","silly","wrapLogger","toWrap","requiredMethods","missingMethods","filter","method","length","Error","level","clean","obj","fromEntries","entries","_","v","stringifyJSON","visited","Set","arrOfKeyVals","arrVals","objKeys","has","el","keyOut","keyValOut","Function","SectionSeparatorSchema","enum","SectionTitlePropertySchema","FormatOptionsSchema","sectionTitlePrefix","sectionTitleSeparator","OptionSchema","logger","any","formatOptions","partial","isSection","isWeighted","formatterOptions","formatPersona","formattedPersona","formatSection","role","content","format","currentSectionDepth","result","formattedItems","map","headingLevel","hashes","repeat","formatArray","formatPrompt","prompt","chatRequest","Chat","formattedAreas","parseMarkdown","input","markdownContent","tokens","marked","lexer","mainSection","createSection","sectionStack","isFirstToken","token","type","depth","newSection","pop","parentSection","instruction","currentSection","listInstructionContent","listInstruction","codeInstruction","lang","fallbackInstruction","parseText","lines","split","line","markdownRegex","isMarkdown","test","effectiveContent","substring","markdownFeatureCount","featurePatterns","significantLineCountEarly","Math","min","indexOf","pattern","significantLineCount","thresholdPercentage","isText","buf","Buffer","from","includes","str","nonPrintable","len","i","charCode","charCodeAt","OptionsSchema","parserOptions","loadOptions","currentOptions","parseFile","filePath","fs","readFile","fileName","path","basename","extname","String","params","exists","promises","stat","isDirectory","stats","isFile","isReadable","access","constants","R_OK","stack","isWritable","W_OK","isFileReadable","isDirectoryWritable","isDirectoryReadable","createDirectory","mkdir","recursive","mkdirError","encoding","writeFile","data","forEachFileIn","directory","callback","filesProcessed","files","glob","cwd","nodir","file","limit","err","readStream","createReadStream","hashFile","crypto","createHash","update","digest","slice","listFiles","readdir","ignorePatterns","extractFirstHeader","markdownText","headerRegex","removeFirstHeader","loaderOptions","load","contextDirectories","contextSections","storage","Storage","contextDir","dirName","mainContextSection","contextFile","mainContextContent","firstHeader","sectionTitle","ignorePatternsRegex","RegExp","filteredFiles","some","regex","fileContent","sectionName","contentToAdd","endsWith","fileHeader","fileSection","configDir","overrides","overrideOptions","override","overrideFile","currentSectionOptions","baseFile","preFile","postFile","response","parser","Parser","customize","overrideContent","finalSection","formatter","Formatter","basePath","overridePath","builderOptions","Override","loader","Loader","personaSection","contextSection","instructionSection","contentSection","instance","loadDirectories","directories","sections","loadContext","context","loadContent","contentDirectories","loadPath","contentPath","defaultPath","overrideSection","addPersonaPath","addContextPath","addInstructionPath","addContentPath","addContent","parsedContentSection","addContext","parsedContextSection","build","createPrompt"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"riotprompt.cjs","sources":["../src/items/parameters.ts","../src/items/weighted.ts","../src/items/content.ts","../src/items/context.ts","../src/items/instruction.ts","../src/items/section.ts","../src/items/trait.ts","../src/prompt.ts","../src/constants.ts","../src/chat.ts","../src/logger.ts","../src/util/general.ts","../src/formatter.ts","../src/parse/markdown.ts","../src/parse/text.ts","../src/util/markdown.ts","../src/util/text.ts","../src/parser.ts","../src/util/storage.ts","../src/loader.ts","../src/override.ts","../src/builder.ts"],"sourcesContent":["import { z } from \"zod\";\n\nexport const ParametersSchema = z.record(z.string(), z.union([z.string(), z.number(), z.boolean(), z.array(z.union([z.string(), z.number(), z.boolean()]))]));\n\nexport type Parameters = z.infer<typeof ParametersSchema>;\n\nexport const create = (parameters: Parameters): Parameters => {\n return parameters;\n}\n\nexport const apply = (text: string, parameters?: Parameters): string => {\n if (!parameters) {\n return text;\n }\n\n // First, trim parameters keys to handle whitespace in placeholder names\n const trimmedParams: Record<string, any> = {};\n Object.keys(parameters).forEach(key => {\n trimmedParams[key.trim()] = parameters[key];\n });\n\n // Process all placeholders, preserving ones that don't have matching parameters\n return text.replace(/\\{\\{([^{}]+)\\}\\}/g, (match, p1) => {\n const paramKey = p1.trim();\n const parameter = trimmedParams[paramKey];\n\n if (parameter === undefined) {\n // Preserve the original placeholder if parameter doesn't exist\n return match;\n } else if (typeof parameter === 'string') {\n return parameter;\n } else if (typeof parameter === 'number') {\n return parameter.toString();\n } else if (typeof parameter === 'boolean') {\n return parameter.toString();\n } else if (Array.isArray(parameter)) {\n return parameter.join(', ');\n } else {\n return match;\n }\n });\n}","import { z } from \"zod\";\nimport { ParametersSchema, apply as applyParameters } from \"./parameters\";\n\nexport const WeightedSchema = z.object({\n text: z.string(),\n weight: z.number().optional(),\n});\n\nexport type Weighted = z.infer<typeof WeightedSchema>;\n\nexport const WeightedOptionsSchema = z.object({\n weight: z.number().optional(),\n parameters: ParametersSchema.optional(),\n});\n\nexport type WeightedOptions = z.infer<typeof WeightedOptionsSchema>;\n\n\nexport const create = <T extends Weighted>(\n text: string,\n options: Partial<WeightedOptions> = {}\n): T => {\n const weightedOptions = WeightedOptionsSchema.parse(options);\n const parameterizedText = applyParameters(text, weightedOptions.parameters);\n\n return {\n text: parameterizedText,\n weight: weightedOptions.weight,\n } as T;\n}","import { Weighted, WeightedOptions, WeightedOptionsSchema, create as createWeighted } from \"./weighted\";\n\n// Define Content as a type alias for Weighted\nexport type Content = Weighted;\n\n// Export create function\nexport const create = (text: string, options: Partial<WeightedOptions> = {}): Content => {\n const weightedOptions = WeightedOptionsSchema.parse(options);\n return createWeighted<Content>(text, weightedOptions);\n}\n\n","import { Weighted, WeightedOptions, WeightedOptionsSchema, create as createWeighted } from \"./weighted\";\n\nexport type Context = Weighted;\n\nexport const create = (text: string, options: Partial<WeightedOptions> = {}): Context => {\n const weightedOptions = WeightedOptionsSchema.parse(options);\n return createWeighted<Context>(text, weightedOptions);\n}\n\n","import { Weighted, WeightedOptions, WeightedOptionsSchema, create as createWeighted } from \"./weighted\";\n\nexport type Instruction = Weighted;\n\nexport const create = (text: string, options: Partial<WeightedOptions> = {}): Instruction => {\n const weightedOptions = WeightedOptionsSchema.parse(options);\n return createWeighted<Instruction>(text, weightedOptions);\n}","import { z } from \"zod\";\nimport { ParametersSchema } from \"./parameters\";\nimport { Weighted, WeightedOptions, WeightedOptionsSchema, create as createWeighted } from \"./weighted\";\n\nexport interface Section<T extends Weighted> {\n title?: string;\n items: (T | Section<T>)[];\n weight?: number;\n add: (\n item: T | T[] | Section<T> | Section<T>[] | string | string[],\n options?: Partial<WeightedOptions>\n ) => Section<T>;\n append: (\n item: T | T[] | Section<T> | Section<T>[] | string | string[],\n options?: Partial<WeightedOptions>\n ) => Section<T>;\n prepend: (\n item: T | T[] | Section<T> | Section<T>[] | string | string[],\n options?: Partial<WeightedOptions>\n ) => Section<T>;\n insert: (\n index: number,\n item: T | T[] | Section<T> | Section<T>[] | string | string[],\n options?: Partial<WeightedOptions>\n ) => Section<T>;\n replace: (\n index: number,\n item: T | Section<T> | string,\n options?: Partial<WeightedOptions>\n ) => Section<T>;\n remove: (index: number) => Section<T>;\n}\n\nexport const SectionOptionsSchema = z.object({\n title: z.string().optional(),\n weight: z.number().optional(),\n itemWeight: z.number().optional(),\n parameters: ParametersSchema.optional().default({}),\n});\n\nexport type SectionOptions = z.infer<typeof SectionOptionsSchema>;\n\nexport const isSection = (object: any): boolean => {\n return object !== undefined && object != null && typeof object === 'object' && 'items' in object;\n}\n\nexport const convertToSection = (\n object: any,\n options: Partial<SectionOptions> = {}\n): Section<Weighted> => {\n const sectionOptions = SectionOptionsSchema.parse(options);\n\n const weightedOptions = WeightedOptionsSchema.parse({\n ...sectionOptions,\n weight: sectionOptions.itemWeight,\n });\n\n if (isSection(object)) {\n const section = create({ ...sectionOptions, title: object.title });\n object.items.forEach((item: any) => {\n if (isSection(item)) {\n section.append(convertToSection(item, sectionOptions));\n } else {\n section.append(createWeighted(item.text, weightedOptions));\n }\n });\n return section;\n } else {\n throw new Error('Object is not a section');\n }\n}\n\nexport const create = <T extends Weighted>(\n options: Partial<SectionOptions> = {}\n): Section<T> => {\n const items: (T | Section<T>)[] = [];\n const sectionOptions = SectionOptionsSchema.parse(options);\n\n const sectionItemOptions = WeightedOptionsSchema.parse({\n ...sectionOptions,\n weight: sectionOptions.itemWeight,\n });\n\n const append = (item: T | T[] | Section<T> | Section<T>[] | string | string[], options: Partial<WeightedOptions> = {}): Section<T> => {\n let itemOptions: WeightedOptions = WeightedOptionsSchema.parse(options);\n itemOptions = { ...sectionItemOptions, ...itemOptions };\n\n if (Array.isArray(item)) {\n item.forEach((item) => {\n append(item);\n });\n } else {\n if (typeof item === 'string') {\n items.push(createWeighted<T>(item, itemOptions));\n } else {\n items.push(item);\n }\n }\n return section;\n }\n\n const prepend = (item: T | T[] | Section<T> | Section<T>[] | string | string[], options: Partial<WeightedOptions> = {}): Section<T> => {\n let itemOptions: WeightedOptions = WeightedOptionsSchema.parse(options);\n itemOptions = { ...sectionItemOptions, ...itemOptions };\n\n if (Array.isArray(item)) {\n item.forEach((item) => {\n prepend(item);\n });\n } else {\n if (typeof item === 'string') {\n items.unshift(createWeighted<T>(item, itemOptions));\n } else {\n items.unshift(item);\n }\n }\n return section;\n }\n\n const insert = (index: number, item: T | T[] | Section<T> | Section<T>[] | string | string[], options: Partial<WeightedOptions> = {}): Section<T> => {\n let itemOptions: WeightedOptions = WeightedOptionsSchema.parse(options);\n itemOptions = { ...sectionItemOptions, ...itemOptions };\n\n if (Array.isArray(item)) {\n item.forEach((item) => {\n insert(index, item);\n });\n } else {\n if (typeof item === 'string') {\n items.splice(index, 0, createWeighted<T>(item, itemOptions));\n } else {\n items.splice(index, 0, item);\n }\n }\n return section;\n }\n\n const remove = (index: number): Section<T> => {\n items.splice(index, 1);\n return section;\n }\n\n const replace = (index: number, item: T | Section<T> | string, options: Partial<WeightedOptions> = {}): Section<T> => {\n let itemOptions: WeightedOptions = WeightedOptionsSchema.parse(options);\n itemOptions = { ...sectionItemOptions, ...itemOptions };\n\n if (typeof item === 'string') {\n items[index] = createWeighted<T>(item, itemOptions);\n } else {\n items[index] = item;\n }\n return section;\n }\n\n const add = (item: T | T[] | Section<T> | Section<T>[] | string | string[], options: Partial<WeightedOptions> = {}): Section<T> => {\n let itemOptions: WeightedOptions = WeightedOptionsSchema.parse(options);\n itemOptions = { ...sectionItemOptions, ...itemOptions };\n\n return append(item, itemOptions);\n }\n\n const section: Section<T> = {\n title: sectionOptions.title,\n items,\n weight: sectionOptions.weight,\n add,\n append,\n prepend,\n insert,\n remove,\n replace,\n }\n\n return section;\n}\n\n\n","import { Weighted, WeightedOptions, WeightedOptionsSchema, create as createWeighted } from \"./weighted\";\n\nexport type Trait = Weighted;\n\nexport const create = (text: string, options: WeightedOptions = {}): Trait => {\n const weightedOptions = WeightedOptionsSchema.parse(options);\n return createWeighted<Trait>(text, weightedOptions);\n}","import { Content } from \"./items/content\";\nimport { Context } from \"./items/context\";\nimport { Instruction } from \"./items/instruction\";\nimport { Section } from \"./items/section\";\n\nexport interface Prompt {\n persona?: Section<Instruction>;\n instructions: Section<Instruction>;\n contents?: Section<Content>;\n contexts?: Section<Context>;\n}\n\nexport const create = ({\n persona,\n instructions,\n contents,\n contexts,\n}: {\n persona?: Section<Instruction>,\n instructions: Section<Instruction>,\n contents?: Section<Content>,\n contexts?: Section<Context>\n}): Prompt => {\n\n return {\n persona,\n instructions,\n contents,\n contexts,\n }\n}","import { SectionSeparator } from \"formatter\";\n\nimport { FormatOptions } from \"formatter\";\n\nexport const DEFAULT_CHARACTER_ENCODING = \"utf8\";\nexport const LIBRARY_NAME = \"riotprompt\";\n\nexport const DEFAULT_PERSONA_ROLE = \"developer\";\n\nexport const DEFAULT_INSTRUCTIONS_AREA_TITLE = \"Instructions\";\nexport const DEFAULT_CONTENTS_AREA_TITLE = \"Contents\";\nexport const DEFAULT_CONTEXT_AREA_TITLE = \"Context\";\n\nexport const DEFAULT_IGNORE_PATTERNS: string[] = [\n \"^\\\\..*\", // Hidden files (e.g., .git, .DS_Store)\n \"\\\\.(jpg|jpeg|png|gif|bmp|svg|webp|ico)$\", // Image files\n \"\\\\.(mp3|wav|ogg|aac|flac)$\", // Audio files\n \"\\\\.(mp4|mov|avi|mkv|webm)$\", // Video files\n \"\\\\.(pdf|doc|docx|xls|xlsx|ppt|pptx)$\", // Document files\n \"\\\\.(zip|tar|gz|rar|7z)$\" // Compressed files\n];\n\nexport const DEFAULT_SECTION_SEPARATOR: SectionSeparator = \"tag\";\nexport const DEFAULT_SECTION_INDENTATION = true;\nexport const DEFAULT_SECTION_TAG = \"section\";\nexport const DEFAULT_SECTION_TITLE_PROPERTY = \"title\";\n\nexport const DEFAULT_FORMAT_OPTIONS: FormatOptions = {\n sectionSeparator: DEFAULT_SECTION_SEPARATOR,\n sectionIndentation: DEFAULT_SECTION_INDENTATION,\n sectionTitleProperty: DEFAULT_SECTION_TITLE_PROPERTY,\n sectionDepth: 0,\n}\n","import { DEFAULT_PERSONA_ROLE } from \"./constants\";\n\nexport type Role = \"user\" | \"assistant\" | \"system\" | \"developer\";\n\nexport type Model = \"gpt-4o\" | \"gpt-4o-mini\" | \"o1-preview\" | \"o1-mini\" | \"o1\" | \"o3-mini\" | \"o1-pro\";\n\nexport interface Message {\n role: Role;\n content: string | string[];\n name?: string;\n}\n\nexport interface Request {\n messages: Message[];\n model: Model;\n\n addMessage(message: Message): void;\n}\n\nexport const getPersonaRole = (model: Model): Role => {\n if (model === \"gpt-4o\" || model === \"gpt-4o-mini\") {\n return \"system\";\n }\n return DEFAULT_PERSONA_ROLE;\n}\n\nexport const createRequest = (model: Model): Request => {\n const messages: Message[] = [];\n\n return {\n model,\n messages,\n addMessage: (message: Message) => {\n messages.push(message);\n }\n }\n}\n","/* eslint-disable no-console */\nimport { LIBRARY_NAME } from \"./constants\";\n\nexport interface Logger {\n name: string;\n debug: (message: string, ...args: any[]) => void;\n info: (message: string, ...args: any[]) => void;\n warn: (message: string, ...args: any[]) => void;\n error: (message: string, ...args: any[]) => void;\n verbose: (message: string, ...args: any[]) => void;\n silly: (message: string, ...args: any[]) => void;\n}\n\nexport const DEFAULT_LOGGER: Logger = {\n name: 'default',\n debug: (message: string, ...args: any[]) => console.debug(message, ...args),\n info: (message: string, ...args: any[]) => console.info(message, ...args),\n warn: (message: string, ...args: any[]) => console.warn(message, ...args),\n error: (message: string, ...args: any[]) => console.error(message, ...args),\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n verbose: (message: string, ...args: any[]) => { },\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n silly: (message: string, ...args: any[]) => { },\n}\n\nexport const wrapLogger = (toWrap: Logger, name?: string): Logger => {\n\n const requiredMethods: (keyof Logger)[] = ['debug', 'info', 'warn', 'error', 'verbose', 'silly'];\n const missingMethods = requiredMethods.filter(method => typeof toWrap[method] !== 'function');\n\n if (missingMethods.length > 0) {\n throw new Error(`Logger is missing required methods: ${missingMethods.join(', ')}`);\n }\n\n const log = (level: keyof Logger, message: string, ...args: any[]) => {\n message = `[${LIBRARY_NAME}] ${name ? `[${name}]` : ''}: ${message}`;\n\n if (level === 'debug') toWrap.debug(message, ...args);\n else if (level === 'info') toWrap.info(message, ...args);\n else if (level === 'warn') toWrap.warn(message, ...args);\n else if (level === 'error') toWrap.error(message, ...args);\n else if (level === 'verbose') toWrap.verbose(message, ...args);\n else if (level === 'silly') toWrap.silly(message, ...args);\n }\n\n return {\n name: 'wrapped',\n debug: (message: string, ...args: any[]) => log('debug', message, ...args),\n info: (message: string, ...args: any[]) => log('info', message, ...args),\n warn: (message: string, ...args: any[]) => log('warn', message, ...args),\n error: (message: string, ...args: any[]) => log('error', message, ...args),\n verbose: (message: string, ...args: any[]) => log('verbose', message, ...args),\n silly: (message: string, ...args: any[]) => log('silly', message, ...args),\n }\n}","export const clean = (obj: any) => {\n return Object.fromEntries(\n Object.entries(obj).filter(([_, v]) => v !== undefined)\n );\n}\n\n//Recursive implementation of jSON.stringify;\nexport const stringifyJSON = function (obj: any, visited: Set<any> = new Set()): string {\n const arrOfKeyVals: string[] = [];\n const arrVals: string[] = [];\n let objKeys: string[] = [];\n\n /*********CHECK FOR PRIMITIVE TYPES**********/\n if (typeof obj === 'number' || typeof obj === 'boolean' || obj === null)\n return '' + obj;\n else if (typeof obj === 'string')\n return '\"' + obj + '\"';\n\n /*********DETECT CIRCULAR REFERENCES**********/\n if (obj instanceof Object && visited.has(obj)) {\n return '\"(circular)\"';\n }\n\n /*********CHECK FOR ARRAY**********/\n else if (Array.isArray(obj)) {\n //check for empty array\n if (obj[0] === undefined)\n return '[]';\n else {\n // Add array to visited before processing its elements\n visited.add(obj);\n obj.forEach(function (el) {\n arrVals.push(stringifyJSON(el, visited));\n });\n return '[' + arrVals + ']';\n }\n }\n /*********CHECK FOR OBJECT**********/\n else if (obj instanceof Object) {\n // Add object to visited before processing its properties\n visited.add(obj);\n //get object keys\n objKeys = Object.keys(obj);\n //set key output;\n objKeys.forEach(function (key) {\n const keyOut = '\"' + key + '\":';\n const keyValOut = obj[key];\n //skip functions and undefined properties\n if (keyValOut instanceof Function || keyValOut === undefined)\n return; // Skip this entry entirely instead of pushing an empty string\n else if (typeof keyValOut === 'string')\n arrOfKeyVals.push(keyOut + '\"' + keyValOut + '\"');\n else if (typeof keyValOut === 'boolean' || typeof keyValOut === 'number' || keyValOut === null)\n arrOfKeyVals.push(keyOut + keyValOut);\n //check for nested objects, call recursively until no more objects\n else if (keyValOut instanceof Object) {\n arrOfKeyVals.push(keyOut + stringifyJSON(keyValOut, visited));\n }\n });\n return '{' + arrOfKeyVals + '}';\n }\n return '';\n};","import { Instruction } from \"riotprompt\";\nimport { z } from \"zod\";\nimport * as Chat from \"./chat\";\nimport { getPersonaRole, Message, Model } from \"./chat\";\nimport { DEFAULT_FORMAT_OPTIONS } from \"./constants\";\nimport { Section } from \"./items/section\";\nimport { Weighted } from \"./items/weighted\";\nimport { DEFAULT_LOGGER, wrapLogger } from \"./logger\";\nimport { Prompt } from \"./prompt\";\nimport { clean, stringifyJSON } from \"./util/general\";\n\nexport const SectionSeparatorSchema = z.enum([\"tag\", \"markdown\"]);\nexport const SectionTitlePropertySchema = z.enum([\"title\", \"name\"]);\n\nexport type SectionSeparator = z.infer<typeof SectionSeparatorSchema>;\nexport type SectionTitleProperty = z.infer<typeof SectionTitlePropertySchema>;\n\n\nexport const FormatOptionsSchema = z.object({\n sectionSeparator: SectionSeparatorSchema,\n sectionIndentation: z.boolean(),\n sectionTitleProperty: SectionTitlePropertySchema,\n sectionTitlePrefix: z.string().optional(),\n sectionTitleSeparator: z.string().optional(),\n sectionDepth: z.number().default(1),\n});\n\nexport type FormatOptions = z.infer<typeof FormatOptionsSchema>;\n\n\nexport const OptionSchema = z.object({\n logger: z.any().optional().default(DEFAULT_LOGGER),\n formatOptions: FormatOptionsSchema.partial().optional().default(DEFAULT_FORMAT_OPTIONS),\n});\n\nexport type Options = z.infer<typeof OptionSchema>;\n\nexport type OptionsParam = Partial<Options>;\n\nexport interface Instance {\n formatPersona: (model: Model, persona: Section<Instruction>) => Message;\n format: <T extends Weighted>(weightedText: T | Section<T>, sectionDepth?: number) => string;\n formatArray: <T extends Weighted>(items: (T | Section<T>)[], sectionDepth?: number) => string;\n formatPrompt: (model: Model, prompt: Prompt) => Chat.Request;\n}\n\n// Type guard to check if an object is a Section\nfunction isSection<T extends Weighted>(obj: T | Section<T>): obj is Section<T> {\n return obj && typeof obj === 'object' && 'items' in obj && Array.isArray((obj as Section<T>).items);\n}\n\n// Type guard to check if an object is a Section\nfunction isWeighted<T extends Weighted>(obj: T | Section<T>): obj is T {\n return obj && typeof obj === 'object' && 'text' in obj;\n}\n\n\nexport const create = (formatterOptions?: OptionsParam): Instance => {\n const options: Required<Options> = OptionSchema.parse(formatterOptions || {}) as Required<Options>;\n\n const logger = wrapLogger(options.logger, 'Formatter');\n\n let formatOptions: FormatOptions = DEFAULT_FORMAT_OPTIONS;\n if (options?.formatOptions) {\n formatOptions = {\n ...formatOptions,\n ...clean(options.formatOptions),\n };\n }\n\n const formatPersona = (model: Model, persona: Section<Instruction>): Message => {\n logger.silly(`Formatting persona`);\n if (persona) {\n const formattedPersona = formatSection(persona);\n\n return {\n role: getPersonaRole(model),\n content: `${formattedPersona}`,\n }\n } else {\n throw new Error(\"Persona is required\");\n }\n }\n\n const format = <T extends Weighted>(\n item: T | Section<T>,\n sectionDepth?: number,\n ): string => {\n logger.silly(`Formatting ${isSection(item) ? \"section\" : \"item\"} Item: %s`, stringifyJSON(item));\n const currentSectionDepth = sectionDepth ?? formatOptions.sectionDepth;\n logger.silly(`\\t\\tCurrent section depth: ${currentSectionDepth}`);\n\n let result: string = \"\";\n if (isSection(item)) {\n result = formatSection(item, currentSectionDepth + 1);\n } else if (isWeighted(item)) {\n result = item.text;\n } else {\n //If the item is neither a section nor a weighted item, it is empty.\n result = '';\n }\n return result;\n }\n\n const formatSection = <T extends Weighted>(section: Section<T>, sectionDepth?: number): string => {\n logger.silly(`Formatting section`);\n const currentSectionDepth = sectionDepth ?? formatOptions.sectionDepth;\n logger.silly(`\\t\\tCurrent section depth: ${currentSectionDepth}`);\n\n if (section) {\n const formattedItems = section.items.map(item => format(item, currentSectionDepth)).join(\"\\n\\n\");\n\n if (formatOptions.sectionSeparator === \"tag\") {\n return `<${section.title ?? \"section\"}>\\n${formattedItems}\\n</${section.title ?? \"section\"}>`;\n } else {\n // Default depth to 1 if not provided, resulting in H2 (##) matching the test case.\n const headingLevel = currentSectionDepth;\n const hashes = '#'.repeat(headingLevel);\n logger.silly(`\\t\\tHeading level: ${headingLevel}`);\n logger.silly(`\\t\\tSection title: ${section.title}`);\n return `${hashes} ${formatOptions.sectionTitlePrefix ? `${formatOptions.sectionTitlePrefix} ${formatOptions.sectionTitleSeparator} ` : \"\"}${section.title}\\n\\n${formattedItems}`;\n }\n } else {\n return '';\n }\n }\n\n // Helper function to format arrays of items or sections\n const formatArray = <T extends Weighted>(\n items: (T | Section<T>)[],\n sectionDepth?: number\n ): string => {\n logger.silly(`Formatting array`);\n const currentSectionDepth = sectionDepth ?? formatOptions.sectionDepth;\n return items.map(item => format(item, currentSectionDepth)).join(\"\\n\\n\");\n }\n\n const formatPrompt = (model: Model, prompt: Prompt): Chat.Request => {\n logger.silly('Formatting prompt');\n const chatRequest: Chat.Request = Chat.createRequest(model);\n\n if (prompt.persona) {\n [prompt.persona].forEach((persona: Section<Instruction>) => {\n chatRequest.addMessage(formatPersona(model, persona));\n });\n }\n\n let formattedAreas: string = formatSection(prompt.instructions) + '\\n\\n';\n\n if (prompt.contents) {\n formattedAreas += formatSection(prompt.contents) + '\\n\\n';\n }\n\n if (prompt.contexts) {\n formattedAreas += formatSection(prompt.contexts) + '\\n\\n';\n }\n\n chatRequest.addMessage({\n role: \"user\",\n content: formattedAreas,\n });\n\n return chatRequest;\n }\n\n return {\n formatPersona,\n format,\n formatPrompt,\n formatArray,\n }\n}\n","import { marked } from 'marked';\nimport { create as createSection, Section, SectionOptions, SectionOptionsSchema } from '../items/section';\nimport { create as createWeighted, Weighted, WeightedOptionsSchema } from '../items/weighted';\n\nexport const parseMarkdown = <T extends Weighted>(\n input: string | Buffer,\n options: Partial<SectionOptions> = {}\n): Section<T> => {\n\n let markdownContent;\n if (typeof input === 'string') {\n markdownContent = input;\n } else {\n markdownContent = input.toString();\n }\n\n const sectionOptions = SectionOptionsSchema.parse(options);\n\n // Use marked.lexer to get tokens without full parsing/rendering\n const tokens = marked.lexer(markdownContent);\n\n // Create the main section (with a Title from the options)\n const mainSection = createSection<T>(sectionOptions);\n\n // Track sections at each depth level\n const sectionStack: Section<T>[] = [mainSection];\n\n // Set if we've seen the first token\n let isFirstToken = true;\n\n // Set the item options\n const itemOptions = WeightedOptionsSchema.parse({\n ...sectionOptions,\n weight: sectionOptions.itemWeight,\n });\n\n for (const token of tokens) {\n switch (token.type) {\n case 'heading': {\n const depth = token.depth;\n\n // If this is the first token and it's a heading, use it as the main section title\n if (isFirstToken) {\n mainSection.title = token.text;\n isFirstToken = false;\n break;\n }\n\n isFirstToken = false;\n\n // Create a new section with this heading\n const newSection = createSection<T>({ ...sectionOptions, title: token.text });\n\n // Ensure the section stack has the right size based on this heading's depth\n // (e.g., a depth-2 heading should be added to the depth-1 section)\n // We need to ensure the stack length is exactly depth, not just less than or equal to depth\n while (sectionStack.length > depth && sectionStack.length > 1) {\n sectionStack.pop();\n }\n\n // Make sure we're at the right level for this heading\n // If we stay at the same heading level (e.g., two h2s in sequence),\n // we need to pop once more to get to the parent level\n if (sectionStack.length === depth && sectionStack.length > 1) {\n sectionStack.pop();\n }\n\n // Add new section to its parent\n const parentSection = sectionStack[sectionStack.length - 1];\n parentSection.add(newSection, itemOptions);\n\n // Push this section onto the stack\n sectionStack.push(newSection);\n break;\n }\n\n case 'paragraph': {\n isFirstToken = false;\n const instruction: T = createWeighted<T>(token.text, itemOptions);\n const currentSection = sectionStack[sectionStack.length - 1];\n currentSection.add(instruction, itemOptions);\n break;\n }\n\n case 'list': {\n isFirstToken = false;\n // Convert list items to instructions\n const listInstructionContent = token.items.map((item: any) => `- ${item.text}`).join('\\n');\n const listInstruction: T = createWeighted<T>(listInstructionContent, itemOptions);\n const currentSection = sectionStack[sectionStack.length - 1];\n currentSection.add(listInstruction, itemOptions);\n break;\n }\n\n case 'code': {\n isFirstToken = false;\n // Represent code blocks as instructions\n const codeInstruction: T = createWeighted<T>(`\\`\\`\\`${token.lang || ''}\\n${token.text}\\n\\`\\`\\``, itemOptions);\n const currentSection = sectionStack[sectionStack.length - 1];\n currentSection.add(codeInstruction, itemOptions);\n break;\n }\n\n case 'space':\n // Usually ignore space tokens between block elements\n break;\n\n default: {\n isFirstToken = false;\n // Treat other block tokens' text as instructions for robustness\n if ('text' in token && token.text) {\n const fallbackInstruction: T = createWeighted<T>(token.text, itemOptions);\n const currentSection = sectionStack[sectionStack.length - 1];\n currentSection.add(fallbackInstruction, itemOptions);\n }\n break;\n }\n }\n }\n return mainSection;\n}\n","import { create as createSection, Section, SectionOptions, SectionOptionsSchema } from '../items/section';\nimport { create as createWeighted, Weighted, WeightedOptionsSchema } from '../items/weighted';\n\nexport const parseText = <T extends Weighted>(\n input: string | Buffer,\n options: Partial<SectionOptions> = {}\n): Section<T> => {\n\n let text;\n if (typeof input === 'string') {\n text = input;\n } else {\n text = input.toString();\n }\n\n const sectionOptions = SectionOptionsSchema.parse(options);\n\n // Set the item options\n const itemOptions = WeightedOptionsSchema.parse({\n ...sectionOptions,\n weight: sectionOptions.itemWeight,\n });\n\n // Split the text on newlines\n const lines = text.split(/\\r?\\n/).filter(line => line.trim().length > 0);\n\n // Create the main section with the supplied title\n const mainSection = createSection<T>(sectionOptions);\n\n for (const line of lines) {\n const instruction: T = createWeighted<T>(line, itemOptions);\n mainSection.add(instruction, itemOptions);\n }\n\n return mainSection;\n}\n","import { DEFAULT_CHARACTER_ENCODING } from \"../constants\";\n\n// Heuristic to check for Markdown syntax. This is not a full parser.\n// It looks for common Markdown patterns.\nconst markdownRegex = /^(#+\\s|\\*\\s|-\\s|\\+\\s|>\\s|\\[.*\\]\\(.*\\)|```|~~~|---\\\\s*$)/m;\n\n/**\n * Inspects a string to see if it likely contains Markdown syntax.\n *\n * @param input The string or Buffer content to inspect.\n * @returns True if Markdown syntax is suspected, false otherwise.\n */\nexport function isMarkdown(input: string | Buffer): boolean {\n if (input == null) {\n return false;\n }\n // Convert Buffer to string if necessary\n const content = typeof input === 'string' ? input : input.toString(DEFAULT_CHARACTER_ENCODING);\n if (!content || content.trim() === '') {\n return false; // Empty string is not considered Markdown\n }\n\n // Check for common Markdown patterns in the entire content\n if (markdownRegex.test(content)) {\n return true;\n }\n\n // Fallback: Check for a high prevalence of Markdown-like list/header starters\n // or thematic breaks, or code blocks.\n // We'll consider up to the first ~2000 characters, roughly equivalent to the byte check.\n const effectiveContent = content.length > 2000 ? content.substring(0, 2000) : content;\n const lines = effectiveContent.split('\\n');\n let markdownFeatureCount = 0;\n const featurePatterns = [\n /^#+\\s+.+/, // Headers (e.g., # Heading)\n /^\\s*[*+-]\\s+.+/, // List items (e.g., * item, - item, + item)\n /^\\s*>\\s+.+/, // Blockquotes (e.g., > quote)\n /\\[.+\\]\\(.+\\)/, // Links (e.g., [text](url))\n /!\\[.+\\]\\(.+\\)/, // Images (e.g., )\n /`{1,3}[^`]+`{1,3}/, // Inline code (e.g., `code`) or code blocks (```code```)\n /^\\s*_{3,}\\s*$/, // Thematic breaks (e.g., ---, ***, ___)\n /^\\s*-{3,}\\s*$/,\n /^\\s*\\*{3,}\\s*$/\n ];\n\n for (const line of lines) {\n // Stop checking if we have already found enough features to be confident.\n // This is a small optimization for very long inputs that are clearly markdown early on.\n if (markdownFeatureCount >= 2 && lines.length > 10) { // Heuristic threshold\n const significantLineCountEarly = Math.min(lines.indexOf(line) + 1, 20);\n if (significantLineCountEarly > 0 && markdownFeatureCount / significantLineCountEarly > 0.1) {\n return true;\n }\n }\n\n for (const pattern of featurePatterns) {\n if (pattern.test(line.trim())) {\n markdownFeatureCount++;\n break; // Count each line only once\n }\n }\n }\n\n // If more than 5% of the first few lines (up to 20 lines or all lines if fewer)\n // show markdown features, or if there are at least 2 distinct features in short texts,\n // consider it Markdown.\n const significantLineCount = Math.min(lines.length, 20);\n if (significantLineCount > 0) {\n // Calculate the exact threshold percentage\n const thresholdPercentage = markdownFeatureCount / significantLineCount;\n\n // Check against the 5% threshold (0.05)\n // Using >= 0.05 exactly matches 5%, > 0.05 requires more than 5%\n if (thresholdPercentage >= 0.05 + 0.0001) { // Adding a small epsilon to ensure exactly 5% passes but just below fails\n return true;\n }\n\n // Other conditions for returning true\n if ((markdownFeatureCount >= 1 && significantLineCount <= 5) || markdownFeatureCount >= 2) {\n return true;\n }\n }\n\n return false;\n}\n\n// Example usage (optional, for testing):\n// function testIsMarkdownString() {\n// console.log('--- Testing isMarkdownString ---');\n// const markdown1 = '# Hello World\\\\nThis is a test.';\n// console.log(`Test 1 (Header): \"${markdown1.substring(0,10)}...\" -> ${isMarkdownString(markdown1)}`); // true\n\n// const markdown2 = '* Item 1\\\\n* Item 2';\n// console.log(`Test 2 (List): \"${markdown2.substring(0,10)}...\" -> ${isMarkdownString(markdown2)}`); // true\n\n// const markdown3 = '[Google](https://google.com)';\n// console.log(`Test 3 (Link): \"${markdown3.substring(0,15)}...\" -> ${isMarkdownString(markdown3)}`); // true\n\n// const markdown4 = '> This is a quote.';\n// console.log(`Test 4 (Blockquote): \"${markdown4.substring(0,10)}...\" -> ${isMarkdownString(markdown4)}`); // true\n\n// const markdown5 = '```javascript\\\\nconsole.log(\"hello\");\\\\n```';\n// console.log(`Test 5 (Code block): \"${markdown5.substring(0,15)}...\" -> ${isMarkdownString(markdown5)}`); // true\n\n// const text1 = 'This is a plain text string.';\n// console.log(`Test 6 (Plain text): \"${text1.substring(0,10)}...\" -> ${isMarkdownString(text1)}`); // false\n\n// const text2 = 'hello_world.this_is_a_test_string_with_underscores_but_not_markdown_thematic_break';\n// console.log(`Test 7 (Long non-markdown): \"${text2.substring(0,10)}...\" -> ${isMarkdownString(text2)}`); // false\n\n// const text3 = '<xml><tag>value</tag></xml>';\n// console.log(`Test 8 (XML): \"${text3.substring(0,10)}...\" -> ${isMarkdownString(text3)}`); // false\n\n// const shortMarkdown = '# H';\n// console.log(`Test 9 (Short Markdown): \"${shortMarkdown}\" -> ${isMarkdownString(shortMarkdown)}`); // true\n\n// const shortNonMarkdown = 'Hello';\n// console.log(`Test 10 (Short Non-Markdown): \"${shortNonMarkdown}\" -> ${isMarkdownString(shortNonMarkdown)}`); // false\n\n// const emptyString = '';\n// console.log(`Test 11 (Empty string): \"\" -> ${isMarkdownString(emptyString)}`); // false\n\n// const whitespaceString = ' \\t \\n ';\n// console.log(`Test 12 (Whitespace string): \"${whitespaceString.substring(0,5)}...\" -> ${isMarkdownString(whitespaceString)}`); // false\n\n// const markdownWithManyFeatures = `# Title\\\\n\\\\n* list\\\\n* list2\\\\n\\\\n> quote here\\\\n\\\\n\\`\\`\\`\\\\ncode\\\\n\\`\\`\\`\\\\n\\\\nnormal text paragraph with a [link](url).\\n---\\nAnother paragraph.\\nThis is just a test string to see how it performs with multiple markdown features present.\\nHello world this is a very long line that does not contain any markdown syntax at all, it is just plain text that goes on and on.\\n* Another list item\\n* And another one\\n# Another Header\\n## Subheader\\nThis is fun.\\nOkay I think this is enough.\\nFinal line.\\nAnother final line.\\nOne more for good measure.\\nOkay that should be enough lines to test the early exit.\\n`;\n// console.log(`Test 13 (Many Features): \"${markdownWithManyFeatures.substring(0,10)}...\" -> ${isMarkdownString(markdownWithManyFeatures)}`); // true\n\n// const htmlLike = '<div><p>Hello</p><ul><li>item</li></ul></div>';\n// console.log(`Test 14 (HTML-like): \"${htmlLike.substring(0,10)}...\" -> ${isMarkdownString(htmlLike)}`); // false\n\n// console.log('--- End Testing ---');\n// }\n\n// testIsMarkdownString();\n","import { DEFAULT_CHARACTER_ENCODING } from \"../constants\";\n\n// Returns true if the input is likely text, false if likely binary\nexport function isText(input: string | Buffer): boolean {\n let buf: Buffer;\n if (typeof input === 'string') {\n buf = Buffer.from(input, DEFAULT_CHARACTER_ENCODING);\n } else {\n buf = input;\n }\n\n // Empty buffers are considered text\n if (buf.length === 0) {\n return true;\n }\n\n // If the buffer contains null bytes, it's likely binary\n if (buf.includes(0)) {\n return false;\n }\n\n // For UTF-8 encoded text (including emoji and international characters),\n // convert to string first and check if there are non-printable characters\n const str = buf.toString(DEFAULT_CHARACTER_ENCODING);\n\n // Count the number of non-printable ASCII characters (excluding common whitespace)\n let nonPrintable = 0;\n const len = Math.min(str.length, 512); // Only check the first 512 characters for performance\n\n for (let i = 0; i < len; i++) {\n const charCode = str.charCodeAt(i);\n // Allow: tab (9), line feed (10), carriage return (13), printable ASCII (32-126)\n // Also allow all non-ASCII Unicode characters (charCode > 127)\n if (\n charCode !== 9 && charCode !== 10 && charCode !== 13 &&\n (charCode < 32 || (charCode > 126 && charCode < 128))\n ) {\n nonPrintable++;\n }\n }\n\n // If more than 10% of the checked characters are non-printable, consider it binary\n return nonPrintable / len < 0.1;\n}\n","import * as fs from 'fs/promises';\nimport * as path from 'path';\nimport { z } from 'zod';\nimport { ParametersSchema } from './items/parameters';\nimport { Section, SectionOptions, SectionOptionsSchema } from './items/section';\nimport { Weighted } from './items/weighted';\nimport { DEFAULT_LOGGER, wrapLogger } from './logger';\nimport { parseMarkdown } from './parse/markdown';\nimport { parseText } from './parse/text';\nimport { isMarkdown } from './util/markdown';\nimport { isText } from './util/text';\n\nconst OptionsSchema = z.object({\n logger: z.any().optional().default(DEFAULT_LOGGER),\n parameters: ParametersSchema.optional().default({}),\n});\n\nexport type Options = z.infer<typeof OptionsSchema>;\n\nexport type OptionsParam = Partial<Options>;\n\nexport interface Instance {\n parse: <T extends Weighted>(input: string | Buffer, options?: SectionOptions) => Section<T>;\n parseFile: <T extends Weighted>(filePath: string, options?: SectionOptions) => Promise<Section<T>>;\n}\n\nexport const create = (parserOptions?: OptionsParam): Instance => {\n const options: Required<Options> = OptionsSchema.parse(parserOptions || {}) as Required<Options>;\n const parameters = options.parameters;\n\n const logger = wrapLogger(options.logger, 'Parser');\n\n const loadOptions = (sectionOptions: Partial<SectionOptions> = {}): SectionOptions => {\n const currentOptions = SectionOptionsSchema.parse(sectionOptions);\n return {\n ...currentOptions,\n parameters: {\n ...parameters,\n ...currentOptions.parameters\n }\n }\n }\n\n const parseFile = async <T extends Weighted>(\n filePath: string,\n options: Partial<SectionOptions> = {}\n ): Promise<Section<T>> => {\n const currentOptions = loadOptions(options);\n try {\n const content = await fs.readFile(filePath, 'utf-8');\n // Only use the filename as title if no title was explicitly provided\n const fileName = path.basename(filePath, path.extname(filePath));\n return parse(content, {\n ...currentOptions,\n title: currentOptions?.title || fileName\n });\n } catch (error) {\n // Log the error or handle it appropriately\n logger.error(`Error reading or parsing file with marked at ${filePath}:`, error);\n throw new Error(`Failed to parse instructions from ${filePath}: ${error instanceof Error ? error.message : String(error)}`);\n }\n }\n\n /**\n * Reads Markdown content and parses it into a single Section.\n * \n * - If the content starts with a heading, that becomes the title of the returned Section\n * - If no heading at the start, creates a Section with no title\n * - Headers within the content create nested sections based on their depth\n * - All content is organized in a hierarchical structure based on heading levels\n *\n * @param content The content to parse\n * @returns A Section containing all content in a hierarchical structure\n */\n const parse = <T extends Weighted>(\n content: string | Buffer,\n options: Partial<SectionOptions> = {}\n ): Section<T> => {\n const currentOptions = loadOptions(options);\n\n let mainSection: Section<T>;\n if (isMarkdown(content)) {\n mainSection = parseMarkdown<T>(content, currentOptions);\n } else if (isText(content)) {\n mainSection = parseText<T>(content, currentOptions);\n } else {\n throw new Error(`Unsupported content supplied to parse, riotprompt currently only supports markdown and text`);\n }\n return mainSection;\n }\n\n return {\n parse,\n parseFile\n }\n}","// eslint-disable-next-line no-restricted-imports\nimport * as fs from 'fs';\nimport { glob } from 'glob';\nimport path from 'path';\nimport crypto from 'crypto';\n/**\n * This module exists to isolate filesystem operations from the rest of the codebase.\n * This makes testing easier by avoiding direct fs mocking in jest configuration.\n * \n * Additionally, abstracting storage operations allows for future flexibility - \n * this export utility may need to work with storage systems other than the local filesystem\n * (e.g. S3, Google Cloud Storage, etc).\n */\n\nexport interface Utility {\n exists: (path: string) => Promise<boolean>;\n isDirectory: (path: string) => Promise<boolean>;\n isFile: (path: string) => Promise<boolean>;\n isReadable: (path: string) => Promise<boolean>;\n isWritable: (path: string) => Promise<boolean>;\n isFileReadable: (path: string) => Promise<boolean>;\n isDirectoryWritable: (path: string) => Promise<boolean>;\n isDirectoryReadable: (path: string) => Promise<boolean>;\n createDirectory: (path: string) => Promise<void>;\n readFile: (path: string, encoding: string) => Promise<string>;\n readStream: (path: string) => Promise<fs.ReadStream>;\n writeFile: (path: string, data: string | Buffer, encoding: string) => Promise<void>;\n forEachFileIn: (directory: string, callback: (path: string) => Promise<void>, options?: { pattern: string, limit?: number }) => Promise<void>;\n hashFile: (path: string, length: number) => Promise<string>;\n listFiles: (directory: string) => Promise<string[]>;\n}\n\nexport const create = (params: { log?: (message: string, ...args: any[]) => void }): Utility => {\n\n // eslint-disable-next-line no-console\n const log = params.log || console.log;\n\n const exists = async (path: string): Promise<boolean> => {\n try {\n await fs.promises.stat(path);\n return true;\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n } catch (error: any) {\n return false;\n }\n }\n\n const isDirectory = async (path: string): Promise<boolean> => {\n const stats = await fs.promises.stat(path);\n if (!stats.isDirectory()) {\n log(`${path} is not a directory`);\n return false;\n }\n return true;\n }\n\n const isFile = async (path: string): Promise<boolean> => {\n const stats = await fs.promises.stat(path);\n if (!stats.isFile()) {\n log(`${path} is not a file`);\n return false;\n }\n return true;\n }\n\n const isReadable = async (path: string): Promise<boolean> => {\n try {\n await fs.promises.access(path, fs.constants.R_OK);\n } catch (error: any) {\n log(`${path} is not readable: %s %s`, error.message, error.stack);\n return false;\n }\n return true;\n }\n\n const isWritable = async (path: string): Promise<boolean> => {\n try {\n await fs.promises.access(path, fs.constants.W_OK);\n } catch (error: any) {\n log(`${path} is not writable: %s %s`, error.message, error.stack);\n return false;\n }\n return true;\n }\n\n const isFileReadable = async (path: string): Promise<boolean> => {\n return await exists(path) && await isFile(path) && await isReadable(path);\n }\n\n const isDirectoryWritable = async (path: string): Promise<boolean> => {\n return await exists(path) && await isDirectory(path) && await isWritable(path);\n }\n\n const isDirectoryReadable = async (path: string): Promise<boolean> => {\n return await exists(path) && await isDirectory(path) && await isReadable(path);\n }\n\n const createDirectory = async (path: string): Promise<void> => {\n try {\n await fs.promises.mkdir(path, { recursive: true });\n } catch (mkdirError: any) {\n throw new Error(`Failed to create output directory ${path}: ${mkdirError.message} ${mkdirError.stack}`);\n }\n }\n\n const readFile = async (path: string, encoding: string): Promise<string> => {\n return await fs.promises.readFile(path, { encoding: encoding as BufferEncoding });\n }\n\n const writeFile = async (path: string, data: string | Buffer, encoding: string): Promise<void> => {\n await fs.promises.writeFile(path, data, { encoding: encoding as BufferEncoding });\n }\n\n const forEachFileIn = async (\n directory: string,\n callback: (file: string) => Promise<void>,\n options: { pattern: string | string[], limit?: number } = { pattern: '*.*' },\n ): Promise<void> => {\n try {\n let filesProcessed = 0;\n const files = await glob(options.pattern, { cwd: directory, nodir: true });\n for (const file of files) {\n await callback(path.join(directory, file));\n filesProcessed++;\n if (options.limit && filesProcessed >= options.limit) {\n log(`Reached limit of ${options.limit} files, stopping`);\n break;\n }\n }\n } catch (err: any) {\n throw new Error(`Failed to glob pattern ${options.pattern} in ${directory}: ${err.message}`);\n }\n }\n\n const readStream = async (path: string): Promise<fs.ReadStream> => {\n return fs.createReadStream(path);\n }\n\n const hashFile = async (path: string, length: number): Promise<string> => {\n const file = await readFile(path, 'utf8');\n return crypto.createHash('sha256').update(file).digest('hex').slice(0, length);\n }\n\n const listFiles = async (directory: string): Promise<string[]> => {\n return await fs.promises.readdir(directory);\n }\n\n return {\n exists,\n isDirectory,\n isFile,\n isReadable,\n isWritable,\n isFileReadable,\n isDirectoryWritable,\n isDirectoryReadable,\n createDirectory,\n readFile,\n readStream,\n writeFile,\n forEachFileIn,\n hashFile,\n listFiles,\n };\n}","import path from \"path\";\nimport { z } from \"zod\";\nimport { DEFAULT_IGNORE_PATTERNS } from \"./constants\";\nimport { ParametersSchema } from \"./items/parameters\";\nimport { SectionOptions, SectionOptionsSchema } from \"./items/section\";\nimport { DEFAULT_LOGGER, wrapLogger } from \"./logger\";\nimport { Section, Weighted, createSection } from \"./riotprompt\";\nimport * as Storage from \"./util/storage\";\n\nconst OptionsSchema = z.object({\n logger: z.any().optional().default(DEFAULT_LOGGER),\n ignorePatterns: z.array(z.string()).optional().default(DEFAULT_IGNORE_PATTERNS),\n parameters: ParametersSchema.optional().default({}),\n});\n\nexport type Options = z.infer<typeof OptionsSchema>;\n\nexport type OptionsParam = Partial<Options>;\n\nexport interface Instance {\n load: <T extends Weighted>(contextDirectories?: string[], options?: SectionOptions) => Promise<Section<T>[]>;\n}\n\n/**\n * Extracts the first header from Markdown text\n * @param markdownText The Markdown text to parse\n * @returns The first header found in the Markdown or null if none is found\n */\nexport function extractFirstHeader(markdownText: string): string | null {\n // Regular expression to match Markdown headers (# Header, ## Header, etc.)\n const headerRegex = /^(#{1,6})\\s+(.+?)(?:\\n|$)/m;\n const match = markdownText.match(headerRegex);\n\n if (match && match[2]) {\n return match[2].trim();\n }\n\n return null;\n}\n\n/**\n * Removes the first header from Markdown text\n * @param markdownText The Markdown text to process\n * @returns The Markdown text without the first header\n */\nexport function removeFirstHeader(markdownText: string): string {\n // Regular expression to match Markdown headers (# Header, ## Header, etc.)\n const headerRegex = /^(#{1,6})\\s+(.+?)(?:\\n|$)/m;\n const match = markdownText.match(headerRegex);\n\n if (match) {\n return markdownText.replace(headerRegex, '').trim();\n }\n\n return markdownText;\n}\n\nexport const create = (loaderOptions?: OptionsParam): Instance => {\n const options: Required<Options> = OptionsSchema.parse(loaderOptions || {}) as Required<Options>;\n const parameters = options.parameters;\n\n const logger = wrapLogger(options.logger, 'Loader');\n const ignorePatterns = options.ignorePatterns;\n\n const loadOptions = (sectionOptions: Partial<SectionOptions> = {}): SectionOptions => {\n const currentOptions = SectionOptionsSchema.parse(sectionOptions);\n return {\n ...currentOptions,\n parameters: {\n ...parameters,\n ...currentOptions.parameters\n }\n }\n }\n\n /**\n * Loads context from the provided directories and returns instruction sections\n * \n * @param contextDirectories Directories containing context files\n * @returns Array of instruction sections loaded from context directories\n */\n const load = async<T extends Weighted>(\n contextDirectories: string[] = [],\n options: Partial<SectionOptions> = {}\n ): Promise<Section<T>[]> => {\n const sectionOptions = loadOptions(options);\n\n logger.debug(`Loading context from ${contextDirectories}`);\n const contextSections: Section<T>[] = [];\n\n if (!contextDirectories || contextDirectories.length === 0) {\n logger.debug(`No context directories provided, returning empty context`);\n return contextSections;\n }\n\n const storage = Storage.create({ log: logger.debug });\n\n // Add context sections from each directory\n for (const contextDir of contextDirectories) {\n try {\n const dirName = path.basename(contextDir);\n logger.debug(`Processing context directory ${dirName}`);\n let mainContextSection: Section<T>;\n\n // First check if there's a context.md file\n const contextFile = path.join(contextDir, 'context.md');\n\n if (await storage.exists(contextFile)) {\n logger.debug(`Found context.md file in ${contextDir}`);\n const mainContextContent = await storage.readFile(contextFile, 'utf8');\n // Extract the first header from the Markdown content\n const firstHeader = extractFirstHeader(mainContextContent);\n\n // Use the header from context.md as the section title, or fallback to directory name\n const sectionTitle = firstHeader || dirName;\n mainContextSection = createSection<T>({ ...sectionOptions, title: sectionTitle });\n\n // Add content without the header\n if (firstHeader) {\n mainContextSection.add(removeFirstHeader(mainContextContent), { ...sectionOptions });\n } else {\n mainContextSection.add(mainContextContent, { ...sectionOptions });\n }\n } else {\n // If no context.md exists, use directory name as title\n mainContextSection = createSection<T>({ ...sectionOptions, title: dirName });\n }\n\n // Get all other files in the directory\n const files = await storage.listFiles(contextDir);\n const ignorePatternsRegex = ignorePatterns.map(pattern => new RegExp(pattern, 'i'));\n\n const filteredFiles = files.filter(file =>\n !ignorePatternsRegex.some(regex => regex.test(file))\n );\n\n for (const file of filteredFiles) {\n // Skip the context.md file as it's already processed\n if (file === 'context.md') continue;\n\n logger.debug(`Processing file ${file} in ${contextDir}`);\n const filePath = path.join(contextDir, file);\n if (await storage.isFile(filePath)) {\n const fileContent = await storage.readFile(filePath, 'utf8');\n let sectionName = file;\n let contentToAdd = fileContent;\n\n // Extract header if it exists\n if (file.endsWith('.md')) {\n const fileHeader = extractFirstHeader(fileContent);\n if (fileHeader) {\n sectionName = fileHeader;\n // Remove the header from the content\n contentToAdd = removeFirstHeader(fileContent);\n }\n }\n\n // Create a subsection with the extracted name\n const fileSection = createSection<T>({ ...sectionOptions, title: sectionName });\n fileSection.add(contentToAdd, { ...sectionOptions });\n\n // Add this file section to the main context section\n mainContextSection.add(fileSection as unknown as T, { ...sectionOptions });\n }\n }\n\n contextSections.push(mainContextSection);\n } catch (error) {\n logger.error(`Error processing context directory ${contextDir}: ${error}`);\n }\n }\n\n return contextSections;\n }\n\n\n return {\n load\n }\n}\n","import path from 'path';\nimport { z } from 'zod';\nimport { ParametersSchema } from './items/parameters';\nimport { SectionOptions, SectionOptionsSchema } from './items/section';\nimport { DEFAULT_LOGGER, wrapLogger } from './logger';\nimport { Formatter, Parser, Section, Weighted } from './riotprompt';\nimport * as Storage from './util/storage';\n\nconst OptionsSchema = z.object({\n logger: z.any().optional().default(DEFAULT_LOGGER),\n configDir: z.string().default('./overrides'),\n overrides: z.boolean().default(false),\n parameters: ParametersSchema.optional().default({}),\n});\n\nexport type Options = z.infer<typeof OptionsSchema>;\n\nexport type OptionsParam = Partial<Options>;\n\nexport interface Instance {\n customize: <T extends Weighted>(overrideFile: string, section: Section<T>, sectionOptions?: SectionOptions) => Promise<Section<T>>;\n override: <T extends Weighted>(overrideFile: string, section: Section<T>, sectionOptions?: SectionOptions) =>\n Promise<{ override?: Section<T>, prepend?: Section<T>, append?: Section<T> }>;\n}\n\nexport const create = (overrideOptions: OptionsParam = {}): Instance => {\n const options: Required<Options> = OptionsSchema.parse(overrideOptions) as Required<Options>;\n\n const parameters = options.parameters;\n\n const logger = wrapLogger(options?.logger, 'Override');\n const storage = Storage.create({ log: logger.debug });\n\n const loadOptions = (sectionOptions: Partial<SectionOptions> = {}): SectionOptions => {\n const currentOptions = SectionOptionsSchema.parse(sectionOptions);\n return {\n ...currentOptions,\n parameters: {\n ...parameters,\n ...currentOptions.parameters\n }\n }\n }\n\n const override = async <T extends Weighted>(\n overrideFile: string,\n section: Section<T>,\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<{ override?: Section<T>, prepend?: Section<T>, append?: Section<T> }> => {\n const currentSectionOptions = loadOptions(sectionOptions);\n\n const baseFile = path.join(options.configDir, overrideFile);\n const preFile = baseFile.replace('.md', '-pre.md');\n const postFile = baseFile.replace('.md', '-post.md');\n\n const response: { override?: Section<T>, prepend?: Section<T>, append?: Section<T> } = {};\n\n if (await storage.exists(preFile)) {\n logger.silly('Found pre file %s', preFile);\n const parser = Parser.create({ logger });\n response.prepend = await parser.parseFile<T>(preFile, currentSectionOptions);\n }\n\n if (await storage.exists(postFile)) {\n logger.silly('Found post file %s', postFile);\n const parser = Parser.create({ logger });\n response.append = await parser.parseFile<T>(postFile, currentSectionOptions);\n }\n\n if (await storage.exists(baseFile)) {\n logger.silly('Found base file %s', baseFile);\n if (options.overrides) {\n logger.warn('WARNING: Core directives are being overwritten by custom configuration');\n const parser = Parser.create({ logger });\n response.override = await parser.parseFile<T>(baseFile, currentSectionOptions);\n } else {\n logger.error('ERROR: Core directives are being overwritten by custom configuration');\n throw new Error('Core directives are being overwritten by custom configuration, but overrides are not enabled. Please enable --overrides to use this feature.');\n }\n }\n\n return response;\n }\n\n const customize = async <T extends Weighted>(\n overrideFile: string,\n section: Section<T>,\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Section<T>> => {\n const currentSectionOptions = loadOptions(sectionOptions);\n\n const { overrideContent, prepend, append }: { overrideContent?: Section<T>, prepend?: Section<T>, append?: Section<T> } = await override(overrideFile, section, currentSectionOptions);\n let finalSection: Section<T> = section;\n\n if (overrideContent) {\n if (options.overrides) {\n logger.warn('Override found, replacing content from file %s', overrideContent);\n finalSection = overrideContent;\n } else {\n logger.error('ERROR: Core directives are being overwritten by custom configuration');\n throw new Error('Core directives are being overwritten by custom configuration, but overrides are not enabled. Please enable --overrides to use this feature.');\n }\n }\n\n if (prepend) {\n logger.silly('Prepend found, adding to content from file %s', prepend);\n finalSection = finalSection.prepend(prepend);\n }\n\n if (append) {\n logger.silly('Append found, adding to content from file %s', append);\n finalSection = finalSection.append(append);\n }\n\n const formatter = Formatter.create({ logger });\n logger.silly('Final section %s:\\n\\n%s\\n\\n', logger.name, formatter.format(finalSection));\n\n return finalSection;\n }\n\n return {\n override,\n customize,\n }\n}","import path from \"path\";\nimport { z } from \"zod\";\nimport { ParametersSchema } from \"./items/parameters\";\nimport { SectionOptions, SectionOptionsSchema } from \"./items/section\";\nimport { DEFAULT_LOGGER, wrapLogger } from \"./logger\";\nimport { Content, Context, createPrompt, createSection, Instruction, Loader, Override, Parser, Prompt, Section, Weighted } from \"./riotprompt\";\n\nconst OptionSchema = z.object({\n logger: z.any().optional().default(DEFAULT_LOGGER),\n basePath: z.string(),\n overridePath: z.string().optional().default(\"./\"),\n overrides: z.boolean().optional().default(false),\n parameters: ParametersSchema.optional().default({}),\n});\n\nexport type Options = z.infer<typeof OptionSchema>;\n\nexport type OptionsParam = Required<Pick<Options, 'basePath'>> & Partial<Omit<Options, 'basePath'>>;\n\nexport interface Instance {\n addPersonaPath(contentPath: string, sectionOptions?: Partial<SectionOptions>): Promise<Instance>;\n addContextPath(contentPath: string, sectionOptions?: Partial<SectionOptions>): Promise<Instance>;\n addInstructionPath(contentPath: string, sectionOptions?: Partial<SectionOptions>): Promise<Instance>;\n addContentPath(contentPath: string, sectionOptions?: Partial<SectionOptions>): Promise<Instance>;\n addContent(content: string, sectionOptions?: Partial<SectionOptions>): Promise<Instance>;\n addContext(context: string, sectionOptions?: Partial<SectionOptions>): Promise<Instance>;\n loadContext(contextDirectories: string[], sectionOptions?: Partial<SectionOptions>): Promise<Instance>;\n loadContent(contentDirectories: string[], sectionOptions?: Partial<SectionOptions>): Promise<Instance>;\n build(): Promise<Prompt>;\n}\n\nexport const create = (builderOptions: OptionsParam): Instance => {\n const options: Required<Options> = OptionSchema.parse(builderOptions) as Required<Options>;\n\n const logger = wrapLogger(options.logger, 'Builder');\n const parser = Parser.create({ logger });\n const override = Override.create({\n logger, configDir: options.overridePath || \"./\",\n overrides: options.overrides || false\n });\n const loader = Loader.create({ logger });\n\n const personaSection: Section<Instruction> = createSection({ title: \"Persona\" });\n const contextSection: Section<Context> = createSection({ title: \"Context\" });\n const instructionSection: Section<Instruction> = createSection({ title: \"Instruction\" });\n const contentSection: Section<Content> = createSection({ title: \"Content\" });\n const parameters = options.parameters;\n\n\n const instance: Partial<Instance> = {}\n\n const loadOptions = (sectionOptions: Partial<SectionOptions> = {}): SectionOptions => {\n const currentOptions = SectionOptionsSchema.parse(sectionOptions);\n return {\n ...currentOptions,\n parameters: {\n ...parameters,\n ...currentOptions.parameters\n }\n }\n }\n\n const loadDirectories = async <T extends Weighted>(\n directories: string[],\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Section<T>[]> => {\n const currentOptions = loadOptions(sectionOptions);\n logger.debug(\"Loading directories\", directories);\n const sections: Section<T>[] = await loader.load<T>(directories, currentOptions);\n return sections;\n }\n\n const loadContext = async (\n contextDirectories: string[],\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Instance> => {\n const currentOptions = loadOptions(sectionOptions);\n logger.debug('Loading context', contextDirectories);\n const context: Section<Context>[] = await loadDirectories<Context>(contextDirectories, currentOptions);\n contextSection.add(context);\n return instance as Instance;\n }\n instance.loadContext = loadContext;\n\n const loadContent = async (\n contentDirectories: string[],\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Instance> => {\n const currentOptions = loadOptions(sectionOptions);\n const content: Section<Content>[] = await loadDirectories<Content>(contentDirectories, currentOptions);\n contentSection.add(content);\n return instance as Instance;\n }\n instance.loadContent = loadContent;\n\n const loadPath = async <T extends Weighted>(\n contentPath: string,\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Section<T>> => {\n const currentOptions = loadOptions(sectionOptions);\n const defaultPath = path.join(options.basePath as string, contentPath);\n const section: Section<T> = await parser.parseFile<T>(defaultPath, currentOptions);\n const overrideSection = await override.customize<T>(contentPath, section, currentOptions);\n return overrideSection;\n }\n\n const addPersonaPath = async (\n contentPath: string,\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Instance> => {\n const currentOptions = loadOptions(sectionOptions);\n const persona: Section<Instruction> = await loadPath<Instruction>(contentPath, currentOptions);\n personaSection.add(persona);\n return instance as Instance;\n }\n instance.addPersonaPath = addPersonaPath;\n\n const addContextPath = async (\n contentPath: string,\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Instance> => {\n logger.debug(\"Adding context path\", contentPath);\n const currentOptions = loadOptions(sectionOptions);\n const context: Section<Context> = await loadPath<Context>(contentPath, currentOptions);\n contextSection.add(context);\n return instance as Instance;\n }\n instance.addContextPath = addContextPath;\n\n const addInstructionPath = async (\n contentPath: string,\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Instance> => {\n logger.debug(\"Adding instruction path\", contentPath);\n const currentOptions = loadOptions(sectionOptions);\n const instruction: Section<Instruction> = await loadPath<Instruction>(contentPath, currentOptions);\n instructionSection.add(instruction);\n return instance as Instance;\n }\n instance.addInstructionPath = addInstructionPath;\n\n const addContentPath = async (\n contentPath: string,\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Instance> => {\n logger.debug(\"Adding content path\", contentPath);\n const currentOptions = loadOptions(sectionOptions);\n const content: Section<Content> = await loadPath<Content>(contentPath, currentOptions);\n contentSection.add(content);\n return instance as Instance;\n }\n instance.addContentPath = addContentPath;\n\n const addContent = async (\n content: string | Buffer,\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Instance> => {\n logger.debug(\"Adding content\", typeof content);\n const currentOptions = loadOptions(sectionOptions);\n const parsedContentSection: Section<Content> = parser.parse<Content>(content, currentOptions);\n contentSection.add(parsedContentSection);\n return instance as Instance;\n }\n instance.addContent = addContent;\n\n const addContext = async (\n context: string | Buffer,\n sectionOptions: Partial<SectionOptions> = {}\n ): Promise<Instance> => {\n logger.debug(\"Adding context\", typeof context);\n const currentOptions = loadOptions(sectionOptions);\n const parsedContextSection: Section<Context> = parser.parse<Context>(context, currentOptions);\n contextSection.add(parsedContextSection);\n return instance as Instance;\n }\n instance.addContext = addContext;\n\n const build = async () => {\n logger.debug(\"Building prompt\", {});\n const prompt = createPrompt({ persona: personaSection, contexts: contextSection, instructions: instructionSection, contents: contentSection });\n return prompt;\n }\n instance.build = build;\n\n return instance as Instance;\n}\n"],"names":["ParametersSchema","z","record","string","union","number","boolean","array","create","parameters","apply","text","trimmedParams","Object","keys","forEach","key","trim","replace","match","p1","paramKey","parameter","undefined","toString","Array","isArray","join","object","weight","optional","WeightedOptionsSchema","options","weightedOptions","parse","parameterizedText","applyParameters","createWeighted","SectionOptionsSchema","title","itemWeight","default","items","sectionOptions","sectionItemOptions","append","item","itemOptions","push","section","prepend","unshift","insert","index","splice","remove","add","persona","instructions","contents","contexts","DEFAULT_CHARACTER_ENCODING","LIBRARY_NAME","DEFAULT_PERSONA_ROLE","DEFAULT_IGNORE_PATTERNS","DEFAULT_SECTION_SEPARATOR","DEFAULT_SECTION_INDENTATION","DEFAULT_SECTION_TITLE_PROPERTY","DEFAULT_FORMAT_OPTIONS","sectionSeparator","sectionIndentation","sectionTitleProperty","sectionDepth","getPersonaRole","model","createRequest","messages","addMessage","message","DEFAULT_LOGGER","name","debug","args","console","info","warn","error","verbose","silly","wrapLogger","toWrap","requiredMethods","missingMethods","filter","method","length","Error","log","level","clean","obj","fromEntries","entries","_","v","stringifyJSON","visited","Set","arrOfKeyVals","arrVals","objKeys","has","el","keyOut","keyValOut","Function","SectionSeparatorSchema","enum","SectionTitlePropertySchema","FormatOptionsSchema","sectionTitlePrefix","sectionTitleSeparator","OptionSchema","logger","any","formatOptions","partial","isSection","isWeighted","formatterOptions","formatPersona","formattedPersona","formatSection","role","content","format","currentSectionDepth","result","formattedItems","map","headingLevel","hashes","repeat","formatArray","formatPrompt","prompt","chatRequest","Chat","formattedAreas","parseMarkdown","input","markdownContent","tokens","marked","lexer","mainSection","createSection","sectionStack","isFirstToken","token","type","depth","newSection","pop","parentSection","instruction","currentSection","listInstructionContent","listInstruction","codeInstruction","lang","fallbackInstruction","parseText","lines","split","line","markdownRegex","isMarkdown","test","effectiveContent","substring","markdownFeatureCount","featurePatterns","significantLineCountEarly","Math","min","indexOf","pattern","significantLineCount","thresholdPercentage","isText","buf","Buffer","from","includes","str","nonPrintable","len","i","charCode","charCodeAt","OptionsSchema","parserOptions","loadOptions","currentOptions","parseFile","filePath","fs","readFile","fileName","path","basename","extname","String","params","exists","promises","stat","isDirectory","stats","isFile","isReadable","access","constants","R_OK","stack","isWritable","W_OK","isFileReadable","isDirectoryWritable","isDirectoryReadable","createDirectory","mkdir","recursive","mkdirError","encoding","writeFile","data","forEachFileIn","directory","callback","filesProcessed","files","glob","cwd","nodir","file","limit","err","readStream","createReadStream","hashFile","crypto","createHash","update","digest","slice","listFiles","readdir","ignorePatterns","extractFirstHeader","markdownText","headerRegex","removeFirstHeader","loaderOptions","load","contextDirectories","contextSections","storage","Storage","contextDir","dirName","mainContextSection","contextFile","mainContextContent","firstHeader","sectionTitle","ignorePatternsRegex","RegExp","filteredFiles","some","regex","fileContent","sectionName","contentToAdd","endsWith","fileHeader","fileSection","configDir","overrides","overrideOptions","override","overrideFile","currentSectionOptions","baseFile","preFile","postFile","response","parser","Parser","customize","overrideContent","finalSection","formatter","Formatter","basePath","overridePath","builderOptions","Override","loader","Loader","personaSection","contextSection","instructionSection","contentSection","instance","loadDirectories","directories","sections","loadContext","context","loadContent","contentDirectories","loadPath","contentPath","defaultPath","overrideSection","addPersonaPath","addContextPath","addInstructionPath","addContentPath","addContent","parsedContentSection","addContext","parsedContextSection","build","createPrompt"],"mappings":"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"}
|