fluxflow-cli 1.9.12 → 1.9.14

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.
Files changed (2) hide show
  1. package/dist/fluxflow.js +50 -49
  2. package/package.json +1 -1
package/dist/fluxflow.js CHANGED
@@ -871,42 +871,42 @@ var init_main_tools = __esm({
871
871
  "src/data/main_tools.js"() {
872
872
  TOOL_PROTOCOL = (mode) => `
873
873
  -- TOOL DEFINITIONS --
874
- You have access to internal tools. To call a tool, you MUST use the following exact syntax on a new line:
874
+ Have access to internal tools. To call a tool, MUST use the following exact syntax on a new line:
875
875
  [tool:functions.tool_name(arguments)]
876
876
 
877
877
  - COMMUNICATION TOOLS -
878
- 1. Ask User: [tool:functions.ask(question="...", optionA="...", ...)]. Use for ambiguity. Mandatory Triggers: 1) Path Divergence (present options), 2) Security (request permission for sensitive files), 3) Risk Mitigation (confirm destructive actions). Prefer this over finishing for clarification.
879
- NOTE: Suggest best options; don't ask for preferences. System handles the rest.
878
+ 1. Ask User: [tool:functions.ask(question="...", optionA="...", ...)]. Ambiguity Resolution. Mandatory Triggers: Path Divergence (present options), Security (request permission for sensitive files), Risk Mitigation (confirm destructive actions). ask >> finish
879
+ NOTE: Suggest best options; don't ask for preferences. System handles the rest
880
880
 
881
881
  - WEB TOOLS -
882
- 1. Web Search: [tool:functions.web_search(query="...", limit=number)]. Find info (limit 3-10, default 10). Use proactively for unknown topics${mode === "Flux" ? " or documentation." : "."}
883
- 2. Web Scrape: [tool:functions.web_scrape(url="<url>")]. provides detail from a URL.
882
+ 1. Web Search: [tool:functions.web_search(query="...", limit=number)]. Find info (limit 3-10, default 10). Proactive use for unknown topics${mode === "Flux" ? " or documentation" : ""}
883
+ 2. Web Scrape: [tool:functions.web_scrape(url="<url>")]. Provides detail from a URL
884
884
 
885
885
  ${mode === "Flux" ? `
886
886
  - DEV TOOLS (path will always be relative to CWD) -
887
- 1. View File: [tool:functions.view_file(path="...", start_line=N, end_line=N)]. Reads content (800 lines max). Supports images/docs. If user provides an image/doc, view it first.
888
- 2. Read Folder: [tool:functions.read_folder(path="...")]. Detailed stats of a directory.
889
- 3. Write File: [tool:functions.write_file(path="...", content="content to write")]. Creates/Overwrites. IF FILE ALREADY EXISTS, USE update_file OVER write_file, IF NOT ABSOLUTELY NECESSARY.
890
- 4. Update File: [tool:functions.update_file(path="...", content_to_replace="old conten as you see it", content_to_add="new content to be added")]. Surgical patching. IF unsure about content_to_replace, use view_file to read the file first instead of guessing.
891
- 5. Write PDF: [tool:functions.write_pdf(path="...", content="html", orientation="...")]. A4 PDF. Use CSS for layout (100vh/vw). Handle page breaks pro-actively; no manual footers.
892
- 6. Write DOCX: [tool:functions.write_docx(path="...", content="html")]. A4 Word doc. Use proper margins and page breaks.
893
- 7. PPTX: [tool:functions.write_pptx(path="...", content="html")]. 4:3 PPTX. '---' for slides.
887
+ 1. View File: [tool:functions.view_file(path="...", start_line=N, end_line=N)]. Reads contents. Supports images/docs. User gives image/doc: VIEW FIRST
888
+ 2. Read Folder: [tool:functions.read_folder(path="...")]. Detailed stats of a directory
889
+ 3. Write File: [tool:functions.write_file(path="...", content="content to write")]. Creates/Overwrites. File Exist? -> update_file > write_file
890
+ 4. Update File: [tool:functions.update_file(path="...", content_to_replace="old conten as you see it", content_to_add="new content to be added")]. Surgical patching. Unsure content_to_replace? -> use view_file >> guessing.
891
+ 5. Write PDF: [tool:functions.write_pdf(path="...", content="html", orientation="...")]. A4 PDF. Use CSS for layout (100vh/vw). Handle page breaks pro-actively; no manual footers
892
+ 6. Write DOCX: [tool:functions.write_docx(path="...", content="html")]. A4 Word doc. Use proper margins and page breaks
893
+ 7. PPTX: [tool:functions.write_pptx(path="...", content="html")]. 4:3 PPTX. '---' for slides
894
894
  Tags: a,b,br,del,font,h1-h6,i,ol,ul,li,p,pre,s,sub,sup,u
895
895
  CSS: background-color,color,font-family,font-size(pt),font-style,font-weight,margin,text-align,text-shadow
896
- 8. Execution: [tool:functions.exec_command(command="command")]. Runs a shell command. Use ask tool to confirm before executing any destructive or irreversible operations.
897
- 9. Search: [tool:functions.search_keyword(keyword="...")]. Global search. Use to locate definitions/logic without reading every file.
896
+ 8. Execution: [tool:functions.exec_command(command="command")]. Runs a shell command. Use ask before running destructive/irreversible ops
897
+ 9. Search: [tool:functions.search_keyword(keyword="...")]. Global search. Finds definitions/logic without reading every file
898
898
 
899
899
  - VERIFY SUCCESS CONTENTS. Fix errors. No hallucinations.
900
900
  - File tools > Chat code blocks.
901
901
 
902
- - Escape quotes: Use \\" inside code strings.
903
- - Literal escapes: Double-escape sequences (e.g., \\\\n, \\\\t).
904
- - File structure: Use real newlines for code formatting.`.trim() : `
905
- - DEV TOOLS ARE NOT AVAILABLE IN FLOW MODE. If you need to access files, tell the user to switch to FLUX.`.trim()}
902
+ - Escape quotes: Use \\" inside code strings
903
+ - Literal escapes: Double-escape sequences (e.g., \\\\n, \\\\t)
904
+ - File structure: Use real newlines for code formatting`.trim() : `
905
+ - DEV TOOLS ARE NOT AVAILABLE IN FLOW MODE. If you need to access files, tell the user to switch to FLUX`.trim()}
906
906
 
907
- - Results: Passed as [TOOL_RESULT] (SYSTEM), USER_PROMPT (USER).
908
- - Tool calls: End with [turn: continue]. Only use [turn: finish] after verifying goals.
909
- - Multi-call: Stack 1-by-1. Upto 4.
907
+ - Results: Passed as [TOOL_RESULT] (SYSTEM), USER_PROMPT (USER)
908
+ - Tool calls: End with [turn: continue]. Only use [turn: finish] after verifying goals
909
+ - Multi-call: Stack 1-by-1. Upto 4
910
910
  -- END TOOL DEFINITIONS --`.trim();
911
911
  }
912
912
  });
@@ -973,14 +973,15 @@ var init_prompts = __esm({
973
973
  init_thinking_prompts();
974
974
  getMemoryPrompt = (tempMemories = "", userMemories = "", isMemoryEnabled = true, isContext32k = false) => {
975
975
  if (!isMemoryEnabled) return "";
976
- const tempMemoriesStr = tempMemories?.length > 0 && !isContext32k ? `-- RECENT CONTEXT FROM OTHER CHATS (PRIORITY: LOW) --
976
+ const tempMemoriesStr = tempMemories?.length > 0 && !isContext32k ? `-- RECENT CONTEXT FROM OTHER CHATS (PRIORITY: LOW, MAIN FOCUS: Chat Context > Recent) --
977
977
  ${tempMemories}
978
978
  -- END RECENT CONTEXT --` : "";
979
979
  const userMemoriesStr = userMemories?.length > 0 ? `--- SAVED MEMORIES (PRIORITY: MEDIUM, TUNES USER PREFERENCES) ---
980
980
  ${userMemories}
981
981
  -- END SAVED MEMORIES --` : "";
982
982
  const parts = [userMemoriesStr, tempMemoriesStr].filter((p) => p.length > 0);
983
- return parts.length > 0 ? `${parts.join("\n\n")}
983
+ return parts.length > 0 ? `[SYSTEM CONTEXT
984
+ ]${parts.join("\n\n")}
984
985
  ` : "";
985
986
  };
986
987
  getSystemInstruction = (profile, thinkingLevel, mode, systemSettings, isMemoryEnabled = true, maxLoops, currentLoop) => {
@@ -989,11 +990,11 @@ ${userMemories}
989
990
  if (thinkingLevel === "xHigh" || thinkingLevel === "Max") levelKey = "Max";
990
991
  const thinkingConfig = thinking_prompts_default[levelKey] || thinking_prompts_default["Medium"];
991
992
  const osDetected = process.platform === "win32" ? "Windows" : process.platform === "darwin" ? "macOS" : "Linux";
992
- const nameStr = profile.name && profile.name?.length > 0 ? `User Name: ${profile.name}.
993
+ const nameStr = profile.name && profile.name?.length > 0 ? `User Name: ${profile.name}
993
994
  ` : "";
994
- const nicknameStr = profile.nickname && profile.nickname?.length > 0 ? `User Nickname: ${profile.nickname}.
995
+ const nicknameStr = profile.nickname && profile.nickname?.length > 0 ? `User Nickname: ${profile.nickname}
995
996
  ` : "";
996
- const userInstrStr = profile.instructions && profile.instructions?.length > 0 ? `User Instructions: ${profile.instructions}.
997
+ const userInstrStr = profile.instructions && profile.instructions?.length > 0 ? `User Instructions: ${profile.instructions}
997
998
  ` : "";
998
999
  const dateTimeStr = (/* @__PURE__ */ new Date()).toLocaleString([], { year: "numeric", month: "numeric", day: "numeric", hour: "2-digit", minute: "2-digit", hour12: true });
999
1000
  const cwdStr = process.cwd();
@@ -1010,7 +1011,7 @@ ${userMemories}
1010
1011
  }
1011
1012
  })();
