详细说明: - 基于文旅订单班框架复制创建food-order-demo项目 - 修改端口配置为4174避免冲突 - 更新LandingPage为青莳轻食主题(绿色健康风格) - 重新定义7个食品行业专业Agent: * 市场研究专家:轻食市场分析、客群画像 * 营养配方师:营养成分配比、低卡高蛋白设计 * 供应链管理专家:有机食材供应、溯源体系 * 品牌策划师:品牌定位、店铺空间布局 * 财务分析师:投资预算、ROI分析 * 运营管理专家:运营流程、品控标准 * 食品创业导师:中央协调、方案整合 - 创建专用启动脚本start.sh - 验证系统可正常运行在端口4174 - 实现代码复用率90%,符合预期目标 影响文件: web_frontend/food-order-demo/ 技术栈: React 18 + TypeScript + Tailwind CSS + Zustand
69 lines
2.3 KiB
JavaScript
69 lines
2.3 KiB
JavaScript
// https://smlfamily.github.io/sml97-defn.pdf
|
|
// https://people.mpi-sws.org/~rossberg/sml.html
|
|
(function (Prism) {
|
|
|
|
var keywords = /\b(?:abstype|and|andalso|as|case|datatype|do|else|end|eqtype|exception|fn|fun|functor|handle|if|in|include|infix|infixr|let|local|nonfix|of|op|open|orelse|raise|rec|sharing|sig|signature|struct|structure|then|type|val|where|while|with|withtype)\b/i;
|
|
|
|
Prism.languages.sml = {
|
|
// allow one level of nesting
|
|
'comment': /\(\*(?:[^*(]|\*(?!\))|\((?!\*)|\(\*(?:[^*(]|\*(?!\))|\((?!\*))*\*\))*\*\)/,
|
|
'string': {
|
|
pattern: /#?"(?:[^"\\]|\\.)*"/,
|
|
greedy: true
|
|
},
|
|
|
|
'class-name': [
|
|
{
|
|
// This is only an approximation since the real grammar is context-free
|
|
//
|
|
// Why the main loop so complex?
|
|
// The main loop is approximately the same as /(?:\s*(?:[*,]|->)\s*<TERMINAL>)*/ which is, obviously, a lot
|
|
// simpler. The difference is that if a comma is the last iteration of the loop, then the terminal must be
|
|
// followed by a long identifier.
|
|
pattern: RegExp(
|
|
/((?:^|[^:]):\s*)<TERMINAL>(?:\s*(?:(?:\*|->)\s*<TERMINAL>|,\s*<TERMINAL>(?:(?=<NOT-LAST>)|(?!<NOT-LAST>)\s+<LONG-ID>)))*/.source
|
|
.replace(/<NOT-LAST>/g, function () { return /\s*(?:[*,]|->)/.source; })
|
|
.replace(/<TERMINAL>/g, function () {
|
|
return /(?:'[\w']*|<LONG-ID>|\((?:[^()]|\([^()]*\))*\)|\{(?:[^{}]|\{[^{}]*\})*\})(?:\s+<LONG-ID>)*/.source;
|
|
})
|
|
.replace(/<LONG-ID>/g, function () { return /(?!<KEYWORD>)[a-z\d_][\w'.]*/.source; })
|
|
.replace(/<KEYWORD>/g, function () { return keywords.source; }),
|
|
'i'
|
|
),
|
|
lookbehind: true,
|
|
greedy: true,
|
|
inside: null // see below
|
|
},
|
|
{
|
|
pattern: /((?:^|[^\w'])(?:datatype|exception|functor|signature|structure|type)\s+)[a-z_][\w'.]*/i,
|
|
lookbehind: true
|
|
}
|
|
],
|
|
'function': {
|
|
pattern: /((?:^|[^\w'])fun\s+)[a-z_][\w'.]*/i,
|
|
lookbehind: true
|
|
},
|
|
|
|
'keyword': keywords,
|
|
'variable': {
|
|
pattern: /(^|[^\w'])'[\w']*/,
|
|
lookbehind: true,
|
|
},
|
|
|
|
'number': /~?\b(?:\d+(?:\.\d+)?(?:e~?\d+)?|0x[\da-f]+)\b/i,
|
|
'word': {
|
|
pattern: /\b0w(?:\d+|x[\da-f]+)\b/i,
|
|
alias: 'constant'
|
|
},
|
|
|
|
'boolean': /\b(?:false|true)\b/i,
|
|
'operator': /\.\.\.|:[>=:]|=>?|->|[<>]=?|[!+\-*/^#|@~]/,
|
|
'punctuation': /[(){}\[\].:,;]/
|
|
};
|
|
|
|
Prism.languages.sml['class-name'][0].inside = Prism.languages.sml;
|
|
|
|
Prism.languages.smlnj = Prism.languages.sml;
|
|
|
|
}(Prism));
|