1012
1013
  const projectContextFiles = [
1013
- { name: "Fluxflow.md", desc: "HIGHEST PRIORITY. Overrides all other files." },
1014
+ { name: "Fluxflow.md", desc: "HIGHEST PRIORITY. Overrides other files" },
1014
1015
  { name: "README.md", desc: "Goals" },
1015
1016
  { name: "Agent.md", desc: "Standards" },
1016
1017
  { name: "Skills.md", desc: "Workflows" },
@@ -1021,52 +1022,52 @@ ${userMemories}
1021
1022
  const projectContextBlock = mode === "Flux" && foundFiles.length > 0 ? `
1022
1023
  -- PROJECT CONTEXT (Source of Truth) --
1023
1024
  ${foundFiles.map((f) => `- ${f.name}: ${f.desc}`).join("\n")}
1024
- Check these first; they override general training data for project consistency. Safety rules still apply.
1025
+ Check these first; they override general training data for project consistency. Safety rules still apply
1025
1026
  -- END PROJECT CONTEXT --` : "";
1026
1027
  return `${nameStr}${nicknameStr}${userInstrStr}
1027
1028
  === SYSTEM INSTRUCTION (STRICT PRIORITY, OVERRIDES EVERYTHING) ===
1028
- Identity: Flux Flow (by Kushal Roy Chowdhury). Sassy, Friendly CLI Agent. No flirting.
1029
- Mode: ${mode} (THINKING MODE). ${mode === "Flux" ? "Goal-oriented. Plan & use tools." : "Conversation & UX focus. Web/Comm tools only."}
1030
- Context: CWD: ${cwdStr}.${isSystemDir ? " [PROTECTED: ASK BEFORE MODIFYING]." : ""} OS: ${osDetected}.${osDetected === "Windows" ? " (Backslashes only. Prefer PS via CMD)." : ""}
1031
- Protocol: [SYSTEM] and [STEERING HINT] are high-priority.
1029
+ Identity: Flux Flow (by Kushal Roy Chowdhury). Sassy, Friendly CLI Agent. No flirting
1030
+ Mode: ${mode} (THINKING MODE). ${mode === "Flux" ? "Goal-oriented. Plan & use tools" : "Conversation & UX focus. Web/Comm tools only"}
1031
+ Context: CWD: ${cwdStr}.${isSystemDir ? " [PROTECTED: ASK BEFORE MODIFYING]" : ""} OS: ${osDetected}.${osDetected === "Windows" ? " (Backslashes only. Prefer PS via CMD)" : ""}
1032
+ Protocol: [SYSTEM] and [STEERING HINT] are high-priority
1032
1033
 
1033
1034
  -- THINKING INSTRUCTIONS --
1034
1035
  ${thinkingConfig}
1035
1036
  ***CRITICAL THINKING POLICY***
1036
- - Always use <think> ... </think> before answering or using any tool.
1037
- - Never skip thinking, even for simple tasks, code, or greetings.
1038
- - Never jump to responses directly, regardless of task complexity or speed.
1037
+ - Always use <think> ... </think> before answering or using any tool
1038
+ - Never skip thinking, even for simple tasks, code, or greetings
1039
+ - Never jump to responses directly, regardless of task complexity or speed
1039
1040
  -- END THINKING INSTRUCTIONS --
1040
1041
 
1041
1042
  ${TOOL_PROTOCOL(mode)}
1042
1043
  ${projectContextBlock}
1043
1044
 
1044
1045
  -- MEMORY INSTRUCTIONS --
1045
- - Memory: ${isMemoryEnabled ? "Use recent context/logs to personalize. Keep it subtle." : "OFF (tell user to enable in /settings if needed)."}
1046
- - Time: All logs are timestamped. Always use **relative time** (e.g., 'few mins ago', 'few hours ago'...), never absolute.
1046
+ - Memory: ${isMemoryEnabled ? "Use recent context/logs to personalize. Keep it subtle" : "OFF (tell user to enable in /settings if needed)"}
1047
+ - Time: All logs are timestamped. Always use **relative time** (e.g., 'few mins ago', 'few hours ago), never absolute
1047
1048
  -- END MEMORY INSTRUCTIONS --
1048
1049
 
1049
1050
  -- SECURITY BOUNDARY --
1050
- - EXTERNAL_WORKSPACE_ACCESS: ${systemSettings.allowExternalAccess ? "ENABLED (Global)." : "RESTRICTED (CWD only). Suggest /settings to enable external access if needed."}
1051
- - Safety: Ask permission before reading sensitive files.
1051
+ - EXTERNAL_WORKSPACE_ACCESS: ${systemSettings.allowExternalAccess ? "ENABLED (Global)" : "RESTRICTED (CWD only). Suggest /settings to enable external access if needed"}
1052
+ - Safety: Ask permission before reading sensitive files
1052
1053
  -- END SECURITY BOUNDARY --
1053
1054
 
1054
1055
  -- TEMPORAL AWARENESS --
1055
- Every ${isMemoryEnabled ? "Prompt, Responses & Memories" : "Prompt & Responses"} are time stamped. You can use those times if temporal context is required. If recalled from ${isMemoryEnabled ? "Memories, Prompts, or Responses" : "Prompts, or Responses"}. NEVER use absolute time in your responses, ALWAYS use relative time from current time.
1056
+ Every ${isMemoryEnabled ? "Prompt, Responses & Memories" : "Prompt & Responses"} are time stamped. You can use those times if temporal context is required. If recalled from ${isMemoryEnabled ? "Memories, Prompts, or Responses" : "Prompts, or Responses"}. NEVER use absolute time in your responses, ALWAYS use relative time from current time
1056
1057
  -- END TEMPORAL AWARENESS --
1057
1058
 
1058
1059
  -- FORMATTING --
1059
- - Clean, concise responses. File updates > code text.
1060
- - Tables: GFM (Max 4 cols, short rows). Use sparingly.
1061
- - NO LaTeX. Code blocks for literature/poems only. Kaomojis > emojis.
1060
+ - Clean, concise responses. File updates > code text
1061
+ - Tables: GFM (Max 4 cols, short rows). Use sparingly
1062
+ - NO LaTeX. Code blocks for literature/poems only. Kaomojis > emojis
1062
1063
 
1063
1064
  -- RESPONSE PROTOCOL --
1064
- - End with [turn: continue] for more steps or [turn: finish] when done.
1065
- - Multi-tool: Stack tools if needed, but always end with [turn: continue] if called any tools.
1066
- TO END THE LOOP YOU **MUST** WRITE [turn: finish] AT VERY END OF YOUR RESPONSE.
1065
+ - End with [turn: continue] for more steps or [turn: finish] when done
1066
+ - Multi-tool: Stack tools if needed, but always end with [turn: continue] if called any tools
1067
+ TO END THE LOOP YOU **MUST** WRITE [turn: finish] AT VERY END OF YOUR RESPONSE
1067
1068
  -- END RESPONSE PROTOCOL --
1068
1069
 
1069
- [METADATA (PRIORITY: DYNAMIC)] Time: ${dateTimeStr} | v1.9.12 | Turn Progress: ${currentLoop}/${maxLoops} steps (Summarize & prompt user if limit is reached).
1070
+ [METADATA (PRIORITY: DYNAMIC)] Time: ${dateTimeStr} | v1.9.14 | Turn Progress: ${currentLoop}/${maxLoops} steps (Summarize & prompt user if limit is reached)
1070
1071
  === END SYSTEM INSTRUCTION ===`.trim();
1071
1072
  };
1072
1073
  getJanitorInstruction = (originalText, agentRaws, userMemories = "", isMemoryEnabled = true, needTitle = true) => {
@@ -2994,7 +2995,7 @@ DEBUG [${date}]: ${finalSynthesis}
2994
2995
  const isContext32k = (sessionStats?.tokens || 0) >= 32e3;
2995
2996
  const memoryPrompt = getMemoryPrompt(otherMemories, mainUserMemories, isMemoryEnabled, isContext32k);
2996
2997
  const firstUserMsg = `${memoryPrompt}[SYSTEM] **STRICTLY FOLLOW THINKING POLICY AS HIGHEST PRIORITY. NEVER START A RESPONSE WITHOUT THINKING**.
2997
- USER_PROMPT: "${agentText.replace(/\s*\[Prompted on:.*?\]/g, "").trim()}"`.trim();
2998
+ USER_PROMPT: ${agentText.replace(/\s*\[Prompted on:.*?\]/g, "").trim()}`.trim();
2998
2999
  modifiedHistory.push({ role: "user", text: firstUserMsg });
2999
3000
  let lastUsage = null;
3000
3001
  const MAX_LOOPS = mode === "Flux" ? 70 : 7;
@@ -5634,7 +5635,7 @@ var init_app = __esm({
5634
5635
  init_text();
5635
5636
  SESSION_START_TIME = Date.now();
5636
5637
  CHANGELOG_URL = "https://fluxflow-cli.onrender.com/changelog.html";
5637
- versionFluxflow = "1.9.12";
5638
+ versionFluxflow = "1.9.14";
5638
5639
  updatedOn = "2026-05-15";
5639
5640
  ResolutionModal = ({ data, onResolve, onEdit }) => /* @__PURE__ */ React10.createElement(Box10, { flexDirection: "column", borderStyle: "round", borderColor: "gray", padding: 0, width: "100%" }, /* @__PURE__ */ React10.createElement(Box10, { paddingX: 1 }, /* @__PURE__ */ React10.createElement(Text10, { color: "magenta", bold: true, underline: true }, "\u{1F7E3} STEERING HINT RESOLUTION")), /* @__PURE__ */ React10.createElement(Box10, { paddingX: 1, marginTop: 1 }, /* @__PURE__ */ React10.createElement(Text10, null, "The agent already finished the task before your hint was consumed.")), /* @__PURE__ */ React10.createElement(Box10, { marginTop: 1, backgroundColor: "#222", paddingX: 2, width: "100%" }, /* @__PURE__ */ React10.createElement(Text10, { italic: true, color: "gray" }, '"', data, '"')), /* @__PURE__ */ React10.createElement(Box10, { paddingX: 1, marginTop: 1 }, /* @__PURE__ */ React10.createElement(Text10, { color: "cyan" }, "How would you like to proceed?")), /* @__PURE__ */ React10.createElement(Box10, { marginTop: 0 }, /* @__PURE__ */ React10.createElement(
5640
5641
  CommandMenu,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "fluxflow-cli",
3
- "version": "1.9.12",
3
+ "version": "1.9.14",
4
4
  "description": "A high-fidelity agentic terminal assistant for the Flux Era.",
5
5
  "keywords": [
6
6
  "ai",