tweakcc-fixed 2.0.13 → 2.0.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.
- package/README.md +3 -3
- package/dist/{config-CWf6QnZA.mjs → config-Cm8OeFpK.mjs} +45 -45
- package/dist/{content-CQB3e2Mu.mjs → content-HDL8pov8.mjs} +1 -1
- package/dist/identifierUnion-CqfoGx_F.mjs +1 -0
- package/dist/index.mjs +1 -1
- package/dist/lib/index.mjs +1 -1
- package/dist/{nativeInstallation-PcRMjj4R.mjs → nativeInstallation-CHSAij_R.mjs} +1 -1
- package/package.json +1 -1
- package/dist/identifierUnion-CV566DfO.mjs +0 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import{createRequire as e}from"node:module";import t from"chalk";import*as n from"node:os";import r,{EOL as i}from"node:os";import*as a from"node:fs/promises";import o from"node:fs/promises";import*as s from"node:fs";import c from"node:fs";import*as l from"node:path";import u from"node:path";import*as d from"fs";import*as f from"path";import*as p from"os";import*as m from"child_process";import*as h from"crypto";import{spawnSync as g}from"node:child_process";import _ from"gray-matter";import{fileURLToPath as v}from"node:url";import{Worker as y}from"node:worker_threads";import{diffWordsWithSpace as b}from"diff";let x=null;async function S(){if(x!==null)return x;try{return await import(`node-lief`),x=await import(`./nativeInstallation-PcRMjj4R.mjs`),x}catch(e){return U(`Error loading native installation module: ${e instanceof Error?e.message:String(e)}`),e instanceof Error&&U(e),null}}async function C(e,t){let n=await S();return n?n.extractClaudeJsFromNativeInstallation(e,t):{data:null,clearBytecode:!1,error:`node-lief native module unavailable on this platform/runtime (cannot extract from native installs)`}}async function w(e,t,n,r){let i=await S();if(!i)throw Error("`repackNativeInstallation()` called but `node-lief` is not available. This is unexpected - `extractClaudeJsFromNativeInstallation()` should have been called first.");i.repackNativeInstallation(e,t,n,r)}async function T(e){let t=await S();return t?t.resolveNixBinaryWrapper(e):null}const E={themes:[{name:`Dark mode`,id:`dark`,colors:{autoAccept:`rgb(175,135,255)`,bashBorder:`rgb(253,93,177)`,claude:`rgb(215,119,87)`,claudeShimmer:`rgb(235,159,127)`,claudeBlue_FOR_SYSTEM_SPINNER:`rgb(147,165,255)`,claudeBlueShimmer_FOR_SYSTEM_SPINNER:`rgb(177,195,255)`,permission:`rgb(177,185,249)`,permissionShimmer:`rgb(207,215,255)`,planMode:`rgb(72,150,140)`,ide:`rgb(71,130,200)`,promptBorder:`rgb(136,136,136)`,promptBorderShimmer:`rgb(166,166,166)`,text:`rgb(255,255,255)`,inverseText:`rgb(0,0,0)`,inactive:`rgb(153,153,153)`,subtle:`rgb(80,80,80)`,suggestion:`rgb(177,185,249)`,remember:`rgb(177,185,249)`,background:`rgb(0,204,204)`,success:`rgb(78,186,101)`,error:`rgb(255,107,128)`,warning:`rgb(255,193,7)`,warningShimmer:`rgb(255,223,57)`,diffAdded:`rgb(34,92,43)`,diffRemoved:`rgb(122,41,54)`,diffAddedDimmed:`rgb(71,88,74)`,diffRemovedDimmed:`rgb(105,72,77)`,diffAddedWord:`rgb(56,166,96)`,diffRemovedWord:`rgb(179,89,107)`,diffAddedWordDimmed:`rgb(46,107,58)`,diffRemovedWordDimmed:`rgb(139,57,69)`,red_FOR_SUBAGENTS_ONLY:`rgb(220,38,38)`,blue_FOR_SUBAGENTS_ONLY:`rgb(37,99,235)`,green_FOR_SUBAGENTS_ONLY:`rgb(22,163,74)`,yellow_FOR_SUBAGENTS_ONLY:`rgb(202,138,4)`,purple_FOR_SUBAGENTS_ONLY:`rgb(147,51,234)`,orange_FOR_SUBAGENTS_ONLY:`rgb(234,88,12)`,pink_FOR_SUBAGENTS_ONLY:`rgb(219,39,119)`,cyan_FOR_SUBAGENTS_ONLY:`rgb(8,145,178)`,professionalBlue:`rgb(106,155,204)`,rainbow_red:`rgb(235,95,87)`,rainbow_orange:`rgb(245,139,87)`,rainbow_yellow:`rgb(250,195,95)`,rainbow_green:`rgb(145,200,130)`,rainbow_blue:`rgb(130,170,220)`,rainbow_indigo:`rgb(155,130,200)`,rainbow_violet:`rgb(200,130,180)`,rainbow_red_shimmer:`rgb(250,155,147)`,rainbow_orange_shimmer:`rgb(255,185,137)`,rainbow_yellow_shimmer:`rgb(255,225,155)`,rainbow_green_shimmer:`rgb(185,230,180)`,rainbow_blue_shimmer:`rgb(180,205,240)`,rainbow_indigo_shimmer:`rgb(195,180,230)`,rainbow_violet_shimmer:`rgb(230,180,210)`,clawd_body:`rgb(215,119,87)`,clawd_background:`rgb(0,0,0)`,userMessageBackground:`rgb(55, 55, 55)`,bashMessageBackgroundColor:`rgb(65, 60, 65)`,memoryBackgroundColor:`rgb(55, 65, 70)`,rate_limit_fill:`rgb(177,185,249)`,rate_limit_empty:`rgb(80,83,112)`}},{name:`Light mode`,id:`light`,colors:{autoAccept:`rgb(135,0,255)`,bashBorder:`rgb(255,0,135)`,claude:`rgb(215,119,87)`,claudeShimmer:`rgb(245,149,117)`,claudeBlue_FOR_SYSTEM_SPINNER:`rgb(87,105,247)`,claudeBlueShimmer_FOR_SYSTEM_SPINNER:`rgb(117,135,255)`,permission:`rgb(87,105,247)`,permissionShimmer:`rgb(137,155,255)`,planMode:`rgb(0,102,102)`,ide:`rgb(71,130,200)`,promptBorder:`rgb(153,153,153)`,promptBorderShimmer:`rgb(183,183,183)`,text:`rgb(0,0,0)`,inverseText:`rgb(255,255,255)`,inactive:`rgb(102,102,102)`,subtle:`rgb(175,175,175)`,suggestion:`rgb(87,105,247)`,remember:`rgb(0,0,255)`,background:`rgb(0,153,153)`,success:`rgb(44,122,57)`,error:`rgb(171,43,63)`,warning:`rgb(150,108,30)`,warningShimmer:`rgb(200,158,80)`,diffAdded:`rgb(105,219,124)`,diffRemoved:`rgb(255,168,180)`,diffAddedDimmed:`rgb(199,225,203)`,diffRemovedDimmed:`rgb(253,210,216)`,diffAddedWord:`rgb(47,157,68)`,diffRemovedWord:`rgb(209,69,75)`,diffAddedWordDimmed:`rgb(144,194,156)`,diffRemovedWordDimmed:`rgb(232,165,173)`,red_FOR_SUBAGENTS_ONLY:`rgb(220,38,38)`,blue_FOR_SUBAGENTS_ONLY:`rgb(37,99,235)`,green_FOR_SUBAGENTS_ONLY:`rgb(22,163,74)`,yellow_FOR_SUBAGENTS_ONLY:`rgb(202,138,4)`,purple_FOR_SUBAGENTS_ONLY:`rgb(147,51,234)`,orange_FOR_SUBAGENTS_ONLY:`rgb(234,88,12)`,pink_FOR_SUBAGENTS_ONLY:`rgb(219,39,119)`,cyan_FOR_SUBAGENTS_ONLY:`rgb(8,145,178)`,professionalBlue:`rgb(106,155,204)`,rainbow_red:`rgb(235,95,87)`,rainbow_orange:`rgb(245,139,87)`,rainbow_yellow:`rgb(250,195,95)`,rainbow_green:`rgb(145,200,130)`,rainbow_blue:`rgb(130,170,220)`,rainbow_indigo:`rgb(155,130,200)`,rainbow_violet:`rgb(200,130,180)`,rainbow_red_shimmer:`rgb(250,155,147)`,rainbow_orange_shimmer:`rgb(255,185,137)`,rainbow_yellow_shimmer:`rgb(255,225,155)`,rainbow_green_shimmer:`rgb(185,230,180)`,rainbow_blue_shimmer:`rgb(180,205,240)`,rainbow_indigo_shimmer:`rgb(195,180,230)`,rainbow_violet_shimmer:`rgb(230,180,210)`,clawd_body:`rgb(215,119,87)`,clawd_background:`rgb(0,0,0)`,userMessageBackground:`rgb(240, 240, 240)`,bashMessageBackgroundColor:`rgb(250, 245, 250)`,memoryBackgroundColor:`rgb(230, 245, 250)`,rate_limit_fill:`rgb(87,105,247)`,rate_limit_empty:`rgb(39,47,111)`}},{name:`Light mode (ANSI colors only)`,id:`light-ansi`,colors:{autoAccept:`ansi:magenta`,bashBorder:`ansi:magenta`,claude:`ansi:redBright`,claudeShimmer:`ansi:yellowBright`,claudeBlue_FOR_SYSTEM_SPINNER:`ansi:blue`,claudeBlueShimmer_FOR_SYSTEM_SPINNER:`ansi:blueBright`,permission:`ansi:blue`,permissionShimmer:`ansi:blueBright`,planMode:`ansi:cyan`,ide:`ansi:blueBright`,promptBorder:`ansi:white`,promptBorderShimmer:`ansi:whiteBright`,text:`ansi:black`,inverseText:`ansi:white`,inactive:`ansi:blackBright`,subtle:`ansi:blackBright`,suggestion:`ansi:blue`,remember:`ansi:blue`,background:`ansi:cyan`,success:`ansi:green`,error:`ansi:red`,warning:`ansi:yellow`,warningShimmer:`ansi:yellowBright`,diffAdded:`ansi:green`,diffRemoved:`ansi:red`,diffAddedDimmed:`ansi:green`,diffRemovedDimmed:`ansi:red`,diffAddedWord:`ansi:greenBright`,diffRemovedWord:`ansi:redBright`,diffAddedWordDimmed:`ansi:green`,diffRemovedWordDimmed:`ansi:red`,red_FOR_SUBAGENTS_ONLY:`ansi:red`,blue_FOR_SUBAGENTS_ONLY:`ansi:blue`,green_FOR_SUBAGENTS_ONLY:`ansi:green`,yellow_FOR_SUBAGENTS_ONLY:`ansi:yellow`,purple_FOR_SUBAGENTS_ONLY:`ansi:magenta`,orange_FOR_SUBAGENTS_ONLY:`ansi:redBright`,pink_FOR_SUBAGENTS_ONLY:`ansi:magentaBright`,cyan_FOR_SUBAGENTS_ONLY:`ansi:cyan`,professionalBlue:`ansi:blueBright`,rainbow_red:`ansi:red`,rainbow_orange:`ansi:redBright`,rainbow_yellow:`ansi:yellow`,rainbow_green:`ansi:green`,rainbow_blue:`ansi:cyan`,rainbow_indigo:`ansi:blue`,rainbow_violet:`ansi:magenta`,rainbow_red_shimmer:`ansi:redBright`,rainbow_orange_shimmer:`ansi:yellow`,rainbow_yellow_shimmer:`ansi:yellowBright`,rainbow_green_shimmer:`ansi:greenBright`,rainbow_blue_shimmer:`ansi:cyanBright`,rainbow_indigo_shimmer:`ansi:blueBright`,rainbow_violet_shimmer:`ansi:magentaBright`,clawd_body:`ansi:redBright`,clawd_background:`ansi:black`,userMessageBackground:`ansi:white`,bashMessageBackgroundColor:`ansi:whiteBright`,memoryBackgroundColor:`ansi:white`,rate_limit_fill:`ansi:yellow`,rate_limit_empty:`ansi:black`}},{name:`Dark mode (ANSI colors only)`,id:`dark-ansi`,colors:{autoAccept:`ansi:magentaBright`,bashBorder:`ansi:magentaBright`,claude:`ansi:redBright`,claudeShimmer:`ansi:yellowBright`,claudeBlue_FOR_SYSTEM_SPINNER:`ansi:blueBright`,claudeBlueShimmer_FOR_SYSTEM_SPINNER:`ansi:blueBright`,permission:`ansi:blueBright`,permissionShimmer:`ansi:blueBright`,planMode:`ansi:cyanBright`,ide:`ansi:blue`,promptBorder:`ansi:white`,promptBorderShimmer:`ansi:whiteBright`,text:`ansi:whiteBright`,inverseText:`ansi:black`,inactive:`ansi:white`,subtle:`ansi:white`,suggestion:`ansi:blueBright`,remember:`ansi:blueBright`,background:`ansi:cyanBright`,success:`ansi:greenBright`,error:`ansi:redBright`,warning:`ansi:yellowBright`,warningShimmer:`ansi:yellowBright`,diffAdded:`ansi:green`,diffRemoved:`ansi:red`,diffAddedDimmed:`ansi:green`,diffRemovedDimmed:`ansi:red`,diffAddedWord:`ansi:greenBright`,diffRemovedWord:`ansi:redBright`,diffAddedWordDimmed:`ansi:green`,diffRemovedWordDimmed:`ansi:red`,red_FOR_SUBAGENTS_ONLY:`ansi:redBright`,blue_FOR_SUBAGENTS_ONLY:`ansi:blueBright`,green_FOR_SUBAGENTS_ONLY:`ansi:greenBright`,yellow_FOR_SUBAGENTS_ONLY:`ansi:yellowBright`,purple_FOR_SUBAGENTS_ONLY:`ansi:magentaBright`,orange_FOR_SUBAGENTS_ONLY:`ansi:redBright`,pink_FOR_SUBAGENTS_ONLY:`ansi:magentaBright`,cyan_FOR_SUBAGENTS_ONLY:`ansi:cyanBright`,professionalBlue:`rgb(106,155,204)`,rainbow_red:`ansi:red`,rainbow_orange:`ansi:redBright`,rainbow_yellow:`ansi:yellow`,rainbow_green:`ansi:green`,rainbow_blue:`ansi:cyan`,rainbow_indigo:`ansi:blue`,rainbow_violet:`ansi:magenta`,rainbow_red_shimmer:`ansi:redBright`,rainbow_orange_shimmer:`ansi:yellow`,rainbow_yellow_shimmer:`ansi:yellowBright`,rainbow_green_shimmer:`ansi:greenBright`,rainbow_blue_shimmer:`ansi:cyanBright`,rainbow_indigo_shimmer:`ansi:blueBright`,rainbow_violet_shimmer:`ansi:magentaBright`,clawd_body:`ansi:redBright`,clawd_background:`ansi:black`,userMessageBackground:`ansi:blackBright`,bashMessageBackgroundColor:`ansi:black`,memoryBackgroundColor:`ansi:blackBright`,rate_limit_fill:`ansi:yellow`,rate_limit_empty:`ansi:white`}},{name:`Light mode (colorblind-friendly)`,id:`light-daltonized`,colors:{autoAccept:`rgb(135,0,255)`,bashBorder:`rgb(0,102,204)`,claude:`rgb(255,153,51)`,claudeShimmer:`rgb(255,183,101)`,claudeBlue_FOR_SYSTEM_SPINNER:`rgb(51,102,255)`,claudeBlueShimmer_FOR_SYSTEM_SPINNER:`rgb(101,152,255)`,permission:`rgb(51,102,255)`,permissionShimmer:`rgb(101,152,255)`,planMode:`rgb(51,102,102)`,ide:`rgb(71,130,200)`,promptBorder:`rgb(153,153,153)`,promptBorderShimmer:`rgb(183,183,183)`,text:`rgb(0,0,0)`,inverseText:`rgb(255,255,255)`,inactive:`rgb(102,102,102)`,subtle:`rgb(175,175,175)`,suggestion:`rgb(51,102,255)`,remember:`rgb(51,102,255)`,background:`rgb(0,153,153)`,success:`rgb(0,102,153)`,error:`rgb(204,0,0)`,warning:`rgb(255,153,0)`,warningShimmer:`rgb(255,183,50)`,diffAdded:`rgb(153,204,255)`,diffRemoved:`rgb(255,204,204)`,diffAddedDimmed:`rgb(209,231,253)`,diffRemovedDimmed:`rgb(255,233,233)`,diffAddedWord:`rgb(51,102,204)`,diffRemovedWord:`rgb(153,51,51)`,diffAddedWordDimmed:`rgb(102,153,204)`,diffRemovedWordDimmed:`rgb(204,153,153)`,red_FOR_SUBAGENTS_ONLY:`rgb(204,0,0)`,blue_FOR_SUBAGENTS_ONLY:`rgb(0,102,204)`,green_FOR_SUBAGENTS_ONLY:`rgb(0,204,0)`,yellow_FOR_SUBAGENTS_ONLY:`rgb(255,204,0)`,purple_FOR_SUBAGENTS_ONLY:`rgb(128,0,128)`,orange_FOR_SUBAGENTS_ONLY:`rgb(255,128,0)`,pink_FOR_SUBAGENTS_ONLY:`rgb(255,102,178)`,cyan_FOR_SUBAGENTS_ONLY:`rgb(0,178,178)`,professionalBlue:`rgb(106,155,204)`,rainbow_red:`rgb(235,95,87)`,rainbow_orange:`rgb(245,139,87)`,rainbow_yellow:`rgb(250,195,95)`,rainbow_green:`rgb(145,200,130)`,rainbow_blue:`rgb(130,170,220)`,rainbow_indigo:`rgb(155,130,200)`,rainbow_violet:`rgb(200,130,180)`,rainbow_red_shimmer:`rgb(250,155,147)`,rainbow_orange_shimmer:`rgb(255,185,137)`,rainbow_yellow_shimmer:`rgb(255,225,155)`,rainbow_green_shimmer:`rgb(185,230,180)`,rainbow_blue_shimmer:`rgb(180,205,240)`,rainbow_indigo_shimmer:`rgb(195,180,230)`,rainbow_violet_shimmer:`rgb(230,180,210)`,clawd_body:`rgb(215,119,87)`,clawd_background:`rgb(0,0,0)`,userMessageBackground:`rgb(220, 220, 220)`,bashMessageBackgroundColor:`rgb(250, 245, 250)`,memoryBackgroundColor:`rgb(230, 245, 250)`,rate_limit_fill:`rgb(51,102,255)`,rate_limit_empty:`rgb(23,46,114)`}},{name:`Dark mode (colorblind-friendly)`,id:`dark-daltonized`,colors:{autoAccept:`rgb(175,135,255)`,bashBorder:`rgb(51,153,255)`,claude:`rgb(255,153,51)`,claudeShimmer:`rgb(255,183,101)`,claudeBlue_FOR_SYSTEM_SPINNER:`rgb(153,204,255)`,claudeBlueShimmer_FOR_SYSTEM_SPINNER:`rgb(183,224,255)`,permission:`rgb(153,204,255)`,permissionShimmer:`rgb(183,224,255)`,planMode:`rgb(102,153,153)`,ide:`rgb(71,130,200)`,promptBorder:`rgb(136,136,136)`,promptBorderShimmer:`rgb(166,166,166)`,text:`rgb(255,255,255)`,inverseText:`rgb(0,0,0)`,inactive:`rgb(153,153,153)`,subtle:`rgb(80,80,80)`,suggestion:`rgb(153,204,255)`,remember:`rgb(153,204,255)`,background:`rgb(0,204,204)`,success:`rgb(51,153,255)`,error:`rgb(255,102,102)`,warning:`rgb(255,204,0)`,warningShimmer:`rgb(255,234,50)`,diffAdded:`rgb(0,68,102)`,diffRemoved:`rgb(102,0,0)`,diffAddedDimmed:`rgb(62,81,91)`,diffRemovedDimmed:`rgb(62,44,44)`,diffAddedWord:`rgb(0,119,179)`,diffRemovedWord:`rgb(179,0,0)`,diffAddedWordDimmed:`rgb(26,99,128)`,diffRemovedWordDimmed:`rgb(128,21,21)`,red_FOR_SUBAGENTS_ONLY:`rgb(255,102,102)`,blue_FOR_SUBAGENTS_ONLY:`rgb(102,178,255)`,green_FOR_SUBAGENTS_ONLY:`rgb(102,255,102)`,yellow_FOR_SUBAGENTS_ONLY:`rgb(255,255,102)`,purple_FOR_SUBAGENTS_ONLY:`rgb(178,102,255)`,orange_FOR_SUBAGENTS_ONLY:`rgb(255,178,102)`,pink_FOR_SUBAGENTS_ONLY:`rgb(255,153,204)`,cyan_FOR_SUBAGENTS_ONLY:`rgb(102,204,204)`,professionalBlue:`rgb(106,155,204)`,rainbow_red:`rgb(235,95,87)`,rainbow_orange:`rgb(245,139,87)`,rainbow_yellow:`rgb(250,195,95)`,rainbow_green:`rgb(145,200,130)`,rainbow_blue:`rgb(130,170,220)`,rainbow_indigo:`rgb(155,130,200)`,rainbow_violet:`rgb(200,130,180)`,rainbow_red_shimmer:`rgb(250,155,147)`,rainbow_orange_shimmer:`rgb(255,185,137)`,rainbow_yellow_shimmer:`rgb(255,225,155)`,rainbow_green_shimmer:`rgb(185,230,180)`,rainbow_blue_shimmer:`rgb(180,205,240)`,rainbow_indigo_shimmer:`rgb(195,180,230)`,rainbow_violet_shimmer:`rgb(230,180,210)`,clawd_body:`rgb(215,119,87)`,clawd_background:`rgb(0,0,0)`,userMessageBackground:`rgb(55, 55, 55)`,bashMessageBackgroundColor:`rgb(65, 60, 65)`,memoryBackgroundColor:`rgb(55, 65, 70)`,rate_limit_fill:`rgb(153,204,255)`,rate_limit_empty:`rgb(69,92,115)`}},{name:`Monochrome`,id:`monochrome`,colors:{autoAccept:`rgb(200,200,200)`,bashBorder:`rgb(180,180,180)`,claude:`rgb(255,255,255)`,claudeShimmer:`rgb(230,230,230)`,claudeBlue_FOR_SYSTEM_SPINNER:`rgb(200,200,200)`,claudeBlueShimmer_FOR_SYSTEM_SPINNER:`rgb(220,220,220)`,permission:`rgb(200,200,200)`,permissionShimmer:`rgb(220,220,220)`,planMode:`rgb(180,180,180)`,ide:`rgb(190,190,190)`,promptBorder:`rgb(160,160,160)`,promptBorderShimmer:`rgb(180,180,180)`,text:`rgb(255,255,255)`,inverseText:`rgb(40,40,40)`,inactive:`rgb(120,120,120)`,subtle:`rgb(100,100,100)`,suggestion:`rgb(200,200,200)`,remember:`rgb(200,200,200)`,background:`rgb(180,180,180)`,success:`rgb(220,220,220)`,error:`rgb(180,180,180)`,warning:`rgb(200,200,200)`,warningShimmer:`rgb(220,220,220)`,diffAdded:`rgb(90,90,90)`,diffRemoved:`rgb(60,60,60)`,diffAddedDimmed:`rgb(110,110,110)`,diffRemovedDimmed:`rgb(80,80,80)`,diffAddedWord:`rgb(200,200,200)`,diffRemovedWord:`rgb(80,80,80)`,diffAddedWordDimmed:`rgb(160,160,160)`,diffRemovedWordDimmed:`rgb(70,70,70)`,red_FOR_SUBAGENTS_ONLY:`rgb(200,200,200)`,blue_FOR_SUBAGENTS_ONLY:`rgb(180,180,180)`,green_FOR_SUBAGENTS_ONLY:`rgb(210,210,210)`,yellow_FOR_SUBAGENTS_ONLY:`rgb(190,190,190)`,purple_FOR_SUBAGENTS_ONLY:`rgb(170,170,170)`,orange_FOR_SUBAGENTS_ONLY:`rgb(195,195,195)`,pink_FOR_SUBAGENTS_ONLY:`rgb(205,205,205)`,cyan_FOR_SUBAGENTS_ONLY:`rgb(185,185,185)`,professionalBlue:`rgb(190,190,190)`,rainbow_red:`rgb(240,240,240)`,rainbow_orange:`rgb(230,230,230)`,rainbow_yellow:`rgb(220,220,220)`,rainbow_green:`rgb(210,210,210)`,rainbow_blue:`rgb(200,200,200)`,rainbow_indigo:`rgb(190,190,190)`,rainbow_violet:`rgb(180,180,180)`,rainbow_red_shimmer:`rgb(255,255,255)`,rainbow_orange_shimmer:`rgb(245,245,245)`,rainbow_yellow_shimmer:`rgb(235,235,235)`,rainbow_green_shimmer:`rgb(225,225,225)`,rainbow_blue_shimmer:`rgb(215,215,215)`,rainbow_indigo_shimmer:`rgb(205,205,205)`,rainbow_violet_shimmer:`rgb(195,195,195)`,clawd_body:`rgb(255,255,255)`,clawd_background:`rgb(40,40,40)`,userMessageBackground:`rgb(70,70,70)`,bashMessageBackgroundColor:`rgb(65,65,65)`,memoryBackgroundColor:`rgb(75,75,75)`,rate_limit_fill:`rgb(200,200,200)`,rate_limit_empty:`rgb(90,90,90)`}}],thinkingVerbs:{format:`{}… `,verbs:`Accomplishing.Actioning.Actualizing.Architecting.Baking.Beaming.Beboppin'.Befuddling.Billowing.Blanching.Bloviating.Boogieing.Boondoggling.Booping.Bootstrapping.Brewing.Burrowing.Calculating.Canoodling.Caramelizing.Cascading.Catapulting.Cerebrating.Channeling.Channelling.Choreographing.Churning.Clauding.Coalescing.Cogitating.Combobulating.Composing.Computing.Concocting.Considering.Contemplating.Cooking.Crafting.Creating.Crunching.Crystallizing.Cultivating.Deciphering.Deliberating.Determining.Dilly-dallying.Discombobulating.Doing.Doodling.Drizzling.Ebbing.Effecting.Elucidating.Embellishing.Enchanting.Envisioning.Evaporating.Fermenting.Fiddle-faddling.Finagling.Flambéing.Flibbertigibbeting.Flowing.Flummoxing.Fluttering.Forging.Forming.Frolicking.Frosting.Gallivanting.Galloping.Garnishing.Generating.Germinating.Gitifying.Grooving.Gusting.Harmonizing.Hashing.Hatching.Herding.Honking.Hullaballooing.Hyperspacing.Ideating.Imagining.Improvising.Incubating.Inferring.Infusing.Ionizing.Jitterbugging.Julienning.Kneading.Leavening.Levitating.Lollygagging.Manifesting.Marinating.Meandering.Metamorphosing.Misting.Moonwalking.Moseying.Mulling.Mustering.Musing.Nebulizing.Nesting.Newspapering.Noodling.Nucleating.Orbiting.Orchestrating.Osmosing.Perambulating.Percolating.Perusing.Philosophising.Photosynthesizing.Pollinating.Pondering.Pontificating.Pouncing.Precipitating.Prestidigitating.Processing.Proofing.Propagating.Puttering.Puzzling.Quantumizing.Razzle-dazzling.Razzmatazzing.Recombobulating.Reticulating.Roosting.Ruminating.Sautéing.Scampering.Schlepping.Scurrying.Seasoning.Shenaniganing.Shimmying.Simmering.Skedaddling.Sketching.Slithering.Smooshing.Sock-hopping.Spelunking.Spinning.Sprouting.Stewing.Sublimating.Swirling.Swooping.Symbioting.Synthesizing.Tempering.Thinking.Thundering.Tinkering.Tomfoolering.Topsy-turvying.Transfiguring.Transmuting.Twisting.Undulating.Unfurling.Unravelling.Vibing.Waddling.Wandering.Warping.Whatchamacalliting.Whirlpooling.Whirring.Whisking.Wibbling.Working.Wrangling.Zesting.Zigzagging`.split(`.`)},thinkingStyle:{updateInterval:120,phases:process.env.TERM===`xterm-ghostty`?[`·`,`✢`,`✳`,`✶`,`✻`,`*`]:process.platform===`darwin`?[`·`,`✢`,`✳`,`✶`,`✻`,`✽`]:[`·`,`✢`,`*`,`✶`,`✻`,`✽`],reverseMirror:!0},userMessageDisplay:{format:` > {} `,styling:[],foregroundColor:`default`,backgroundColor:`default`,borderStyle:`none`,borderColor:`rgb(255,255,255)`,paddingX:`default`,paddingY:`default`,fitBoxToContent:!1},inputBox:{removeBorder:!1},misc:{showTweakccVersion:!0,showPatchesApplied:!0,expandThinkingBlocks:!0,enableConversationTitle:!0,hideStartupBanner:!1,hideCtrlGToEdit:!1,hideStartupClawd:!1,increaseFileReadLimit:!1,suppressLineNumbers:!1,suppressRateLimitOptions:!1,mcpConnectionNonBlocking:!0,mcpServerBatchSize:null,statuslineThrottleMs:null,statuslineUseFixedInterval:!1,tableFormat:`default`,enableSwarmMode:!0,enableSessionMemory:!0,enableDreamMode:!0,enableLeanMemoryTypes:!1,fixSummarizeFromHere:!0,fixRewindSummaryHeader:!0,enableRememberSkill:!1,tokenCountRounding:null,autoAcceptPlanMode:!1,allowBypassPermissionsInSudo:!1,suppressNativeInstallerWarning:!1,filterScrollEscapeSequences:!1,enableWorktreeMode:!0,allowCustomAgentModels:!1,enableContextLimitOverride:!1,enableModelCustomizations:!0,enableVoiceMode:!1,enableVoiceConciseOutput:!0,enableChannelsMode:!1,maxEffortDefault:!1,autonomousOperationAllModels:!1,autoModeClassifierModel:`default`,suppressDeferredTools:!1,claudemdContextOncePerConversation:!0},toolsets:[],defaultToolset:null,planModeToolset:null,subagentModels:{plan:null,explore:null,generalPurpose:null},inputPatternHighlighters:[],inputPatternHighlightersTestText:`Type test text here to see highlighting`,claudeMdAltNames:[`AGENTS.md`,`GEMINI.md`,`CRUSH.md`,`QWEN.md`,`IFLOW.md`,`WARP.md`,`copilot-instructions.md`]},ee={name:`Unnamed Highlighter`,regex:``,regexFlags:`g`,format:`{MATCH}`,styling:[],foregroundColor:null,backgroundColor:null,enabled:!0},te={name:`Unnamed Toolset`,allowedTools:`*`},D=E.themes[0],ne=e=>{let t=[],n=/visibleOptionCount:[\w$]+=(\d+)/g,r;for(;(r=n.exec(e))!==null;){let e=r.index+r[0].indexOf(`=`)+1;t.push({startIndex:e,endIndex:e+r[1].length})}return t},re=e=>{let t=e.match(/\{rows:([\w$]+),columns:[\w$]+\}=[\w$]+\(\),[\w$]+=[\w$]+\?[\w$]+:Math\.max\(1,Math\.min\(Math\.max\(6,Math\.floor\(\1\/2\)\),\1-3\)\)/);if(t&&t.index!==void 0){let n=t[1],r=`Math.floor(${n}/2)`,i=t.index+t[0].indexOf(r),a=i+r.length,o=e.slice(0,i)+n+e.slice(a);return F(e,o,n,i,a),o}let n=e.match(/\{rows:([\w$]+),columns:[\w$]+\}=[\w$]+\(\),([\w$]+)=Math\.floor\(\1\/2\)/);if(n&&n.index!==void 0){let t=n.index+n[0].indexOf(n[2]+`=Math.floor(`),r=n.index+n[0].length,i=`${n[2]}=${n[1]}`,a=e.slice(0,t)+i+e.slice(r);return F(e,a,i,t,r),a}let r=/Math\.max\(1,Math\.floor\(\(([\w$]+)-([\w$]+)\)\/([\w$]+)\)\)/g,i;for(;(i=r.exec(e))!==null;){let t=Math.max(0,i.index-250),n=e.slice(t,i.index);if(!n.includes(`"expanded"?3`)||!n.includes(`"compact"?1:2`))continue;let r=i.index,a=i.index+i[0].length,o=`Math.max(1,${i[1]}-${i[2]})`,s=e.slice(0,r)+o+e.slice(a);return F(e,s,o,r,a),s}return null},O=e=>{let t=e.match(/Math\.max\(1,Math\.floor\(\(([\w$]+)-10\)\/2\)\)/);if(!t||t.index===void 0)return null;let n=`Math.max(1,${t[1]}-3)`,r=e.slice(0,t.index)+n+e.slice(t.index+t[0].length);return F(e,r,n,t.index,t.index+t[0].length),r},k=e=>{if(!e.includes(`Math.min(6,Math.max(1,`))return U(`patch: showMoreItemsInSelectMenus: suggestions cap already removed in this CC build — no-op`),e;let t=e.match(/Math\.min\(6,Math\.max\(1,([\w$]+)-3\)\)/);if(!t||t.index===void 0)return null;let n=`Math.max(1,${t[1]}-3)`,r=e.slice(0,t.index)+n+e.slice(t.index+t[0].length);return F(e,r,n,t.index,t.index+t[0].length),r},ie=(e,t)=>{let n=ne(e);if(n.length===0)return console.error(`patch: writeShowMoreItemsInSelectMenus: failed to find locations`),null;let r=n.sort((e,t)=>t.startIndex-e.startIndex),i=e;for(let e of r){let n=t.toString(),r=i.slice(0,e.startIndex)+n+i.slice(e.endIndex);F(i,r,n,e.startIndex,e.endIndex),i=r}let a=re(i);a?i=a:console.error(`patch: writeShowMoreItemsInSelectMenus: failed to find help menu height pattern`);let o=O(i);o?i=o:console.error(`patch: writeShowMoreItemsInSelectMenus: failed to find visibleCount pattern`);let s=k(i);return s&&(i=s),i};function ae(e){let t=-1,n=-1,r=``,i=e.match(/switch\(([$\w]+)\)\{case"(?:light|dark)":[^}]*return [$\w]+;[^}]*default:return [$\w]+\}/);if(i&&i.index!=null)t=i.index,n=t+i[0].length,r=i[1];else{if(e.indexOf(`case"dark":return{"autoAccept"`)===-1&&e.indexOf(`case"light":return{`)===-1)return console.error(`patch: themes: failed to find switchMatch`),null;let i=e.indexOf(`case"dark":return{`)===-1?e.indexOf(`case"light":return{`):e.indexOf(`case"dark":return{`),a=e.slice(Math.max(0,i-200),i).match(/switch\(([$\w]+)\)\{\s*$/);if(!a||a.index==null)return console.error(`patch: themes: failed to find switchMatch (old format)`),null;t=Math.max(0,i-200)+a.index,r=a[1];let o=0;for(let r=t;r<e.length&&r<t+5e4;r++)if(e[r]===`{`&&o++,e[r]===`}`&&(o--,o===0)){n=r+1;break}}if(t===-1||n===-1)return console.error(`patch: themes: failed to find switchMatch`),null;let a=-1,o=-1,s=``,c=e.match(/\[(?:\.\.\.\[\],)?(?:\{"?label"?:"(?:Dark|Light|Auto|Monochrome)[^"]*","?value"?:"[^"]+"\},?)+\]/);if(c&&c.index!==void 0)a=c.index,o=c.index+c[0].length;else{let t=[...e.matchAll(/([$\w]+)=\{label:"(?:Auto|Dark|Light|Monochrome)[^"]*",value:"[^"]+"\}/g)];if(t.length<2)return console.error(`patch: themes: failed to find objArrMatch`),null;let n=t.map(e=>e[1]).map(e=>e.replace(/\$/g,`\\$`)).join(`,`),r=RegExp(`\\[${n}((?:,\\.\\.\\.[^\\]]+)*)\\]`),i=e.match(r);if(!i||i.index===void 0)return console.error(`patch: themes: failed to find objArrMatch (new var-collected form)`),null;a=i.index,o=i.index+i[0].length,s=i[1]}let l=e.match(/(return|[$\w]+=)\{(?:"?(?:[$\w-]+)"?:"(?:Auto |Dark|Light|Monochrome)[^"]*",?)+\}/);return(!l||l.index==null)&&U(`patch: themes: objMatch not found — colors will still apply, theme name map unchanged`),{switchStatement:{startIndex:t,endIndex:n,identifiers:[r]},objArr:{startIndex:a,endIndex:o,identifiers:[s]},obj:l&&l.index!==void 0?{startIndex:l.index,endIndex:l.index+l[0].length,identifiers:[l[1]]}:null}}const oe=(e,t)=>{let n=ae(e);if(!n)return null;if(t.length===0)return e;let r=e;if(n.obj){let i=(n.obj.identifiers?.[0]??`return`)+JSON.stringify(Object.fromEntries(t.map(e=>[e.id,e.name])));r=r.slice(0,n.obj.startIndex)+i+r.slice(n.obj.endIndex),F(e,r,i,n.obj.startIndex,n.obj.endIndex),e=r}let i=n.objArr.identifiers?.[0]??``,a=`[${t.map(e=>JSON.stringify({label:e.name,value:e.id})).join(`,`)}${i}]`;r=r.slice(0,n.objArr.startIndex)+a+r.slice(n.objArr.endIndex),F(e,r,a,n.objArr.startIndex,n.objArr.endIndex),e=r;let o=`switch(${n.switchStatement.identifiers?.[0]}){\n`;return t.forEach(e=>{o+=`case${JSON.stringify(e.id)}:return${JSON.stringify(e.colors)};\n`}),o+=`default:return${JSON.stringify(t[0].colors)};\n}`,r=r.slice(0,n.switchStatement.startIndex)+o+r.slice(n.switchStatement.endIndex),F(e,r,o,n.switchStatement.startIndex,n.switchStatement.endIndex),r},se=`(+process.env.CLAUDE_CODE_CONTEXT_LIMIT||200000)`,ce=e=>{let t=/var ([\w$]+)=200000,([\w$]+)=200000,([\w$]+)=20000,([\w$]+)=32000,([\w$]+)=(128000|64000);/,n=e.match(t);if(n)return e.replace(t,`var ${n[1]}=${se},${n[2]}=${se},${n[3]}=20000,${n[4]}=32000,${n[5]}=${n[6]};`);let r=/var ([\w$]+)=200000,([\w$]+)=20000,([\w$]+)=32000,([\w$]+)=(128000|64000);/,i=e.match(r);return i?e.replace(r,`var ${i[1]}=${se},${i[2]}=20000,${i[3]}=32000,${i[4]}=${i[5]};`):(console.error(`patch: contextLimit: failed to find context limit constants`),null)},le=(e,t)=>{if(!t)return e;let n=e,r=!1,i=n.match(/createElement\(([$\w]+),\{color:([$\w]+)\.bgColor\},"─"\.repeat\(([$\w]+)\)\)/);if(i){let e=i[1];n=n.replace(i[0],`createElement(${e},null,"")`);let t=RegExp(`createElement\\(${e},\\{color:${i[2]}\\.bgColor\\},${i[2]}\\.text\\?.+?"─"\\.repeat\\(${i[3]}\\)\\)`),a=n.match(t);a&&(n=n.replace(a[0],`createElement(${e},null,"")`)),r=!0}let a=n.match(/(borderColor:[$\w]+\(\),)borderStyle:"round"(,borderLeft:!1,borderRight:!1,borderBottom:!0,width:"100%",borderText:)/);a&&(n=n.replace(a[0],`${a[1]}borderStyle:undefined${a[2]}`),r=!0);let o=n.match(/borderStyle:"round"(,borderLeft:!1,borderRight:!1,borderBottom:!0,width:"100%"\}.+?Save and close editor)/);return o&&(n=n.replace(o[0],`borderStyle:undefined${o[1]}`),r=!0),r?(F(e,n,`(input border removed)`,0,0),n):(console.error(`patch: input border: failed to find input border pattern`),null)},ue=e=>{let t=(e.match(/overrideMessage:[$\w]+,isCompacting:[$\w]+,compactingHintText:[$\w]+,compactingStartTime:[$\w]+,spinnerSuffix:[$\w]+,verbose:[$\w]+,.{300}/)||e.match(/spinnerTip:[$\w]+,(?:[$\w]+:[$\w]+,)*overrideMessage:[$\w]+,.{300}/)||e.match(/overrideMessage:[$\w]+,spinnerSuffix:[$\w]+,verbose:[$\w]+,.{300}/)||e.match(/pauseStartTimeRef:[$\w]+,spinnerSuffix:[$\w]+,verbose:[$\w]+,.{300}/))?.index,n=t===void 0?``:e.slice(t,t+2e4),r=n.match(/,([$\w]+)(=\(([^;]{1,200}?)\)\+"(?:…|\\u2026)")/);if(r&&r.index!=null)return{startIndex:t+r.index+r[1].length+1,endIndex:t+r.index+r[1].length+r[2].length+1,identifiers:[r[3]]};let i=/,([$\w]+)(=(\([$\w]+&&![$\w]+\.isIdle\?[$\w]+\.spinnerVerb\?\?[$\w]+:[$\w]+\))\+"(?:…|\\u2026)")/,a=n.match(i);if(a&&a.index!=null)return{startIndex:t+a.index+a[1].length+1,endIndex:t+a.index+a[1].length+a[2].length+1,identifiers:[a[3]]};let o=n.match(/,([$\w]+)(=`\$\{([$\w]+&&![$\w]+\.isIdle\?[$\w]+\.spinnerVerb\?\?[$\w]+:[$\w]+)\}(?:…|\\u2026) ?`)/);if(o&&o.index!=null)return{startIndex:t+o.index+o[1].length+1,endIndex:t+o.index+o[1].length+o[2].length+1,identifiers:[o[3]]};let s=new RegExp(i.source,`g`),c=[...e.matchAll(s)].filter(t=>{if(t.index==null)return!1;let n=e.slice(Math.max(0,t.index-2500),t.index+1e3);return n.includes(`overrideMessage:`)&&n.includes(`.activeForm`)&&n.includes(`.isIdle`)&&n.includes(`.spinnerVerb`)&&n.includes(`spinnerTip`)});if(c.length===1){let e=c[0];return{startIndex:e.index+e[1].length+1,endIndex:e.index+e[1].length+e[2].length+1,identifiers:[e[3]]}}return console.error(`patch: thinker format: failed to find formatMatch`),null},de=(e,t)=>{let n=ue(e);if(!n)return null;let r=n,i=G(t.replace(/\\/g,`\\\\`).replace(/`/g,"\\`").replace(/\$\{/g,"\\${")),a=r.identifiers?.[0],o=`=${"`"+i.replace(/\{\}/g,"${"+a+`}`)+"`"}`,s=e.slice(0,r.startIndex)+o+e.slice(r.endIndex);return F(e,s,o,r.startIndex,r.endIndex),s},fe=e=>{let t=e.match(/=\s*\[\.\.\.([$\w]+),\s*\.\.\.?\[\.\.\.\1\]\.reverse\(\)\]/);return!t||t.index==null?(console.error(`patch: thinker symbol mirror option: failed to find match`),null):{startIndex:t.index,endIndex:t.index+t[0].length,identifiers:[t[1]]}},pe=(e,t)=>{let n=fe(e);if(!n)return null;let r=n.identifiers?.[0],i=t?`=[...${r},...[...${r}].reverse()]`:`=[...${r}]`,a=e.slice(0,n.startIndex)+i+e.slice(n.endIndex);return F(e,a,i,n.startIndex,n.endIndex),a},me=(e,t)=>{let n=[],r=/\["(?:[·✢*✳✶✻✽]|\\u00b7|\\xb7|\\u2722|\\x2a|\\u002a|\\u2733|\\u2736|\\u273b|\\u273d)",\s*(?:"(?:[·✢*✳✶✻✽]|\\u00b7|\\xb7|\\u2722|\\x2a|\\u002a|\\u2733|\\u2736|\\u273b|\\u273d)",?\s*)+\]/gi,i;for(;(i=r.exec(e))!==null;)n.push({startIndex:i.index,endIndex:i.index+i[0].length});if(n.length===0)return console.error(`patch: thinkerSymbolChars: could not find any thinker symbol char arrays`),null;let a=G(JSON.stringify(t)),o=n.sort((e,t)=>t.startIndex-e.startIndex),s=e;for(let e=0;e<o.length;e++){let t=s.slice(0,o[e].startIndex)+a+s.slice(o[e].endIndex);F(s,t,a,o[e].startIndex,o[e].endIndex),s=t}return s},he=(e,t)=>{let n=e.match(/(if\(![$\w]+\)\{[$\w]+\(4\);return\})(.{0,200})120\)/);if(!n||n.index===void 0)return console.error(`patch: thinkerSymbolSpeed: failed to find thinker symbol speed pattern`),null;let r=n[2]+t+`)`,i=n.index,a=i+n[0].length,o=e.slice(0,i)+r+e.slice(a);return F(e,o,r,i,a),o},ge=e=>{let t=e.match(/\{("aria-hidden":!0,)?flexWrap:"wrap",height:1,width:2\}/);return!t||t.index==null?(console.error(`patch: thinker symbol width: failed to find match`),null):{startIndex:t.index,endIndex:t.index+t[0].length,prefix:t[1]??``}},_e=(e,t)=>{let n=ge(e);if(!n)return null;let r=`{${n.prefix}flexWrap:"wrap",height:1,width:${t}}`,i=e.slice(0,n.startIndex)+r+e.slice(n.endIndex);return F(e,i,r,n.startIndex,n.endIndex),i},ve=(e,t)=>{let n=e.match(/\[("[A-Z][a-z'é\-\\xA-F0-9]+in[g']",?){50,}\]/);if(!n||n.index===void 0)return console.error(`patch: thinkingVerbs: failed to find present tense verbs pattern`),null;let r=G(JSON.stringify(t)),i=n.index,a=i+n[0].length,o=e.slice(0,i)+r+e.slice(a);return F(e,o,r,i,a),o},ye=(e,t)=>{let n=e.match(/\[("[A-Z][a-z'é\-\\xA-F0-9]+ed",?){6,}\]/);if(!n||n.index===void 0)return console.error(`patch: thinkingVerbs: failed to find past tense verbs pattern`),null;let r=t.map(e=>e.replace(/ing$/,`ed`)),i=G(JSON.stringify(r)),a=n.index,o=a+n[0].length,s=e.slice(0,a)+i+e.slice(o);return F(e,s,i,a,o),s},be=(e,t)=>{let n=ve(e,t);if(n===null)return null;let r=ye(n,t);return r===null?null:r},xe=e=>e.replace(/\\/g,`\\\\`).replace(/`/g,"\\`").replace(/\$\{/g,"\\${"),Se=(e,t)=>{let n=zi(e);if(!n)return console.error(`patch: userMessageDisplay: failed to find Text component`),null;let r=Vi(e),i=R(e);if(!i)return console.error(`patch: userMessageDisplay: failed to find chalk variable`),null;let a=/(No content found in user prompt message.{0,250}?\b)([$\w]+(?:\.default)?\.createElement.{0,30}\b[$\w]+(?:\.default)?\.createElement.{0,40}">.+?)?(([$\w]+(?:\.default)?\.createElement).{0,200})(\([$\w]+,(?:\{[^{}]+wrap:"wrap"\},([$\w]+)(?:\.trim\(\))?\)\)|\{text:([$\w]+)[^}]*\}\)\)?))/,o=e.match(/(No content found in user prompt message[\s\S]{0,100}?;return )([$\w]+(?:\.default)?)\.createElement\(([$\w]+),(\{flexDirection:"column"[^{}]*\}),([$\w]+(?:\.default)?)\.createElement\(([$\w]+),\{text:([$\w]+)[^{}]*\}\)\)/),s=o?null:e.match(/(No content found in user prompt message.{0,1200}?)([$\w]+)=([$\w]+(?:\.default)?\.createElement)\([$\w]+,\{text:([$\w]+),useBriefLayout:[$\w]+,timestamp:[$\w]+\}\)/),c=o||s?null:e.match(a);if(!o&&(!s||s.index===void 0)&&(!c||c.index===void 0))return console.error(`patch: userMessageDisplay: failed to find user message display pattern`),e;let l=e=>`(typeof ${e}==="object"&&${e}!==null?${e}.head+"\\n("+${e}.hiddenLines+" line"+(${e}.hiddenLines===1?"":"s")+" hidden)\\n"+${e}.tail:${e})`;if(o){let r=o[1],i=o[2],a=o[3],s=o[4],c=o[5],u=o[7],d=s.slice(1,-1),f=/backgroundColor:[^,}]+(?:\?[^,}:]+:[^,}:]+)*/;if(t.backgroundColor===null)d=d.replace(RegExp(`,?${f.source}`),``).replace(/^,|,$/g,``);else if(t.backgroundColor!==`default`){let e=t.backgroundColor.match(/\d+/g);if(e){let t=`"rgb(${e.join(`,`)})"`;d=d.replace(/"userMessageBackground"/g,t)}}let p=[];if(t.borderStyle!==`none`){if(t.borderStyle.startsWith(`topBottom`)){let e=``;t.borderStyle===`topBottomSingle`?e=`{top:"─",bottom:"─",left:" ",right:" ",topLeft:" ",topRight:" ",bottomLeft:" ",bottomRight:" "}`:t.borderStyle===`topBottomDouble`?e=`{top:"═",bottom:"═",left:" ",right:" ",topLeft:" ",topRight:" ",bottomLeft:" ",bottomRight:" "}`:t.borderStyle===`topBottomBold`&&(e=`{top:"━",bottom:"━",left:" ",right:" ",topLeft:" ",topRight:" ",bottomLeft:" ",bottomRight:" "}`),p.push(`borderStyle:${G(e)}`)}else p.push(`borderStyle:"${t.borderStyle}"`);let e=t.borderColor.match(/\d+/g);e&&p.push(`borderColor:"rgb(${e.join(`,`)})"`)}t.paddingX!==`default`&&t.paddingX>0&&p.push(`paddingX:${t.paddingX}`),t.paddingY!==`default`&&t.paddingY>0&&p.push(`paddingY:${t.paddingY}`),t.fitBoxToContent&&p.push(`alignSelf:"flex-start"`),p.length>0&&(d=d?`${d},${p.join(`,`)}`:p.join(`,`));let m=`{${d}}`,h=[];if(t.foregroundColor===`default`)h.push(`color:"text"`);else{let e=t.foregroundColor.match(/\d+/g);e&&h.push(`color:"rgb(${e.join(`,`)})"`)}if(t.backgroundColor!==`default`&&t.backgroundColor!==null){let e=t.backgroundColor.match(/\d+/g);e&&h.push(`backgroundColor:"rgb(${e.join(`,`)})"`)}else t.backgroundColor===`default`&&h.push(`backgroundColor:"userMessageBackground"`);t.styling.includes(`bold`)&&h.push(`bold:!0`),t.styling.includes(`italic`)&&h.push(`italic:!0`),t.styling.includes(`underline`)&&h.push(`underline:!0`),t.styling.includes(`strikethrough`)&&h.push(`strikethrough:!0`),t.styling.includes(`inverse`)&&h.push(`inverse:!0`);let g=h.length>0?`{${h.join(`,`)}}`:`null`,_=l(u),v=r+`${i}.createElement(${a},${m},${c}.createElement(${n},${g},${"`"+xe(t.format).replace(/\{\}/g,()=>"${"+_+`}`)+"`"}))`,y=o.index,b=y+o[0].length,x=e.slice(0,y)+v+e.slice(b);return F(e,x,v,y,b),x}if(!r)return console.error(`patch: userMessageDisplay: failed to find Box component`),null;let u=s??c,d=s?s[3]:c[4],f=s?s[4]:c[6]??c[7],p=[],m=t.borderStyle.startsWith(`topBottom`);if(t.borderStyle!==`none`){if(m){let e=``;t.borderStyle===`topBottomSingle`?e=`{top:"─",bottom:"─",left:" ",right:" ",topLeft:" ",topRight:" ",bottomLeft:" ",bottomRight:" "}`:t.borderStyle===`topBottomDouble`?e=`{top:"═",bottom:"═",left:" ",right:" ",topLeft:" ",topRight:" ",bottomLeft:" ",bottomRight:" "}`:t.borderStyle===`topBottomBold`&&(e=`{top:"━",bottom:"━",left:" ",right:" ",topLeft:" ",topRight:" ",bottomLeft:" ",bottomRight:" "}`),p.push(`borderStyle:${G(e)}`)}else p.push(`borderStyle:"${t.borderStyle}"`);let e=t.borderColor.match(/\d+/g);e&&p.push(`borderColor:"rgb(${e.join(`,`)})"`)}t.paddingX===`default`?p.push(`paddingRight:1`):t.paddingX>0&&p.push(`paddingX:${t.paddingX}`),t.paddingY!==`default`&&t.paddingY>0&&p.push(`paddingY:${t.paddingY}`),t.fitBoxToContent&&p.push(`alignSelf:"flex-start"`);let h=i,g=[];if(t.foregroundColor!==`default`){let e=t.foregroundColor.match(/\d+/g);e&&(h+=`.rgb(${e.join(`,`)})`)}else g.push(`color:"text"`);if(t.backgroundColor!==`default`&&t.backgroundColor!==null){let e=t.backgroundColor.match(/\d+/g);if(e){h+=`.bgRgb(${e.join(`,`)})`;let t=`"rgb(${e.join(`,`)})"`;p.push(`backgroundColor:${t}`),g.push(`backgroundColor:${t}`)}}else t.backgroundColor===`default`&&(p.push(`backgroundColor:"userMessageBackground"`),g.push(`backgroundColor:"userMessageBackground"`));t.styling.includes(`bold`)&&(h+=`.bold`),t.styling.includes(`italic`)&&(h+=`.italic`),t.styling.includes(`underline`)&&(h+=`.underline`),t.styling.includes(`strikethrough`)&&(h+=`.strikethrough`),t.styling.includes(`inverse`)&&(h+=`.inverse`);let _=l(f),v="`"+xe(t.format).replace(/\{\}/g,()=>"${"+_+`}`)+"`",y=`${h}(${v})`,b=p.length>0?`{${p.join(`,`)}}`:`null`,x=g.length>0?`{${g.join(`,`)}}`:`null`,S=s?`${s[2]}=`:``,C=u[1]+`${S}${d}(${r},${b},${d}(${n},${x},${y}))`,w=u.index,T=w+u[0].length,E=e.slice(0,w)+C+e.slice(T);return F(e,E,C,w,T),E},Ce=(e,t)=>{let n=e;if(t.foregroundColor){let e=t.foregroundColor.match(/\d+/g);e&&(n+=`.rgb(${e.join(`,`)})`)}if(t.backgroundColor){let e=t.backgroundColor.match(/\d+/g);e&&(n+=`.bgRgb(${e.join(`,`)})`)}return t.styling.includes(`bold`)&&(n+=`.bold`),t.styling.includes(`italic`)&&(n+=`.italic`),t.styling.includes(`underline`)&&(n+=`.underline`),t.styling.includes(`strikethrough`)&&(n+=`.strikethrough`),t.styling.includes(`inverse`)&&(n+=`.inverse`),n},we=e=>{let t=e.match(/(if\(([$\w]+)\.highlight\?\.color\))((return [$\w]+\.createElement\([$\w]+,\{key:[$\w]+),color:[$\w]+\.highlight\.color(\},[$\w]+\.createElement\([$\w]+,null,)([$\w]+\.text)(\)\)));/);if(t&&t.index!==void 0){let n=`${t[2]}.highlight.color(${t[6]})`,r=t[1]+`{if(typeof ${t[2]}.highlight.color==='function')`+t[4]+t[5]+n+t[7]+`;else `+t[3]+`}`,i=e.slice(0,t.index)+r+e.slice(t.index+t[0].length);return F(e,i,r,t.index,t.index+t[0].length),i}let n=/(return ([$\w]+)\.createElement\(([$\w]+),\{key:([$\w]+)),color:([$\w]+)\.highlight\?\.color,dimColor:\5\.highlight\?\.dimColor,inverse:\5\.highlight\?\.inverse\},(\2\.createElement\([$\w]+,null,\5\.text\))\)/,r=e.match(n);if(!r||r.index===void 0)return console.error(`patch: inputPatternHighlighters: failed to find highlight?.color renderer pattern`),null;let i=r[2],a=r[3],o=r[4],s=r[5];r[6];let c=RegExp(`if\\(${s.replace(`$`,`\\$`)}\\.highlight\\.color\\)return ([$\\w]+)\\.createElement\\([$\\w]+,\\{key:[$\\w]+\\},${s.replace(`$`,`\\$`)}\\.text\\.split\\(""\\)\\.map\\([^)]+\\)\\)`),l=e,u=l.match(c);if(u&&u.index!==void 0){let e=`if(typeof ${s}.highlight?.color==='function')return ${i}.createElement(${a},{key:${o}},${i}.createElement(${a},null,${s}.highlight.color(${s}.text)));`;l=l.slice(0,u.index)+e+l.slice(u.index)}let d=l.match(n);if(!d||d.index===void 0)return console.error(`patch: inputPatternHighlighters: failed to re-find renderer after shimmer patch`),null;let f=d[2],p=d[3],m=d[4],h=d[5],g=d[6],_=`${h}.highlight?.style?${h}.highlight.style(${h}.text):${h}.text`,v=`return ${f}.createElement(${p},{key:${m},color:${h}.highlight?.style?void 0:${h}.highlight?.color,backgroundColor:${h}.highlight?.style?void 0:${h}.highlight?.backgroundColor,dimColor:${h}.highlight?.dimColor,inverse:${h}.highlight?.style?void 0:${h}.highlight?.inverse,bold:${h}.highlight?.style?void 0:${h}.highlight?.bold,italic:${h}.highlight?.style?void 0:${h}.highlight?.italic,underline:${h}.highlight?.style?void 0:${h}.highlight?.underline,strikethrough:${h}.highlight?.style?void 0:${h}.highlight?.strikethrough},${g.replace(`${h}.text`,_)})`,y=l.slice(0,d.index)+v+l.slice(d.index+d[0].length);return F(e,y,`shimmer guard + renderer`,0,0),y},Te=(e,t,n)=>{let r=e.match(/((?:,|;let )[$\w]+=[$\w]+\.useMemo\(\(\)=>\{let [$\w]+=\[\];[\s\S]{0,2000}?)(if\([$\w]+&&[$\w]+&&![$\w]+\)([$\w]+)\.push\(\{start:[$\w]+,end:[$\w]+\+[$\w]+\.length,color:"warning",priority:\d+\})/);if(!r||r.index===void 0)return console.error(`patch: inputPatternHighlighters: failed to find useMemo/push pattern`),null;let i=r[3],a=r[1].match(/[^$\w]([$\w]+(?:\.default)?)\.useMemo\(/);if(!a)return console.error(`patch: inputPatternHighlighters: failed to extract React var from useMemo`),null;a[1];let o=Math.max(0,r.index-15e3),s=e.slice(o,r.index),c=/\binputValue:([$\w]+),/g,l=/\binput:([$\w]+),/g,u=[...s.matchAll(c)],d=[...s.matchAll(l)],f=u.at(-1)??d.at(-1)??null;if(!f)return console.error(`patch: inputPatternHighlighters: failed to find input variable pattern (looked for inputValue: and input:)`),null;let p=f[1],m=``;for(let e=0;e<n.length;e++){let r=n[e],a=Ce(t,r),o=r.format??`{MATCH}`;JSON.stringify(o).replace(/\{MATCH\}/g,`"+x+"`);let s=r.foregroundColor;if(s){let e=s.match(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/);if(e){let[,t,n,r]=e.map(Number);s=`#${t.toString(16).padStart(2,`0`)}${n.toString(16).padStart(2,`0`)}${r.toString(16).padStart(2,`0`)}`}}let c=s?JSON.stringify(s):`undefined`,l=r.backgroundColor;if(l){let e=l.match(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/);if(e){let[,t,n,r]=e.map(Number);l=`#${t.toString(16).padStart(2,`0`)}${n.toString(16).padStart(2,`0`)}${r.toString(16).padStart(2,`0`)}`}}let u=l?JSON.stringify(l):null,d=r.styling??[],f=d.includes(`bold`),h=d.includes(`italic`),g=d.includes(`underline`),_=d.includes(`inverse`),v=d.includes(`dim`),y=d.includes(`strikethrough`),b=r.regex??r.pattern;if(!b){console.error(`patch: inputPatternHighlighters: highlighter "${r.name}" has no regex/pattern; skipping`);continue}let x=r.regexFlags??``;x.includes(`g`)||(x+=`g`);let S;try{S=new RegExp(b,x)}catch(e){console.error(`patch: inputPatternHighlighters: highlighter "${r.name}" has invalid regex; skipping`,e);continue}let C=ba(S);m+=`if(typeof ${p}==="string"){for(let m of ${p}.matchAll(${C})){${i}.push({start:m.index,end:m.index+m[0].length,color:${c}${u?`,backgroundColor:${u}`:``}${f?`,bold:!0`:``}${h?`,italic:!0`:``}${g?`,underline:!0`:``}${_?`,inverse:!0`:``}${v?`,dimColor:!0`:``}${y?`,strikethrough:!0`:``},style:(x)=>${a}(x),priority:100})}}`}if(!m)return console.error(`patch: inputPatternHighlighters: no usable highlighters generated (all skipped)`),null;let h=r[1]+m+r[2],g=e.slice(0,r.index),_=e.slice(r.index+r[0].length),v=g+``+h+_,y=v.indexOf(`for(let m of ${p}.matchAll(`);if(y>-1){let e=[...v.slice(Math.max(0,y-2e3),y).matchAll(/useMemo\(\(\)=>\{/g)];if(e.length>0){let t=Math.max(0,y-2e3)+e[e.length-1].index,n=v.slice(t),r=0;for(let e=0;e<n.length;e++)if(n[e]===`(`)r++;else if(n[e]===`)`&&(r--,r===0)){let n=t+e;v.slice(n-1,n)===`]`&&(v.slice(n-200,n).includes(`,${p}]`)||(v=v.slice(0,n-1)+`,${p}]`+v.slice(n)));break}}}return F(e,v,``+h,r.index,r.index+r[0].length),v},Ee=(e,t)=>{let n=t.filter(e=>e.enabled!==!1);if(n.length===0)return console.error(`patch: inputPatternHighlighters: no enabled highlighters provided`),null;let r=R(e);if(!r)return console.error(`patch: inputPatternHighlighters: failed to find chalk variable`),null;let i;return i=we(e),i?(i=Te(i,r,n),i||(console.error(`^ patch: inputPatternHighlighters: writeCustomHighlighterCreation failed`),null)):(console.error(`^ patch: inputPatternHighlighters: writeCustomHighlighterImpl failed`),null)},De=e=>{let t=e.match(/(?:[$\w]+\.)?createElement\([$\w]+,\{(?=[^}]*responseLengthRef:)(?=[^}]*spinnerSuffix:)(?=[^}]*thinkingStatus:)(?=[^}]*isCompacting:)[^}]*verbose:[^,}]+[^}]*\}/);if(t&&t.index!==void 0){let e=t[0].match(/verbose:[^,}]+/);if(!e||e.index===void 0)return console.error(`patch: verbose: failed to find verbose property`),null;let n=t.index+e.index;return{startIndex:n,endIndex:n+e[0].length,replacement:`verbose:true`}}let n=e.match(/\{[^{}]{0,400}overrideMessage:[$\w]+,[^{}]{0,200}verbose:([$\w]+)[^{}]{0,200}\}\)\{/);if(n&&n.index!==void 0){let e=n[1],t=n.index+n[0].length;return{startIndex:t,endIndex:t,replacement:`${e}=!0;`}}return console.error(`patch: verbose: failed to find spinner props containing overrideMessage and verbose`),null},Oe=e=>{let t=De(e);if(!t)return null;let n=e.slice(0,t.startIndex)+t.replacement+e.slice(t.endIndex);return F(e,n,t.replacement,t.startIndex,t.endIndex),n},ke=e=>{let t=e.match(/if\s*\(\s*([$\w]+)\(\)\s*===\s*"opusplan"\s*&&\s*([$\w]+)\s*===\s*"plan"\s*&&\s*!([$\w]+)\s*\)\s*return\s*([$\w]+)\(\);/);if(!t||t.index===void 0)return console.error(`patch: opusplan1m: patchModeSwitchingFunction: failed to find mode switching pattern`),null;let[n,r,i,a,o]=t,s=`if((${r}()==="opusplan"||${r}()==="opusplan[1m]")&&${i}==="plan"&&!${a})return ${o}();`,c=e.slice(0,t.index)+s+e.slice(t.index+n.length);return F(e,c,s,t.index,t.index+n.length),c},Ae=e=>{let t=e.match(/(\["sonnet","opus","haiku",(?:"best",)?"sonnet\[1m\]",(?:"opus\[1m\]",)?"opusplan")/);if(!t||t.index===void 0)return console.error(`patch: opusplan1m: patchModelAliasesList: failed to find model aliases list`),null;let n=t[0]+`,"opusplan[1m]"`,r=e.slice(0,t.index)+n+e.slice(t.index+t[0].length);return F(e,r,n,t.index,t.index+t[0].length),r},je=e=>{let t=e.match(/(if\s*\(\s*([$\w]+)\s*===\s*"opusplan"\s*\)\s*return\s*"([^"]*Opus[^"]*plan mode[^"]*Sonnet[^"]*)";)/);if(!t||t.index===void 0)return console.error(`patch: opusplan1m: patchDescriptionFunction: failed to find description pattern`),null;let[n,,r,i]=t,a=n+`if(${r}==="opusplan[1m]")return"${i} (1M context)";`,o=e.slice(0,t.index)+a+e.slice(t.index+n.length);return F(e,o,a,t.index,t.index+n.length),o},Me=e=>{let t=e.match(/(if\s*\(\s*([$\w]+)\s*===\s*"opusplan"\s*\)\s*return\s*"Opus Plan";)/);if(!t||t.index===void 0)return console.error(`patch: opusplan1m: patchLabelFunction: failed to find label pattern`),null;let[n,,r]=t,i=n+`if(${r}==="opusplan[1m]")return"Opus Plan 1M";`,a=e.slice(0,t.index)+i+e.slice(t.index+n.length);return F(e,a,i,t.index,t.index+n.length),a},Ne=e=>{let t=e.match(/(if\s*\(\s*([$\w]+)\s*===\s*"opusplan"\s*\)\s*return\s*(?:[$\w]+\()?\[\s*\.\.\.([$\w]+)\s*,\s*([$\w]+)\(\)\s*\]\)?;)/);if(!t||t.index===void 0)return console.error(`patch: opusplan1m: patchModelSelectorOptions: failed to find model selector pattern`),null;let[n,,r,i]=t,a=n.match(RegExp(`return\\s*([$\\w]+)\\(\\s*\\[\\.\\.\\.${H(i)}`)),o=a?a[1]:null,s=`{value:"opusplan[1m]",label:"Opus Plan Mode 1M",description:"Use Opus in plan mode, Sonnet (1M context) otherwise"}`,c=n+`if(${r}==="opusplan[1m]")return ${o?`${o}([...${i},${s}])`:`[...${i},${s}]`};`,l=e.slice(0,t.index)+c+e.slice(t.index+n.length);return F(e,l,c,t.index,t.index+n.length),l},Pe=e=>{let t=e.match(/(if\s*\(\s*[$\w]+\s*===\s*null\s*\|\|\s*([$\w]+)\.some\s*\(\s*\(\s*[$\w]+\s*\)\s*=>\s*[$\w]+\.value\s*===\s*[$\w]+\s*\)\s*\)\s*return\s*(?:[$\w]+\()?[$\w]+\)?\s*;)/);if(!t||t.index===void 0)return console.error(`patch: opusplan1m: patchAlwaysShowInModelSelector: failed to find model list check pattern`),null;let[,,n]=t,r=`${n}.push({value:"opusplan",label:"Opus Plan Mode",description:"Use Opus in plan mode, Sonnet otherwise"});${n}.push({value:"opusplan[1m]",label:"Opus Plan Mode 1M",description:"Use Opus in plan mode, Sonnet (1M context) otherwise"});`,i=e.slice(0,t.index)+r+e.slice(t.index);return F(e,i,r,t.index,t.index),i},Fe=e=>{if(e.includes(`"opusplan[1m]"`))return console.log(`patch: opusplan1m: opusplan[1m] already supported natively — skipping`),e;let t=e,n=ke(t);if(n)t=n;else return console.error(`patch: opusplan1m: failed to apply mode switching patch`),null;if(n=Ae(t),n)t=n;else return console.error(`patch: opusplan1m: failed to apply model aliases list patch`),null;if(n=je(t),n)t=n;else return console.error(`patch: opusplan1m: failed to apply description function patch`),null;if(n=Me(t),n)t=n;else return console.error(`patch: opusplan1m: failed to apply label function patch`),null;if(n=Ne(t),n)t=n;else return console.error(`patch: opusplan1m: failed to apply model selector options patch`),null;if(n=Pe(t),n)t=n;else return console.error(`patch: opusplan1m: failed to apply always-show-in-selector patch`),null;return t},Ie=e=>{if(/case"thinking":\{(?:(?!case")[^]){0,600}isTranscriptMode:true/.test(e))return console.log(`patch: thinkingVisibility: already configured natively — skipping`),e;let t=e.match(/(case"thinking":\{?)(if\(.+?\)return null;)(.{0,400}isTranscriptMode:).+?,/);if(!t||t.index===void 0)return console.error(`patch: thinkingVisibility: failed to find thinking visibility pattern`),null;let n=t[1]+t[3]+`true,`,r=t.index,i=r+t[0].length,a=e.slice(0,r)+n+e.slice(i);return F(e,a,n,r,i),a},Le=(e,t)=>{let n=e.match(/(agentType\s*:\s*"Plan"\s*,[\s\S]{1,2500}?\bmodel\s*:\s*")[^"]+(")/);if(!n||n.index===void 0)return console.error(`patch: subagentModels: failed to find Plan agent pattern`),null;let r=n[1].slice(0,-1)+JSON.stringify(t),i=n.index,a=i+n[0].length,o=e.slice(0,i)+r+e.slice(a);return F(e,o,r,i,a),o},Re=(e,t)=>{let n=e.match(/(\{agentType\s*:\s*"Explore"\s*,[\s\S]{1,2500}?\bmodel\s*:\s*")[^"]+(")/);if(!n||n.index===void 0)return console.error(`patch: subagentModels: failed to find Explore agent pattern`),null;let r=n[1].slice(0,-1)+JSON.stringify(t),i=n.index,a=i+n[0].length,o=e.slice(0,i)+r+e.slice(a);return F(e,o,r,i,a),o},ze=(e,t)=>{let n=e.match(/([^$\w][$\w]+\s*=\s*\{agentType\s*:\s*"general-purpose"[\s\S]{0,2500}?)(\})/);if(!n||n.index===void 0)return console.error(`patch: subagentModels: failed to find general-purpose agent pattern`),null;let r=n[1],i=n[2],a;a=r.includes(`model:`)?r.replace(/(model\s*:\s*)"[^"]+"/,(e,n)=>n+JSON.stringify(t))+i:r+`${r.trim().endsWith(`,`)?``:`,`}model:`+JSON.stringify(t)+i;let o=n.index,s=o+n[0].length,c=e.slice(0,o)+a+e.slice(s);return F(e,c,a,o,s),c},Be=(e,t)=>{let n=e;if(t.plan){let e=Le(n,t.plan);if(e===null)return null;n=e}if(t.explore){let e=Re(n,t.explore);if(e===null)return null;n=e}if(t.generalPurpose){let e=ze(n,t.generalPurpose);if(e===null)return null;n=e}return n},Ve=(e,t,n,r)=>`${e}.createElement(${t}, null, ${e}.createElement(${n}, {color: "success", bold: true}, "\\u2503 "), ${e}.createElement(${n}, {dimColor: true}, \` * ${G(r)}\`)),`,He=e=>{let t=e.indexOf(`}.VERSION} (Claude Code)`);return t==-1?(console.error(`patch: patchesAppliedIndication: failed to find versionIndex`),null):{startIndex:0,endIndex:t+24}},Ue=e=>{let t=e.match(/createElement\(([$\w]+),\{bold:!0\},"Claude Code"\),([$\w]+)\[\d+\]=[$\w]+;else [$\w]+=([$\w]+)\[\d+\]/);if(!t||t.index===void 0)return console.error(`patch: patchesAppliedIndication: PATCH 2 failed to find bold Claude Code pattern`),null;let n=t[1],r=t.index+t[0].length,i=e.indexOf(`;`,r);if(i===-1)return null;let a=i+1,o=e.match(/[^$\w]([$\w]+)\.createElement\(([$\w]+),null,[$\w]+," ",([$\w]+)\.createElement\(([$\w]+),\{dimColor:!0\},"v",[$\w]+\)\)/);if(!o||o.index===void 0){let t=e.match(/[^$\w]([$\w]+)\.createElement\(([$\w]+),\{bold:!0\},"Claude Code"\)," ",([$\w]+)\.createElement\(([$\w]+),\{dimColor:!0\},"v",[$\w]+\)/);return!t||t.index===void 0?(console.error(`patch: patchesAppliedIndication: PATCH 2 failed to find version createElement`),null):{varInsertIndex:a,refInsertIndex:t.index+t[0].length,reactVar:t[1],textComponent:n}}return{varInsertIndex:a,refInsertIndex:o.index+o[0].length-1,reactVar:o[1],textComponent:n}},We=e=>{let t=e.match(/"Claude Code".{0,200}\{dimColor:!0\},"v",[$\w]+\)/);if(!t||t.index===void 0)return console.error(`patch: patchesAppliedIndication: failed to find version display for patch 3`),null;let n={index:t.index},r=Math.max(0,n.index-5e3),i=e.slice(r,n.index),a=Array.from(i.matchAll(/[};]\s*function ([$\w]+)\(/g));if(a.length===0)return console.error(`patch: patchesAppliedIndication: failed to find header component function`),null;let o=a[a.length-1][1],s=RegExp(`[^$\\w]([$\\w]+)\\.createElement\\(${H(o)},null\\),?`),c=e.match(s);if(!c||c.index===void 0)return console.error(`patch: patchesAppliedIndication: failed to find createElement call for header`),null;let l=e.slice(Math.max(0,c.index-30),c.index+1).match(/([$\w]+)=(?:[$\w]+&&)?[^$\w]?$/);if(l){let t=l[1],n=e.slice(c.index,c.index+2e3),r=RegExp(`,${H(t)}([,\\)])`),i=n.match(r);if(i&&i.index!==void 0){let e=c.index+i.index+i[0].length-i[1].length;return{startIndex:e,endIndex:e}}}let u=c.index+c[0].length;return{startIndex:u,endIndex:u}},Ge=(e,t,n,r=!0,i=!0)=>{let a=He(e);if(!a)return console.error(`patch: patchesAppliedIndication: failed to version output location`),null;let o=`\\n${t} (tweakcc-fixed)`,s=`}.VERSION} (Claude Code)`,c=e.replaceAll(s,s+o);F(e,c,o,a.endIndex,a.endIndex);let l=R(e);if(!l)return console.error(`patch: patchesAppliedIndication: failed to find chalk variable`),null;let u=zi(e);if(!u)return console.error(`patch: patchesAppliedIndication: failed to find text component`),null;let d=Ni(e);if(!d)return console.error(`patch: patchesAppliedIndication: failed to find React variable`),null;if(r){let e=c.match(/(\$\{([$\w]+)\("inactive",([$\w]+)\)\(`v\$\{[$\w]+\}`\)\}) `,/);if(e&&e.index!==void 0){let n=e[0],r=e[2],i=e[3],a=`${e[1]} \${${r}("warning",${i})("+ tweakcc v${t}")} \`,`;c=c.replace(n,a)}c=c.replace(/([$\w]+\("claude",[$\w]+\)\(" Claude Code) ("\))/,`$1 + tweakcc v${t} $2`);let n=Ue(c);if(!n)console.error(`patch: patchesAppliedIndication: patch 2 skipped (header version pattern changed)`);else{let e=`let _tw=${n.reactVar}.createElement(${n.textComponent},null,${l}.hex("#FF8400").bold("+ tweakcc v${t}"));`,r=c;c=c.slice(0,n.varInsertIndex)+e+c.slice(n.varInsertIndex),F(r,c,e,n.varInsertIndex,n.varInsertIndex);let i=n.refInsertIndex+e.length,a=`," ",_tw`,o=c;c=c.slice(0,i)+a+c.slice(i),F(o,c,a,i,i)}}if(i){let e=Vi(c);if(!e)return console.error(`patch: patchesAppliedIndication: PATCH 3 skipped (Box component not located on this CC version)`),c;let t=We(c);if(!t)console.log(`patch: patchesAppliedIndication: patch 3 skipped (see prior message)`);else{let r=[];r.push(`,${d}.createElement(${e}, { flexDirection: "column" },`),r.push(`${d}.createElement(${e}, null, ${d}.createElement(${u}, {color: "success", bold: true}, "\\u2503 "), ${d}.createElement(${u}, {color: "success", bold: true}, "\\u2713 tweakcc-fixed patches are applied")),`);for(let t of n)t=t.replace(`CHALK_VAR`,l),r.push(Ve(d,e,u,t));r.push(`),`);let i=r.join(`
|
|
2
|
-
`);t.startIndex>0&&c[t.startIndex-1]===`,`&&i.startsWith(`,`)&&(i=i.slice(1)),i.endsWith(`,`)&&c[t.startIndex]===`,`&&(i=i.slice(0,-1));let a=c;c=c.slice(0,t.startIndex)+i+c.slice(t.endIndex),F(a,c,i,t.startIndex,t.endIndex)}}return c};function
|
|
1
|
+
import{createRequire as e}from"node:module";import t from"chalk";import*as n from"node:os";import r,{EOL as i}from"node:os";import*as a from"node:fs/promises";import o from"node:fs/promises";import*as s from"node:fs";import c from"node:fs";import*as l from"node:path";import u from"node:path";import*as d from"fs";import*as f from"path";import*as p from"os";import*as m from"child_process";import*as h from"crypto";import{spawnSync as g}from"node:child_process";import _ from"gray-matter";import{fileURLToPath as v}from"node:url";import{Worker as y}from"node:worker_threads";import{diffWordsWithSpace as b}from"diff";let x=null;async function S(){if(x!==null)return x;try{return await import(`node-lief`),x=await import(`./nativeInstallation-CHSAij_R.mjs`),x}catch(e){return W(`Error loading native installation module: ${e instanceof Error?e.message:String(e)}`),e instanceof Error&&W(e),null}}async function C(e,t){let n=await S();return n?n.extractClaudeJsFromNativeInstallation(e,t):{data:null,clearBytecode:!1,error:`node-lief native module unavailable on this platform/runtime (cannot extract from native installs)`}}async function w(e,t,n,r){let i=await S();if(!i)throw Error("`repackNativeInstallation()` called but `node-lief` is not available. This is unexpected - `extractClaudeJsFromNativeInstallation()` should have been called first.");i.repackNativeInstallation(e,t,n,r)}async function T(e){let t=await S();return t?t.resolveNixBinaryWrapper(e):null}const E={themes:[{name:`Dark mode`,id:`dark`,colors:{autoAccept:`rgb(175,135,255)`,bashBorder:`rgb(253,93,177)`,claude:`rgb(215,119,87)`,claudeShimmer:`rgb(235,159,127)`,claudeBlue_FOR_SYSTEM_SPINNER:`rgb(147,165,255)`,claudeBlueShimmer_FOR_SYSTEM_SPINNER:`rgb(177,195,255)`,permission:`rgb(177,185,249)`,permissionShimmer:`rgb(207,215,255)`,planMode:`rgb(72,150,140)`,ide:`rgb(71,130,200)`,promptBorder:`rgb(136,136,136)`,promptBorderShimmer:`rgb(166,166,166)`,text:`rgb(255,255,255)`,inverseText:`rgb(0,0,0)`,inactive:`rgb(153,153,153)`,subtle:`rgb(80,80,80)`,suggestion:`rgb(177,185,249)`,remember:`rgb(177,185,249)`,background:`rgb(0,204,204)`,success:`rgb(78,186,101)`,error:`rgb(255,107,128)`,warning:`rgb(255,193,7)`,warningShimmer:`rgb(255,223,57)`,diffAdded:`rgb(34,92,43)`,diffRemoved:`rgb(122,41,54)`,diffAddedDimmed:`rgb(71,88,74)`,diffRemovedDimmed:`rgb(105,72,77)`,diffAddedWord:`rgb(56,166,96)`,diffRemovedWord:`rgb(179,89,107)`,diffAddedWordDimmed:`rgb(46,107,58)`,diffRemovedWordDimmed:`rgb(139,57,69)`,red_FOR_SUBAGENTS_ONLY:`rgb(220,38,38)`,blue_FOR_SUBAGENTS_ONLY:`rgb(37,99,235)`,green_FOR_SUBAGENTS_ONLY:`rgb(22,163,74)`,yellow_FOR_SUBAGENTS_ONLY:`rgb(202,138,4)`,purple_FOR_SUBAGENTS_ONLY:`rgb(147,51,234)`,orange_FOR_SUBAGENTS_ONLY:`rgb(234,88,12)`,pink_FOR_SUBAGENTS_ONLY:`rgb(219,39,119)`,cyan_FOR_SUBAGENTS_ONLY:`rgb(8,145,178)`,professionalBlue:`rgb(106,155,204)`,rainbow_red:`rgb(235,95,87)`,rainbow_orange:`rgb(245,139,87)`,rainbow_yellow:`rgb(250,195,95)`,rainbow_green:`rgb(145,200,130)`,rainbow_blue:`rgb(130,170,220)`,rainbow_indigo:`rgb(155,130,200)`,rainbow_violet:`rgb(200,130,180)`,rainbow_red_shimmer:`rgb(250,155,147)`,rainbow_orange_shimmer:`rgb(255,185,137)`,rainbow_yellow_shimmer:`rgb(255,225,155)`,rainbow_green_shimmer:`rgb(185,230,180)`,rainbow_blue_shimmer:`rgb(180,205,240)`,rainbow_indigo_shimmer:`rgb(195,180,230)`,rainbow_violet_shimmer:`rgb(230,180,210)`,clawd_body:`rgb(215,119,87)`,clawd_background:`rgb(0,0,0)`,userMessageBackground:`rgb(55, 55, 55)`,bashMessageBackgroundColor:`rgb(65, 60, 65)`,memoryBackgroundColor:`rgb(55, 65, 70)`,rate_limit_fill:`rgb(177,185,249)`,rate_limit_empty:`rgb(80,83,112)`}},{name:`Light mode`,id:`light`,colors:{autoAccept:`rgb(135,0,255)`,bashBorder:`rgb(255,0,135)`,claude:`rgb(215,119,87)`,claudeShimmer:`rgb(245,149,117)`,claudeBlue_FOR_SYSTEM_SPINNER:`rgb(87,105,247)`,claudeBlueShimmer_FOR_SYSTEM_SPINNER:`rgb(117,135,255)`,permission:`rgb(87,105,247)`,permissionShimmer:`rgb(137,155,255)`,planMode:`rgb(0,102,102)`,ide:`rgb(71,130,200)`,promptBorder:`rgb(153,153,153)`,promptBorderShimmer:`rgb(183,183,183)`,text:`rgb(0,0,0)`,inverseText:`rgb(255,255,255)`,inactive:`rgb(102,102,102)`,subtle:`rgb(175,175,175)`,suggestion:`rgb(87,105,247)`,remember:`rgb(0,0,255)`,background:`rgb(0,153,153)`,success:`rgb(44,122,57)`,error:`rgb(171,43,63)`,warning:`rgb(150,108,30)`,warningShimmer:`rgb(200,158,80)`,diffAdded:`rgb(105,219,124)`,diffRemoved:`rgb(255,168,180)`,diffAddedDimmed:`rgb(199,225,203)`,diffRemovedDimmed:`rgb(253,210,216)`,diffAddedWord:`rgb(47,157,68)`,diffRemovedWord:`rgb(209,69,75)`,diffAddedWordDimmed:`rgb(144,194,156)`,diffRemovedWordDimmed:`rgb(232,165,173)`,red_FOR_SUBAGENTS_ONLY:`rgb(220,38,38)`,blue_FOR_SUBAGENTS_ONLY:`rgb(37,99,235)`,green_FOR_SUBAGENTS_ONLY:`rgb(22,163,74)`,yellow_FOR_SUBAGENTS_ONLY:`rgb(202,138,4)`,purple_FOR_SUBAGENTS_ONLY:`rgb(147,51,234)`,orange_FOR_SUBAGENTS_ONLY:`rgb(234,88,12)`,pink_FOR_SUBAGENTS_ONLY:`rgb(219,39,119)`,cyan_FOR_SUBAGENTS_ONLY:`rgb(8,145,178)`,professionalBlue:`rgb(106,155,204)`,rainbow_red:`rgb(235,95,87)`,rainbow_orange:`rgb(245,139,87)`,rainbow_yellow:`rgb(250,195,95)`,rainbow_green:`rgb(145,200,130)`,rainbow_blue:`rgb(130,170,220)`,rainbow_indigo:`rgb(155,130,200)`,rainbow_violet:`rgb(200,130,180)`,rainbow_red_shimmer:`rgb(250,155,147)`,rainbow_orange_shimmer:`rgb(255,185,137)`,rainbow_yellow_shimmer:`rgb(255,225,155)`,rainbow_green_shimmer:`rgb(185,230,180)`,rainbow_blue_shimmer:`rgb(180,205,240)`,rainbow_indigo_shimmer:`rgb(195,180,230)`,rainbow_violet_shimmer:`rgb(230,180,210)`,clawd_body:`rgb(215,119,87)`,clawd_background:`rgb(0,0,0)`,userMessageBackground:`rgb(240, 240, 240)`,bashMessageBackgroundColor:`rgb(250, 245, 250)`,memoryBackgroundColor:`rgb(230, 245, 250)`,rate_limit_fill:`rgb(87,105,247)`,rate_limit_empty:`rgb(39,47,111)`}},{name:`Light mode (ANSI colors only)`,id:`light-ansi`,colors:{autoAccept:`ansi:magenta`,bashBorder:`ansi:magenta`,claude:`ansi:redBright`,claudeShimmer:`ansi:yellowBright`,claudeBlue_FOR_SYSTEM_SPINNER:`ansi:blue`,claudeBlueShimmer_FOR_SYSTEM_SPINNER:`ansi:blueBright`,permission:`ansi:blue`,permissionShimmer:`ansi:blueBright`,planMode:`ansi:cyan`,ide:`ansi:blueBright`,promptBorder:`ansi:white`,promptBorderShimmer:`ansi:whiteBright`,text:`ansi:black`,inverseText:`ansi:white`,inactive:`ansi:blackBright`,subtle:`ansi:blackBright`,suggestion:`ansi:blue`,remember:`ansi:blue`,background:`ansi:cyan`,success:`ansi:green`,error:`ansi:red`,warning:`ansi:yellow`,warningShimmer:`ansi:yellowBright`,diffAdded:`ansi:green`,diffRemoved:`ansi:red`,diffAddedDimmed:`ansi:green`,diffRemovedDimmed:`ansi:red`,diffAddedWord:`ansi:greenBright`,diffRemovedWord:`ansi:redBright`,diffAddedWordDimmed:`ansi:green`,diffRemovedWordDimmed:`ansi:red`,red_FOR_SUBAGENTS_ONLY:`ansi:red`,blue_FOR_SUBAGENTS_ONLY:`ansi:blue`,green_FOR_SUBAGENTS_ONLY:`ansi:green`,yellow_FOR_SUBAGENTS_ONLY:`ansi:yellow`,purple_FOR_SUBAGENTS_ONLY:`ansi:magenta`,orange_FOR_SUBAGENTS_ONLY:`ansi:redBright`,pink_FOR_SUBAGENTS_ONLY:`ansi:magentaBright`,cyan_FOR_SUBAGENTS_ONLY:`ansi:cyan`,professionalBlue:`ansi:blueBright`,rainbow_red:`ansi:red`,rainbow_orange:`ansi:redBright`,rainbow_yellow:`ansi:yellow`,rainbow_green:`ansi:green`,rainbow_blue:`ansi:cyan`,rainbow_indigo:`ansi:blue`,rainbow_violet:`ansi:magenta`,rainbow_red_shimmer:`ansi:redBright`,rainbow_orange_shimmer:`ansi:yellow`,rainbow_yellow_shimmer:`ansi:yellowBright`,rainbow_green_shimmer:`ansi:greenBright`,rainbow_blue_shimmer:`ansi:cyanBright`,rainbow_indigo_shimmer:`ansi:blueBright`,rainbow_violet_shimmer:`ansi:magentaBright`,clawd_body:`ansi:redBright`,clawd_background:`ansi:black`,userMessageBackground:`ansi:white`,bashMessageBackgroundColor:`ansi:whiteBright`,memoryBackgroundColor:`ansi:white`,rate_limit_fill:`ansi:yellow`,rate_limit_empty:`ansi:black`}},{name:`Dark mode (ANSI colors only)`,id:`dark-ansi`,colors:{autoAccept:`ansi:magentaBright`,bashBorder:`ansi:magentaBright`,claude:`ansi:redBright`,claudeShimmer:`ansi:yellowBright`,claudeBlue_FOR_SYSTEM_SPINNER:`ansi:blueBright`,claudeBlueShimmer_FOR_SYSTEM_SPINNER:`ansi:blueBright`,permission:`ansi:blueBright`,permissionShimmer:`ansi:blueBright`,planMode:`ansi:cyanBright`,ide:`ansi:blue`,promptBorder:`ansi:white`,promptBorderShimmer:`ansi:whiteBright`,text:`ansi:whiteBright`,inverseText:`ansi:black`,inactive:`ansi:white`,subtle:`ansi:white`,suggestion:`ansi:blueBright`,remember:`ansi:blueBright`,background:`ansi:cyanBright`,success:`ansi:greenBright`,error:`ansi:redBright`,warning:`ansi:yellowBright`,warningShimmer:`ansi:yellowBright`,diffAdded:`ansi:green`,diffRemoved:`ansi:red`,diffAddedDimmed:`ansi:green`,diffRemovedDimmed:`ansi:red`,diffAddedWord:`ansi:greenBright`,diffRemovedWord:`ansi:redBright`,diffAddedWordDimmed:`ansi:green`,diffRemovedWordDimmed:`ansi:red`,red_FOR_SUBAGENTS_ONLY:`ansi:redBright`,blue_FOR_SUBAGENTS_ONLY:`ansi:blueBright`,green_FOR_SUBAGENTS_ONLY:`ansi:greenBright`,yellow_FOR_SUBAGENTS_ONLY:`ansi:yellowBright`,purple_FOR_SUBAGENTS_ONLY:`ansi:magentaBright`,orange_FOR_SUBAGENTS_ONLY:`ansi:redBright`,pink_FOR_SUBAGENTS_ONLY:`ansi:magentaBright`,cyan_FOR_SUBAGENTS_ONLY:`ansi:cyanBright`,professionalBlue:`rgb(106,155,204)`,rainbow_red:`ansi:red`,rainbow_orange:`ansi:redBright`,rainbow_yellow:`ansi:yellow`,rainbow_green:`ansi:green`,rainbow_blue:`ansi:cyan`,rainbow_indigo:`ansi:blue`,rainbow_violet:`ansi:magenta`,rainbow_red_shimmer:`ansi:redBright`,rainbow_orange_shimmer:`ansi:yellow`,rainbow_yellow_shimmer:`ansi:yellowBright`,rainbow_green_shimmer:`ansi:greenBright`,rainbow_blue_shimmer:`ansi:cyanBright`,rainbow_indigo_shimmer:`ansi:blueBright`,rainbow_violet_shimmer:`ansi:magentaBright`,clawd_body:`ansi:redBright`,clawd_background:`ansi:black`,userMessageBackground:`ansi:blackBright`,bashMessageBackgroundColor:`ansi:black`,memoryBackgroundColor:`ansi:blackBright`,rate_limit_fill:`ansi:yellow`,rate_limit_empty:`ansi:white`}},{name:`Light mode (colorblind-friendly)`,id:`light-daltonized`,colors:{autoAccept:`rgb(135,0,255)`,bashBorder:`rgb(0,102,204)`,claude:`rgb(255,153,51)`,claudeShimmer:`rgb(255,183,101)`,claudeBlue_FOR_SYSTEM_SPINNER:`rgb(51,102,255)`,claudeBlueShimmer_FOR_SYSTEM_SPINNER:`rgb(101,152,255)`,permission:`rgb(51,102,255)`,permissionShimmer:`rgb(101,152,255)`,planMode:`rgb(51,102,102)`,ide:`rgb(71,130,200)`,promptBorder:`rgb(153,153,153)`,promptBorderShimmer:`rgb(183,183,183)`,text:`rgb(0,0,0)`,inverseText:`rgb(255,255,255)`,inactive:`rgb(102,102,102)`,subtle:`rgb(175,175,175)`,suggestion:`rgb(51,102,255)`,remember:`rgb(51,102,255)`,background:`rgb(0,153,153)`,success:`rgb(0,102,153)`,error:`rgb(204,0,0)`,warning:`rgb(255,153,0)`,warningShimmer:`rgb(255,183,50)`,diffAdded:`rgb(153,204,255)`,diffRemoved:`rgb(255,204,204)`,diffAddedDimmed:`rgb(209,231,253)`,diffRemovedDimmed:`rgb(255,233,233)`,diffAddedWord:`rgb(51,102,204)`,diffRemovedWord:`rgb(153,51,51)`,diffAddedWordDimmed:`rgb(102,153,204)`,diffRemovedWordDimmed:`rgb(204,153,153)`,red_FOR_SUBAGENTS_ONLY:`rgb(204,0,0)`,blue_FOR_SUBAGENTS_ONLY:`rgb(0,102,204)`,green_FOR_SUBAGENTS_ONLY:`rgb(0,204,0)`,yellow_FOR_SUBAGENTS_ONLY:`rgb(255,204,0)`,purple_FOR_SUBAGENTS_ONLY:`rgb(128,0,128)`,orange_FOR_SUBAGENTS_ONLY:`rgb(255,128,0)`,pink_FOR_SUBAGENTS_ONLY:`rgb(255,102,178)`,cyan_FOR_SUBAGENTS_ONLY:`rgb(0,178,178)`,professionalBlue:`rgb(106,155,204)`,rainbow_red:`rgb(235,95,87)`,rainbow_orange:`rgb(245,139,87)`,rainbow_yellow:`rgb(250,195,95)`,rainbow_green:`rgb(145,200,130)`,rainbow_blue:`rgb(130,170,220)`,rainbow_indigo:`rgb(155,130,200)`,rainbow_violet:`rgb(200,130,180)`,rainbow_red_shimmer:`rgb(250,155,147)`,rainbow_orange_shimmer:`rgb(255,185,137)`,rainbow_yellow_shimmer:`rgb(255,225,155)`,rainbow_green_shimmer:`rgb(185,230,180)`,rainbow_blue_shimmer:`rgb(180,205,240)`,rainbow_indigo_shimmer:`rgb(195,180,230)`,rainbow_violet_shimmer:`rgb(230,180,210)`,clawd_body:`rgb(215,119,87)`,clawd_background:`rgb(0,0,0)`,userMessageBackground:`rgb(220, 220, 220)`,bashMessageBackgroundColor:`rgb(250, 245, 250)`,memoryBackgroundColor:`rgb(230, 245, 250)`,rate_limit_fill:`rgb(51,102,255)`,rate_limit_empty:`rgb(23,46,114)`}},{name:`Dark mode (colorblind-friendly)`,id:`dark-daltonized`,colors:{autoAccept:`rgb(175,135,255)`,bashBorder:`rgb(51,153,255)`,claude:`rgb(255,153,51)`,claudeShimmer:`rgb(255,183,101)`,claudeBlue_FOR_SYSTEM_SPINNER:`rgb(153,204,255)`,claudeBlueShimmer_FOR_SYSTEM_SPINNER:`rgb(183,224,255)`,permission:`rgb(153,204,255)`,permissionShimmer:`rgb(183,224,255)`,planMode:`rgb(102,153,153)`,ide:`rgb(71,130,200)`,promptBorder:`rgb(136,136,136)`,promptBorderShimmer:`rgb(166,166,166)`,text:`rgb(255,255,255)`,inverseText:`rgb(0,0,0)`,inactive:`rgb(153,153,153)`,subtle:`rgb(80,80,80)`,suggestion:`rgb(153,204,255)`,remember:`rgb(153,204,255)`,background:`rgb(0,204,204)`,success:`rgb(51,153,255)`,error:`rgb(255,102,102)`,warning:`rgb(255,204,0)`,warningShimmer:`rgb(255,234,50)`,diffAdded:`rgb(0,68,102)`,diffRemoved:`rgb(102,0,0)`,diffAddedDimmed:`rgb(62,81,91)`,diffRemovedDimmed:`rgb(62,44,44)`,diffAddedWord:`rgb(0,119,179)`,diffRemovedWord:`rgb(179,0,0)`,diffAddedWordDimmed:`rgb(26,99,128)`,diffRemovedWordDimmed:`rgb(128,21,21)`,red_FOR_SUBAGENTS_ONLY:`rgb(255,102,102)`,blue_FOR_SUBAGENTS_ONLY:`rgb(102,178,255)`,green_FOR_SUBAGENTS_ONLY:`rgb(102,255,102)`,yellow_FOR_SUBAGENTS_ONLY:`rgb(255,255,102)`,purple_FOR_SUBAGENTS_ONLY:`rgb(178,102,255)`,orange_FOR_SUBAGENTS_ONLY:`rgb(255,178,102)`,pink_FOR_SUBAGENTS_ONLY:`rgb(255,153,204)`,cyan_FOR_SUBAGENTS_ONLY:`rgb(102,204,204)`,professionalBlue:`rgb(106,155,204)`,rainbow_red:`rgb(235,95,87)`,rainbow_orange:`rgb(245,139,87)`,rainbow_yellow:`rgb(250,195,95)`,rainbow_green:`rgb(145,200,130)`,rainbow_blue:`rgb(130,170,220)`,rainbow_indigo:`rgb(155,130,200)`,rainbow_violet:`rgb(200,130,180)`,rainbow_red_shimmer:`rgb(250,155,147)`,rainbow_orange_shimmer:`rgb(255,185,137)`,rainbow_yellow_shimmer:`rgb(255,225,155)`,rainbow_green_shimmer:`rgb(185,230,180)`,rainbow_blue_shimmer:`rgb(180,205,240)`,rainbow_indigo_shimmer:`rgb(195,180,230)`,rainbow_violet_shimmer:`rgb(230,180,210)`,clawd_body:`rgb(215,119,87)`,clawd_background:`rgb(0,0,0)`,userMessageBackground:`rgb(55, 55, 55)`,bashMessageBackgroundColor:`rgb(65, 60, 65)`,memoryBackgroundColor:`rgb(55, 65, 70)`,rate_limit_fill:`rgb(153,204,255)`,rate_limit_empty:`rgb(69,92,115)`}},{name:`Monochrome`,id:`monochrome`,colors:{autoAccept:`rgb(200,200,200)`,bashBorder:`rgb(180,180,180)`,claude:`rgb(255,255,255)`,claudeShimmer:`rgb(230,230,230)`,claudeBlue_FOR_SYSTEM_SPINNER:`rgb(200,200,200)`,claudeBlueShimmer_FOR_SYSTEM_SPINNER:`rgb(220,220,220)`,permission:`rgb(200,200,200)`,permissionShimmer:`rgb(220,220,220)`,planMode:`rgb(180,180,180)`,ide:`rgb(190,190,190)`,promptBorder:`rgb(160,160,160)`,promptBorderShimmer:`rgb(180,180,180)`,text:`rgb(255,255,255)`,inverseText:`rgb(40,40,40)`,inactive:`rgb(120,120,120)`,subtle:`rgb(100,100,100)`,suggestion:`rgb(200,200,200)`,remember:`rgb(200,200,200)`,background:`rgb(180,180,180)`,success:`rgb(220,220,220)`,error:`rgb(180,180,180)`,warning:`rgb(200,200,200)`,warningShimmer:`rgb(220,220,220)`,diffAdded:`rgb(90,90,90)`,diffRemoved:`rgb(60,60,60)`,diffAddedDimmed:`rgb(110,110,110)`,diffRemovedDimmed:`rgb(80,80,80)`,diffAddedWord:`rgb(200,200,200)`,diffRemovedWord:`rgb(80,80,80)`,diffAddedWordDimmed:`rgb(160,160,160)`,diffRemovedWordDimmed:`rgb(70,70,70)`,red_FOR_SUBAGENTS_ONLY:`rgb(200,200,200)`,blue_FOR_SUBAGENTS_ONLY:`rgb(180,180,180)`,green_FOR_SUBAGENTS_ONLY:`rgb(210,210,210)`,yellow_FOR_SUBAGENTS_ONLY:`rgb(190,190,190)`,purple_FOR_SUBAGENTS_ONLY:`rgb(170,170,170)`,orange_FOR_SUBAGENTS_ONLY:`rgb(195,195,195)`,pink_FOR_SUBAGENTS_ONLY:`rgb(205,205,205)`,cyan_FOR_SUBAGENTS_ONLY:`rgb(185,185,185)`,professionalBlue:`rgb(190,190,190)`,rainbow_red:`rgb(240,240,240)`,rainbow_orange:`rgb(230,230,230)`,rainbow_yellow:`rgb(220,220,220)`,rainbow_green:`rgb(210,210,210)`,rainbow_blue:`rgb(200,200,200)`,rainbow_indigo:`rgb(190,190,190)`,rainbow_violet:`rgb(180,180,180)`,rainbow_red_shimmer:`rgb(255,255,255)`,rainbow_orange_shimmer:`rgb(245,245,245)`,rainbow_yellow_shimmer:`rgb(235,235,235)`,rainbow_green_shimmer:`rgb(225,225,225)`,rainbow_blue_shimmer:`rgb(215,215,215)`,rainbow_indigo_shimmer:`rgb(205,205,205)`,rainbow_violet_shimmer:`rgb(195,195,195)`,clawd_body:`rgb(255,255,255)`,clawd_background:`rgb(40,40,40)`,userMessageBackground:`rgb(70,70,70)`,bashMessageBackgroundColor:`rgb(65,65,65)`,memoryBackgroundColor:`rgb(75,75,75)`,rate_limit_fill:`rgb(200,200,200)`,rate_limit_empty:`rgb(90,90,90)`}}],thinkingVerbs:{format:`{}… `,verbs:`Accomplishing.Actioning.Actualizing.Architecting.Baking.Beaming.Beboppin'.Befuddling.Billowing.Blanching.Bloviating.Boogieing.Boondoggling.Booping.Bootstrapping.Brewing.Burrowing.Calculating.Canoodling.Caramelizing.Cascading.Catapulting.Cerebrating.Channeling.Channelling.Choreographing.Churning.Clauding.Coalescing.Cogitating.Combobulating.Composing.Computing.Concocting.Considering.Contemplating.Cooking.Crafting.Creating.Crunching.Crystallizing.Cultivating.Deciphering.Deliberating.Determining.Dilly-dallying.Discombobulating.Doing.Doodling.Drizzling.Ebbing.Effecting.Elucidating.Embellishing.Enchanting.Envisioning.Evaporating.Fermenting.Fiddle-faddling.Finagling.Flambéing.Flibbertigibbeting.Flowing.Flummoxing.Fluttering.Forging.Forming.Frolicking.Frosting.Gallivanting.Galloping.Garnishing.Generating.Germinating.Gitifying.Grooving.Gusting.Harmonizing.Hashing.Hatching.Herding.Honking.Hullaballooing.Hyperspacing.Ideating.Imagining.Improvising.Incubating.Inferring.Infusing.Ionizing.Jitterbugging.Julienning.Kneading.Leavening.Levitating.Lollygagging.Manifesting.Marinating.Meandering.Metamorphosing.Misting.Moonwalking.Moseying.Mulling.Mustering.Musing.Nebulizing.Nesting.Newspapering.Noodling.Nucleating.Orbiting.Orchestrating.Osmosing.Perambulating.Percolating.Perusing.Philosophising.Photosynthesizing.Pollinating.Pondering.Pontificating.Pouncing.Precipitating.Prestidigitating.Processing.Proofing.Propagating.Puttering.Puzzling.Quantumizing.Razzle-dazzling.Razzmatazzing.Recombobulating.Reticulating.Roosting.Ruminating.Sautéing.Scampering.Schlepping.Scurrying.Seasoning.Shenaniganing.Shimmying.Simmering.Skedaddling.Sketching.Slithering.Smooshing.Sock-hopping.Spelunking.Spinning.Sprouting.Stewing.Sublimating.Swirling.Swooping.Symbioting.Synthesizing.Tempering.Thinking.Thundering.Tinkering.Tomfoolering.Topsy-turvying.Transfiguring.Transmuting.Twisting.Undulating.Unfurling.Unravelling.Vibing.Waddling.Wandering.Warping.Whatchamacalliting.Whirlpooling.Whirring.Whisking.Wibbling.Working.Wrangling.Zesting.Zigzagging`.split(`.`)},thinkingStyle:{updateInterval:120,phases:process.env.TERM===`xterm-ghostty`?[`·`,`✢`,`✳`,`✶`,`✻`,`*`]:process.platform===`darwin`?[`·`,`✢`,`✳`,`✶`,`✻`,`✽`]:[`·`,`✢`,`*`,`✶`,`✻`,`✽`],reverseMirror:!0},userMessageDisplay:{format:` > {} `,styling:[],foregroundColor:`default`,backgroundColor:`default`,borderStyle:`none`,borderColor:`rgb(255,255,255)`,paddingX:`default`,paddingY:`default`,fitBoxToContent:!1},inputBox:{removeBorder:!1},misc:{showTweakccVersion:!0,showPatchesApplied:!0,expandThinkingBlocks:!0,enableConversationTitle:!0,hideStartupBanner:!1,hideCtrlGToEdit:!1,hideStartupClawd:!1,increaseFileReadLimit:!1,suppressLineNumbers:!1,suppressRateLimitOptions:!1,mcpConnectionNonBlocking:!0,mcpServerBatchSize:null,statuslineThrottleMs:null,statuslineUseFixedInterval:!1,tableFormat:`default`,enableSwarmMode:!0,enableSessionMemory:!0,enableDreamMode:!0,enableLeanMemoryTypes:!1,fixSummarizeFromHere:!0,fixRewindSummaryHeader:!0,enableRememberSkill:!1,tokenCountRounding:null,autoAcceptPlanMode:!1,allowBypassPermissionsInSudo:!1,suppressNativeInstallerWarning:!1,filterScrollEscapeSequences:!1,enableWorktreeMode:!0,allowCustomAgentModels:!1,enableContextLimitOverride:!1,enableModelCustomizations:!0,enableVoiceMode:!1,enableVoiceConciseOutput:!0,enableChannelsMode:!1,maxEffortDefault:!1,autonomousOperationAllModels:!1,autoModeClassifierModel:`default`,suppressDeferredTools:!1,claudemdContextOncePerConversation:!0},toolsets:[],defaultToolset:null,planModeToolset:null,subagentModels:{plan:null,explore:null,generalPurpose:null},inputPatternHighlighters:[],inputPatternHighlightersTestText:`Type test text here to see highlighting`,claudeMdAltNames:[`AGENTS.md`,`GEMINI.md`,`CRUSH.md`,`QWEN.md`,`IFLOW.md`,`WARP.md`,`copilot-instructions.md`]},D={name:`Unnamed Highlighter`,regex:``,regexFlags:`g`,format:`{MATCH}`,styling:[],foregroundColor:null,backgroundColor:null,enabled:!0},O={name:`Unnamed Toolset`,allowedTools:`*`},k=E.themes[0],ee=e=>{let t=[],n=/visibleOptionCount:[\w$]+=(\d+)/g,r;for(;(r=n.exec(e))!==null;){let e=r.index+r[0].indexOf(`=`)+1;t.push({startIndex:e,endIndex:e+r[1].length})}return t},te=e=>{let t=e.match(/\{rows:([\w$]+),columns:[\w$]+\}=[\w$]+\(\),[\w$]+=[\w$]+\?[\w$]+:Math\.max\(1,Math\.min\(Math\.max\(6,Math\.floor\(\1\/2\)\),\1-3\)\)/);if(t&&t.index!==void 0){let n=t[1],r=`Math.floor(${n}/2)`,i=t.index+t[0].indexOf(r),a=i+r.length,o=e.slice(0,i)+n+e.slice(a);return F(e,o,n,i,a),o}let n=e.match(/\{rows:([\w$]+),columns:[\w$]+\}=[\w$]+\(\),([\w$]+)=Math\.floor\(\1\/2\)/);if(n&&n.index!==void 0){let t=n.index+n[0].indexOf(n[2]+`=Math.floor(`),r=n.index+n[0].length,i=`${n[2]}=${n[1]}`,a=e.slice(0,t)+i+e.slice(r);return F(e,a,i,t,r),a}let r=/Math\.max\(1,Math\.floor\(\(([\w$]+)-([\w$]+)\)\/([\w$]+)\)\)/g,i;for(;(i=r.exec(e))!==null;){let t=Math.max(0,i.index-250),n=e.slice(t,i.index);if(!n.includes(`"expanded"?3`)||!n.includes(`"compact"?1:2`))continue;let r=i.index,a=i.index+i[0].length,o=`Math.max(1,${i[1]}-${i[2]})`,s=e.slice(0,r)+o+e.slice(a);return F(e,s,o,r,a),s}return null},A=e=>{let t=e.match(/Math\.max\(1,Math\.floor\(\(([\w$]+)-10\)\/2\)\)/);if(!t||t.index===void 0)return null;let n=`Math.max(1,${t[1]}-3)`,r=e.slice(0,t.index)+n+e.slice(t.index+t[0].length);return F(e,r,n,t.index,t.index+t[0].length),r},j=e=>{if(!e.includes(`Math.min(6,Math.max(1,`))return W(`patch: showMoreItemsInSelectMenus: suggestions cap already removed in this CC build — no-op`),e;let t=e.match(/Math\.min\(6,Math\.max\(1,([\w$]+)-3\)\)/);if(!t||t.index===void 0)return null;let n=`Math.max(1,${t[1]}-3)`,r=e.slice(0,t.index)+n+e.slice(t.index+t[0].length);return F(e,r,n,t.index,t.index+t[0].length),r},ne=(e,t)=>{let n=ee(e);if(n.length===0)return console.error(`patch: writeShowMoreItemsInSelectMenus: failed to find locations`),null;let r=n.sort((e,t)=>t.startIndex-e.startIndex),i=e;for(let e of r){let n=t.toString(),r=i.slice(0,e.startIndex)+n+i.slice(e.endIndex);F(i,r,n,e.startIndex,e.endIndex),i=r}let a=te(i);a?i=a:console.error(`patch: writeShowMoreItemsInSelectMenus: failed to find help menu height pattern`);let o=A(i);o?i=o:console.error(`patch: writeShowMoreItemsInSelectMenus: failed to find visibleCount pattern`);let s=j(i);return s&&(i=s),i};function re(e){let t=-1,n=-1,r=``,i=e.match(/switch\(([$\w]+)\)\{case"(?:light|dark)":[^}]*return [$\w]+;[^}]*default:return [$\w]+\}/);if(i&&i.index!=null)t=i.index,n=t+i[0].length,r=i[1];else{if(e.indexOf(`case"dark":return{"autoAccept"`)===-1&&e.indexOf(`case"light":return{`)===-1)return console.error(`patch: themes: failed to find switchMatch`),null;let i=e.indexOf(`case"dark":return{`)===-1?e.indexOf(`case"light":return{`):e.indexOf(`case"dark":return{`),a=e.slice(Math.max(0,i-200),i).match(/switch\(([$\w]+)\)\{\s*$/);if(!a||a.index==null)return console.error(`patch: themes: failed to find switchMatch (old format)`),null;t=Math.max(0,i-200)+a.index,r=a[1];let o=0;for(let r=t;r<e.length&&r<t+5e4;r++)if(e[r]===`{`&&o++,e[r]===`}`&&(o--,o===0)){n=r+1;break}}if(t===-1||n===-1)return console.error(`patch: themes: failed to find switchMatch`),null;let a=-1,o=-1,s=``,c=e.match(/\[(?:\.\.\.\[\],)?(?:\{"?label"?:"(?:Dark|Light|Auto|Monochrome)[^"]*","?value"?:"[^"]+"\},?)+\]/);if(c&&c.index!==void 0)a=c.index,o=c.index+c[0].length;else{let t=[...e.matchAll(/([$\w]+)=\{label:"(?:Auto|Dark|Light|Monochrome)[^"]*",value:"[^"]+"\}/g)];if(t.length<2)return console.error(`patch: themes: failed to find objArrMatch`),null;let n=t.map(e=>e[1]).map(e=>e.replace(/\$/g,`\\$`)).join(`,`),r=RegExp(`\\[${n}((?:,\\.\\.\\.[^\\]]+)*)\\]`),i=e.match(r);if(!i||i.index===void 0)return console.error(`patch: themes: failed to find objArrMatch (new var-collected form)`),null;a=i.index,o=i.index+i[0].length,s=i[1]}let l=e.match(/(return|[$\w]+=)\{(?:"?(?:[$\w-]+)"?:"(?:Auto |Dark|Light|Monochrome)[^"]*",?)+\}/);return(!l||l.index==null)&&W(`patch: themes: objMatch not found — colors will still apply, theme name map unchanged`),{switchStatement:{startIndex:t,endIndex:n,identifiers:[r]},objArr:{startIndex:a,endIndex:o,identifiers:[s]},obj:l&&l.index!==void 0?{startIndex:l.index,endIndex:l.index+l[0].length,identifiers:[l[1]]}:null}}const ie=(e,t)=>{let n=re(e);if(!n)return null;if(t.length===0)return e;let r=e;if(n.obj){let i=(n.obj.identifiers?.[0]??`return`)+JSON.stringify(Object.fromEntries(t.map(e=>[e.id,e.name])));r=r.slice(0,n.obj.startIndex)+i+r.slice(n.obj.endIndex),F(e,r,i,n.obj.startIndex,n.obj.endIndex),e=r}let i=n.objArr.identifiers?.[0]??``,a=`[${t.map(e=>JSON.stringify({label:e.name,value:e.id})).join(`,`)}${i}]`;r=r.slice(0,n.objArr.startIndex)+a+r.slice(n.objArr.endIndex),F(e,r,a,n.objArr.startIndex,n.objArr.endIndex),e=r;let o=`switch(${n.switchStatement.identifiers?.[0]}){\n`;return t.forEach(e=>{o+=`case${JSON.stringify(e.id)}:return${JSON.stringify(e.colors)};\n`}),o+=`default:return${JSON.stringify(t[0].colors)};\n}`,r=r.slice(0,n.switchStatement.startIndex)+o+r.slice(n.switchStatement.endIndex),F(e,r,o,n.switchStatement.startIndex,n.switchStatement.endIndex),r},ae=`(+process.env.CLAUDE_CODE_CONTEXT_LIMIT||200000)`,oe=e=>{let t=/var ([\w$]+)=200000,([\w$]+)=200000,([\w$]+)=20000,([\w$]+)=32000,([\w$]+)=(128000|64000);/,n=e.match(t);if(n)return e.replace(t,`var ${n[1]}=${ae},${n[2]}=${ae},${n[3]}=20000,${n[4]}=32000,${n[5]}=${n[6]};`);let r=/var ([\w$]+)=200000,([\w$]+)=20000,([\w$]+)=32000,([\w$]+)=(128000|64000);/,i=e.match(r);return i?e.replace(r,`var ${i[1]}=${ae},${i[2]}=20000,${i[3]}=32000,${i[4]}=${i[5]};`):(console.error(`patch: contextLimit: failed to find context limit constants`),null)},se=(e,t)=>{if(!t)return e;let n=e,r=!1,i=n.match(/createElement\(([$\w]+),\{color:([$\w]+)\.bgColor\},"─"\.repeat\(([$\w]+)\)\)/);if(i){let e=i[1];n=n.replace(i[0],`createElement(${e},null,"")`);let t=RegExp(`createElement\\(${e},\\{color:${i[2]}\\.bgColor\\},${i[2]}\\.text\\?.+?"─"\\.repeat\\(${i[3]}\\)\\)`),a=n.match(t);a&&(n=n.replace(a[0],`createElement(${e},null,"")`)),r=!0}let a=n.match(/(borderColor:[$\w]+\(\),)borderStyle:"round"(,borderLeft:!1,borderRight:!1,borderBottom:!0,width:"100%",borderText:)/);a&&(n=n.replace(a[0],`${a[1]}borderStyle:undefined${a[2]}`),r=!0);let o=n.match(/borderStyle:"round"(,borderLeft:!1,borderRight:!1,borderBottom:!0,width:"100%"\}.+?Save and close editor)/);return o&&(n=n.replace(o[0],`borderStyle:undefined${o[1]}`),r=!0),r?(F(e,n,`(input border removed)`,0,0),n):(console.error(`patch: input border: failed to find input border pattern`),null)},ce=e=>{let t=(e.match(/overrideMessage:[$\w]+,isCompacting:[$\w]+,compactingHintText:[$\w]+,compactingStartTime:[$\w]+,spinnerSuffix:[$\w]+,verbose:[$\w]+,.{300}/)||e.match(/spinnerTip:[$\w]+,(?:[$\w]+:[$\w]+,)*overrideMessage:[$\w]+,.{300}/)||e.match(/overrideMessage:[$\w]+,spinnerSuffix:[$\w]+,verbose:[$\w]+,.{300}/)||e.match(/pauseStartTimeRef:[$\w]+,spinnerSuffix:[$\w]+,verbose:[$\w]+,.{300}/))?.index,n=t===void 0?``:e.slice(t,t+2e4),r=n.match(/,([$\w]+)(=\(([^;]{1,200}?)\)\+"(?:…|\\u2026)")/);if(r&&r.index!=null)return{startIndex:t+r.index+r[1].length+1,endIndex:t+r.index+r[1].length+r[2].length+1,identifiers:[r[3]]};let i=/,([$\w]+)(=(\([$\w]+&&![$\w]+\.isIdle\?[$\w]+\.spinnerVerb\?\?[$\w]+:[$\w]+\))\+"(?:…|\\u2026)")/,a=n.match(i);if(a&&a.index!=null)return{startIndex:t+a.index+a[1].length+1,endIndex:t+a.index+a[1].length+a[2].length+1,identifiers:[a[3]]};let o=n.match(/,([$\w]+)(=`\$\{([$\w]+&&![$\w]+\.isIdle\?[$\w]+\.spinnerVerb\?\?[$\w]+:[$\w]+)\}(?:…|\\u2026) ?`)/);if(o&&o.index!=null)return{startIndex:t+o.index+o[1].length+1,endIndex:t+o.index+o[1].length+o[2].length+1,identifiers:[o[3]]};let s=new RegExp(i.source,`g`),c=[...e.matchAll(s)].filter(t=>{if(t.index==null)return!1;let n=e.slice(Math.max(0,t.index-2500),t.index+1e3);return n.includes(`overrideMessage:`)&&n.includes(`.activeForm`)&&n.includes(`.isIdle`)&&n.includes(`.spinnerVerb`)&&n.includes(`spinnerTip`)});if(c.length===1){let e=c[0];return{startIndex:e.index+e[1].length+1,endIndex:e.index+e[1].length+e[2].length+1,identifiers:[e[3]]}}return console.error(`patch: thinker format: failed to find formatMatch`),null},le=(e,t)=>{let n=ce(e);if(!n)return null;let r=n,i=K(t.replace(/\\/g,`\\\\`).replace(/`/g,"\\`").replace(/\$\{/g,"\\${")),a=r.identifiers?.[0],o=`=${"`"+i.replace(/\{\}/g,"${"+a+`}`)+"`"}`,s=e.slice(0,r.startIndex)+o+e.slice(r.endIndex);return F(e,s,o,r.startIndex,r.endIndex),s},ue=e=>{let t=e.match(/=\s*\[\.\.\.([$\w]+),\s*\.\.\.?\[\.\.\.\1\]\.reverse\(\)\]/);return!t||t.index==null?(console.error(`patch: thinker symbol mirror option: failed to find match`),null):{startIndex:t.index,endIndex:t.index+t[0].length,identifiers:[t[1]]}},de=(e,t)=>{let n=ue(e);if(!n)return null;let r=n.identifiers?.[0],i=t?`=[...${r},...[...${r}].reverse()]`:`=[...${r}]`,a=e.slice(0,n.startIndex)+i+e.slice(n.endIndex);return F(e,a,i,n.startIndex,n.endIndex),a},fe=(e,t)=>{let n=[],r=/\["(?:[·✢*✳✶✻✽]|\\u00b7|\\xb7|\\u2722|\\x2a|\\u002a|\\u2733|\\u2736|\\u273b|\\u273d)",\s*(?:"(?:[·✢*✳✶✻✽]|\\u00b7|\\xb7|\\u2722|\\x2a|\\u002a|\\u2733|\\u2736|\\u273b|\\u273d)",?\s*)+\]/gi,i;for(;(i=r.exec(e))!==null;)n.push({startIndex:i.index,endIndex:i.index+i[0].length});if(n.length===0)return console.error(`patch: thinkerSymbolChars: could not find any thinker symbol char arrays`),null;let a=K(JSON.stringify(t)),o=n.sort((e,t)=>t.startIndex-e.startIndex),s=e;for(let e=0;e<o.length;e++){let t=s.slice(0,o[e].startIndex)+a+s.slice(o[e].endIndex);F(s,t,a,o[e].startIndex,o[e].endIndex),s=t}return s},pe=(e,t)=>{let n=e.match(/(if\(![$\w]+\)\{[$\w]+\(4\);return\})(.{0,200})120\)/);if(!n||n.index===void 0)return console.error(`patch: thinkerSymbolSpeed: failed to find thinker symbol speed pattern`),null;let r=n[2]+t+`)`,i=n.index,a=i+n[0].length,o=e.slice(0,i)+r+e.slice(a);return F(e,o,r,i,a),o},me=(e,t)=>{let n=/\{(ref:[$\w]+,)("aria-hidden":!0,)?flexWrap:"wrap",height:1,width:2(,children:[$\w]+)?\}/g,r=[],i;for(;(i=n.exec(e))!==null;)r.push({startIndex:i.index,endIndex:i.index+i[0].length,replacement:`{${i[1]}${i[2]??``}flexWrap:"wrap",height:1,width:${t}${i[3]??``}}`});if(r.length>0)return r;let a=e.match(/\{("aria-hidden":!0,)?flexWrap:"wrap",height:1,width:2\}/);return a&&a.index!=null?[{startIndex:a.index,endIndex:a.index+a[0].length,replacement:`{${a[1]??``}flexWrap:"wrap",height:1,width:${t}}`}]:null},he=(e,t)=>{let n=me(e,t);if(!n||n.length===0)return console.error(`patch: thinker symbol width: failed to find match`),null;let r=[...n].sort((e,t)=>t.startIndex-e.startIndex),i=e;for(let e of r){let t=i.slice(0,e.startIndex)+e.replacement+i.slice(e.endIndex);F(i,t,e.replacement,e.startIndex,e.endIndex),i=t}return i},ge=(e,t)=>{let n=e.match(/\[("[A-Z][a-z'é\-\\xA-F0-9]+in[g']",?){50,}\]/);if(!n||n.index===void 0)return console.error(`patch: thinkingVerbs: failed to find present tense verbs pattern`),null;let r=K(JSON.stringify(t)),i=n.index,a=i+n[0].length,o=e.slice(0,i)+r+e.slice(a);return F(e,o,r,i,a),o},_e=(e,t)=>{let n=e.match(/\[("[A-Z][a-z'é\-\\xA-F0-9]+ed",?){6,}\]/);if(!n||n.index===void 0)return console.error(`patch: thinkingVerbs: failed to find past tense verbs pattern`),null;let r=t.map(e=>e.replace(/ing$/,`ed`)),i=K(JSON.stringify(r)),a=n.index,o=a+n[0].length,s=e.slice(0,a)+i+e.slice(o);return F(e,s,i,a,o),s},ve=(e,t)=>{let n=ge(e,t);if(n===null)return null;let r=_e(n,t);return r===null?null:r},ye=e=>e.replace(/\\/g,`\\\\`).replace(/`/g,"\\`").replace(/\$\{/g,"\\${"),be=(e,t)=>{let n=zi(e);if(!n)return console.error(`patch: userMessageDisplay: failed to find Text component`),null;let r=Vi(e),i=R(e);if(!i)return console.error(`patch: userMessageDisplay: failed to find chalk variable`),null;let a=/(No content found in user prompt message.{0,250}?\b)([$\w]+(?:\.default)?\.createElement.{0,30}\b[$\w]+(?:\.default)?\.createElement.{0,40}">.+?)?(([$\w]+(?:\.default)?\.createElement).{0,200})(\([$\w]+,(?:\{[^{}]+wrap:"wrap"\},([$\w]+)(?:\.trim\(\))?\)\)|\{text:([$\w]+)[^}]*\}\)\)?))/,o=/(No content found in user prompt message[\s\S]{0,100}?;return )([$\w]+(?:\.default)?)\.createElement\(([$\w]+),(\{flexDirection:"column"[^{}]*\}),([$\w]+(?:\.default)?)\.createElement\(([$\w]+),\{text:([$\w]+)[^{}]*\}\)\)/,s=e.match(/(No content found in user prompt message[\s\S]{0,400}?\.jsx\([$\w]+,\{text:([$\w]+),useBriefLayout:[$\w]+,timestamp:[$\w]+\}\)[\s\S]{0,200}?([$\w]+)\.jsx\([$\w]+,)(\{flexDirection:"column"[^{}]*?)(,children:)([$\w]+)(\}\))/),c=s?null:e.match(o),l=s||c?null:e.match(/(No content found in user prompt message.{0,1200}?)([$\w]+)=([$\w]+(?:\.default)?\.createElement)\([$\w]+,\{text:([$\w]+),useBriefLayout:[$\w]+,timestamp:[$\w]+\}\)/),u=s||c||l?null:e.match(a);if(!s&&!c&&(!l||l.index===void 0)&&(!u||u.index===void 0))return console.error(`patch: userMessageDisplay: failed to find user message display pattern`),e;let d=e=>`(typeof ${e}==="object"&&${e}!==null?${e}.head+"\\n("+${e}.hiddenLines+" line"+(${e}.hiddenLines===1?"":"s")+" hidden)\\n"+${e}.tail:${e})`;if(s){let r=s[1],i=s[2],a=s[3],o=s[4],c=s[5],l=o.slice(1),u=/backgroundColor:[$\w]+/;if(t.backgroundColor===null)l=l.replace(RegExp(`,?${u.source}`),``).replace(/^,|,$/g,``);else if(t.backgroundColor!==`default`){let e=t.backgroundColor.match(/\d+/g);if(e){let t=`backgroundColor:"rgb(${e.join(`,`)})"`;l=u.test(l)?l.replace(u,t):l?`${l},${t}`:t}}let f=[];if(t.borderStyle!==`none`){if(t.borderStyle.startsWith(`topBottom`)){let e=``;t.borderStyle===`topBottomSingle`?e=`{top:"─",bottom:"─",left:" ",right:" ",topLeft:" ",topRight:" ",bottomLeft:" ",bottomRight:" "}`:t.borderStyle===`topBottomDouble`?e=`{top:"═",bottom:"═",left:" ",right:" ",topLeft:" ",topRight:" ",bottomLeft:" ",bottomRight:" "}`:t.borderStyle===`topBottomBold`&&(e=`{top:"━",bottom:"━",left:" ",right:" ",topLeft:" ",topRight:" ",bottomLeft:" ",bottomRight:" "}`),f.push(`borderStyle:${K(e)}`)}else f.push(`borderStyle:"${t.borderStyle}"`);let e=t.borderColor.match(/\d+/g);e&&f.push(`borderColor:"rgb(${e.join(`,`)})"`)}t.paddingX!==`default`&&t.paddingX>0&&f.push(`paddingX:${t.paddingX}`),t.paddingY!==`default`&&t.paddingY>0&&f.push(`paddingY:${t.paddingY}`),t.fitBoxToContent&&f.push(`alignSelf:"flex-start"`),f.length>0&&(l=l?`${l},${f.join(`,`)}`:f.join(`,`));let p=[];if(t.foregroundColor===`default`)p.push(`color:"text"`);else{let e=t.foregroundColor.match(/\d+/g);e&&p.push(`color:"rgb(${e.join(`,`)})"`)}if(t.backgroundColor!==`default`&&t.backgroundColor!==null){let e=t.backgroundColor.match(/\d+/g);e&&p.push(`backgroundColor:"rgb(${e.join(`,`)})"`)}else t.backgroundColor===`default`&&p.push(`backgroundColor:"userMessageBackground"`);t.styling.includes(`bold`)&&p.push(`bold:!0`),t.styling.includes(`italic`)&&p.push(`italic:!0`),t.styling.includes(`underline`)&&p.push(`underline:!0`),t.styling.includes(`strikethrough`)&&p.push(`strikethrough:!0`),t.styling.includes(`inverse`)&&p.push(`inverse:!0`);let m=p.length>0?`${p.join(`,`)},`:``,h=d(i),g=`${a}.jsx(${n},{${m}children:${"`"+ye(t.format).replace(/\{\}/g,()=>"${"+h+`}`)+"`"}})`,_=r+`{${l}`+c+g+`})`,v=s.index,y=v+s[0].length,b=e.slice(0,v)+_+e.slice(y);return F(e,b,_,v,y),b}if(c){let r=c[1],i=c[2],a=c[3],o=c[4],s=c[5],l=c[7],u=o.slice(1,-1),f=/backgroundColor:[^,}]+(?:\?[^,}:]+:[^,}:]+)*/;if(t.backgroundColor===null)u=u.replace(RegExp(`,?${f.source}`),``).replace(/^,|,$/g,``);else if(t.backgroundColor!==`default`){let e=t.backgroundColor.match(/\d+/g);if(e){let t=`"rgb(${e.join(`,`)})"`;u=u.replace(/"userMessageBackground"/g,t)}}let p=[];if(t.borderStyle!==`none`){if(t.borderStyle.startsWith(`topBottom`)){let e=``;t.borderStyle===`topBottomSingle`?e=`{top:"─",bottom:"─",left:" ",right:" ",topLeft:" ",topRight:" ",bottomLeft:" ",bottomRight:" "}`:t.borderStyle===`topBottomDouble`?e=`{top:"═",bottom:"═",left:" ",right:" ",topLeft:" ",topRight:" ",bottomLeft:" ",bottomRight:" "}`:t.borderStyle===`topBottomBold`&&(e=`{top:"━",bottom:"━",left:" ",right:" ",topLeft:" ",topRight:" ",bottomLeft:" ",bottomRight:" "}`),p.push(`borderStyle:${K(e)}`)}else p.push(`borderStyle:"${t.borderStyle}"`);let e=t.borderColor.match(/\d+/g);e&&p.push(`borderColor:"rgb(${e.join(`,`)})"`)}t.paddingX!==`default`&&t.paddingX>0&&p.push(`paddingX:${t.paddingX}`),t.paddingY!==`default`&&t.paddingY>0&&p.push(`paddingY:${t.paddingY}`),t.fitBoxToContent&&p.push(`alignSelf:"flex-start"`),p.length>0&&(u=u?`${u},${p.join(`,`)}`:p.join(`,`));let m=`{${u}}`,h=[];if(t.foregroundColor===`default`)h.push(`color:"text"`);else{let e=t.foregroundColor.match(/\d+/g);e&&h.push(`color:"rgb(${e.join(`,`)})"`)}if(t.backgroundColor!==`default`&&t.backgroundColor!==null){let e=t.backgroundColor.match(/\d+/g);e&&h.push(`backgroundColor:"rgb(${e.join(`,`)})"`)}else t.backgroundColor===`default`&&h.push(`backgroundColor:"userMessageBackground"`);t.styling.includes(`bold`)&&h.push(`bold:!0`),t.styling.includes(`italic`)&&h.push(`italic:!0`),t.styling.includes(`underline`)&&h.push(`underline:!0`),t.styling.includes(`strikethrough`)&&h.push(`strikethrough:!0`),t.styling.includes(`inverse`)&&h.push(`inverse:!0`);let g=h.length>0?`{${h.join(`,`)}}`:`null`,_=d(l),v=r+`${i}.createElement(${a},${m},${s}.createElement(${n},${g},${"`"+ye(t.format).replace(/\{\}/g,()=>"${"+_+`}`)+"`"}))`,y=c.index,b=y+c[0].length,x=e.slice(0,y)+v+e.slice(b);return F(e,x,v,y,b),x}if(!r)return console.error(`patch: userMessageDisplay: failed to find Box component`),null;let f=l??u,p=l?l[3]:u[4],m=l?l[4]:u[6]??u[7],h=[],g=t.borderStyle.startsWith(`topBottom`);if(t.borderStyle!==`none`){if(g){let e=``;t.borderStyle===`topBottomSingle`?e=`{top:"─",bottom:"─",left:" ",right:" ",topLeft:" ",topRight:" ",bottomLeft:" ",bottomRight:" "}`:t.borderStyle===`topBottomDouble`?e=`{top:"═",bottom:"═",left:" ",right:" ",topLeft:" ",topRight:" ",bottomLeft:" ",bottomRight:" "}`:t.borderStyle===`topBottomBold`&&(e=`{top:"━",bottom:"━",left:" ",right:" ",topLeft:" ",topRight:" ",bottomLeft:" ",bottomRight:" "}`),h.push(`borderStyle:${K(e)}`)}else h.push(`borderStyle:"${t.borderStyle}"`);let e=t.borderColor.match(/\d+/g);e&&h.push(`borderColor:"rgb(${e.join(`,`)})"`)}t.paddingX===`default`?h.push(`paddingRight:1`):t.paddingX>0&&h.push(`paddingX:${t.paddingX}`),t.paddingY!==`default`&&t.paddingY>0&&h.push(`paddingY:${t.paddingY}`),t.fitBoxToContent&&h.push(`alignSelf:"flex-start"`);let _=i,v=[];if(t.foregroundColor!==`default`){let e=t.foregroundColor.match(/\d+/g);e&&(_+=`.rgb(${e.join(`,`)})`)}else v.push(`color:"text"`);if(t.backgroundColor!==`default`&&t.backgroundColor!==null){let e=t.backgroundColor.match(/\d+/g);if(e){_+=`.bgRgb(${e.join(`,`)})`;let t=`"rgb(${e.join(`,`)})"`;h.push(`backgroundColor:${t}`),v.push(`backgroundColor:${t}`)}}else t.backgroundColor===`default`&&(h.push(`backgroundColor:"userMessageBackground"`),v.push(`backgroundColor:"userMessageBackground"`));t.styling.includes(`bold`)&&(_+=`.bold`),t.styling.includes(`italic`)&&(_+=`.italic`),t.styling.includes(`underline`)&&(_+=`.underline`),t.styling.includes(`strikethrough`)&&(_+=`.strikethrough`),t.styling.includes(`inverse`)&&(_+=`.inverse`);let y=d(m),b="`"+ye(t.format).replace(/\{\}/g,()=>"${"+y+`}`)+"`",x=`${_}(${b})`,S=h.length>0?`{${h.join(`,`)}}`:`null`,C=v.length>0?`{${v.join(`,`)}}`:`null`,w=l?`${l[2]}=`:``,T=f[1]+`${w}${p}(${r},${S},${p}(${n},${C},${x}))`,E=f.index,D=E+f[0].length,O=e.slice(0,E)+T+e.slice(D);return F(e,O,T,E,D),O},xe=(e,t)=>{let n=e;if(t.foregroundColor){let e=t.foregroundColor.match(/\d+/g);e&&(n+=`.rgb(${e.join(`,`)})`)}if(t.backgroundColor){let e=t.backgroundColor.match(/\d+/g);e&&(n+=`.bgRgb(${e.join(`,`)})`)}return t.styling.includes(`bold`)&&(n+=`.bold`),t.styling.includes(`italic`)&&(n+=`.italic`),t.styling.includes(`underline`)&&(n+=`.underline`),t.styling.includes(`strikethrough`)&&(n+=`.strikethrough`),t.styling.includes(`inverse`)&&(n+=`.inverse`),n},Se=e=>{let t=e.match(/(if\(([$\w]+)\.highlight\?\.color\))((return [$\w]+\.createElement\([$\w]+,\{key:[$\w]+),color:[$\w]+\.highlight\.color(\},[$\w]+\.createElement\([$\w]+,null,)([$\w]+\.text)(\)\)));/);if(t&&t.index!==void 0){let n=`${t[2]}.highlight.color(${t[6]})`,r=t[1]+`{if(typeof ${t[2]}.highlight.color==='function')`+t[4]+t[5]+n+t[7]+`;else `+t[3]+`}`,i=e.slice(0,t.index)+r+e.slice(t.index+t[0].length);return F(e,i,r,t.index,t.index+t[0].length),i}let n=/(return ([$\w]+)\.createElement\(([$\w]+),\{key:([$\w]+)),color:([$\w]+)\.highlight\?\.color,dimColor:\5\.highlight\?\.dimColor,inverse:\5\.highlight\?\.inverse\},(\2\.createElement\([$\w]+,null,\5\.text\))\)/,r=e.match(n);if(!r||r.index===void 0)return console.error(`patch: inputPatternHighlighters: failed to find highlight?.color renderer pattern`),null;let i=r[2],a=r[3],o=r[4],s=r[5];r[6];let c=RegExp(`if\\(${s.replace(`$`,`\\$`)}\\.highlight\\.color\\)return ([$\\w]+)\\.createElement\\([$\\w]+,\\{key:[$\\w]+\\},${s.replace(`$`,`\\$`)}\\.text\\.split\\(""\\)\\.map\\([^)]+\\)\\)`),l=e,u=l.match(c);if(u&&u.index!==void 0){let e=`if(typeof ${s}.highlight?.color==='function')return ${i}.createElement(${a},{key:${o}},${i}.createElement(${a},null,${s}.highlight.color(${s}.text)));`;l=l.slice(0,u.index)+e+l.slice(u.index)}let d=l.match(n);if(!d||d.index===void 0)return console.error(`patch: inputPatternHighlighters: failed to re-find renderer after shimmer patch`),null;let f=d[2],p=d[3],m=d[4],h=d[5],g=d[6],_=`${h}.highlight?.style?${h}.highlight.style(${h}.text):${h}.text`,v=`return ${f}.createElement(${p},{key:${m},color:${h}.highlight?.style?void 0:${h}.highlight?.color,backgroundColor:${h}.highlight?.style?void 0:${h}.highlight?.backgroundColor,dimColor:${h}.highlight?.dimColor,inverse:${h}.highlight?.style?void 0:${h}.highlight?.inverse,bold:${h}.highlight?.style?void 0:${h}.highlight?.bold,italic:${h}.highlight?.style?void 0:${h}.highlight?.italic,underline:${h}.highlight?.style?void 0:${h}.highlight?.underline,strikethrough:${h}.highlight?.style?void 0:${h}.highlight?.strikethrough},${g.replace(`${h}.text`,_)})`,y=l.slice(0,d.index)+v+l.slice(d.index+d[0].length);return F(e,y,`shimmer guard + renderer`,0,0),y},Ce=(e,t,n)=>{let r=e.match(/((?:,|;let )[$\w]+=[$\w]+\.useMemo\(\(\)=>\{let [$\w]+=\[\];[\s\S]{0,2000}?)(if\([$\w]+&&[$\w]+&&![$\w]+\)([$\w]+)\.push\(\{start:[$\w]+,end:[$\w]+\+[$\w]+\.length,color:"warning",priority:\d+\})/);if(!r||r.index===void 0)return console.error(`patch: inputPatternHighlighters: failed to find useMemo/push pattern`),null;let i=r[3],a=r[1].match(/[^$\w]([$\w]+(?:\.default)?)\.useMemo\(/);if(!a)return console.error(`patch: inputPatternHighlighters: failed to extract React var from useMemo`),null;a[1];let o=Math.max(0,r.index-15e3),s=e.slice(o,r.index),c=/\binputValue:([$\w]+),/g,l=/\binput:([$\w]+),/g,u=[...s.matchAll(c)],d=[...s.matchAll(l)],f=u.at(-1)??d.at(-1)??null;if(!f)return console.error(`patch: inputPatternHighlighters: failed to find input variable pattern (looked for inputValue: and input:)`),null;let p=f[1],m=``;for(let e=0;e<n.length;e++){let r=n[e],a=xe(t,r),o=r.format??`{MATCH}`;JSON.stringify(o).replace(/\{MATCH\}/g,`"+x+"`);let s=r.foregroundColor;if(s){let e=s.match(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/);if(e){let[,t,n,r]=e.map(Number);s=`#${t.toString(16).padStart(2,`0`)}${n.toString(16).padStart(2,`0`)}${r.toString(16).padStart(2,`0`)}`}}let c=s?JSON.stringify(s):`undefined`,l=r.backgroundColor;if(l){let e=l.match(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/);if(e){let[,t,n,r]=e.map(Number);l=`#${t.toString(16).padStart(2,`0`)}${n.toString(16).padStart(2,`0`)}${r.toString(16).padStart(2,`0`)}`}}let u=l?JSON.stringify(l):null,d=r.styling??[],f=d.includes(`bold`),h=d.includes(`italic`),g=d.includes(`underline`),_=d.includes(`inverse`),v=d.includes(`dim`),y=d.includes(`strikethrough`),b=r.regex??r.pattern;if(!b){console.error(`patch: inputPatternHighlighters: highlighter "${r.name}" has no regex/pattern; skipping`);continue}let x=r.regexFlags??``;x.includes(`g`)||(x+=`g`);let S;try{S=new RegExp(b,x)}catch(e){console.error(`patch: inputPatternHighlighters: highlighter "${r.name}" has invalid regex; skipping`,e);continue}let C=ba(S);m+=`if(typeof ${p}==="string"){for(let m of ${p}.matchAll(${C})){${i}.push({start:m.index,end:m.index+m[0].length,color:${c}${u?`,backgroundColor:${u}`:``}${f?`,bold:!0`:``}${h?`,italic:!0`:``}${g?`,underline:!0`:``}${_?`,inverse:!0`:``}${v?`,dimColor:!0`:``}${y?`,strikethrough:!0`:``},style:(x)=>${a}(x),priority:100})}}`}if(!m)return console.error(`patch: inputPatternHighlighters: no usable highlighters generated (all skipped)`),null;let h=r[1]+m+r[2],g=e.slice(0,r.index),_=e.slice(r.index+r[0].length),v=g+``+h+_,y=v.indexOf(`for(let m of ${p}.matchAll(`);if(y>-1){let e=[...v.slice(Math.max(0,y-2e3),y).matchAll(/useMemo\(\(\)=>\{/g)];if(e.length>0){let t=Math.max(0,y-2e3)+e[e.length-1].index,n=v.slice(t),r=0;for(let e=0;e<n.length;e++)if(n[e]===`(`)r++;else if(n[e]===`)`&&(r--,r===0)){let n=t+e;v.slice(n-1,n)===`]`&&(v.slice(n-200,n).includes(`,${p}]`)||(v=v.slice(0,n-1)+`,${p}]`+v.slice(n)));break}}}return F(e,v,``+h,r.index,r.index+r[0].length),v},we=(e,t)=>{let n=t.filter(e=>e.enabled!==!1);if(n.length===0)return console.error(`patch: inputPatternHighlighters: no enabled highlighters provided`),null;let r=R(e);if(!r)return console.error(`patch: inputPatternHighlighters: failed to find chalk variable`),null;let i;return i=Se(e),i?(i=Ce(i,r,n),i||(console.error(`^ patch: inputPatternHighlighters: writeCustomHighlighterCreation failed`),null)):(console.error(`^ patch: inputPatternHighlighters: writeCustomHighlighterImpl failed`),null)},Te=e=>{let t=e.match(/(?:[$\w]+\.)?createElement\([$\w]+,\{(?=[^}]*responseLengthRef:)(?=[^}]*spinnerSuffix:)(?=[^}]*thinkingStatus:)(?=[^}]*isCompacting:)[^}]*verbose:[^,}]+[^}]*\}/);if(t&&t.index!==void 0){let e=t[0].match(/verbose:[^,}]+/);if(!e||e.index===void 0)return console.error(`patch: verbose: failed to find verbose property`),null;let n=t.index+e.index;return{startIndex:n,endIndex:n+e[0].length,replacement:`verbose:true`}}let n=e.match(/\{[^{}]{0,400}overrideMessage:[$\w]+,[^{}]{0,200}verbose:([$\w]+)[^{}]{0,200}\}\)\{/);if(n&&n.index!==void 0){let e=n[1],t=n.index+n[0].length;return{startIndex:t,endIndex:t,replacement:`${e}=!0;`}}return console.error(`patch: verbose: failed to find spinner props containing overrideMessage and verbose`),null},Ee=e=>{let t=Te(e);if(!t)return null;let n=e.slice(0,t.startIndex)+t.replacement+e.slice(t.endIndex);return F(e,n,t.replacement,t.startIndex,t.endIndex),n},De=e=>{let t=e.match(/if\s*\(\s*([$\w]+)\(\)\s*===\s*"opusplan"\s*&&\s*([$\w]+)\s*===\s*"plan"\s*&&\s*!([$\w]+)\s*\)\s*return\s*([$\w]+)\(\);/);if(!t||t.index===void 0)return console.error(`patch: opusplan1m: patchModeSwitchingFunction: failed to find mode switching pattern`),null;let[n,r,i,a,o]=t,s=`if((${r}()==="opusplan"||${r}()==="opusplan[1m]")&&${i}==="plan"&&!${a})return ${o}();`,c=e.slice(0,t.index)+s+e.slice(t.index+n.length);return F(e,c,s,t.index,t.index+n.length),c},Oe=e=>{let t=e.match(/(\["sonnet","opus","haiku",(?:"best",)?"sonnet\[1m\]",(?:"opus\[1m\]",)?"opusplan")/);if(!t||t.index===void 0)return console.error(`patch: opusplan1m: patchModelAliasesList: failed to find model aliases list`),null;let n=t[0]+`,"opusplan[1m]"`,r=e.slice(0,t.index)+n+e.slice(t.index+t[0].length);return F(e,r,n,t.index,t.index+t[0].length),r},ke=e=>{let t=e.match(/(if\s*\(\s*([$\w]+)\s*===\s*"opusplan"\s*\)\s*return\s*"([^"]*Opus[^"]*plan mode[^"]*Sonnet[^"]*)";)/);if(!t||t.index===void 0)return console.error(`patch: opusplan1m: patchDescriptionFunction: failed to find description pattern`),null;let[n,,r,i]=t,a=n+`if(${r}==="opusplan[1m]")return"${i} (1M context)";`,o=e.slice(0,t.index)+a+e.slice(t.index+n.length);return F(e,o,a,t.index,t.index+n.length),o},Ae=e=>{let t=e.match(/(if\s*\(\s*([$\w]+)\s*===\s*"opusplan"\s*\)\s*return\s*"Opus Plan";)/);if(!t||t.index===void 0)return console.error(`patch: opusplan1m: patchLabelFunction: failed to find label pattern`),null;let[n,,r]=t,i=n+`if(${r}==="opusplan[1m]")return"Opus Plan 1M";`,a=e.slice(0,t.index)+i+e.slice(t.index+n.length);return F(e,a,i,t.index,t.index+n.length),a},je=e=>{let t=e.match(/(if\s*\(\s*([$\w]+)\s*===\s*"opusplan"\s*\)\s*return\s*(?:[$\w]+\()?\[\s*\.\.\.([$\w]+)\s*,\s*([$\w]+)\(\)\s*\]\)?;)/);if(!t||t.index===void 0)return console.error(`patch: opusplan1m: patchModelSelectorOptions: failed to find model selector pattern`),null;let[n,,r,i]=t,a=n.match(RegExp(`return\\s*([$\\w]+)\\(\\s*\\[\\.\\.\\.${U(i)}`)),o=a?a[1]:null,s=`{value:"opusplan[1m]",label:"Opus Plan Mode 1M",description:"Use Opus in plan mode, Sonnet (1M context) otherwise"}`,c=n+`if(${r}==="opusplan[1m]")return ${o?`${o}([...${i},${s}])`:`[...${i},${s}]`};`,l=e.slice(0,t.index)+c+e.slice(t.index+n.length);return F(e,l,c,t.index,t.index+n.length),l},Me=e=>{let t=e.match(/(if\s*\(\s*[$\w]+\s*===\s*null\s*\|\|\s*([$\w]+)\.some\s*\(\s*\(\s*[$\w]+\s*\)\s*=>\s*[$\w]+\.value\s*===\s*[$\w]+\s*\)\s*\)\s*return\s*(?:[$\w]+\()?[$\w]+\)?\s*;)/);if(!t||t.index===void 0)return console.error(`patch: opusplan1m: patchAlwaysShowInModelSelector: failed to find model list check pattern`),null;let[,,n]=t,r=`${n}.push({value:"opusplan",label:"Opus Plan Mode",description:"Use Opus in plan mode, Sonnet otherwise"});${n}.push({value:"opusplan[1m]",label:"Opus Plan Mode 1M",description:"Use Opus in plan mode, Sonnet (1M context) otherwise"});`,i=e.slice(0,t.index)+r+e.slice(t.index);return F(e,i,r,t.index,t.index),i},Ne=e=>{if(e.includes(`"opusplan[1m]"`))return console.log(`patch: opusplan1m: opusplan[1m] already supported natively — skipping`),e;let t=e,n=De(t);if(n)t=n;else return console.error(`patch: opusplan1m: failed to apply mode switching patch`),null;if(n=Oe(t),n)t=n;else return console.error(`patch: opusplan1m: failed to apply model aliases list patch`),null;if(n=ke(t),n)t=n;else return console.error(`patch: opusplan1m: failed to apply description function patch`),null;if(n=Ae(t),n)t=n;else return console.error(`patch: opusplan1m: failed to apply label function patch`),null;if(n=je(t),n)t=n;else return console.error(`patch: opusplan1m: failed to apply model selector options patch`),null;if(n=Me(t),n)t=n;else return console.error(`patch: opusplan1m: failed to apply always-show-in-selector patch`),null;return t},Pe=e=>{if(/case"thinking":\{(?:(?!case")[^]){0,600}isTranscriptMode:true/.test(e))return console.log(`patch: thinkingVisibility: already configured natively — skipping`),e;let t=e.match(/(case"thinking":\{?)(if\(.+?\)return null;)(.{0,400}isTranscriptMode:).+?,/);if(!t||t.index===void 0)return console.error(`patch: thinkingVisibility: failed to find thinking visibility pattern`),null;let n=t[1]+t[3]+`true,`,r=t.index,i=r+t[0].length,a=e.slice(0,r)+n+e.slice(i);return F(e,a,n,r,i),a},Fe=(e,t)=>{let n=e.match(/(agentType\s*:\s*"Plan"\s*,[\s\S]{1,2500}?\bmodel\s*:\s*")[^"]+(")/);if(!n||n.index===void 0)return console.error(`patch: subagentModels: failed to find Plan agent pattern`),null;let r=n[1].slice(0,-1)+JSON.stringify(t),i=n.index,a=i+n[0].length,o=e.slice(0,i)+r+e.slice(a);return F(e,o,r,i,a),o},Ie=(e,t)=>{let n=e.match(/(\{agentType\s*:\s*"Explore"\s*,[\s\S]{1,2500}?\bmodel\s*:\s*")[^"]+(")/);if(!n||n.index===void 0)return console.error(`patch: subagentModels: failed to find Explore agent pattern`),null;let r=n[1].slice(0,-1)+JSON.stringify(t),i=n.index,a=i+n[0].length,o=e.slice(0,i)+r+e.slice(a);return F(e,o,r,i,a),o},Le=(e,t)=>{let n=e.match(/([^$\w][$\w]+\s*=\s*\{agentType\s*:\s*"general-purpose"[\s\S]{0,2500}?)(\})/);if(!n||n.index===void 0)return console.error(`patch: subagentModels: failed to find general-purpose agent pattern`),null;let r=n[1],i=n[2],a;a=r.includes(`model:`)?r.replace(/(model\s*:\s*)"[^"]+"/,(e,n)=>n+JSON.stringify(t))+i:r+`${r.trim().endsWith(`,`)?``:`,`}model:`+JSON.stringify(t)+i;let o=n.index,s=o+n[0].length,c=e.slice(0,o)+a+e.slice(s);return F(e,c,a,o,s),c},Re=(e,t)=>{let n=e;if(t.plan){let e=Fe(n,t.plan);if(e===null)return null;n=e}if(t.explore){let e=Ie(n,t.explore);if(e===null)return null;n=e}if(t.generalPurpose){let e=Le(n,t.generalPurpose);if(e===null)return null;n=e}return n},ze=(e,t,n,r)=>`${e}.createElement(${t}, null, ${e}.createElement(${n}, {color: "success", bold: true}, "\\u2503 "), ${e}.createElement(${n}, {dimColor: true}, \` * ${K(r)}\`)),`,Be=e=>{let t=e.indexOf(`}.VERSION} (Claude Code)`);return t==-1?(console.error(`patch: patchesAppliedIndication: failed to find versionIndex`),null):{startIndex:0,endIndex:t+24}},Ve=e=>{let t=e.match(/([$\w]+)\.jsxs\(([$\w]+),\{children:\[(?:[^[\]]{0,200})," ",([$\w]+)\.jsxs\(([$\w]+),\{dimColor:!0,children:\["v",[$\w]+\]\}\)\]\}\)/);if(t&&t.index!==void 0)return{jsxInline:{insertIndex:t.index+t[0].length-3,helper:t[1],textComponent:t[2]}};let n=e.match(/createElement\(([$\w]+),\{bold:!0\},"Claude Code"\),([$\w]+)\[\d+\]=[$\w]+;else [$\w]+=([$\w]+)\[\d+\]/);if(!n||n.index===void 0)return console.error(`patch: patchesAppliedIndication: PATCH 2 failed to find bold Claude Code pattern`),null;let r=n[1],i=n.index+n[0].length,a=e.indexOf(`;`,i);if(a===-1)return null;let o=a+1,s=e.match(/[^$\w]([$\w]+)\.createElement\(([$\w]+),null,[$\w]+," ",([$\w]+)\.createElement\(([$\w]+),\{dimColor:!0\},"v",[$\w]+\)\)/);if(!s||s.index===void 0){let t=e.match(/[^$\w]([$\w]+)\.createElement\(([$\w]+),\{bold:!0\},"Claude Code"\)," ",([$\w]+)\.createElement\(([$\w]+),\{dimColor:!0\},"v",[$\w]+\)/);return!t||t.index===void 0?(console.error(`patch: patchesAppliedIndication: PATCH 2 failed to find version createElement`),null):{varInsertIndex:o,refInsertIndex:t.index+t[0].length,reactVar:t[1],textComponent:r}}return{varInsertIndex:o,refInsertIndex:s.index+s[0].length-1,reactVar:s[1],textComponent:r}},He=e=>{let t=e.match(/[,;){}\]]([$\w]+)=([$\w]+)\.jsxs\(([$\w]+),\{children:\[(?:[^[\]]{0,200})," ",[$\w]+\.jsxs\([$\w]+,\{dimColor:!0,children:\["v",[$\w]+\]\}\)/);if(!t||t.index===void 0)return null;let n=t[1],r=t.index,i=e.slice(r,r+4e3),a=RegExp(`[$\\w]+\\.jsxs\\([$\\w]+,\\{flexDirection:"column",children:\\[(?:[^[\\]]*?,)?${U(n)}[,\\]]`),o=i.match(a);if(!o||o.index===void 0)return null;let s=r+o.index,c=e.indexOf(`children:[`,s)+10;if(c<10)return null;let l=1,u=-1;for(let t=c;t<e.length;t++){let n=e[t];if(n===`[`)l++;else if(n===`]`&&(l--,l===0)){u=t;break}}return u===-1?null:{startIndex:u,endIndex:u}},Ue=e=>{let t=He(e);if(t)return t;let n=e.match(/"Claude Code".{0,200}\{dimColor:!0\},"v",[$\w]+\)/);if(!n||n.index===void 0)return console.error(`patch: patchesAppliedIndication: failed to find version display for patch 3`),null;let r={index:n.index},i=Math.max(0,r.index-5e3),a=e.slice(i,r.index),o=Array.from(a.matchAll(/[};]\s*function ([$\w]+)\(/g));if(o.length===0)return console.error(`patch: patchesAppliedIndication: failed to find header component function`),null;let s=o[o.length-1][1],c=RegExp(`[^$\\w]([$\\w]+)\\.createElement\\(${U(s)},null\\),?`),l=e.match(c);if(!l||l.index===void 0)return console.error(`patch: patchesAppliedIndication: failed to find createElement call for header`),null;let u=e.slice(Math.max(0,l.index-30),l.index+1).match(/([$\w]+)=(?:[$\w]+&&)?[^$\w]?$/);if(u){let t=u[1],n=e.slice(l.index,l.index+2e3),r=RegExp(`,${U(t)}([,\\)])`),i=n.match(r);if(i&&i.index!==void 0){let e=l.index+i.index+i[0].length-i[1].length;return{startIndex:e,endIndex:e}}}let d=l.index+l[0].length;return{startIndex:d,endIndex:d}},We=(e,t,n,r=!0,i=!0)=>{let a=Be(e);if(!a)return console.error(`patch: patchesAppliedIndication: failed to version output location`),null;let o=`\\n${t} (tweakcc-fixed)`,s=`}.VERSION} (Claude Code)`,c=e.replaceAll(s,s+o);F(e,c,o,a.endIndex,a.endIndex);let l=R(e);if(!l)return console.error(`patch: patchesAppliedIndication: failed to find chalk variable`),null;let u=zi(e);if(!u)return console.error(`patch: patchesAppliedIndication: failed to find text component`),null;let d=V(e);if(!d)return console.error(`patch: patchesAppliedIndication: failed to find React variable`),null;if(r){let e=c.match(/(\$\{([$\w]+)\("inactive",([$\w]+)\)\(`v\$\{[$\w]+\}`\)\}) `,/);if(e&&e.index!==void 0){let n=e[0],r=e[2],i=e[3],a=`${e[1]} \${${r}("warning",${i})("+ tweakcc v${t}")} \`,`;c=c.replace(n,a)}c=c.replace(/([$\w]+\("claude",[$\w]+\)\(" Claude Code) ("\))/,`$1 + tweakcc v${t} $2`);let n=Ve(c);if(!n)console.error(`patch: patchesAppliedIndication: patch 2 skipped (header version pattern changed)`);else if(`jsxInline`in n){let{insertIndex:e,helper:r,textComponent:i}=n.jsxInline,a=`," ",${r}.jsx(${i},{children:${l}.hex("#FF8400").bold("+ tweakcc v${t}")})`,o=c;c=c.slice(0,e)+a+c.slice(e),F(o,c,a,e,e)}else{let e=`let _tw=${n.reactVar}.createElement(${n.textComponent},null,${l}.hex("#FF8400").bold("+ tweakcc v${t}"));`,r=c;c=c.slice(0,n.varInsertIndex)+e+c.slice(n.varInsertIndex),F(r,c,e,n.varInsertIndex,n.varInsertIndex);let i=n.refInsertIndex+e.length,a=`," ",_tw`,o=c;c=c.slice(0,i)+a+c.slice(i),F(o,c,a,i,i)}}if(i){let e=Vi(c);if(!e)return console.error(`patch: patchesAppliedIndication: PATCH 3 skipped (Box component not located on this CC version)`),c;let t=Ue(c);if(!t)console.log(`patch: patchesAppliedIndication: patch 3 skipped (see prior message)`);else{let r=[];r.push(`,${d}.createElement(${e}, { flexDirection: "column" },`),r.push(`${d}.createElement(${e}, null, ${d}.createElement(${u}, {color: "success", bold: true}, "\\u2503 "), ${d}.createElement(${u}, {color: "success", bold: true}, "\\u2713 tweakcc-fixed patches are applied")),`);for(let t of n)t=t.replace(`CHALK_VAR`,l),r.push(ze(d,e,u,t));r.push(`),`);let i=r.join(`
|
|
2
|
+
`);t.startIndex>0&&c[t.startIndex-1]===`,`&&i.startsWith(`,`)&&(i=i.slice(1)),i.endsWith(`,`)&&c[t.startIndex]===`,`&&(i=i.slice(0,-1));let a=c;c=c.slice(0,t.startIndex)+i+c.slice(t.endIndex),F(a,c,i,t.startIndex,t.endIndex)}}return c};function Ge(){try{let e=v(import.meta.url),t=f.dirname(e);for(let e=0;e<5;e++){let e=f.join(t,`data`,`prompts`),n=f.join(t,`package.json`);if(s.existsSync(n)&&s.existsSync(e))return e;let r=f.dirname(t);if(r===t)break;t=r}}catch{}return null}async function Ke(e){let t=Ge();if(t){let n=f.join(t,`prompts-${e}.json`);try{let e=await a.readFile(n,`utf-8`);return JSON.parse(e)}catch{}}let n=f.join(Oa,`prompts-${e}.json`),r=async()=>{try{return JSON.parse(await a.readFile(n,`utf-8`))}catch{return null}},i=`https://raw.githubusercontent.com/skrabe/tweakcc-fixed/refs/heads/main/data/prompts/prompts-${e}.json`;try{let t=await fetch(i,{signal:AbortSignal.timeout(2e4)});if(!t.ok){let n=await r();if(n)return n;let i;throw i=t.status===429?`Rate limit exceeded. GitHub has temporarily blocked requests. Please wait a few minutes and try again.`:t.status===404?`Prompts file not found for Claude Code v${e}. The fork's version-bump pipeline hasn't published prompts for this release yet — check https://github.com/skrabe/tweakcc-fixed for status.`:t.status>=500?`GitHub server error (${t.status}). Please try again later.`:`HTTP ${t.status}: ${t.statusText}`,Error(i)}let o=JSON.parse(await xa(t));try{await a.mkdir(Oa,{recursive:!0}),await a.writeFile(n,JSON.stringify(o,null,2),`utf-8`)}catch(e){console.warn(`Failed to write to cache to ${n}: ${e}`)}return o}catch(t){let n=await r();if(n)return n;if(t instanceof Error){if(t.message.includes(`Rate limit`)||t.message.includes(`not found`)||t.message.includes(`server error`)||t.message.includes(`HTTP`))throw t;let n=`Failed to download prompts for version ${e}: ${t.message}`;throw Error(n)}throw t}}const qe=()=>f.join(J,`systemPromptOriginalHashes.json`),Je=()=>f.join(J,`systemPromptAppliedHashes.json`),Ye=(e,t)=>`${e}-${t}`,Xe=e=>h.createHash(`md5`).update(e.trim(),`utf8`).digest(`hex`),Ze=async e=>{try{return JSON.parse(await a.readFile(e,`utf8`))}catch(t){if(t instanceof Error&&`code`in t&&t.code===`ENOENT`)return{};if(t instanceof SyntaxError)return W(`${e} was not valid JSON — ignoring it and rebuilding.`),{};throw t}},Qe=async(e,t)=>{await a.mkdir(J,{recursive:!0});let n={};for(let e of Object.keys(t).sort())n[e]=t[e];let r=`${e}.tmp-${process.pid}`;try{await a.writeFile(r,JSON.stringify(n,null,2),`utf8`),await a.rename(r,e)}catch(e){try{await a.unlink(r)}catch{}throw e}},$e=async()=>Ze(qe()),et=async e=>Qe(qe(),e),tt=async e=>{let t=await $e(),n=0;for(let r of e.prompts){let e=Ye(r.id,r.version);t[e]||(t[e]=Xe(Dt(r.pieces,r.identifiers,r.identifierMap)),n++)}return await et(t),n},nt=async(e,t)=>(await $e())[Ye(e,t)],rt=async()=>Ze(Je()),it=async e=>Qe(Je(),e),at=async e=>{if(Object.keys(e).length===0)return;let t=await rt();for(let[n,r]of Object.entries(e))t[n]=r;await it(t)},ot=async()=>{let e=await rt(),t={};for(let n of Object.keys(e))t[n]=null;await it(t)},st=async e=>{try{let t=await rt();if(Object.keys(t).length===0)return!1;let n=(await a.readdir(e)).filter(e=>e.endsWith(`.md`));for(let r of n){let n=t[r.replace(`.md`,``)];if(n==null)continue;let i=f.join(e,r),o=await a.readFile(i,`utf8`);if(Xe((await import(`gray-matter`)).default(o,{delimiters:[`<!--`,`-->`]}).content)!==n)return!0}return!1}catch(e){if(e instanceof Error&&`code`in e&&e.code===`ENOENT`)return!1;throw e}},ct=(e,t)=>{let n=_(t,{delimiters:[`<!--`,`-->`]}),r=n.data,i=(n.content??``).replace(/^\n+/,``).replace(/\n+$/,``);return{id:e,name:typeof r.name==`string`?r.name:e,description:typeof r.description==`string`?r.description:``,ccVersion:typeof r.ccVersion==`string`?r.ccVersion:``,placeholders:Array.isArray(r.placeholders)?r.placeholders.filter(e=>typeof e==`string`):[],body:i,isSuppressed:i.trim().length===0}},lt=(e,t,n,r,i)=>{let a={name:e,description:t,ccVersion:n};return r.length>0&&(a.placeholders=r),_.stringify(i,a,{delimiters:[`<!--`,`-->`]})},ut=async e=>{let t=l.join(Da,`${e}.md`);try{return ct(e,await a.readFile(t,`utf8`))}catch(e){if(e instanceof Error&&`code`in e&&e.code===`ENOENT`)return null;throw e}},dt=async(e,t,n,r,i,o)=>{let s=l.join(Da,`${e}.md`);try{return await a.stat(s),!1}catch(e){if(!(e instanceof Error&&`code`in e&&e.code===`ENOENT`))throw e}return await a.mkdir(l.dirname(s),{recursive:!0}),await a.writeFile(s,lt(t,n,r,i,o)),!0},ft=(e,t)=>{let n=[],r=new Set(Object.keys(t)),i=/\{\{\s*([a-zA-Z_][a-zA-Z0-9_]*)\s*\}\}/g,a;for(;(a=i.exec(e))!==null;)r.has(a[1])||n.push(`unknown placeholder "{{${a[1]}}}"; allowed: ${[...r].map(e=>`{{${e}}}`).join(`, `)||`(none)`}`);if(n.length>0)return{result:``,errors:n};let o=e.split(i),s=``;for(let e=0;e<o.length;e++)e%2==0?s+=K(o[e].replace(/\\/g,`\\\\`).replace(/`/g,"\\`").replace(/\$\{/g,"\\${")):s+=t[o[e]];return{result:s,errors:[]}},M=(e,t,n,r,i)=>{let a=e.match(t);if(!a||a.index===void 0)return i&&i(e)?e:(console.error(`patch: reminder ${r}: failed to find anchor`),null);let o=n(a),s=e.slice(0,a.index)+o+e.slice(a.index+a[0].length);return F(e,s,o,a.index,a.index+a[0].length),s},pt=(e,t,n)=>{let r=`case"${t}":{`,i=[],a=0;for(;;){let t=e.indexOf(r,a);if(t<0)break;i.push(t),a=t+r.length}if(i.length===0)return null;let o=i.find(t=>e.slice(t,t+2048).includes(n));if(o===void 0)return null;let s=o+r.length,c=1,l=s,u=!1,d=!1,f=!1,p=0;for(;l<e.length&&c>0;){let t=e[l],n=e[l-1];if(d)t===`\\`?l++:t===`'`&&(d=!1);else if(f)t===`\\`?l++:t===`"`&&(f=!1);else if(u)t===`\\`?l++:t==="`"&&p===0?u=!1:t===`$`&&e[l+1]===`{`?(p++,l++):t===`}`&&p>0&&p--;else if(t===`'`&&n!==`\\`)d=!0;else if(t===`"`&&n!==`\\`)f=!0;else if(t==="`"&&n!==`\\`)u=!0;else if(t===`{`)c++;else if(t===`}`&&(c--,c===0))return{headerIdx:o,bodyStart:s,bodyEnd:l};l++}return null},mt=e=>{let t=/return\s+[^;]*?([$\w]+)\(\[([$\w]+)\(\{content:/g,n=null,r;for(;(r=t.exec(e))!==null;)n=r;return n?{arrayWrap:n[1],msgCtor:n[2]}:{arrayWrap:`o5`,msgCtor:`j6`}},ht=e=>{let t=e.match(/^\s*if\(!([$\w]+)\(\)\)return\s*\[\]/);return t?t[1]:`GX`},gt=(e,t)=>{let n=e.match(RegExp(`([$\\w]+)\\.${t}\\b`));return n?n[1]:`H`},_t=[{id:`claudemd-context`,name:`claudeMd context wrapper`,description:`Per-turn <system-reminder> that bundles { claudeMd, userEmail, currentDate } into a 'As you answer the user's questions...' block. Empty .md body = suppress entirely.`,placeholders:{context_blocks:"${Object.entries(_).map(([q,K])=>`# ${q}\\n${K}`).join(`\\n`)}"},defaultBody:`As you answer the user's questions, you can use the following context:
|
|
3
3
|
{{context_blocks}}
|
|
4
4
|
|
|
5
5
|
IMPORTANT: this context may or may not be relevant to your tasks. You should not respond to this context unless it is highly relevant to your task.`,apply(e,t,n){let r=e.match(/function ([$\w]+)\(([$\w]+),([$\w]+)\)\{if\(Object\.entries\(\3\)\.length===0\)return \2;return\[([$\w]+)\(\{content:`<system-reminder>\n[\s\S]*?\n<\/system-reminder>\n`,isMeta:!0\}\),\.\.\.\2\]\}/);if(!r||r.index===void 0)return/function [$\w]+\([$\w]+,[$\w]+\)\{return [$\w]+;\}/.test(e)?e:(console.error(`patch: reminder claudemd-context: failed to find kY6 wrapper`),null);let[i,a,o,s,c]=r,l;l=n?`function ${a}(${o},${s}){return ${o};}`:`function ${a}(${o},${s}){if(Object.entries(${s}).length===0)return ${o};return[${c}({content:\`<system-reminder>\n${t.replace(/\bObject\.entries\(_\)/g,`Object.entries(${s})`)}\n</system-reminder>\n\`,isMeta:!0}),...${o}]}`;let u=e.slice(0,r.index)+l+e.slice(r.index+i.length);return F(e,u,l,r.index,r.index+i.length),u}},{id:`skills-listing`,name:`Skills listing reminder`,description:`The "The following skills are available..." block. Empty .md body = suppress entirely.`,placeholders:{skill_content:"${H.content}"},defaultBody:`The following skills are available for use with the Skill tool:
|
|
@@ -8,39 +8,39 @@ import{createRequire as e}from"node:module";import t from"chalk";import*as n fro
|
|
|
8
8
|
|
|
9
9
|
The following MCP servers have provided instructions for how to use their tools and resources:
|
|
10
10
|
|
|
11
|
-
{{added_blocks}}`,apply(e,t,n){let r=
|
|
12
|
-
{{listing}}`,apply(e,t,n){let r=
|
|
13
|
-
{{result}}`,apply(e,t,n){return
|
|
14
|
-
{{snippet}}`,apply(e,t,n){return
|
|
11
|
+
{{added_blocks}}`,apply(e,t,n){let r=pt(e,`mcp_instructions_delta`,`# MCP Server Instructions`);if(!r)return console.error(`patch: reminder mcp-instructions: failed to find case body`),null;let{bodyStart:i,bodyEnd:a}=r,o=e.slice(i,a),{arrayWrap:s,msgCtor:c}=mt(o),l=gt(o,`addedBlocks`),u=t.replace(/\$\{H\./g,`\${${l}.`),d=n?`return [];`:`if(${l}.addedBlocks.length===0&&${l}.removedNames.length===0)return [];return ${s}([${c}({content:\`${u}\`,isMeta:!0})])`,f=e.slice(0,i)+d+e.slice(a);return F(e,f,d,i,a),f}},{id:`agent-listing`,name:`Agent listing reminder`,description:`The "Available agent types for the Agent tool" block emitted at session start. Empty .md body = suppress entirely.`,placeholders:{listing:"${H.addedLines.join(`\\n`)}",removed:"${H.removedTypes.map((K)=>`- ${K}`).join(`\\n`)}"},defaultBody:`Available agent types for the Agent tool:
|
|
12
|
+
{{listing}}`,apply(e,t,n){let r=pt(e,`agent_listing_delta`,`Available agent types for the Agent tool:`);if(!r)return console.error(`patch: reminder agent-listing: failed to find case body`),null;let{bodyStart:i,bodyEnd:a}=r,o=e.slice(i,a),{arrayWrap:s,msgCtor:c}=mt(o),l=gt(o,`addedLines`),u=t.replace(/\$\{H\./g,`\${${l}.`),d=n?`return [];`:`if(${l}.addedLines.length===0&&${l}.removedTypes.length===0)return [];return ${s}([${c}({content:\`${u}\`,isMeta:!0})])`,f=e.slice(0,i)+d+e.slice(a);return F(e,f,d,i,a),f}},{id:`output-style-banner`,name:`Output style banner`,description:`Per-turn "X output style is active. Remember to follow..." reminder. Empty .md body = suppress entirely.`,placeholders:{style_name:"${_.name}",turn_reminder:'${H.turnReminder??"Remember to follow the specific guidelines for this style."}'},defaultBody:`{{style_name}} output style is active. {{turn_reminder}}`,apply(e,t,n){let r=e.match(/output_style:\(([$\w]+)\)=>\{let ([$\w]+)=([$\w]+)\[\1\.style\];if\(!\2\)return\[\];return ([$\w]+)\(\[([$\w]+)\(\{content:`\$\{\2\.name\} output style is active\. \$\{\1\.turnReminder\?\?"Remember to follow the specific guidelines for this style\."\}`,isMeta:!0\}\)\]\)\}/);if(!r||r.index===void 0)return/output_style:\([$\w]+\)=>\{return \[\]/.test(e)?e:(console.error(`patch: reminder output-style-banner: failed to find output_style arrow`),null);let[i,a,o,s,c,l]=r,u=t.replace(/\$\{_\.name\}/g,`\${${o}.name}`).replace(/\$\{H\.turnReminder/g,`\${${a}.turnReminder`),d;d=n?`output_style:(${a})=>{return [];}`:`output_style:(${a})=>{let ${o}=${s}[${a}.style];if(!${o})return[];return ${c}([${l}({content:\`${u}\`,isMeta:!0})])}`;let f=e.slice(0,r.index)+d+e.slice(r.index+i.length);return F(e,f,d,r.index,r.index+i.length),f}},{id:`thinking-reminder`,name:`Thinking reminder (anti-thinking nudge / F97)`,description:`Per-turn 'Respond with just the action or changes and without a thinking block...' nudge that fires when CC decides you shouldn't be thinking. Conditional (only most turns). Empty .md body = suppress entirely.`,placeholders:{},defaultBody:`Respond with just the action or changes and without a thinking block, unless this is a redesign or requires fresh reasoning.`,apply(e,t,n){return/thinking_reminder:\(/.test(e)?M(e,/thinking_reminder:\(\)=>\[([$\w]+)\(\{content:([$\w]+)\(([$\w]+)\),isMeta:!0\}\)\]/,e=>{let[,r,i]=e;return n?`thinking_reminder:()=>[]`:`thinking_reminder:()=>[${r}({content:${i}(\`${t}\`),isMeta:!0})]`},`thinking-reminder`,e=>/thinking_reminder:\(\)=>\[\]/.test(e)):e}},{id:`ultrathink-effort`,name:`Ultrathink keyword booster`,description:`Fires when user input matches /\\bultrathink\\b/i. Empty .md body = the keyword triggers nothing.`,placeholders:{},defaultBody:`The user included the keyword "ultrathink", requesting deeper reasoning on this turn. Reason as thoroughly as the task warrants.`,apply(e,t,n){return M(e,/ultrathink_effort:\(\)=>([$\w]+)\(\[([$\w]+)\(\{content:'[^']*',isMeta:!0\}\)\]\)/,e=>{let[,r,i]=e;return n?`ultrathink_effort:()=>[]`:`ultrathink_effort:()=>${r}([${i}({content:\`${t}\`,isMeta:!0})])`},`ultrathink-effort`,e=>/ultrathink_effort:\(\)=>\[\]/.test(e))}},{id:`date-change`,name:`Date change reminder`,description:`Fires when the system date rolls over mid-session. Conditional. Empty .md body = silent date rollover.`,placeholders:{new_date:"${H.newDate}"},defaultBody:`The date has changed. Today's date is now {{new_date}}. DO NOT mention this to the user explicitly because they are already aware.`,apply(e,t,n){return M(e,/date_change:\(([$\w]+)\)=>([$\w]+)\(\[([$\w]+)\(\{content:`The date has changed\. Today's date is now \$\{\1\.newDate\}\. DO NOT mention this to the user explicitly because they are already aware\.`,isMeta:!0\}\)\]\)/,e=>{let[,r,i,a]=e;return n?`date_change:(${r})=>[]`:`date_change:(${r})=>${i}([${a}({content:\`${t.replace(/\$\{H\.newDate\}/g,`\${${r}.newDate}`)}\`,isMeta:!0})])`},`date-change`,e=>/date_change:\([$\w]+\)=>\[\]/.test(e))}},{id:`hook-additional-context`,name:`Hook additional-context wrapper`,description:`Wraps content returned by user-defined hooks into the model context. Conditional. Empty .md body = hook content suppressed.`,placeholders:{hook_name:"${H.hookName}",hook_content:"${H.content.join(`\n`)}"},defaultBody:`{{hook_name}} hook additional context: {{hook_content}}`,apply(e,t,n){return M(e,/hook_additional_context:\(([$\w]+)\)=>\{if\(\1\.content\.length===0\)return\[\];return\[([$\w]+)\(\{content:([$\w]+)\(`\$\{\1\.hookName\} hook additional context: \$\{\1\.content\.join\(`\n`\)\}`\),isMeta:!0\}\)\]\}/,e=>{let[,r,i,a]=e;return n?`hook_additional_context:(${r})=>[]`:`hook_additional_context:(${r})=>{if(${r}.content.length===0)return[];return[${i}({content:${a}(\`${t.replace(/\$\{H\.hookName\}/g,`\${${r}.hookName}`).replace(/\$\{H\.content\.join\(`\n`\)\}/g,`\${${r}.content.join(\`\n\`)}`)}\`),isMeta:!0})]}`},`hook-additional-context`,e=>/hook_additional_context:\([$\w]+\)=>\[\]/.test(e))}},{id:`hook-blocking-error`,name:`Hook blocking-error wrapper`,description:`Surfaces hook command failures that block CC continuing. Conditional. Empty .md body = errors silenced (DANGEROUS — model will not see why hook blocked).`,placeholders:{hook_name:"${H.hookName}",command:"${H.blockingError.command}",error:"${H.blockingError.blockingError}"},defaultBody:`{{hook_name}} hook blocking error from command: "{{command}}": {{error}}`,apply(e,t,n){return M(e,/hook_blocking_error:\(([$\w]+)\)=>\[([$\w]+)\(\{content:([$\w]+)\(`\$\{\1\.hookName\} hook blocking error from command: "\$\{\1\.blockingError\.command\}": \$\{\1\.blockingError\.blockingError\}`\),isMeta:!0\}\)\]/,e=>{let[,r,i,a]=e;return n?`hook_blocking_error:(${r})=>[]`:`hook_blocking_error:(${r})=>[${i}({content:${a}(\`${t.replace(/\$\{H\.hookName\}/g,`\${${r}.hookName}`).replace(/\$\{H\.blockingError\.command\}/g,`\${${r}.blockingError.command}`).replace(/\$\{H\.blockingError\.blockingError\}/g,`\${${r}.blockingError.blockingError}`)}\`),isMeta:!0})]`},`hook-blocking-error`,e=>/hook_blocking_error:\([$\w]+\)=>\[\]/.test(e))}},{id:`hook-stopped-continuation`,name:`Hook stopped-continuation wrapper`,description:`Fires when a hook returned a stop signal. Conditional. Empty .md body = stop reason hidden from model.`,placeholders:{hook_name:"${H.hookName}",message:"${H.message}"},defaultBody:`{{hook_name}} hook stopped continuation: {{message}}`,apply(e,t,n){return M(e,/hook_stopped_continuation:\(([$\w]+)\)=>\[([$\w]+)\(\{content:([$\w]+)\(`\$\{\1\.hookName\} hook stopped continuation: \$\{\1\.message\}`\),isMeta:!0\}\)\]/,e=>{let[,r,i,a]=e;return n?`hook_stopped_continuation:(${r})=>[]`:`hook_stopped_continuation:(${r})=>[${i}({content:${a}(\`${t.replace(/\$\{H\.hookName\}/g,`\${${r}.hookName}`).replace(/\$\{H\.message\}/g,`\${${r}.message}`)}\`),isMeta:!0})]`},`hook-stopped-continuation`,e=>/hook_stopped_continuation:\([$\w]+\)=>\[\]/.test(e))}},{id:`tool-called`,name:`Tool-called preamble`,description:`Per-tool-call preamble: "Called the X tool with the following input: ...". Empty .md body = no preamble (LW strips empty content).`,placeholders:{tool_name:"${H}",tool_input:"${SH(_)}"},defaultBody:`Called the {{tool_name}} tool with the following input: {{tool_input}}`,apply(e,t,n){return M(e,/function ([$\w]+)\(([$\w]+),([$\w]+)\)\{return ([$\w]+)\(\{content:`Called the \$\{\2\} tool with the following input: \$\{([$\w]+)\(\3\)\}`,isMeta:!0\}\)\}/,e=>{let[,r,i,a,o,s]=e;return n?`function ${r}(${i},${a}){return ${o}({content:"",isMeta:!0})}`:`function ${r}(${i},${a}){return ${o}({content:\`${t.replace(/\$\{H\}/g,`\${${i}}`).replace(/\$\{SH\(_\)\}/g,`\${${s}(${a})}`)}\`,isMeta:!0})}`},`tool-called`)}},{id:`tool-result`,name:`Tool-result wrapper`,description:`Per-tool-call result wrapper: "Result of calling the X tool: <output>". Empty .md body = strip the wrapper line (just emit the result).`,placeholders:{tool_name:"${H.name}",result:"${K}"},defaultBody:`Result of calling the {{tool_name}} tool:
|
|
13
|
+
{{result}}`,apply(e,t,n){return M(e,/return ([$\w]+)\(\{content:`Result of calling the \$\{([$\w]+)\.name\} tool:\n\$\{([$\w]+)\}`,isMeta:!0\}\)\}catch\{return [$\w]+\(\{content:`Result of calling the \$\{\2\.name\} tool: Error`,isMeta:!0\}\)\}/,e=>{let[,r,i,a]=e;return n?`return ${r}({content:\`\${${a}}\`,isMeta:!0})}catch{return ${r}({content:"",isMeta:!0})}`:`return ${r}({content:\`${t.replace(/\$\{H\.name\}/g,`\${${i}.name}`).replace(/\$\{K\}/g,`\${${a}}`)}\`,isMeta:!0})}catch{return ${r}({content:\`Result of calling the \${${i}.name} tool: Error\`,isMeta:!0})}`},`tool-result`)}},{id:`tool-error`,name:`Tool-error wrapper`,description:`Fires from the catch branch of the tool-result wrapper when result formatting throws. Empty .md body = silent error.`,placeholders:{tool_name:"${H.name}"},defaultBody:`Result of calling the {{tool_name}} tool: Error`,apply(e,t,n){return M(e,/catch\{return ([$\w]+)\(\{content:`Result of calling the \$\{([$\w]+)\.name\} tool: Error`,isMeta:!0\}\)\}/,e=>{let[,r,i]=e;return n?`catch{return ${r}({content:"",isMeta:!0})}`:`catch{return ${r}({content:\`${t.replace(/\$\{H\.name\}/g,`\${${i}.name}`)}\`,isMeta:!0})}`},`tool-error`)}},{id:`local-command-caveat`,name:`Local-command caveat wrapper`,description:`Wraps output of !shell-command with anti-confusion framing. Empty .md body = no caveat (security-relevant; suppressing means the model may misinterpret command output as user input).`,placeholders:{tag_name:"${Gq_}"},defaultBody:`Caveat: The messages below were generated by the user while running local commands. DO NOT respond to these messages or otherwise consider them in your response unless the user explicitly asks you to.`,apply(e,t,n){return M(e,/([$\w]+)\(\{content:`<\$\{([$\w]+)\}>Caveat: The messages below were generated by the user while running local commands\. DO NOT respond to these messages or otherwise consider them in your response unless the user explicitly asks you to\.<\/\$\{\2\}>`,isMeta:!0\}\)/,e=>{let[,r,i]=e;return n?`${r}({content:"",isMeta:!0})`:`${r}({content:\`<\${${i}}>${t.replace(/\$\{Gq_\}/g,`\${${i}}`)}</\${${i}}>\`,isMeta:!0})`},`local-command-caveat`)}},{id:`compact-file-reference`,name:`Compact-time file reference note`,description:`Note injected after compaction when a referenced file is too large to inline. Conditional. Empty .md body = silent omission.`,placeholders:{filename:"${H.filename}",read_tool_name:"${oO.name}"},defaultBody:`Note: {{filename}} was read before the last conversation was summarized, but the contents are too large to include. Use {{read_tool_name}} tool if you need to access it.`,apply(e,t,n){return M(e,/compact_file_reference:\(([$\w]+)\)=>([$\w]+)\(\[([$\w]+)\(\{content:`Note: \$\{\1\.filename\} was read before the last conversation was summarized, but the contents are too large to include\. Use \$\{([$\w]+)\.name\} tool if you need to access it\.`,isMeta:!0\}\)\]\)/,e=>{let[,r,i,a,o]=e;return n?`compact_file_reference:(${r})=>[]`:`compact_file_reference:(${r})=>${i}([${a}({content:\`${t.replace(/\$\{H\.filename\}/g,`\${${r}.filename}`).replace(/\$\{oO\.name\}/g,`\${${o}.name}`)}\`,isMeta:!0})])`},`compact-file-reference`,e=>/compact_file_reference:\([$\w]+\)=>\[\]/.test(e))}},{id:`pdf-reference`,name:`PDF too-large note`,description:`Conditional note when a referenced PDF is too large for direct read. Empty .md body = silent omission.`,placeholders:{filename:"${H.filename}",page_count:"${H.pageCount}",file_size:"${l7(H.fileSize)}",read_tool:"${uq}"},defaultBody:`PDF file: {{filename}} ({{page_count}} pages, {{file_size}}). This PDF is too large to read all at once. You MUST use the {{read_tool}} tool with the pages parameter to read specific page ranges (e.g., pages: "1-5"). Do NOT call {{read_tool}} without the pages parameter or it will fail. Start by reading the first few pages to understand the structure, then read more as needed. Maximum 20 pages per request.`,apply(e,t,n){return M(e,/pdf_reference:\(([$\w]+)\)=>([$\w]+)\(\[([$\w]+)\(\{content:`PDF file: \$\{\1\.filename\} \(\$\{\1\.pageCount\} pages, \$\{([$\w]+)\(\1\.fileSize\)\}\)\. This PDF is too large to read all at once\. You MUST use the \$\{([$\w]+)\} tool with the pages parameter[\s\S]*?Maximum 20 pages per request\.`,isMeta:!0\}\)\]\)/,e=>{let[,r,i,a,o,s]=e;return n?`pdf_reference:(${r})=>[]`:`pdf_reference:(${r})=>${i}([${a}({content:\`${t.replace(/\$\{H\.filename\}/g,`\${${r}.filename}`).replace(/\$\{H\.pageCount\}/g,`\${${r}.pageCount}`).replace(/\$\{l7\(H\.fileSize\)\}/g,`\${${o}(${r}.fileSize)}`).replace(/\$\{uq\}/g,`\${${s}}`)}\`,isMeta:!0})])`},`pdf-reference`,e=>/pdf_reference:\([$\w]+\)=>\[\]/.test(e))}},{id:`edited-text-file`,name:`Edited-text-file post-edit note`,description:`Conditional note injected after a file is edited (by user or linter). Empty .md body = silent edits.`,shadows:[`system-reminder-file-modification-detected-budget-exceeded`,`system-reminder-file-modified-externally`],placeholders:{filename:"${H.filename}",snippet:"${H.snippet}"},defaultBody:`Note: {{filename}} was modified, either by the user or by a linter. This change was intentional, so make sure to take it into account as you proceed (ie. don't revert it unless the user asks you to). Don't tell the user this, since they are already aware. Here are the relevant changes (shown with line numbers):
|
|
14
|
+
{{snippet}}`,apply(e,t,n){return M(e,/edited_text_file:\(([$\w]+)\)=>([$\w]+)\(\[([$\w]+)\(\{content:\1\.snippet===""\?`Note: \$\{\1\.filename\} was modified, either by the user or by a linter\. This change was intentional, so make sure to take it into account as you proceed \(ie\. don't revert it unless the user asks you to\)\. Don't tell the user this, since they are already aware\. The diff was omitted because other modified files in this turn already exceeded the snippet budget; use the Read tool if you need the current content\.`:`Note: \$\{\1\.filename\} was modified, either by the user or by a linter\. This change was intentional, so make sure to take it into account as you proceed \(ie\. don't revert it unless the user asks you to\)\. Don't tell the user this, since they are already aware\. Here are the relevant changes \(shown with line numbers\):\n\$\{\1\.snippet\}`,isMeta:!0\}\)\]\)/,e=>{let[,r,i,a]=e;return n?`edited_text_file:(${r})=>[]`:`edited_text_file:(${r})=>${i}([${a}({content:\`${t.replace(/\$\{H\.filename\}/g,`\${${r}.filename}`).replace(/\$\{H\.snippet\}/g,`\${${r}.snippet}`)}\`,isMeta:!0})])`},`edited-text-file`,e=>/edited_text_file:\([$\w]+\)=>\[\]/.test(e))}},{id:`selected-lines-in-ide`,name:`IDE selected-lines reminder`,description:`Fires when an IDE selection is sent into chat. Conditional. Empty .md body = silent selection (model not told what user selected).`,placeholders:{line_start:"${H.lineStart}",line_end:"${H.lineEnd}",filename:"${H.filename}",selected_text:"${q}"},defaultBody:`The user selected the lines {{line_start}} to {{line_end}} from {{filename}}:
|
|
15
15
|
{{selected_text}}
|
|
16
16
|
|
|
17
|
-
This may or may not be related to the current task.`,apply(e,t,n){return
|
|
17
|
+
This may or may not be related to the current task.`,apply(e,t,n){let r=/selected_lines_in_ide:\(([$\w]+)\)=>([$\w]+)\(\[([$\w]+)\(\{content:`The user selected the lines \$\{\1\.lineStart\} to \$\{\1\.lineEnd\} from \$\{\1\.filename\}:\n\$\{([^`]*?)\}\n\nThis may or may not be related to the current task\.`,isMeta:!0\}\)\]\)/;return r.test(e)?M(e,r,e=>{let[,r,i,a,o]=e;return n?`selected_lines_in_ide:(${r})=>[]`:`selected_lines_in_ide:(${r})=>${i}([${a}({content:\`${t.replace(/\$\{H\.lineStart\}/g,`\${${r}.lineStart}`).replace(/\$\{H\.lineEnd\}/g,`\${${r}.lineEnd}`).replace(/\$\{H\.filename\}/g,`\${${r}.filename}`).replace(/\$\{q\}/g,`\${${o}}`)}\`,isMeta:!0})])`},`selected-lines-in-ide`,e=>/selected_lines_in_ide:\([$\w]+\)=>\[\]/.test(e)):M(e,/selected_lines_in_ide:\(([$\w]+)\)=>\{let ([$\w]+)=\1\.content\.length>2000\?\1\.content\.substring\(0,2000\)\+`\n\.\.\. \(truncated\)`:\1\.content;return ([$\w]+)\(\[([$\w]+)\(\{content:`The user selected the lines \$\{\1\.lineStart\} to \$\{\1\.lineEnd\} from \$\{\1\.filename\}:\n\$\{\2\}\n\nThis may or may not be related to the current task\.`,isMeta:!0\}\)\]\)\}/,e=>{let[,r,i,a,o]=e;return n?`selected_lines_in_ide:(${r})=>[]`:`selected_lines_in_ide:(${r})=>{let ${i}=${r}.content.length>2000?${r}.content.substring(0,2000)+\`\n... (truncated)\`:${r}.content;return ${a}([${o}({content:\`${t.replace(/\$\{H\.lineStart\}/g,`\${${r}.lineStart}`).replace(/\$\{H\.lineEnd\}/g,`\${${r}.lineEnd}`).replace(/\$\{H\.filename\}/g,`\${${r}.filename}`).replace(/\$\{q\}/g,`\${${i}}`)}\`,isMeta:!0})])}`},`selected-lines-in-ide`,e=>/selected_lines_in_ide:\([$\w]+\)=>\[\]/.test(e))}},{id:`opened-file-in-ide`,name:`IDE opened-file reminder`,description:`Fires when user focuses a new file in the IDE during a CC session. Conditional. Empty .md body = silent.`,placeholders:{filename:"${H.filename}"},defaultBody:`The user opened the file {{filename}} in the IDE. This may or may not be related to the current task.`,apply(e,t,n){return M(e,/opened_file_in_ide:\(([$\w]+)\)=>([$\w]+)\(\[([$\w]+)\(\{content:`The user opened the file \$\{\1\.filename\} in the IDE\. This may or may not be related to the current task\.`,isMeta:!0\}\)\]\)/,e=>{let[,r,i,a]=e;return n?`opened_file_in_ide:(${r})=>[]`:`opened_file_in_ide:(${r})=>${i}([${a}({content:\`${t.replace(/\$\{H\.filename\}/g,`\${${r}.filename}`)}\`,isMeta:!0})])`},`opened-file-in-ide`,e=>/opened_file_in_ide:\([$\w]+\)=>\[\]/.test(e))}},{id:`plan-file-reference`,name:`Plan-file reference`,description:`Surfaces an existing plan file from plan mode. Conditional. Empty .md body = plan file invisible to model.`,placeholders:{plan_file_path:"${H.planFilePath}",plan_content:"${H.planContent}"},defaultBody:`A plan file exists from plan mode at: {{plan_file_path}}
|
|
18
18
|
|
|
19
19
|
Plan contents:
|
|
20
20
|
|
|
21
21
|
{{plan_content}}
|
|
22
22
|
|
|
23
|
-
If this plan is relevant to the current work and not already complete, continue working on it.`,apply(e,t,n){return
|
|
23
|
+
If this plan is relevant to the current work and not already complete, continue working on it.`,apply(e,t,n){return M(e,/plan_file_reference:\(([$\w]+)\)=>([$\w]+)\(\[([$\w]+)\(\{content:`A plan file exists from plan mode at: \$\{\1\.planFilePath\}\n\nPlan contents:\n\n\$\{\1\.planContent\}\n\nIf this plan is relevant to the current work and not already complete, continue working on it\.`,isMeta:!0\}\)\]\)/,e=>{let[,r,i,a]=e;return n?`plan_file_reference:(${r})=>[]`:`plan_file_reference:(${r})=>${i}([${a}({content:\`${t.replace(/\$\{H\.planFilePath\}/g,`\${${r}.planFilePath}`).replace(/\$\{H\.planContent\}/g,`\${${r}.planContent}`)}\`,isMeta:!0})])`},`plan-file-reference`,e=>/plan_file_reference:\([$\w]+\)=>\[\]/.test(e))}},{id:`plan-mode-exit`,name:`Plan-mode exit reminder`,description:`Fires when leaving plan mode. Conditional. Empty .md body = silent exit.`,placeholders:{plan_suffix:"${_}"},defaultBody:`## Exited Plan Mode
|
|
24
24
|
|
|
25
|
-
You have exited plan mode. You can now make edits, run tools, and take actions.{{plan_suffix}}`,apply(e,t,n){return
|
|
25
|
+
You have exited plan mode. You can now make edits, run tools, and take actions.{{plan_suffix}}`,apply(e,t,n){return M(e,/plan_mode_exit:\(([$\w]+)\)=>\{let ([$\w]+)=\1\.planExists\?` The plan file is located at \$\{\1\.planFilePath\} if you need to reference it\.`:"";return ([$\w]+)\(\[([$\w]+)\(\{content:`## Exited Plan Mode\n\nYou have exited plan mode\. You can now make edits, run tools, and take actions\.\$\{\2\}`,isMeta:!0\}\)\]\)\}/,e=>{let[,r,i,a,o]=e;return n?`plan_mode_exit:(${r})=>[]`:`plan_mode_exit:(${r})=>{let ${i}=${r}.planExists?\` The plan file is located at \${${r}.planFilePath} if you need to reference it.\`:"";return ${a}([${o}({content:\`${t.replace(/\$\{_\}/g,`\${${i}}`)}\`,isMeta:!0})])}`},`plan-mode-exit`,e=>/plan_mode_exit:\([$\w]+\)=>\[\]/.test(e))}},{id:`auto-mode-exit`,name:`Auto-mode exit reminder`,description:`Fires when leaving auto mode. Conditional. Empty .md body = silent exit.`,placeholders:{},defaultBody:`## Exited Auto Mode
|
|
26
26
|
|
|
27
|
-
You have exited auto mode. The user may now want to interact more directly. You should ask clarifying questions when the approach is ambiguous rather than making assumptions.`,apply(e,t,n){return
|
|
27
|
+
You have exited auto mode. The user may now want to interact more directly. You should ask clarifying questions when the approach is ambiguous rather than making assumptions.`,apply(e,t,n){return M(e,/auto_mode_exit:\(\)=>([$\w]+)\(\[([$\w]+)\(\{content:`## Exited Auto Mode\n\nYou have exited auto mode\. The user may now want to interact more directly\. You should ask clarifying questions when the approach is ambiguous rather than making assumptions\.`,isMeta:!0\}\)\]\)/,e=>{let[,r,i]=e;return n?`auto_mode_exit:()=>[]`:`auto_mode_exit:()=>${r}([${i}({content:\`${t}\`,isMeta:!0})])`},`auto-mode-exit`,e=>/auto_mode_exit:\(\)=>\[\]/.test(e))}},{id:`nested-memory`,name:`Nested memory reference`,description:`Loads a referenced memory file into context. Conditional. Empty .md body = nested memory invisible.`,placeholders:{memory_path:"${H.content.path}",memory_content:"${H.content.content}"},defaultBody:`Contents of {{memory_path}}:
|
|
28
28
|
|
|
29
|
-
{{memory_content}}`,apply(e,t,n){return
|
|
29
|
+
{{memory_content}}`,apply(e,t,n){return M(e,/nested_memory:\(([$\w]+)\)=>([$\w]+)\(\[([$\w]+)\(\{content:`Contents of \$\{\1\.content\.path\}:\n\n\$\{\1\.content\.content\}`,isMeta:!0\}\)\]\)/,e=>{let[,r,i,a]=e;return n?`nested_memory:(${r})=>[]`:`nested_memory:(${r})=>${i}([${a}({content:\`${t.replace(/\$\{H\.content\.path\}/g,`\${${r}.content.path}`).replace(/\$\{H\.content\.content\}/g,`\${${r}.content.content}`)}\`,isMeta:!0})])`},`nested-memory`,e=>/nested_memory:\([$\w]+\)=>\[\]/.test(e))}},{id:`agent-mention`,name:`Agent-mention nudge`,description:`Nudges Claude to invoke an agent when user @-mentions one. Conditional. Empty .md body = silent (model decides on its own).`,placeholders:{agent_type:"${H.agentType}"},defaultBody:`The user has expressed a desire to invoke the agent "{{agent_type}}". Please invoke the agent appropriately, passing in the required context to it. `,apply(e,t,n){return M(e,/agent_mention:\(([$\w]+)\)=>([$\w]+)\(\[([$\w]+)\(\{content:`The user has expressed a desire to invoke the agent "\$\{\1\.agentType\}"\. Please invoke the agent appropriately, passing in the required context to it\. `,isMeta:!0\}\)\]\)/,e=>{let[,r,i,a]=e;return n?`agent_mention:(${r})=>[]`:`agent_mention:(${r})=>${i}([${a}({content:\`${t.replace(/\$\{H\.agentType\}/g,`\${${r}.agentType}`)}\`,isMeta:!0})])`},`agent-mention`,e=>/agent_mention:\([$\w]+\)=>\[\]/.test(e))}},{id:`memory-update`,name:`Memory-update reminder`,description:`Fires after dream / consolidation writes new memory files. Conditional. Empty .md body = silent updates.`,placeholders:{source:"${YT3[H.source]}",summary:"${H.summary}",paths:'${H.paths.join(", ")}',in_context_paths:'${H.inContextPaths.join(", ")}'},defaultBody:`{{source}} updated your memory directory: {{summary}}
|
|
30
30
|
Files changed: {{paths}}
|
|
31
31
|
Your loaded copy of {{in_context_paths}} is now stale relative to disk — Read it again if you need current contents.
|
|
32
|
-
This is ambient context — do not narrate it to the user unless they ask or it is directly relevant to their request.`,apply(e,t,n){let r=
|
|
32
|
+
This is ambient context — do not narrate it to the user unless they ask or it is directly relevant to their request.`,apply(e,t,n){let r=pt(e,`memory_update`,`updated your memory directory`);if(!r)return console.error(`patch: reminder memory-update: failed to find case body`),null;let{bodyStart:i,bodyEnd:a}=r,o=e.slice(i,a),{arrayWrap:s,msgCtor:c}=mt(o),l=gt(o,`summary`),u=o.match(/\$\{([$\w]+)\[/)?.[1]??`YT3`,d=t.replace(/\$\{YT3\[H\.source\]\}/g,`\${${u}[${l}.source]}`).replace(/\$\{H\./g,`\${${l}.`),f=n?`return [];`:`return ${s}([${c}({content:\`${d}\`,isMeta:!0})])`,p=e.slice(0,i)+f+e.slice(a);return F(e,p,f,i,a),p}},{id:`verify-plan-reminder`,name:`Verify-plan reminder`,description:`Fires after plan implementation completes, directing Claude to call a verification tool. Conditional. Empty .md body = no automatic verification nudge.`,placeholders:{plan_verifier_tool:"${J7}"},defaultBody:`You have completed implementing the plan. Please call the "" tool directly (NOT the {{plan_verifier_tool}} tool or an agent) to verify that all plan items were completed correctly.`,apply(e,t,n){let r=pt(e,`verify_plan_reminder`,`You have completed implementing the plan`);if(!r)return console.error(`patch: reminder verify-plan-reminder: failed to find case body`),null;let{bodyStart:i,bodyEnd:a}=r,o=e.slice(i,a),{arrayWrap:s,msgCtor:c}=mt(o),l=o.match(/\(NOT the \$\{([$\w]+)\} tool/)?.[1]??`J7`,u=t.replace(/\$\{J7\}/g,`\${${l}}`),d=n?`return [];`:`let K=\`${u}\`;return ${s}([${c}({content:K,isMeta:!0})])`,f=e.slice(0,i)+d+e.slice(a);return F(e,f,d,i,a),f}},{id:`token-usage`,name:`Token usage updater`,description:`Per-turn token usage status. Conditional (only some turns). Empty .md body = no telemetry leak into context.`,placeholders:{used:"${H.used}",total:"${H.total}",remaining:"${H.remaining}"},defaultBody:`Token usage: {{used}}/{{total}}; {{remaining}} remaining`,apply(e,t,n){return M(e,/token_usage:\(([$\w]+)\)=>\[([$\w]+)\(\{content:([$\w]+)\(`Token usage: \$\{\1\.used\}\/\$\{\1\.total\}; \$\{\1\.remaining\} remaining`\),isMeta:!0\}\)\]/,e=>{let[,r,i,a]=e;return n?`token_usage:(${r})=>[]`:`token_usage:(${r})=>[${i}({content:${a}(\`${t.replace(/\$\{H\.used\}/g,`\${${r}.used}`).replace(/\$\{H\.total\}/g,`\${${r}.total}`).replace(/\$\{H\.remaining\}/g,`\${${r}.remaining}`)}\`),isMeta:!0})]`},`token-usage`,e=>/token_usage:\([$\w]+\)=>\[\]/.test(e))}},{id:`budget-usd`,name:`USD budget updater`,description:`Per-turn USD budget status. Conditional. Empty .md body = no telemetry leak into context.`,placeholders:{used:"${H.used}",total:"${H.total}",remaining:"${H.remaining}"},defaultBody:"USD budget: ${{used}}/${{total}}; ${{remaining}} remaining",apply(e,t,n){return M(e,/budget_usd:\(([$\w]+)\)=>\[([$\w]+)\(\{content:([$\w]+)\(`USD budget: \$\$\{\1\.used\}\/\$\$\{\1\.total\}; \$\$\{\1\.remaining\} remaining`\),isMeta:!0\}\)\]/,e=>{let[,r,i,a]=e;return n?`budget_usd:(${r})=>[]`:`budget_usd:(${r})=>[${i}({content:${a}(\`${t.replace(/\$\{H\.used\}/g,`\${${r}.used}`).replace(/\$\{H\.total\}/g,`\${${r}.total}`).replace(/\$\{H\.remaining\}/g,`\${${r}.remaining}`)}\`),isMeta:!0})]`},`budget-usd`,e=>/budget_usd:\([$\w]+\)=>\[\]/.test(e))}},{id:`output-token-usage`,name:`Output-token usage updater`,description:`Per-turn output-token telemetry. Conditional. Empty .md body = no telemetry leak.`,placeholders:{turn:"${_}",session:"${gK(H.session)}"},defaultBody:`Output tokens — turn: {{turn}} · session: {{session}}`,apply(e,t,n){return M(e,/output_token_usage:\(([$\w]+)\)=>\{let ([$\w]+)=\1\.budget!==null\?`\$\{([$\w]+)\(\1\.turn\)\} \/ \$\{\3\(\1\.budget\)\}`:\3\(\1\.turn\);return\[([$\w]+)\(\{content:([$\w]+)\(`Output tokens \\u2014 turn: \$\{\2\} \\xB7 session: \$\{\3\(\1\.session\)\}`\),isMeta:!0\}\)\]\}/,e=>{let[,r,i,a,o,s]=e;return n?`output_token_usage:(${r})=>[]`:`output_token_usage:(${r})=>{let ${i}=${r}.budget!==null?\`\${${a}(${r}.turn)} / \${${a}(${r}.budget)}\`:${a}(${r}.turn);return[${o}({content:${s}(\`${t.replace(/\$\{_\}/g,`\${${i}}`).replace(/\$\{gK\(H\.session\)\}/g,`\${${a}(${r}.session)}`)}\`),isMeta:!0})]}`},`output-token-usage`,e=>/output_token_usage:\([$\w]+\)=>\[\]/.test(e))}},{id:`task-list-reminder`,name:`Task-list status reminder`,description:`Fires every turn while TaskList has entries. Wraps the current task list with reminder text about using TaskCreate. Empty .md = suppress entirely.`,shadows:[`system-reminder-task-tools-reminder`],placeholders:{tasks:"${q}"},defaultBody:"The task tools haven't been used to track work in this session yet. Now is a good time to consider whether the work warrants using them. Use this to demonstrate thoroughness, organize complex tasks, and avoid losing track of multi-step work (e.g. multi-bug fixes, feature implementations, etc). Don't use them on small or trivial tasks where they would feel intrusive.\n\nIf you've already started work without using the task tools, use `TaskCreate` to add tasks for the work you've already completed (with status `completed`) and a task for whatever you're currently working on (with status `in_progress`). Remember, in a single response, never have more than one task `in_progress` (the one you're actively working on) and you should mark a task as `completed` immediately after starting and finishing the work (don't wait until you're done). Also consider cleaning up the task list if it has become stale. Only use these if relevant to the current work. This is just a gentle reminder - ignore if not applicable.\n\nHere are the existing tasks:\n\n{{tasks}}",apply(e,t,n){let r=pt(e,`task_reminder`,`Here are the existing tasks`);if(!r)return console.error(`patch: reminder task-list-reminder: failed to find case body`),null;let{bodyStart:i,bodyEnd:a}=r,o=e.slice(i,a),{arrayWrap:s,msgCtor:c}=mt(o),l=ht(o),u=gt(o,`content`),d=n?`return [];`:`if(!${l}())return[];let q=${u}.content.map((O)=>\`#\${O.id}. [\${O.status}] \${O.subject}\`).join(\`\\n\`);return ${s}([${c}({content:\`${t}\`,isMeta:!0})])`,f=e.slice(0,i)+d+e.slice(a);return F(e,f,d,i,a),f}},{id:`task-notification-framing`,name:`Task-notification framing wrapper`,description:`The "[SYSTEM NOTIFICATION - NOT USER INPUT]" text wrapping background-task event content. Fires when a run_in_background completes/errors. Empty .md = no framing (just the content).`,placeholders:{content:"${H}"},defaultBody:`[SYSTEM NOTIFICATION - NOT USER INPUT]
|
|
33
33
|
This is an automated background-task event, NOT a message from the user.
|
|
34
34
|
Do NOT interpret this as user acknowledgement, confirmation, or response to any pending question.
|
|
35
35
|
|
|
36
|
-
{{content}}`,apply(e,t,n){return
|
|
36
|
+
{{content}}`,apply(e,t,n){return M(e,/(case"task-notification":return|function [$\w]+\([$\w]+\)\{return)`\[SYSTEM NOTIFICATION - NOT USER INPUT\]\nThis is an automated background-task event, NOT a message from the user\.\nDo NOT interpret this as user acknowledgement, confirmation, or response to any pending question\.\n\n\$\{([$\w]+)\}`(;|\})/,e=>{let[,r,i,a]=e;return n?`${r}\`\${${i}}\`${a}`:`${r}\`${t.replace(/\$\{H\}/g,`\${${i}}`)}\`${a}`},`task-notification-framing`,e=>/case"task-notification":return`\$\{[$\w]+\}`;/.test(e))}},{id:`user-sent-new-message`,name:`User-sent-new-message wrapper`,description:`Wraps a user message that arrives mid-turn. Carries the "IMPORTANT: After completing your current task, you MUST address" framing. Empty .md = no wrapping (just the message text).`,placeholders:{message:"${H}"},defaultBody:`The user sent a new message while you were working:
|
|
37
37
|
{{message}}
|
|
38
38
|
|
|
39
|
-
IMPORTANT: After completing your current task, you MUST address the user's message above. Do not ignore it.`,apply(e,t,n){return
|
|
40
|
-
`).length-1),{name:n||``,description:r||``,ccVersion:i||``,variables:a||[],content:t.content,contentLineOffset:o}},
|
|
39
|
+
IMPORTANT: After completing your current task, you MUST address the user's message above. Do not ignore it.`,apply(e,t,n){return M(e,/((?:case"auto-continuation":)?case"human":case void 0:(?:default:)?)return`(?:The user sent a new message while you were working:\n|\$\{[$\w]+\})\$\{([$\w]+)\}\n\nIMPORTANT: After completing your current task, you MUST address the user's message above\. Do not ignore it\.`/,e=>{let[,r,i]=e;return n?`${r}return\`\${${i}}\``:`${r}return\`${t.replace(/\$\{H\}/g,`\${${i}}`)}\``},`user-sent-new-message`,e=>/(?:case"auto-continuation":)?case"human":case void 0:(?:default:)?return`\$\{[$\w]+\}`/.test(e))}},{id:`stop-hook-session-goal`,name:`Stop-hook session-goal reminder`,description:`Fires when /goal sets a session-scoped stop hook. Carries the "do not pause to ask" framing. Empty .md = silent goal activation (just the condition value used internally).`,placeholders:{condition:"${H}"},defaultBody:'A session-scoped Stop hook is now active with condition: "{{condition}}". Briefly acknowledge the goal, then immediately start (or continue) working toward it — treat the condition itself as your directive and do not pause to ask the user what to do. The hook will block stopping until the condition holds. It auto-clears once the condition is met — do not tell the user to run `/goal clear` after success; that\'s only for clearing a goal early.',apply(e,t,n){return M(e,/([$\w]+)=\(([$\w]+)\)=>`A session-scoped Stop hook is now active with condition: "\$\{\2\}"\. Briefly acknowledge the goal, then immediately start \(or continue\) working toward it[\s\S]*?after success; that's only for clearing a goal early\.`/,e=>{let[,r,i]=e;return n?`${r}=(${i})=>""`:`${r}=(${i})=>\`${t.replace(/\$\{H\}/g,`\${${i}}`)}\``},`stop-hook-session-goal`,e=>/[$\w]+=\([$\w]+\)=>""/.test(e))}},{id:`mcp-per-server-router`,name:`MCP per-server instruction router`,description:`Patches CC's MCP instruction assembly to consult ~/.tweakcc/system-reminders/mcp-<server-name>.md at runtime. Empty body in that file drops the server's block. Body containing {{server_instructions}} resolves to the server's pristine instructions. Custom body replaces. THIS .md does nothing on its own — it just enables per-server .md files. Empty body = disable this routing (servers use pristine instructions verbatim).`,placeholders:{},defaultBody:`This file is a marker that enables per-MCP-server overrides. Edit per-server content in mcp-<server-name>.md alongside this file. Leave this file with content (any content) to enable routing; empty it to disable.`,apply(e,t,n){if(n)return e;let r=e.match(/for\(let ([$\w]+) of ([$\w]+)\)if\(\1\.instructions\)([$\w]+)\.set\(\1\.name,`## \$\{\1\.name\}\n\$\{\1\.instructions\}`\);/);if(!r||r.index===void 0)return e.includes(`__tweakccMcpOverride`)?e:(console.error(`patch: reminder mcp-per-server-router: failed to find MCP assembly loop`),null);let[i,a,o,s]=r,c=`function __tweakccMcpOverride(_n,_d){try{let _f=require('fs'),_p=require('os').homedir()+'/.tweakcc/system-reminders/mcp-'+_n+'.md';let _r=_f.readFileSync(_p,'utf8');let _m=_r.match(/-->\\s*([\\s\\S]*?)\\s*\$/);if(!_m)return _d;let _b=_m[1].trim();if(_b==='')return null;return _b.replace(/\\{\\{server_instructions\\}\\}/g,_d||'')}catch{return _d}}for(let ${a} of ${o}){let _c=__tweakccMcpOverride(${a}.name,${a}.instructions);if(_c)${s}.set(${a}.name,\`## \${${a}.name}\n\${_c}\`)}`,l=e.slice(0,r.index)+c+e.slice(r.index+i.length);return F(e,l,c,r.index,r.index+i.length),l}}],vt=async()=>{let e=[l.join(n.homedir(),`.claude.json`),l.join(n.homedir(),`.claude`,`mcp.json`)];for(let t of e)try{let e=await a.readFile(t,`utf8`),n=JSON.parse(e);if(n.mcpServers&&typeof n.mcpServers==`object`)return Object.keys(n.mcpServers)}catch{}return[]},yt=async(e,t)=>{let n=[],r=e,i=await vt();for(let e of i)await dt(`mcp-${e}`,`MCP server: ${e}`,`Instructions block content for MCP server "${e}". {{server_instructions}} expands at runtime to the server's pristine instructions. Empty body drops the server's block from the model's context. Custom body replaces it.`,t,[`server_instructions`],`{{server_instructions}}`);for(let e of _t){let i=await dt(e.id,e.name,e.description,t,Object.keys(e.placeholders),e.defaultBody),a=await ut(e.id);if(!a){n.push({id:e.id,name:e.name,description:e.description,state:`default`,applied:!1,failed:!1,skipped:!0,details:`override file missing after ensure (unexpected)`});continue}let{result:o,errors:s}=ft(a.body,e.placeholders);if(s.length>0){n.push({id:e.id,name:e.name,description:e.description,state:`override`,applied:!1,failed:!0,skipped:!1,details:s.join(`; `)});continue}let c=e.apply(r,o,a.isSuppressed);if(c===null){n.push({id:e.id,name:e.name,description:e.description,state:a.isSuppressed?`suppressed`:`override`,applied:!1,failed:!0,skipped:!1,details:`patch function returned null`});continue}let l=c!==r;r=c;let u;u=a.isSuppressed?`suppressed`:a.body===e.defaultBody.trim()?`default`:`override`,n.push({id:e.id,name:e.name,description:e.description,state:u,applied:l,failed:!1,skipped:!1,details:i?`seeded default file`:void 0})}return{content:r,results:n}};let bt=null;const xt=async()=>{if(bt)return bt;let e=new Set,t=[Z,Da];for(let n of t){let t;try{t=await a.readdir(n)}catch{continue}if(Array.isArray(t))for(let r of t){if(!r.endsWith(`.md`))continue;let t;try{t=await a.readFile(f.join(n,r),`utf8`)}catch{continue}let i=_(t,{delimiters:[`<!--`,`-->`]}).data?.shadows;if(Array.isArray(i))for(let t of i)typeof t==`string`&&t&&e.add(t)}}for(let t of _t)if(Array.isArray(t.shadows))for(let n of t.shadows)typeof n==`string`&&n&&e.add(n);return bt=e,e};let St=null;const Ct=async()=>{if(St)return St;let e=new Set,t=Ge();if(t){let n;try{n=await a.readdir(t)}catch{n=[]}for(let r of n)if(!(!r.startsWith(`prompts-`)||!r.endsWith(`.json`)))try{let n=await a.readFile(f.join(t,r),`utf8`),i=JSON.parse(n);for(let t of i.prompts??[])for(let n of Object.values(t.identifierMap??{}))n&&e.add(n)}catch{continue}}if(e.size===0)try{let t=await import(`./identifierUnion-CqfoGx_F.mjs`);for(let n of t.IDENTIFIER_UNION)e.add(n)}catch{}return St=e,e},wt=e=>{let t=_(e,{delimiters:[`<!--`,`-->`]}),{name:n,description:r,ccVersion:i,variables:a}=t.data,o=0,s=e.indexOf(t.content);return s>=0&&(o=e.slice(0,s).split(`
|
|
40
|
+
`).length-1),{name:n||``,description:r||``,ccVersion:i||``,variables:a||[],content:t.content,contentLineOffset:o}},Tt=(e,t,n)=>{let r=t||Dt(e.pieces,e.identifiers,e.identifierMap),i=Object.keys(e.identifierMap).length>0?[...new Set(Object.values(e.identifierMap))]:void 0,a={name:e.name,description:e.description,ccVersion:e.version};if(i&&i.length>0&&(a.variables=i),n)for(let[e,t]of Object.entries(n))e in a||(a[e]=t);return _.stringify(r,a,{delimiters:[`<!--`,`-->`]})},Et=async e=>{let t={};try{let n=N(e),r=_(await a.readFile(n,`utf8`),{delimiters:[`<!--`,`-->`]}),i=new Set([`name`,`description`,`ccVersion`,`variables`]);for(let[e,n]of Object.entries(r.data))i.has(e)||(t[e]=n)}catch{}return t},Dt=(e,t,n)=>{let r=``;for(let i=0;i<e.length;i++)if(r+=e[i],i<t.length){let e=t[i],a=n[String(e)]||`UNKNOWN_${e}`;r+=a}return r},Ot=(e,t)=>{let n=e.split(`.`).map(Number),r=t.split(`.`).map(Number);for(let e=0;e<Math.max(n.length,r.length);e++){let t=n[e]||0,i=r[e]||0;if(t<i)return-1;if(t>i)return 1}return 0},N=e=>f.join(Z,`${e}.md`),kt=async e=>{try{return await a.access(N(e)),!0}catch{return!1}},At=async e=>{let t=N(e);return wt(await a.readFile(t,`utf-8`))},jt=async(e,t)=>{let n=N(e);await a.writeFile(n,t,`utf-8`)},Mt=async(e,t)=>{let n=N(e),r=await a.readFile(n,`utf-8`),i=_(r,{delimiters:[`<!--`,`-->`]}),o=Object.keys(t).length>0?[...new Set(Object.values(t))]:void 0,s=new Set([`name`,`description`,`ccVersion`,`variables`]),c={name:i.data.name,description:i.data.description,ccVersion:i.data.ccVersion};o&&o.length>0&&(c.variables=o);for(let[e,t]of Object.entries(i.data))s.has(e)||(c[e]=t);let l=_.stringify(i.content,c,{delimiters:[`<!--`,`-->`]});l!==r&&await jt(e,l)},Nt=(e,t)=>{let n=e=>e.split(/(\s+)/),r=n(e),i=n(t),a=r.length,o=i.length,s=Array(a+1).fill(0).map(()=>Array(o+1).fill(0));for(let e=1;e<=a;e++)for(let t=1;t<=o;t++)r[e-1]===i[t-1]?s[e][t]=s[e-1][t-1]+1:s[e][t]=Math.max(s[e-1][t],s[e][t-1]);let c=Array(a).fill(!1),l=Array(o).fill(!1),u=a,d=o;for(;u>0||d>0;)u>0&&d>0&&r[u-1]===i[d-1]?(u--,d--):d>0&&(u===0||s[u][d-1]>=s[u-1][d])?(l[d-1]=!0,d--):u>0&&(c[u-1]=!0,u--);let f=e=>e.replace(/&/g,`&`).replace(/</g,`<`).replace(/>/g,`>`).replace(/"/g,`"`).replace(/'/g,`'`),p=``;for(let e=0;e<r.length;e++){let t=f(r[e]);p+=c[e]?`<mark>${t}</mark>`:t}let m=``;for(let e=0;e<i.length;e++){let t=f(i[e]);m+=l[e]?`<mark>${t}</mark>`:t}return{oldHtml:p,newHtml:m}},Pt=(e,t)=>{let n=e.length,r=t.length,i=Array(n+1).fill(0).map(()=>Array(r+1).fill(0));for(let a=1;a<=n;a++)for(let n=1;n<=r;n++)e[a-1]===t[n-1]?i[a][n]=i[a-1][n-1]+1:i[a][n]=Math.max(i[a-1][n],i[a][n-1]);let a=[],o=n,s=r,c=[];for(;o>0||s>0;)o>0&&s>0&&e[o-1]===t[s-1]?(c.unshift({type:`unchanged`,line:e[o-1],oldLineNo:o,newLineNo:s}),o--,s--):s>0&&(o===0||i[o][s-1]>=i[o-1][s])?(c.unshift({type:`added`,line:t[s-1],newLineNo:s}),s--):o>0&&(c.unshift({type:`removed`,line:e[o-1],oldLineNo:o}),o--);for(let e=0;e<c.length;e++){let t=c[e],n=c[e+1];if(t.type===`removed`&&n?.type===`added`){let r=Nt(t.line,n.line);a.push({type:`modified`,line:t.line,oldLineNo:t.oldLineNo,newLineNo:n.newLineNo,oldHtml:r.oldHtml,newHtml:r.newHtml}),e++}else a.push(t)}return a},Ft=async(e,t,n,r,i,o,s,c)=>{let l=n.split(`
|
|
41
41
|
`),u=r.split(`
|
|
42
42
|
`),d=i.split(`
|
|
43
|
-
`),p=e=>e.replace(/&/g,`&`).replace(/</g,`<`).replace(/>/g,`>`).replace(/"/g,`"`).replace(/'/g,`'`),m=
|
|
43
|
+
`),p=e=>e.replace(/&/g,`&`).replace(/</g,`<`).replace(/>/g,`>`).replace(/"/g,`"`).replace(/'/g,`'`),m=Pt(l,u),h=Pt(l,d),g=``;for(let e of m){let t=p(e.line);if(e.type===`modified`){let t=e.oldLineNo?String(e.oldLineNo).padStart(4,` `):` `,n=e.newLineNo?String(e.newLineNo).padStart(4,` `):` `;g+=`<div class="line removed"><span class="line-num">${t}</span><span class="prefix">- </span>${e.oldHtml}</div>\n`,g+=`<div class="line added"><span class="line-num">${n}</span><span class="prefix">+ </span>${e.newHtml}</div>\n`}else if(e.type===`removed`){let n=e.oldLineNo?String(e.oldLineNo).padStart(4,` `):` `;g+=`<div class="line removed"><span class="line-num">${n}</span><span class="prefix">- </span>${t}</div>\n`}else if(e.type===`added`){let n=e.newLineNo?String(e.newLineNo).padStart(4,` `):` `;g+=`<div class="line added"><span class="line-num">${n}</span><span class="prefix">+ </span>${t}</div>\n`}else{let n=e.oldLineNo?String(e.oldLineNo).padStart(4,` `):` `,r=e.newLineNo?String(e.newLineNo).padStart(4,` `):` `;g+=`<div class="line unchanged"><span class="line-num">${n} ${r}</span><span class="prefix"> </span>${t}</div>\n`}}let _=``;for(let e of h){let t=p(e.line);if(e.type===`modified`){let t=e.oldLineNo?String(e.oldLineNo).padStart(4,` `):` `,n=e.newLineNo?String(e.newLineNo).padStart(4,` `):` `;_+=`<div class="line removed"><span class="line-num">${t}</span><span class="prefix">- </span>${e.oldHtml}</div>\n`,_+=`<div class="line added"><span class="line-num">${n}</span><span class="prefix">+ </span>${e.newHtml}</div>\n`}else if(e.type===`removed`){let n=e.oldLineNo?String(e.oldLineNo).padStart(4,` `):` `;_+=`<div class="line removed"><span class="line-num">${n}</span><span class="prefix">- </span>${t}</div>\n`}else if(e.type===`added`){let n=e.newLineNo?String(e.newLineNo).padStart(4,` `):` `;_+=`<div class="line added"><span class="line-num">${n}</span><span class="prefix">+ </span>${t}</div>\n`}else{let n=e.oldLineNo?String(e.oldLineNo).padStart(4,` `):` `,r=e.newLineNo?String(e.newLineNo).padStart(4,` `):` `;_+=`<div class="line unchanged"><span class="line-num">${n} ${r}</span><span class="prefix"> </span>${t}</div>\n`}}let v=`<!DOCTYPE html>
|
|
44
44
|
<html>
|
|
45
45
|
<head>
|
|
46
46
|
<meta charset="UTF-8">
|
|
@@ -201,8 +201,8 @@ ${_} </div>
|
|
|
201
201
|
</div>
|
|
202
202
|
</div>
|
|
203
203
|
</body>
|
|
204
|
-
</html>`,y=f.join(Z,`${e}.diff.html`);return await a.writeFile(y,v,`utf-8`),y},
|
|
205
|
-
|\\\\n)`).replace(new RegExp(i,`g`),`\\$\\{[^{}]*\\}`).replace(new RegExp(a,`g`),`(?:\\\\|\\\\\\\\)`).replace(new RegExp(o,`g`),`\\[[\\w$]+\\]`);r+=l,s<e.length-1&&(r+=`([\\w$]+)`)}return r},
|
|
204
|
+
</html>`,y=f.join(Z,`${e}.diff.html`);return await a.writeFile(y,v,`utf-8`),y},It=async e=>{let n={id:e.id,name:e.name,description:e.description,action:`skipped`,newVersion:e.version};if((await xt()).has(e.id))return n.action=`skipped`,n;if(!await kt(e.id)){if(!e.name)return n.action=`skipped`,n;let t=Tt(e);return await jt(e.id,t),n.action=`created`,n}let r=await At(e.id);if(n.oldVersion=r.ccVersion,await Mt(e.id,e.identifierMap),r.ccVersion&&e.version){let i=Ot(r.ccVersion,e.version);if(i===0)return n.action=`skipped`,n;if(i!=0){let i=await nt(e.id,r.ccVersion),a=Xe(r.content);if(!i||i!==a){n.action=`conflict`;let i=r.content;try{let t=(await Ke(r.ccVersion)).prompts.find(t=>t.id===e.id);t&&(i=Dt(t.pieces,t.identifiers,t.identifierMap))}catch{console.log(t.yellow(`Warning: Could not fetch old version ${r.ccVersion} for comparison. Using current file as baseline.`))}let a=Dt(e.pieces,e.identifiers,e.identifierMap),o=N(e.id);n.diffHtmlPath=await Ft(e.id,e.name,i,r.content,a,r.ccVersion,e.version,o)}else{let t=Tt(e,void 0,await Et(e.id));await jt(e.id,t),n.action=`updated`}}}return n},Lt=async e=>{let n={ccVersion:e,results:[]},r=await Ke(e);await tt(r),await a.mkdir(Z,{recursive:!0});for(let e of r.prompts)try{let t=await It(e);n.results.push(t)}catch(n){throw console.log(t.red(`Failed to sync prompt ${e.id}:`)),n}return n};let P=null,Rt=null;const zt=async e=>{try{return P=await Ke(e),Rt=e,{success:!0}}catch(e){return P=null,Rt=null,e instanceof Error?{success:!1,errorMessage:e.message}:{success:!1,errorMessage:`Unknown error occurred while downloading system prompts`}}},Bt=()=>P?P.prompts.map(e=>({id:e.id,name:e.name,description:e.description})):null,Vt=e=>e.split(``).map(e=>/[a-f]/i.test(e)?`[${e.toLowerCase()}${e.toUpperCase()}]`:e).join(``),Ht=e=>e.replace(/[^\x00-\x7F]/g,e=>{let t=e.charCodeAt(0),n=[e.replace(/[.*+?^${}()|[\]\\]/g,`\\$&`),`\\\\u${Vt(t.toString(16).padStart(4,`0`))}`];return t<=255&&n.push(`\\\\x${Vt(t.toString(16).padStart(2,`0`))}`),`(?:${n.join(`|`)})`}),Ut=e=>K(e),Wt=(e,t,n)=>{let r=``,i=`\0INTERP\0`,a=`\0BS\0`,o=`\0MEMBER\0`;for(let s=0;s<e.length;s++){let c=e[s].replace(/<<CCVERSION>>/g,t);n&&(c=c.replace(/<<BUILD_TIME>>/g,n)),s>0&&(c=c.replace(/^\[[A-Za-z_$][\w$]*\](?=\})/,o)),c=c.replace(/\$\{[^{}]*\}/g,i),c=c.replace(/\\/g,a);let l=Ht(c.replace(/[.*+?^${}()|[\]\\]/g,`\\$&`)).replace(/"/g,`(?:"|\\\\")`).replace(/'/g,`(?:'|\\\\')`).replace(/`/g,"(?:`|\\\\`)").replace(/\n/g,`(?:
|
|
205
|
+
|\\\\n)`).replace(new RegExp(i,`g`),`\\$\\{[^{}]*\\}`).replace(new RegExp(a,`g`),`(?:\\\\|\\\\\\\\)`).replace(new RegExp(o,`g`),`\\[[\\w$]+\\]`);r+=l,s<e.length-1&&(r+=`([\\w$]+)`)}return r},Gt=(e,t)=>{let n=0,r=t-1;for(;r>=0&&e[r]===`\\`;)n++,r--;return n},Kt=e=>{let t=``,n=0,r=``,i=[];for(let a=0;a<e.length;a++){let o=e[a],s=e[a+1],c=Gt(e,a)%2==0;if(n){if(i.length>0&&n===i[i.length-1]){if(o==="`"&&c)i.pop();else if(o===`$`&&s===`{`){c&&n++,t+="${",a++;continue}t+=o;continue}if(r)o===r&&c&&(r=``);else if(o===`$`&&s===`{`){c&&n++,t+="${",a++;continue}else o===`"`||o===`'`?r=o:o==="`"&&c?i.push(n):o===`{`?n++:o===`}`&&n--;t+=o;continue}if(o===`$`&&s===`{`&&!r){c&&n++,t+="${",a++;continue}o==="`"&&c?t+="\\`":t+=o}let a=n>0||i.length>0;return a&&W(`escapeDepthZeroBackticks: unclosed interpolation detected (depth=${n}). Some backticks may not have been escaped.`),{content:t,incomplete:a}},qt=e=>{if(e.length===0)return{leading:``,trailing:``};let t=e[0].match(/^(\s*)/),n=t?t[1]:``,r=e[e.length-1].match(/(\s*)$/);return{leading:n,trailing:r?r[1]:``}},Jt=(e,t)=>{if(e.trim()===``)return``;let n=e.trim();return t.leading+n+t.trailing},Yt=(e,t,n,r,i,a=!1,o,s)=>{let c={};for(let e=0;e<r.length;e++){let i=r[e],a=String(t[e]),o=n[a]||`UNKNOWN_${a}`;c[o]=i}let l=e,u=Object.entries(c).sort((e,t)=>t[0].length-e[0].length);for(let[e,t]of u){let n=RegExp(`\\b${e}\\b`,`g`);l=l.replace(n,()=>t)}if(l=l.replace(/<<CCVERSION>>/g,i),o&&(l=l.replace(/<<BUILD_TIME>>/g,o)),a&&(l=Ut(l)),s&&s.length>0){let e=qt(s);l=Jt(l,e)}return l},Xt=async(e,t=!1,n)=>{if(!P||Rt!==e)return[];let r=P,i=[],o=await xt();for(let t of r.prompts){if(!t.id||o.has(t.id))continue;let r=Wt(t.pieces,e,n),s=f.join(Z,`${t.id}.md`),c;try{c=await a.readFile(s,`utf8`)}catch(e){console.error(`Failed to read markdown file ${s}:`,e);continue}let l=wt(c);i.push({promptId:t.id,prompt:l,regex:r,getInterpolatedContent:r=>{let i=r.slice(1);return Yt(l.content,t.identifiers,t.identifierMap,i,e,!1,n,t.pieces)},pieces:t.pieces,identifiers:t.identifiers,identifierMap:t.identifierMap})}return i},Zt=e=>{let n=e.results.filter(e=>e.action===`created`),r=e.results.filter(e=>e.action===`updated`),i=e.results.filter(e=>e.action===`conflict`),a=e.results.filter(e=>e.action===`skipped`);if((n.length>0||r.length>0||i.length>0)&&a.length>0&&(console.log(t.dim(`Skipped ${a.length} up-to-date file(s)`)),console.log()),n.length>0){console.log(t.bold.green(`Created ${n.length} new prompt file(s):`));for(let e of n)console.log(t.green(` ${Z}/${e.id}.md`)),console.log(t.green.dim(` ${e.description}`));console.log()}if(r.length>0){console.log(t.bold.blue(`Updated ${r.length} system prompt file(s):`));for(let e of r)e.oldVersion?console.log(t.blue(` ${e.id}.md (${e.oldVersion} → ${e.newVersion})`)):console.log(t.blue(` ${e.id}.md (→ ${e.newVersion})`));console.log()}if(i.length>0){console.log(t.bold.yellow(`WARNING: Conflicts detected for ${i.length} system prompt file(s)`));for(let e of i)console.log(t.yellow(` ${e.id}.md (${e.oldVersion} → ${e.newVersion})`)),console.log(t.yellow(` Open the diff in your browser: ${e.diffHtmlPath}`));console.log()}if(n.length>0&&(console.log(t.green.bold(`New prompt files have been created; either more are now supported by tweakcc or Anthropic has added new ones.`)),console.log(t.green(`You can now customize the markdown files at ${Z} in a text editor.`)),console.log(t.green(`Then run tweakcc and select "apply" or use tweakcc --apply to update your system prompts`)),console.log()),i.length>0){console.log(),console.log(`Review conflicts:`),console.log(` 1. Open the diff HTML files in your browser`),console.log(` 2. Verify your customizations are still appropriate`),console.log(` 3. Update your markdown files if needed`),console.log(t.bold.cyan(` 4. Important: Update the ccVersion in your markdown files to the latest version of each prompt:`));for(let e of i)console.log(t.yellow(` ${e.id}.md → `)+t.bold.magenta(e.newVersion));console.log(` 5. Delete the diff HTML files`),console.log()}},Qt=/stack overflow|maximum call stack|call stack size/i,$t=e=>e.includes(`g`)?e:e+`g`,en=(e,t,n)=>{let r=new RegExp(e,$t(t)),i=[],a;for(;(a=r.exec(n))!==null;)i.push(a),a[0].length===0&&r.lastIndex++;return i},tn=(e,t,n)=>new Promise((r,i)=>{let a=new y(`
|
|
206
206
|
const { parentPort, workerData } = require('node:worker_threads');
|
|
207
207
|
try {
|
|
208
208
|
const { source, flags, content } = workerData;
|
|
@@ -217,20 +217,20 @@ try {
|
|
|
217
217
|
} catch (err) {
|
|
218
218
|
parentPort.postMessage({ ok: false, error: (err && err.message) || String(err) });
|
|
219
219
|
}
|
|
220
|
-
`,{eval:!0,workerData:{source:e,flags
|
|
221
|
-
`);let{content:e,incomplete:n}=
|
|
222
|
-
--- Diff ---`),
|
|
223
|
-
`));return}let m=b(f,p),h=0,g=0,_=-1,v=-1,y=-1,x=-1,S=0,C=0;for(let e of m)e.added?(y===-1&&(y=g,_=h),x=g+e.value.length,v=h,S=h,C=g+e.value.length,g+=e.value.length):e.removed?(_===-1&&(_=h,y=g),v=h+e.value.length,x=g,S=h+e.value.length,C=g,h+=e.value.length):(h+=e.value.length,g+=e.value.length);_===-1&&(_=0),y===-1&&(y=0),v===-1&&(v=f.length),x===-1&&(x=p.length);let w=f.length-S,T=p.length-C,E=Math.min(w,T,o),
|
|
220
|
+
`,{eval:!0,workerData:{source:e,flags:$t(t),content:n},resourceLimits:{stackSizeMb:16}});a.once(`message`,e=>{if(a.terminate(),!e.ok){i(Error(e.error??`regex worker failed`));return}r((e.matches??[]).map(({index:e,groups:t})=>{let n=t;return n.index=e,n}))}),a.once(`error`,e=>{a.terminate(),i(e)})}),nn=async(e,t,n)=>{try{return en(e,t,n)}catch(r){let i=r instanceof Error?r.message:String(r);if(!Qt.test(i))throw r;return tn(e,t,n)}},rn=e=>/\\u[0-9a-fA-F]{4}/.test(e),an=e=>{let t=e.match(/\bBUILD_TIME:"(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}Z)"/);return t?t[1]:void 0},on=(e,t)=>{let n=``;for(let r=0;r<e.length;r++)if(e[r]===t){let i=0,a=r-1;for(;a>=0&&e[a]===`\\`;)i++,a--;i%2==0?n+=`\\`+t:n+=t}else n+=e[r];return n},sn=async(e,n,r,i,a)=>{let o=r??rn(e);o&&W(`Detected Unicode escaping in cli.js - will escape non-ASCII characters in prompts`);let s=an(e);s&&W(`Extracted BUILD_TIME from cli.js: ${s}`);let c=await Xt(n,o,s);W(`Loaded ${c.length} system prompts with regexes`);let l=await Ct(),u=new Map;for(let e of c){let t=u.get(e.promptId);t||(t=new Set,u.set(e.promptId,t));for(let n of Object.values(e.identifierMap))t.add(n)}let d=[],f={},p=[];for(let{promptId:r,prompt:s,regex:m,getInterpolatedContent:h,pieces:g,identifiers:_,identifierMap:v}of c){if(i&&!i.includes(r)){d.push({id:r,name:s.name,group:H.SYSTEM_PROMPTS,applied:!1,skipped:!0});continue}W(`Applying system prompt: ${s.name}`);let c=new RegExp(m,`si`),y=await nn(m,`sig`,e),b=null;if(y.length===1)b=y[0];else if(y.length>1){let t=e=>e===`"`||e===`'`||e==="`",n=y.filter(n=>{let r=n.index>0?e[n.index-1]:``,i=e[n.index+n[0].length]??``;return t(r)&&r===i});n.length===1?(b=n[0],W(`Disambiguated ${y.length} matches \u2192 1 standalone for "${s.name}"`)):b=y[0]}if(b&&b.index!==void 0){let i=h(b),a=b.index,c=a>0?e[a-1]:``;{let e=[...new Set([...i.matchAll(/(?<!\\)\$\{([A-Za-z_][A-Za-z0-9_]*)\}/g)].map(e=>e[1]))].filter(e=>l.has(e)&&RegExp(`(?<!\\\\)\\$\\{`+e+`\\}`).test(s.content)),a=new Set(Object.values(v)),o=u.get(r);if(e.length>0&&e.every(e=>!a.has(e)&&o?.has(e))){W(`"${s.name}": placeholders resolve via a same-id sibling shape — leaving this site pristine`),d.push({id:r,name:s.name,group:H.SYSTEM_PROMPTS,applied:!1,skipped:!0});continue}if(c==="`"&&e.length>0){console.log(t.red(`Unresolved placeholder \${${e[0]}} in "${s.name}" (markdown vocabulary out of sync with CC ${n} prompt data) - skipping`)),d.push({id:r,name:s.name,group:H.SYSTEM_PROMPTS,applied:!1,details:`unresolved placeholder \${${e[0]}} - markdown out of sync with prompt data`});continue}}let m=Dt(g,_,v).trim().length,y=s.content.trim().length,x=e,S=b[0].length,C=i;if((c===`"`||c===`'`)&&(C=C.replace(/\\/g,`\\\\`)),c===`"`)C=C.replace(/\r\n|\r|\n/g,`\\n`),C=on(C,`"`);else if(c===`'`)C=C.replace(/\r\n|\r|\n/g,`\\n`),C=on(C,`'`);else if(c==="`"){C=C.replace(/\r\n|\r/g,`
|
|
221
|
+
`);let{content:e,incomplete:n}=Kt(C);if(n){console.log(t.red(`Incomplete backtick escaping for "${s.name}" (unclosed interpolation) - skipping`)),d.push({id:r,name:s.name,group:H.SYSTEM_PROMPTS,applied:!1,details:`incomplete escaping: unclosed interpolation detected`});continue}e!==C&&console.log(t.yellow(`Auto-escaped unescaped backticks in "${s.name}"`)),C=e}o&&(C=Ut(C)),e=e.slice(0,a)+C+e.slice(a+S),f[r]=Xe(s.content),F(x,e,C,a,a+S);let w=m-y,T=x!==e,E;E=w>0?t.green(`${w} fewer chars`):w<0?t.red(`${Math.abs(w)} more chars`):`unchanged`;let D=d.length;d.push({id:r,name:s.name,group:H.SYSTEM_PROMPTS,applied:T,details:E}),p.push(D)}else{let n=!1;if(a!==void 0&&a!==e)try{n=(await nn(m,`sig`,a)).length>0}catch{n=!1}if(n){W(`"${s.name}": region consumed by an earlier inline-blob/reminder override — leaving superseded, no warning`),d.push({id:r,name:s.name,group:H.SYSTEM_PROMPTS,applied:!1,skipped:!0});continue}!s.name.startsWith(`Data:`)&&s.name!==`Skill: Build with Claude API`&&console.log(t.yellow(`Could not find system prompt "${s.name}" in cli.js (using regex ${ba(c)})`)),G(`\n Debug info for ${s.name}:`),G(` Regex pattern (first 200 chars): ${m.substring(0,200).replace(/\n/g,`\\n`)}...`),G(` Trying to match pattern in cli.js...`);try{G(` Partial match result: ${e.match(new RegExp(m.substring(0,100)))?`found partial`:`no match`}`)}catch{G(` Partial match failed (regex truncation issue)`)}}}try{await at(f)}catch(e){W(`Failed to store applied prompt hashes: ${e}`);for(let e of p){let t=d[e];t&&(t.failed=!0,t.details=t.details?`${t.details} (hash storage failed)`:`hash storage failed`)}}return{newContent:e,results:d}},cn=e=>e.replace(/\\u([0-9a-fA-F]{4})/g,(e,t)=>String.fromCharCode(parseInt(t,16))),F=(e,n,r,i,a,o=40)=>{if(!na())return;let s=Math.max(0,i-o),c=Math.min(e.length,a+o),l=Math.min(n.length,i+r.length+o),u=e.slice(s,c),d=n.slice(s,l),f=cn(u),p=cn(d);if(f===p){ra()&&(G(`
|
|
222
|
+
--- Diff ---`),G(t.blue(`UNCHANGED: `)+t.dim(f)),G(`--- End Diff ---
|
|
223
|
+
`));return}let m=b(f,p),h=0,g=0,_=-1,v=-1,y=-1,x=-1,S=0,C=0;for(let e of m)e.added?(y===-1&&(y=g,_=h),x=g+e.value.length,v=h,S=h,C=g+e.value.length,g+=e.value.length):e.removed?(_===-1&&(_=h,y=g),v=h+e.value.length,x=g,S=h+e.value.length,C=g,h+=e.value.length):(h+=e.value.length,g+=e.value.length);_===-1&&(_=0),y===-1&&(y=0),v===-1&&(v=f.length),x===-1&&(x=p.length);let w=f.length-S,T=p.length-C,E=Math.min(w,T,o),D=Math.max(0,_-o),O=Math.min(f.length,S+E),k=Math.max(0,y-o),ee=Math.min(p.length,C+E),te=b(f.slice(D,O),p.slice(k,ee)),A=``;for(let e of te)if(!e.added)if(e.removed)if(e.value.includes(`
|
|
224
224
|
`)){let n=e.value.split(`
|
|
225
|
-
`);n.forEach((e,r)=>{e&&(
|
|
226
|
-
`)})}else
|
|
225
|
+
`);n.forEach((e,r)=>{e&&(A+=t.bgRed.white(e)),r<n.length-1&&(A+=t.bgRed.dim(`\\n`)+`
|
|
226
|
+
`)})}else A+=t.bgRed.white(e.value);else A+=t.dim(e.value);let j=``;for(let e of te)if(e.added)if(e.value.includes(`
|
|
227
227
|
`)){let n=e.value.split(`
|
|
228
|
-
`);n.forEach((e,r)=>{e&&(
|
|
229
|
-
`)})}else
|
|
230
|
-
--- Diff ---`),
|
|
231
|
-
`)},I=(e,t,n)=>{let r=[],i=t.global?t:new RegExp(t.source,t.flags+`g`),a;for(;(a=i.exec(e))!==null;)r.push({index:a.index,length:a[0].length});let o=new RegExp(t.source,t.flags.replace(`g`,``)),s=e;for(let e=r.length-1;e>=0;e--){let{index:t,length:i}=r[e],a=s,c=s.slice(t,t+i).replace(o,n);s=s.slice(0,t)+c+s.slice(t+i),F(a,s,c,t,t+i)}return s},
|
|
232
|
-
`)n+=`\\n`;else if(r===`\r`)n+=`\\r`;else if(r===` `)n+=`\\t`;else if(t&&e>126)if(e<=65535)n+=`\\u`+e.toString(16).padStart(4,`0`);else{let t=e-65536,r=55296+(t>>10),i=56320+(t&1023);n+=`\\u`+r.toString(16).padStart(4,`0`)+`\\u`+i.toString(16).padStart(4,`0`)}else n+=r}return n+=`"`,n},
|
|
233
|
-
`).map(e=>
|
|
228
|
+
`);n.forEach((e,r)=>{e&&(j+=t.bgGreen.black(e)),r<n.length-1&&(j+=t.bgGreen.dim(`\\n`)+`
|
|
229
|
+
`)})}else j+=t.bgGreen.black(e.value);else e.removed||(j+=t.dim(e.value));G(`
|
|
230
|
+
--- Diff ---`),G(t.red(`OLD: `)+A),G(t.green(`NEW: `)+j),G(`--- End Diff ---
|
|
231
|
+
`)},I=(e,t,n)=>{let r=[],i=t.global?t:new RegExp(t.source,t.flags+`g`),a;for(;(a=i.exec(e))!==null;)r.push({index:a.index,length:a[0].length});let o=new RegExp(t.source,t.flags.replace(`g`,``)),s=e;for(let e=r.length-1;e>=0;e--){let{index:t,length:i}=r[e],a=s,c=s.slice(t,t+i).replace(o,n);s=s.slice(0,t)+c+s.slice(t+i),F(a,s,c,t,t+i)}return s},ln=(e,t)=>{if(!/^<!--/.test(t))return null;let n;try{n=_(t,{delimiters:[`<!--`,`-->`]})}catch{return null}let r=n.data;return typeof r.inlineBlobAnchor!=`string`||!r.inlineBlobAnchor||typeof r.inlineBlobKind!=`string`||![`array`,`template`,`string`].includes(r.inlineBlobKind)?null:{filename:e,frontmatter:r,body:n.content.replace(/^\n+/,``).replace(/\n+$/,``)}},un=(e,t)=>{if(e[t]!==`[`)return null;let n=0,r=!1,i=null,a=t;for(;a<e.length;){let t=e[a];if(r){if(t===`\\`&&a+1<e.length){a+=2;continue}if(t===i)r=!1;else if(i==="`"&&t===`$`&&a+1<e.length&&e[a+1]===`{`){let t=1,n=a+2;for(;n<e.length&&t>0;){let r=e[n];if(r===`\\`&&n+1<e.length){n+=2;continue}if(r==="`"){let r=dn(e,n);if(r===null){t=0;break}n=r;continue}r===`{`?t++:r===`}`&&t--,n++}a=n;continue}}else if(t===`"`||t===`'`||t==="`")r=!0,i=t;else if(t===`[`)n++;else if(t===`]`&&(n--,n===0))return a+1;a++}return null},dn=(e,t)=>{if(e[t]!=="`")return null;let n=t+1;for(;n<e.length;){let t=e[n];if(t===`\\`&&n+1<e.length){n+=2;continue}if(t==="`")return n+1;if(t===`$`&&n+1<e.length&&e[n+1]===`{`){let t=1,r=n+2;for(;r<e.length&&t>0;){let n=e[r];if(n===`\\`&&r+1<e.length){r+=2;continue}if(n==="`"){let t=dn(e,r);if(t===null)return null;r=t;continue}n===`{`?t++:n===`}`&&t--,r++}n=r;continue}n++}return null},fn=e=>/\\u[0-9a-fA-F]{4}/.test(e),pn=(e,t)=>{let n=`"`;for(let r of e){let e=r.codePointAt(0);if(r===`\\`)n+=`\\\\`;else if(r===`"`)n+=`\\"`;else if(r===`
|
|
232
|
+
`)n+=`\\n`;else if(r===`\r`)n+=`\\r`;else if(r===` `)n+=`\\t`;else if(t&&e>126)if(e<=65535)n+=`\\u`+e.toString(16).padStart(4,`0`);else{let t=e-65536,r=55296+(t>>10),i=56320+(t&1023);n+=`\\u`+r.toString(16).padStart(4,`0`)+`\\u`+i.toString(16).padStart(4,`0`)}else n+=r}return n+=`"`,n},mn=e=>{let t=[],n=0;for(;n<e.length;){if(e[n]===`$`&&n+1<e.length&&e[n+1]===`{`&&(n===0||e[n-1]!==`\\`)){let r=1,i=n+2,a=!1,o=null,s=i;for(;i<e.length&&r>0;){let t=e[i];if(a){if(t===`\\`&&i+1<e.length){i+=2;continue}t===o&&(a=!1)}else if(t===`"`||t===`'`||t==="`")a=!0,o=t;else if(t===`{`)r++;else if(t===`}`&&(r--,r===0))break;i++}t.push(e.slice(s,i)),n=i+1;continue}n++}return t},hn=(e,t)=>{let n=``,r=0,i=0;for(;r<e.length;){if(e[r]===`$`&&r+1<e.length&&e[r+1]===`{`&&(r===0||e[r-1]!==`\\`)){let a=1,o=r+2,s=!1,c=null;for(;o<e.length&&a>0;){let t=e[o];if(s){if(t===`\\`&&o+1<e.length){o+=2;continue}t===c&&(s=!1)}else if(t===`"`||t===`'`||t==="`")s=!0,c=t;else if(t===`{`)a++;else if(t===`}`&&(a--,a===0))break;o++}i<t.length?n+="${"+t[i]+`}`:n+=e.slice(r,o+1),i++,r=o+1;continue}n+=e[r],r++}return n},gn=e=>{let t=new Set;for(let n of e.matchAll(/(?<!\\)\$\{([A-Za-z$][\w$]*)\}/g)){let e=n[1];e.length>4||e===e.toUpperCase()&&/[A-Z]/.test(e)&&e.length>2||t.add(e)}return t},_n=(e,t)=>{let n=gn(e),r=[];for(let e of gn(t))n.has(e)||r.push(e);return r},vn=e=>{let t=[],n=0,r=!1,i=null,a=e=>/[A-Za-z_$]/.test(e),o=e=>/[A-Za-z0-9_$]/.test(e);for(;n<e.length;){let s=e[n];if(r){if(s===`\\`&&n+1<e.length){n+=2;continue}if(s===i){r=!1,n++;continue}if(i==="`"&&s===`$`&&n+1<e.length&&e[n+1]===`{`){let r=1,i=n+2,a=!1,o=null;for(;i<e.length&&r>0;){let t=e[i];if(a){if(t===`\\`&&i+1<e.length){i+=2;continue}t===o&&(a=!1),i++;continue}if(t===`"`||t===`'`||t==="`"){a=!0,o=t,i++;continue}if(t===`{`)r++;else if(t===`}`&&(r--,r===0))break;i++}let s=e.slice(n+2,i);for(let e of vn(s))t.push({name:e.name,start:e.start+n+2,end:e.end+n+2});n=i+1;continue}n++;continue}if(s===`"`||s===`'`||s==="`"){r=!0,i=s,n++;continue}if(a(s)){let r=n>0?e[n-1]:``,i=n>1?e[n-2]:``,a=n>2?e[n-3]:``,s=!(r===`.`&&i===`.`&&a===`.`)&&(r===`.`||r===`?`&&i===`?`),c=n;for(;n<e.length&&o(e[n]);)n++;let l=e.slice(c,n);!s&&![`true`,`false`,`null`,`undefined`,`this`,`void`,`new`].includes(l)&&t.push({name:l,start:c,end:n});continue}n++}return t},yn=(e,t)=>{let n=vn(e);if(n.length===0)return e;let r=``,i=0,a=0;for(let o of n)r+=e.slice(i,o.start),a<t.length?r+=t[a]:r+=o.name,i=o.end,a++;return r+=e.slice(i),r},bn=(e,t)=>{let n="`",r=0;for(;r<e.length;){let i=e[r];if(i===`$`&&r+1<e.length&&e[r+1]===`{`){let t=1,i=r+2,a=!1,o=null;for(;i<e.length&&t>0;){let n=e[i];if(a){if(n===`\\`&&i+1<e.length){i+=2;continue}n===o&&(a=!1)}else n===`"`||n===`'`||n==="`"?(a=!0,o=n):n===`{`?t++:n===`}`&&t--;i++}n+=e.slice(r,i),r=i;continue}let a=i.codePointAt(0);if(i===`\\`)n+=`\\\\`;else if(i==="`")n+="\\`";else if(t&&a>126)if(a<=65535)n+=`\\u`+a.toString(16).padStart(4,`0`);else{let e=a-65536,t=55296+(e>>10),r=56320+(e&1023);n+=`\\u`+t.toString(16).padStart(4,`0`)+`\\u`+r.toString(16).padStart(4,`0`)}else n+=i;r++}return n+="`",n},xn=async e=>{let t=fn(e);t&&W(`inlineBlobOverrides: cli.js uses unicode escaping`);let n;try{n=await a.readdir(Z)}catch{return{content:e,results:[]}}let r=n.filter(e=>e.startsWith(`inline-`)&&e.endsWith(`.md`));if(r.length===0)return{content:e,results:[]};let i=[];for(let n of r.sort()){let r=l.join(Z,n),o;try{o=await a.readFile(r,`utf8`)}catch(e){i.push({filename:n,name:n,applied:!1,failed:!0,details:`read failed: ${e}`});continue}let s=ln(n,o);if(!s){i.push({filename:n,name:n,applied:!1,failed:!0,details:`frontmatter missing inlineBlobAnchor/Kind`});continue}let{frontmatter:c,body:u}=s,d;try{d=new RegExp(c.inlineBlobAnchor,`s`)}catch(e){i.push({filename:n,name:c.name,applied:!1,failed:!0,details:`invalid anchor regex: ${e}`});continue}let f=d.exec(e);if(!f){i.push({filename:n,name:c.name,applied:!1,failed:!0,details:`anchor not found in cli.js`});continue}let p,m,h;if(c.inlineBlobKind===`array`){let r=e.indexOf(`[`,f.index);if(r===-1){i.push({filename:n,name:c.name,applied:!1,failed:!0,details:`no [ after anchor`});continue}let a=un(e,r);if(a===null){i.push({filename:n,name:c.name,applied:!1,failed:!0,details:`array walker failed`});continue}if(p=r,m=a,c.inlineBlobRawPassthrough===`true`){let n=yn(u,vn(e.slice(r+1,a-1)).map(e=>e.name));h=`[`+(t?K(n):n)+`]`}else h=`[`+u.split(`
|
|
233
|
+
`).map(e=>pn(e,t)).join(`,`)+`]`}else if(c.inlineBlobKind===`template`){let r=e[f.index]==="`"?f.index:e.indexOf("`",f.index);if(r===-1){i.push({filename:n,name:c.name,applied:!1,failed:!0,details:`no backtick at/after anchor`});continue}let a=dn(e,r);if(a===null){i.push({filename:n,name:c.name,applied:!1,failed:!0,details:`template walker failed`});continue}p=r,m=a,h=bn(hn(u,mn(e.slice(r+1,a-1))),t)}else if(c.inlineBlobKind===`string`){let r=f.index;for(;r<e.length&&e[r]!==`"`&&e[r]!==`'`;)r++;if(r>=e.length){i.push({filename:n,name:c.name,applied:!1,failed:!0,details:`no quote at/after anchor`});continue}let a=e[r],o=r+1;for(;o<e.length;){if(e[o]===`\\`){o+=2;continue}if(e[o]===a)break;o++}if(o>=e.length){i.push({filename:n,name:c.name,applied:!1,failed:!0,details:`unterminated string`});continue}p=r,m=o+1,h=pn(u,t)}else{i.push({filename:n,name:c.name,applied:!1,failed:!0,details:`kind ${c.inlineBlobKind} not implemented`});continue}let g=f.index,_=f.index+f[0].length;if(!(p<=_&&m>g)){console.log(`inline-blob: anchor for "${c.name}" (${n}) matched outside its target literal — cannot apply safely, skipping`),i.push({filename:n,name:c.name,applied:!1,failed:!1,skipped:!0,details:`anchor matched outside target literal — skipped (unsafe)`});continue}let v=_n(e.slice(p,m),h);if(v.length>0){console.log(`inline-blob: "${c.name}" (${n}) would introduce undefined var \${${v[0]}} (markdown out of sync with CC prompt data) — cannot apply safely, skipping`),i.push({filename:n,name:c.name,applied:!1,failed:!1,skipped:!0,details:`would introduce undefined \${${v[0]}} — skipped (unsafe)`});continue}let y=e;e=e.slice(0,p)+h+e.slice(m);let b=m-p-h.length,x=b>0?`${b} fewer chars`:b<0?`${-b} more chars`:`unchanged`;F(y,e,h,p,m),i.push({filename:n,name:c.name,applied:!0,failed:!1,details:x})}return{content:e,results:i}},Sn=e=>{let t=e.match(/ensureServerStarted:([$\w]+)/);if(!t||t.index===void 0)return console.error(`patch: fixLspSupport: failed to find ensureServerStarted`),null;let n=Math.max(0,t.index-50),r=Math.min(e.length,t.index+50),i=e.slice(n,r),a=i.match(/sendRequest:([$\w]+)[,}]/);if(!a)return console.error(`patch: fixLspSupport: failed to find sendRequest near ensureServerStarted, window=${JSON.stringify([n,r,i])}`),null;let o=a[1],s=Math.max(0,t.index-4e3),c=e.slice(s,t.index),l=RegExp(`async function ${U(o)}\\(([$\\w]+),`,`g`),u,d=null;for(;(u=l.exec(c))!==null;)d=u;if(!d)return console.error(`patch: fixLspSupport: failed to find async function ${o}`),null;let f=d[1],p=s+d.index,m=e.slice(p,t.index).match(/let ([$\w]+)=await [$\w]+\([$\w]+\);/);if(!m||m.index===void 0)return console.error(`patch: fixLspSupport: failed to find second line of sendRequest`),null;let h=m[1],g=p+m.index+m[0].length,_=e.slice(g,t.index),v=RegExp(`if\\(!${U(h)}\\)return;`),y=_.match(v);if(!y||y.index===void 0)return console.error(`patch: fixLspSupport: failed to find if(!serverVar)return; line`),null;let b=g+y.index+y[0].length;return{startIndex:b,endIndex:b,identifiers:[f,h]}},Cn=e=>{let t=/if\([$\w]+\.restartOnCrash!==void 0\)throw Error\(`LSP server '\$\{[$\w]+\}': restartOnCrash is not yet implemented\. Remove this field from the configuration\.`\);/g,n=/if\([$\w]+\.startupTimeout!==void 0\)throw Error\(`LSP server '\$\{[$\w]+\}': startupTimeout is not yet implemented\. Remove this field from the configuration\.`\);/g,r=/if\([$\w]+\.shutdownTimeout!==void 0\)throw Error\(`LSP server '\$\{[$\w]+\}': shutdownTimeout is not yet implemented\. Remove this field from the configuration\.`\);/g,i=e;if(i=I(i,t,``),i=I(i,n,``),i=I(i,r,``),i.includes(`textDocument/didOpen`))return W(`patch: fixLspSupport: native LSP didOpen detected — skipping injection`),i;let a=Sn(i);if(!a||!a.identifiers)return null;let[o,s]=a.identifiers,c=`
|
|
234
234
|
const path = await import('path');
|
|
235
235
|
const ext = path.extname(${o}).toLowerCase();
|
|
236
236
|
const langMap = {
|
|
@@ -380,7 +380,7 @@ try {
|
|
|
380
380
|
}
|
|
381
381
|
});
|
|
382
382
|
} catch (openErr) { }
|
|
383
|
-
`,l=i.slice(0,a.startIndex)+c+i.slice(a.endIndex);return F(i,l,c,a.startIndex,a.endIndex),l},
|
|
383
|
+
`,l=i.slice(0,a.startIndex)+c+i.slice(a.endIndex);return F(i,l,c,a.startIndex,a.endIndex),l},wn=e=>{let t=e.match(/messagesSummarized:([$\w]+)\.length\},([$\w]+)=([$\w]+)==="up_to"\?\1:([$\w]+),([$\w]+)=\3==="up_to"\?\{\.\.\.([$\w]+),forkContextMessages:\1\}:\6/);if(!t||t.index===void 0)return/messagesSummarized:([$\w]+)\.length\},([$\w]+)=\1,([$\w]+)=\{\.\.\.([$\w]+),forkContextMessages:\1\}/.test(e)?(W(`patch: fixSummarizeFromHere: already applied in this CC build — no-op`),e):(console.error(`patch: fixSummarizeFromHere: failed to find the summarize-direction ternary`),null);let[,n,r,,,i,a]=t,o=`messagesSummarized:${n}.length},${r}=${n},${i}={...${a},forkContextMessages:${n}}`,s=e.slice(0,t.index)+o+e.slice(t.index+t[0].length);return F(e,s,o,t.index,t.index+o.length),s},Tn=e=>{let t=e.match(/content:([$\w]+\([$\w]+,!1,[$\w]+,void 0,[$\w]+\)),(isCompactSummary:!0,\.\.\.[$\w]+\.length>0\?\{summarizeMetadata:\{messagesSummarized:[$\w]+\.length,userContext:[$\w]+,direction:([$\w]+)\}\})/);if(!t||t.index===void 0)return e.includes(`.replace(/This session is being continued`)?(W(`patch: fixRewindSummaryHeader: already applied in this CC build — no-op`),e):(console.error(`patch: fixRewindSummaryHeader: failed to find the rewind summary message (summarizeMetadata.direction call site)`),null);if(!e.includes(`This session is being continued from a previous conversation that ran out of context`))return console.error(`patch: fixRewindSummaryHeader: rewind call site found but the compaction header phrase changed — needs re-anchoring`),null;let[,n,r,i]=t,a=`content:${`${n}.replace(/This session is being continued from a previous conversation that ran out of context\\.[^\\n]*/,${i}==="up_to"?${JSON.stringify(`This session was rewound at your request, not a context overflow. The summary below covers the earlier portion up to your selected point; the recent messages are kept intact.`)}:${JSON.stringify(`This session was rewound to an earlier point at your request, not a context overflow. The summary below captures the later work you chose to carry forward; the messages above are intact.`)})`},${r}`,o=e.slice(0,t.index)+a+e.slice(t.index+t[0].length);return F(e,o,a,t.index,t.index+a.length),o},En=(e,t)=>{let n=1,r=t+1,i=0,a=!1,o=null,s=!1;for(;r<e.length;){let t=e[r];if(o){s?s=!1:t===`\\`?s=!0:t===o&&(o=null),r++;continue}if(t===`"`||t===`'`||t==="`")o=t,a=!0;else if(t===`[`||t===`(`||t===`{`)n++,a=!0;else if(t===`]`){if(n===1)return a&&i++,{itemCount:i,closingBracket:r};n--}else t===`)`||t===`}`?n--:t===`,`&&n===1?(a&&i++,a=!1):/\s/.test(t)||(a=!0);r++}return null},Dn=e=>{let t=/=>\s*\[/g,n,r=null;for(;(n=t.exec(e))!==null;){let t=n.index+n[0].length-1,i=e.slice(Math.max(0,n.index-12e3),Math.min(e.length,n.index+12e3));if(!/name:"[^"]+"[\s\S]{0,1200}description:/.test(i))continue;let a=En(e,t);a&&a.itemCount>=30&&(!r||a.itemCount>r.items)&&(r={closing:a.closingBracket,items:a.itemCount})}return r?r.closing:(console.error(`patch: findSlashCommandListEndPosition: failed to find arrayStartPattern`),null)},On=(e,t)=>{let n=Dn(e);if(n===null)return console.error(`patch: writeSlashCommandDefinition: failed to find slash command array end position`),null;let r=e.slice(0,n)+t+e.slice(n);return F(e,r,t,n,n),r},kn=e=>{let t=e.match(/\.createElement\(([$\w]+),.{0,100}"Yes, use recommended settings"/);return t?t[1]:(console.error(`patch: findSelectComponentName: failed to find selectPattern`),null)},An=e=>{let t=Array.from(e.matchAll(/function ([$\w]+)(?:\([$\w]+\)\{let [$\w]+=[$\w]+\(\d+\),\{(?:(?:orientation|title|width|padding|titlePadding|titleColor|titleDimColor|dividerChar|dividerColor|dividerDimColor|boxProps):[$\w]+,?)+\}=|\(\{(?:(?:orientation|title|width|padding|titlePadding|titleColor|titleDimColor|dividerChar|dividerColor|dividerDimColor|boxProps):[$\w]+(?:=(?:[^,]+,|[^}]+\})|[,}]))+\))/g));if(t.length===0)return null;let n=t[0];for(let e of t)e[0].length>n[0].length&&(n=e);return n[1]},L=e=>{let t=e.match(/function ([$\w]+)\(.{0,110}`Your selector in.{0,1000}?function ([$\w]+)\(\)\{return [$\w]+\(\)\.setState\}/);if(t)return{appStateUseSelectorFn:t[1],appStateSetState:t[2]};let n=Array.from(e.matchAll(/function ([$\w]+)\(\)\{return ([$\w]+)\(\)\.setState\}/g));for(let t of n){let n=t[1],r=t[2].replace(/\$/g,`\\$`),i=RegExp(`function ([$\\w]+)\\([$\\w]+\\)\\{(?:(?!\\bfunction\\b).){0,300}${r}\\(\\)(?:(?!\\bfunction\\b).){0,300}useSyncExternalStore\\(`),a=e.match(i);if(!a)continue;let o=a[1],s=o.replace(/\$/g,`\\$`);if(RegExp(`${s}\\(.{0,80}thinkingEnabled`).test(e))return{appStateUseSelectorFn:o,appStateSetState:n}}return console.error(`patch: getAppStateSelectorAndUseState: failed to find pattern`),null},jn=e=>{let t=Dn(e);if(t===null)return console.error(`patch: findTopLevelPositionBeforeSlashCommand: failed to find arrayEnd`),null;let n=1,r=t;for(;r>=0&&n>0;){if(e[r]===`}`)n++;else if(e[r]===`{`&&(n--,n===0))break;r--}if(r<0)return console.error(`patch: findTopLevelPositionBeforeSlashCommand: failed to find matching open-brace`),null;for(;r>=0&&e[r]!==`;`;)r--;return r<0?(console.error(`patch: findTopLevelPositionBeforeSlashCommand: failed to find matching semicolon`),null):r+1},Mn=(e,t)=>{let n=Array.from(e.matchAll(/thinkingEnabled:([$\w]+)\(\)/g));if(n.length===0)return console.error(`patch: toolsets: failed to find thinkingEnabled pattern`),null;let r=[];for(let e of n)if(e.index!==void 0){let t=e.index+e[0].length;r.push({index:t})}r.sort((e,t)=>t.index-e.index);let i=e,a=`,toolset:${t?JSON.stringify(t):`undefined`}`;for(let e of r)i=i.slice(0,e.index)+a+i.slice(e.index);if(i===e)return console.error(`patch: toolsets: failed to modify app state initialization`),null;let o=r[r.length-1];return F(e,i,a,o.index,o.index),i},Nn=(e,t,n)=>{let r=L(e);if(!r)return console.error(`patch: toolsets: toolFetchingMemo: failed to find app state info`),null;let{appStateUseSelectorFn:i}=r,a=e.match(/let ([$\w]+)=([$\w]+\([$\w]+,[$\w]+\.tools,[$\w]+\)),/);if(!a||a.index===void 0)return console.error(`patch: toolsets: failed to find tool aggregation pattern`),null;let o=a[1],s=a[2],c=JSON.stringify(Object.fromEntries(t.map(e=>[e.name,e.allowedTools===`*`?`*`:e.allowedTools]))),l=`let currentToolset = ${i}(state => state.toolset) ?? ${n?JSON.stringify(n):`undefined`};
|
|
384
384
|
let ${o} = undefined;
|
|
385
385
|
const toolsets = ${c};
|
|
386
386
|
if (toolsets.hasOwnProperty(currentToolset)) {
|
|
@@ -392,8 +392,8 @@ if (toolsets.hasOwnProperty(currentToolset)) {
|
|
|
392
392
|
}
|
|
393
393
|
} else {
|
|
394
394
|
${o} = ${s};
|
|
395
|
-
}let `,u=a.index,d=u+a[0].length,f=e.slice(0,u)+l+e.slice(d);return F(e,f,l,u,d),f},
|
|
396
|
-
`,i.indexOf(`// Version:`));return c===-1?(console.error(`patch: toolsets: toolsetAwareErrors: failed to find insertion point for helper`),null):(i=i.slice(0,c+1)+s+i.slice(c+1),i)},
|
|
395
|
+
}let `,u=a.index,d=u+a[0].length,f=e.slice(0,u)+l+e.slice(d);return F(e,f,l,u,d),f},Pn=(e,t,n)=>{if(!L(e))return console.error(`patch: toolsets: computeToolsFilter: failed to find app state info`),null;let r=e.match(/([$\w]+)=(?:([$\w]+\.useCallback\())?\(\)=>\{let ([$\w]+)=([$\w]+)\.getState\(\),([$\w]+)=([$\w]+)\(\3\.toolPermissionContext,\3\.mcp\.tools(?:,\{skillTools:\3\.skillTools\})?\),([$\w]+)=([$\w]+)\([$\w]+,\5,\3\.toolPermissionContext\.mode\);if\(!([$\w]+)\)return \7;return ([$\w]+)\(\9,\7,!1,!0\)\.resolvedTools\}/);if(!r||r.index===void 0)return console.error(`patch: toolsets: computeToolsFilter: failed to find computeTools pattern`),null;let i=r[1],a=r[2]||``,o=r[3],s=r[4],c=r[5],l=r[6],u=r[7],d=r[8],f=r[9],p=r[10],m=r[0].includes(`{skillTools:${o}.skillTools}`)?`,{skillTools:${o}.skillTools}`:``,h=JSON.stringify(Object.fromEntries(t.map(e=>[e.name,e.allowedTools===`*`?`*`:e.allowedTools]))),g=n?JSON.stringify(n):`undefined`,_=r[0],v=_.match(RegExp(`${d.replace(/\$/g,`\\$`)}\\(([$\\w]+),${c.replace(/\$/g,`\\$`)},`));if(!v)return console.error(`patch: toolsets: computeToolsFilter: failed to extract init var from merge call`),null;let y=`${i}=${a}()=>{let ${o}=${s}.getState(),${c}=${l}(${o}.toolPermissionContext,${o}.mcp.tools${m}),${u}=${d}(${v[1]},${c},${o}.toolPermissionContext.mode);const __ts=${h},__tc=${o}.toolset??${g},__tf=(t)=>{globalThis.__tweakcc_toolset={name:__tc,tools:__ts[__tc]};if(__ts.hasOwnProperty(__tc)){const a=__ts[__tc];if(a==="*")return t;return t.filter(d=>a.includes(d.name))}return t};if(!${f})return __tf(${u});return __tf(${p}(${f},${u},!1,!0).resolvedTools)}`,b=r.index,x=b+_.length,S=e.slice(0,b)+y+e.slice(x);return F(e,S,y,b,x),S},Fn=(e,t,n)=>{let r=JSON.stringify(Object.fromEntries(t.map(e=>[e.name,e.allowedTools===`*`?`*`:e.allowedTools]))),i=n?JSON.stringify(n):`undefined`,a=e.match(/let ([$\w]+)=([$\w]+)\(([$\w]+)\);(?=[\s\S]{0,2500}tools:\1,refreshTools:\(\)=>\2\(([$\w]+)\(\)\))/);if(!a||a.index===void 0)return console.error(`patch: toolsets: printToolsFilter: failed to find print tools initialization`),null;let o=a[1],s=a[2],c=a[3],l=a[4],u=`let ${o}=${s}(${c});const __tpts=${r},__tptf=(t,s)=>{const n=s.toolset??${i};globalThis.__tweakcc_toolset={name:n,tools:__tpts[n]};if(__tpts.hasOwnProperty(n)){const a=__tpts[n];if(a==="*")return t;return t.filter(d=>a.includes(d.name))}return t};${o}=__tptf(${o},${c});`,d=e.slice(0,a.index)+u+e.slice(a.index+a[0].length);F(e,d,u,a.index,a.index+a[0].length);let f=RegExp(`refreshTools:\\(\\)=>${s.replace(/\$/g,`\\$`)}\\(${l.replace(/\$/g,`\\$`)}\\(\\)\\)`),p=d.match(f);if(!p||p.index===void 0)return console.error(`patch: toolsets: printToolsFilter: failed to find print refreshTools`),null;let m=`refreshTools:()=>{let s=${l}();return __tptf(${s}(s),s)}`,h=d;return d=d.slice(0,p.index)+m+d.slice(p.index+p[0].length),F(h,d,m,p.index,p.index+p[0].length),d},In=(e,t,n)=>{let r=/`<tool_use_error>Error: No such tool available: \$\{([$\w.]+)\}(?:\$\{([$\w.]+)\})?<\/tool_use_error>`/g,i=e,a=0,o=`__tweakcc_toolErrorMsg`,s=`function ${o}(toolName,hint){hint=hint||"";var info=globalThis.__tweakcc_toolset;if(info&&info.tools&&info.tools!=="*"&&Array.isArray(info.tools)){return "<tool_use_error>Error: No such tool available: "+toolName+hint+". The active toolset is '"+info.name+"' which only includes: "+info.tools.join(", ")+". Do not attempt to use "+toolName+" again — it will fail. If the user switches toolsets via /toolset, you may retry.</tool_use_error>"}return "<tool_use_error>Error: No such tool available: "+toolName+hint+"</tool_use_error>"};`;if(i=i.replace(r,(e,t,n)=>(a++,n?`${o}(${t},${n})`:`${o}(${t})`)),a===0)return console.error(`patch: toolsets: toolsetAwareErrors: failed to find error pattern`),null;i=i.replace(/`Error: No such tool available: \$\{([$\w.]+)\}(?:\$\{([$\w.]+)\})?`/g,(e,t,n)=>`${n?`${o}(${t},${n})`:`${o}(${t})`}.replace(/<\\/?tool_use_error>/g,"")`);let c=i.indexOf(`
|
|
396
|
+
`,i.indexOf(`// Version:`));return c===-1?(console.error(`patch: toolsets: toolsetAwareErrors: failed to find insertion point for helper`),null):(i=i.slice(0,c+1)+s+i.slice(c+1),i)},Ln=(e,t,n)=>{let r=jn(e);if(r===null)return console.error(`patch: toolsets: failed to find slash command insertion point`),null;let i=V(e);if(!i)return console.error(`patch: toolsets: failed to find React variable`),null;let a=Vi(e);if(!a)return console.error(`patch: toolsets: failed to find Box component`),null;let o=zi(e);if(!o)return console.error(`patch: toolsets: failed to find Text component`),null;let s=kn(e);if(!s)return console.error(`patch: toolsets: failed to find Select component`),null;let c=An(e),l=L(e);if(!l)return console.error(`patch: toolsets: failed to find app state getter`),null;let u=R(e);if(!u)return console.error(`patch: toolsets: failed to find chalk variable`),null;let{appStateUseSelectorFn:d,appStateSetState:f}=l,p=JSON.stringify(t.map(e=>e.name)),m=JSON.stringify(t.map(e=>({label:e.name,value:e.name,description:e.allowedTools===`*`?`All tools`:e.allowedTools.length===0?`No tools`:`${e.allowedTools.length} tool${e.allowedTools.length===1?``:`s`}: ${e.allowedTools.join(`, `)}`}))),h=`const toolsetComp = ({ onExit, input }) => {
|
|
397
397
|
const currentToolset = ${d}(state => state.toolset) ?? ${n?JSON.stringify(n):`undefined`};
|
|
398
398
|
|
|
399
399
|
const setState = ${f}();
|
|
@@ -459,7 +459,7 @@ if (toolsets.hasOwnProperty(currentToolset)) {
|
|
|
459
459
|
${i}.createElement(${o}, { dimColor: true, italic: true }, "Enter to confirm · Esc to exit")
|
|
460
460
|
)
|
|
461
461
|
);
|
|
462
|
-
};`,g=e.slice(0,r)+h+e.slice(r);return F(e,g,h,r,r),g},
|
|
462
|
+
};`,g=e.slice(0,r)+h+e.slice(r);return F(e,g,h,r,r),g},Rn=e=>{let t=e.match(/\{color:"bashBorder"\},"! for (?:bash|shell) mode"/);if(!t||t.index===void 0)return console.error(`patch: toolsets: findShiftTabAppStateVarInsertionPoint: failed to find bash mode pattern`),null;let n=Math.max(0,t.index-1e4),r=e.slice(n,t.index),i=Array.from(r.matchAll(/function ([$\w]+)\((?:\{[^}]+\}|[$\w]+)\)\{/g));if(i.length===0)return console.error(`patch: toolsets: findShiftTabAppStateVarInsertionPoint: failed to find function pattern`),null;let a=i[i.length-1];return a.index===void 0?(console.error(`patch: toolsets: findShiftTabAppStateVarInsertionPoint: match has no index`),null):n+a.index+a[0].length},zn=(e,t)=>{let n=Rn(e);if(n===null)return console.error(`patch: toolsets: insertShiftTabAppStateVar: failed to find insertion point`),null;let r=L(e);if(!r)return console.error(`patch: toolsets: insertShiftTabAppStateVar: failed to find app state getter`),null;let{appStateUseSelectorFn:i}=r,a=`let currentToolset=${i}(state => state.toolset) ?? ${t?JSON.stringify(t):`undefined`};`,o=e.slice(0,n)+a+e.slice(n);return F(e,o,a,n,n),o},Bn=e=>{let t=e.match(/([$\w]+)\(([$\w]+)\)\.toLowerCase\(\)," on"/);if(!t||t.index===void 0)return console.error(`patch: toolsets: appendToolsetToModeDisplay: failed to find mode display pattern`),null;let n=t[1],r=t[2],i=t[0],a=`${n}(${r}).toLowerCase(),currentToolset?\` on [\${currentToolset}]\`:""`,o=e.replace(i,a);return o===e?(console.error(`patch: toolsets: appendToolsetToModeDisplay: failed to modify mode display`),null):(F(e,o,a,t.index,t.index+i.length),o)},Vn=e=>{let t=Array.from(e.matchAll(/"\? for shortcuts"/g)).at(-1);if(!t||t.index===void 0)return console.error(`patch: toolsets: appendToolsetToShortcutsDisplay: could not find '? for shortcuts'`),null;let n=t[0],r='currentToolset?`? for shortcuts [${currentToolset}]`:"? for shortcuts"',i=e.replace(n,r);return i===e?(console.error(`patch: toolsets: appendToolsetToShortcutsDisplay: failed to modify shortcuts display`),null):(F(e,i,r,t.index,t.index+n.length),i)},Hn=e=>{let t=V(e);return t?On(e,`, {
|
|
463
463
|
aliases: ["change-tools"],
|
|
464
464
|
type: "local-jsx",
|
|
465
465
|
name: "toolset",
|
|
@@ -473,10 +473,10 @@ if (toolsets.hasOwnProperty(currentToolset)) {
|
|
|
473
473
|
userFacingName() {
|
|
474
474
|
return "toolset";
|
|
475
475
|
}
|
|
476
|
-
}`):(console.error(`patch: toolsets: failed to find React variable`),null)},
|
|
477
|
-
middle: ["|", "-", "|", "|"],bottom: ["", "", "", ""]`),n!==e&&(r++,
|
|
476
|
+
}`):(console.error(`patch: toolsets: failed to find React variable`),null)},Un=e=>{let t=e.match(/[\w$]+\([\w$]+,function\([\w$]+\)\{[\w$]+\("tengu_ext_at_mentioned",\{\}\);/);return!t||t.index===void 0?(console.error(`patch: findToolChangeComponentScope: failed to find tool change component scope`),null):t.index},Wn=(e,t)=>{let n=Un(e);if(n===null)return null;let r=L(e);if(!r)return console.error(`patch: addCurrentToolsetAtToolChangeComponentScope: failed to get app state getter function`),null;let{appStateUseSelectorFn:i}=r,a=`const currentToolset = ${i}(state => state.toolset) ?? ${t?JSON.stringify(t):`undefined`};`,o=e.slice(0,n)+a+e.slice(n);return F(e,o,a,n,n),o},Gn=e=>{let t=e.match(/if\(([$\w]+)\(\([$\w]+\)=>\(\{\.\.\.[$\w]+,toolPermissionContext.{0,200}?mode:([$\w]+)/);return!t||t.index===void 0?(console.error(`patch: findModeChange: failed to find mode change location`),null):{index:t.index,modeVar:t[2],setStateVar:t[1]}},Kn=(e,t,n)=>{let r=Gn(e);if(!r)return null;let{index:i,modeVar:a,setStateVar:o}=r,s=`if(${a}==="plan"){${o}((prev)=>({...prev,toolset:${JSON.stringify(t)}}));}else{${o}((prev)=>({...prev,toolset:${JSON.stringify(n)}}));}`,c=e.slice(0,i)+s+e.slice(i);return F(e,c,s,i,i),c},qn=(e,t,n,r)=>{if(!t||t.length===0)return e;let i=e;if(i=Mn(i,n),!i)return console.error(`patch: toolsets: step 1 failed (writeToolsetFieldToAppState)`),null;if(i=Nn(i,t,n),!i)return console.error(`patch: toolsets: step 2 failed (writeToolFetchingUseMemo)`),null;if(i=Pn(i,t,n),!i)return console.error(`patch: toolsets: step 2b failed (writeComputeToolsFilter)`),null;if(i=Fn(i,t,n),!i)return console.error(`patch: toolsets: step 2c failed (writePrintToolsFilter)`),null;let a=In(i,t,n);if(a?i=a:console.error(`patch: toolsets: step 2d failed (writeToolsetAwareErrors) — continuing without friendlier errors`),i=Ln(i,t,n),!i)return console.error(`patch: toolsets: step 3 failed (writeToolsetComponentDefinition)`),null;if(i=Hn(i),!i)return console.error(`patch: toolsets: step 4 failed (writeSlashCommandDefinition)`),null;if(i=zn(i,n),!i)return console.error(`patch: toolsets: step 5 failed (insertShiftTabAppStateVar)`),null;if(i=Bn(i),!i)return console.error(`patch: toolsets: step 6 failed (appendToolsetToModeDisplay)`),null;if(i=Vn(i),!i)return console.error(`patch: toolsets: step 7 failed (appendToolsetToShortcutsDisplay)`),null;if(r&&n){if(i=Wn(i,n),!i)return console.error(`patch: toolsets: step 8a failed (addCurrentToolsetAtToolChangeComponentScope)`),null;if(i=Kn(i,r,n),!i)return console.error(`patch: toolsets: step 8b failed (writeModeChangeUpdateToolset)`),null}return i},Jn=/\{top:\["┌","─","┬","┐"\],middle:\["├","─","┼","┤"\],bottom:\["└","─","┴","┘"\]\}/,Yn=/top:\["\\u250C","\\u2500","\\u252C","\\u2510"\],middle:\["\\u251C","\\u2500","\\u253C","\\u2524"\],bottom:\["\\u2514","\\u2500","\\u2534","\\u2518"\]/,Xn=/top: \["┌", "─", "┬", "┐"\],\s+middle: \["├", "─", "┼", "┤"\],\s+bottom: \["└", "─", "┴", "┘"\]/,Zn=/if\(([$\w]+)\.push\(\.\.\.([$\w]+)\(([$\w]+),!1\)\),([$\w]+)<([$\w]+)\.rows\.length-1\)([$\w]+)\.push\(([$\w]+)\("middle"\)\)/g,Qn=/if\s*\(\s*\(\s*([$\w]+)\.push\(\.\.\.([$\w]+)\(([$\w]+)\s*,\s*!1\)\)\s*,\s*([$\w]+)\s*<\s*([$\w]+)\.rows\.length\s*-\s*1\s*\)\s*\)\s*([$\w]+)\.push\(([$\w]+)\("middle"\)\)\s*;?/g,$n=/([$\w]+)\.push\(([$\w]+)\("top"\)\),/g,er=/,([$\w]+)\.push\(([$\w]+)\("bottom"\)\),/g,tr=/([$\w]+)\.push\(\s*([$\w]+)\(\s*"top"\s*\)\s*\)\s*,\s*/g,nr=/,\s*([$\w]+)\.push\(\s*([$\w]+)\(\s*"bottom"\s*\)\s*\)\s*,/g;function rr(e){let t=e,n=!1,r=t;t=t.replace(Zn,`$1.push(...$2($3,!1))`),t!==r&&(n=!0);let i=t;return t=t.replace(Qn,`$1.push(...$2($3,!1))`),t!==i&&(n=!0),{result:t,success:n}}function ir(e){let t=e,n=!1,r=t;t=t.replace($n,``),t!==r&&(n=!0);let i=t;t=t.replace(tr,``),t!==i&&(n=!0);let a=t;t=t.replace(er,`,`),t!==a&&(n=!0);let o=t;return t=t.replace(nr,`,`),t!==o&&(n=!0),{result:t,success:n}}const ar=(e,t)=>{if(t===`markdown`&&(t=`ascii`),t===`default`)return W(`Table format is "default", no patching needed`),null;let n=e,r=0;if(t===`ascii`){if(Jn.test(n)){let e=n;n=n.replace(Jn,`{top:["","","",""],middle:["|","-","|","|"],bottom:["","","",""]}`),n!==e&&(r++,W(`Patched table border definition object (minified format)`))}else if(Yn.test(n)){let e=n;n=n.replace(Yn,`top:["","","",""],middle:["|","-","|","|"],bottom:["","","",""]`),n!==e&&(r++,W(`Patched table border definition object (native Unicode format)`))}else if(Xn.test(n)){let e=n;n=n.replace(Xn,`top: ["", "", "", ""],
|
|
477
|
+
middle: ["|", "-", "|", "|"],bottom: ["", "", "", ""]`),n!==e&&(r++,W(`Patched table border definition object (spaced format)`))}else G(`Could not find table border definition pattern - CLI may have changed`);{let e=n,t=n.match(/function [$\w]+\([^)]*\)\{[\s\S]{0,1600}?let ([$\w]+)="(?:\\u2502|│)";[\s\S]{0,1600}?\1\+=" "\+[$\w]+\+" (?:\\u2502|│)"/);if(t&&t.index!==void 0){let e=t.index,r=e+t[0].length,i=n.slice(e,r).replace(/" \\u2502"/g,`" |"`).replace(/" │"/g,`" |"`);n=n.slice(0,e)+i+n.slice(r)}n!==e&&(r++,W(`Patched compact table vertical separators`))}{let e=n;n=n.replace(/"─"\.repeat\(/g,`"-".repeat(`),n=n.replace(/"\\u2500"\.repeat\(/g,`"-".repeat(`),n!==e&&(r++,W(`Patched horizontal separator characters`))}{let{result:e,success:t}=rr(n);t&&(n=e,r++,W(`Removed inter-row separators`))}{let{result:e,success:t}=ir(n);t&&(n=e,r++,W(`Removed top/bottom border pushes`))}}else if(t===`clean`){if(Jn.test(n)){let e=n;n=n.replace(Jn,`{top:["","","",""],middle:["├","─","┼","┤"],bottom:["","","",""]}`),n!==e&&(r++,W(`Patched table border definition for clean format (minified format)`))}else if(Yn.test(n)){let e=n;n=n.replace(Yn,`top:["","","",""],middle:["\\u251C","\\u2500","\\u253C","\\u2524"],bottom:["","","",""]`),n!==e&&(r++,W(`Patched table border definition for clean format (native Unicode format)`))}else if(Xn.test(n)){let e=n;n=n.replace(Xn,`top: ["", "", "", ""],
|
|
478
478
|
middle: ["├", "─", "┼", "┤"],
|
|
479
|
-
bottom: ["", "", "", ""]`),n!==e&&(r++,
|
|
479
|
+
bottom: ["", "", "", ""]`),n!==e&&(r++,W(`Patched table border definition for clean format (spaced format)`))}else G(`Could not find table border definition pattern - CLI may have changed`);{let{result:e,success:t}=rr(n);t&&(n=e,r++,W(`Removed inter-row separators`))}{let{result:e,success:t}=ir(n);t&&(n=e,r++,W(`Removed top/bottom border pushes`))}}else if(t===`clean-top-bottom`){let{result:e,success:t}=rr(n);t&&(n=e,r++,W(`Removed inter-row separators (keeping top/bottom borders)`))}else return console.error(`patch: tableFormat: failed to find handler for unknown format "${t}"`),W(`Unknown table format "${t}", skipping`),null;if(r===0)return console.error(`patch: tableFormat: failed to find any table-rendering patterns to patch for format "${t}" (border-definition object, vertical-border chars, horizontal separator, or inter-row separator)`),G(`No table format patches were applied - patterns may not have matched`),null;W(`[Table format patch: ${r} modifications for ${t} style]`);let i=or(e,n);if(i!==-1){let{oldEnd:t,newEnd:r}=sr(e,n,i),a=n.slice(i,r);F(e,n,a,i,t)}return W(`Table format patch applied: ${r} changes, file size ${e.length} -> ${n.length}`),n};function or(e,t){let n=Math.min(e.length,t.length);for(let r=0;r<n;r++)if(e[r]!==t[r])return r;return e.length===t.length?-1:n}function sr(e,t,n){let r=e.length-1,i=t.length-1;for(;r>=n&&i>=n&&e[r]===t[i];)r--,i--;return{oldEnd:r+1,newEnd:i+1}}const cr=e=>V(e)?On(e,`, {
|
|
480
480
|
type: "local",
|
|
481
481
|
name: "title",
|
|
482
482
|
description: "Set the conversation title",
|
|
@@ -495,7 +495,7 @@ if (toolsets.hasOwnProperty(currentToolset)) {
|
|
|
495
495
|
userFacingName() {
|
|
496
496
|
return "title";
|
|
497
497
|
},
|
|
498
|
-
}`):(console.error(`patch: conversationTitle: failed to find React variable`),null),
|
|
498
|
+
}`):(console.error(`patch: conversationTitle: failed to find React variable`),null),lr=e=>{let t=e.match(/class ([$\w]+)\{summaries;(?:customTitles;)?messages;(?:checkpoints;)?fileHistorySnapshots;/);return!t||t.index===void 0?(console.error(`patch: conversationTitle: findCustomNamingFunctionsLocation: failed to find class pattern`),null):t.index},ur=e=>{let t=lr(e);if(t===null)return console.error(`patch: conversationTitle: failed to find custom naming functions location`),null;let n=Ii(e),r=`
|
|
499
499
|
function getTweakccBaseDir() {
|
|
500
500
|
const { join: pathJoin } = ${n}('path');
|
|
501
501
|
const { homedir: osHomedir } = ${n}('os');
|
|
@@ -669,11 +669,11 @@ function onNewMessage(projectDir, projectSlug, msg) {
|
|
|
669
669
|
}
|
|
670
670
|
}
|
|
671
671
|
|
|
672
|
-
`,i=e.slice(0,t)+r+e.slice(t);return F(e,i,r,t,t),i},
|
|
672
|
+
`,i=e.slice(0,t)+r+e.slice(t);return F(e,i,r,t,t),i},dr=e=>{let t=e.match(/(if\(![$\w]+\.has\(([$\w]+)\.uuid\)\)\{)if\([$\w]+\.appendFileSync\(/);return!t||t.index===void 0?(console.error(`patch: conversationTitle: findAppendEntryInterceptorLocation: failed to find pattern`),null):{location:t.index+t[1].length,messageVar:t[2]}},fr=e=>{let t=dr(e);if(!t)return console.error(`patch: conversationTitle: failed to find append entry interceptor location`),null;let n=Ii(e),{location:r,messageVar:i}=t,a=`const { dirname: pathDirname, basename: pathBasename } = ${n}('path');
|
|
673
673
|
const projectDir = pathDirname(this.sessionFile);
|
|
674
674
|
const projectSlug = pathBasename(projectDir);
|
|
675
675
|
onNewMessage(projectDir, projectSlug, ${i});
|
|
676
|
-
`,o=e.slice(0,r)+a+e.slice(r);return F(e,o,a,r,r),o},
|
|
676
|
+
`,o=e.slice(0,r)+a+e.slice(r);return F(e,o,a,r,r),o},pr=e=>{let t=e.match(/if\([$\w]+\.has\(([$\w]+)\.uuid\)\)continue;/);if(!t||t.index===void 0)return console.error(`patch: conversationTitle: findTweakccSummaryCheckLocations: failed to find continue pattern`),null;let n=t[1],r=t.index+t[0].length-10,i=Math.max(0,t.index-200),a=e.substring(i,t.index).match(/for\(let [$\w]+ of ([$\w]+)\)try/);if(!a)return console.error(`patch: conversationTitle: findTweakccSummaryCheckLocations: failed to find loop pattern`),null;let o=a[1];return{orLocation:r,loopLocation:i+(a.index??0),messageVar:n,fileListVar:o}},mr=e=>{let t=pr(e);if(!t)return console.error(`patch: conversationTitle: failed to find tweakcc summary check locations`),null;let n=Ii(e),{orLocation:r,loopLocation:i,messageVar:a,fileListVar:o}=t,s=e,c=`const { readFileSync: fsReadFileSync } = ${n}('fs');
|
|
677
677
|
const tweakccSummaries = new Set();
|
|
678
678
|
for (const file of ${o}) {
|
|
679
679
|
const contents = fsReadFileSync(file, "utf8").trim();
|
|
@@ -688,7 +688,7 @@ for (const file of ${o}) {
|
|
|
688
688
|
if (obj.type != "summary" || !obj.hasOwnProperty("tweakcc")) continue;
|
|
689
689
|
tweakccSummaries.add(obj.leafUuid);
|
|
690
690
|
}
|
|
691
|
-
`;s=s.slice(0,i)+c+s.slice(i),F(e,s,c,i,i);let l=r+c.length,u=`||tweakccSummaries.has(${a}.uuid)`,d=s.slice(0,l)+u+s.slice(l);return F(s,d,u,l,l),d},mr=e=>{let t=e.match(/description:"Rename the current conversation",isEnabled:\(\)=>!1,/);if(!t)return console.error(`patch: conversationTitle: enableRenameConversationCommand: failed to find pattern`),null;if(t.index===void 0)return console.error(`patch: conversationTitle: enableRenameConversationCommand: match.index is undefined`),null;let n=`description:"Rename the current conversation",isEnabled:()=>!0,`,r=e.replace(`description:"Rename the current conversation",isEnabled:()=>!1,`,n);return r===e?(console.error(`patch: conversationTitle: enableRenameConversationCommand: replacement failed`),null):(F(e,r,n,t.index,t.index+63),r)},hr=e=>{let t=/(([$\w]+)=[$\w]+\(\(\)=>\[)/g,n=null;for(let r of e.matchAll(t)){let t=e.slice(Math.max(0,r.index-12e3),Math.min(e.length,r.index+12e3));if(/name:"[^"]+"[\s\S]{0,1200}description:/.test(t)){n=r;break}}if(!n||n.index===void 0)return null;let r=e.match(/var ([$\w]+)=\{\};[$\w]+\(\1,\{performSetColor:\(\)=>[$\w]+,call:\(\)=>[$\w]+\}\);async function [$\w]+\(([$\w]+),([$\w]+),([$\w]+)\)\{return \2\(await [$\w]+\(\4,\3\),\{display:"system"\}\),null\}/);if(!r||r.index===void 0)return console.error(`patch: conversationTitle: failed to find local command module anchor`),null;let i=e.indexOf(`var `,r.index+r[0].length);if(i===-1)return console.error(`patch: conversationTitle: failed to find local command module end`),null;let a=`var tweakccTitleModule={};${r[0].match(/;([$\w]+)\(/)?.[1]??`P$`}(tweakccTitleModule,{call:()=>tweakccTitleCall});async function tweakccTitleCall(args,context){let title=args?.trim?.()??"";if(!title)return{type:"text",value:"Please specify a conversation title."};context.setAppState?.((state)=>({...state,customTitle:title}));process.env.CLAUDE_CODE_DISABLE_TERMINAL_TITLE="1";if(process.platform==="win32")process.title="Claude: "+title;else process.stdout.write("\\x1B]0;Claude: "+title+"\\x07");let message="Conversation title set to "+title;if(context.options?.isNonInteractiveSession){process.stdout.write(message+"\\n");return{type:"skip"}}return{type:"text",value:message}}`,o=`tweakccTitleCommand={type:"local",name:"title",description:"Set the conversation title",argumentHint:"<title>",supportsNonInteractive:!0,userFacingName(){return"title"},load:()=>Promise.resolve(tweakccTitleModule)},`,s=e.slice(0,i)+a+e.slice(i),c=n.index+n[1].length+(n.index>=i?a.length:0);return s=s.slice(0,c)+o+s.slice(c),F(e,s,a+o,i,i),s},gr=e=>{let t=hr(e);if(t)return t;let n=e;if(n=sr(n),!n)return console.error(`patch: conversationTitle: step 1 failed (writeTitleSlashCommand)`),null;if(n=lr(n),!n)return console.error(`patch: conversationTitle: step 2 failed (writeCustomNamingFunctions)`),null;if(n=dr(n),!n)return console.error(`patch: conversationTitle: step 3 failed (writeAppendEntryInterceptor)`),null;if(n=pr(n),!n)return console.error(`patch: conversationTitle: step 4 failed (writeTweakccSummaryCheck)`),null;let r=mr(n);return r?n=r:console.log(`patch: conversationTitle: step 5 failed (enableRenameConversationCommand)`),n},_r=e=>{let t=e.match(/,[$\w]+\.createElement\([$\w]+,\{isBeforeFirstMessage:!1\}\),/);return t&&t.index!==void 0?{startIndex:t.index,endIndex:t.index+t[0].length}:null},vr=e=>{let t=_r(e);if(t){let n=e.slice(0,t.startIndex)+`,`+e.slice(t.endIndex);return F(e,n,`,`,t.startIndex,t.endIndex),n}for(let t of[/(function [$\w]+\(\)\{)(?=let [$\w]+=[\w$]+\.c\(\d+\),[$\w]+=[\w$]+\(\)\.oauthAccount\?\.displayName\?\?""|let [$\w]+=[\w$]+\(\),[$\w]+=[\w$]+\?\.displayName\?\?"")/,/(function [$\w]+\(\)\{)(?=let [$\w]+=[\w$]+\.c\(\d+\),[$\w]+=[\w$]+\(\),[$\w]+=[\w$]+\?\.displayName\?\?"")/]){let n=e.match(t);if(n&&n.index!==void 0){let t=n.index+n[1].length,r=`return null;`,i=e.slice(0,t)+r+e.slice(t);return F(e,i,r,t,t),i}}let n=/(function ([$\w]+)\(\)\{)(?=[^}]{0,500}Apple_Terminal)/g,r;for(;(r=n.exec(e))!==null;){let t=r.index+r[0].length;if(e.slice(t,t+5e3).includes(`Welcome to Claude Code`)){let n=t,r=`return null;`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i}}return console.error(`patch: hideStartupBanner: failed to find startup banner component`),null},yr=e=>{let t=e.match(/if\(([$\w]+&&[$\w]+)\)[$\w]+\("tengu_external_editor_hint_shown",/);if(!t||t.index===void 0)return console.error(`patch: hideCtrlGToEdit: failed to find tengu_external_editor_hint_shown pattern`),null;let n=t[1],r=t.index+3;return{startIndex:r,endIndex:r+n.length,identifiers:[]}},br=e=>{let t=yr(e);if(!t)return null;let n=`false`,r=e.slice(0,t.startIndex)+n+e.slice(t.endIndex);return F(e,r,n,t.startIndex,t.endIndex),r},xr=e=>{let t=[],n=/▛███▜|\\u259B\\u2588\\u2588\\u2588\\u259C/gi.exec(e);if(!n)return t;let r=n.index,i=Math.max(0,r-2e3),a=e.slice(i,r),o=/function ([$\w]+)\([^)]*\)\{/g,s=null,c;for(;(c=o.exec(a))!==null;)s=c;if(!s)return console.error(`patch: hideStartupClawd: failed to find inner Clawd function`),t;let l=s[1],u=/function ([$\w]+)\([^)]*\)\{/g,d,f=null;for(;(d=u.exec(e))!==null;){let t=d.index+d[0].length,n=e.slice(t,t+500),r=n.indexOf(`createElement(${l},`);if(r===-1)continue;let i=n.indexOf(`function `);if(!(i!==-1&&i<r)){f={index:d.index,length:d[0].length};break}}if(f){let e=f.index+f.length;t.push(e)}else{let e=i+s.index+s[0].length;t.push(e)}return t},Sr=e=>{let t=xr(e);if(t.length===0)return console.error(`patch: hideStartupClawd: no Clawd components found`),null;let n=[...t].sort((e,t)=>t-e),r=`return null;`,i=e;for(let e of n)i=i.slice(0,e)+r+i.slice(e);if(n.length>0){let t=n[n.length-1];F(e,i,r,t,t)}return i},Cr=e=>{let t=e.match(/CLAUDE_CODE_FILE_READ_MAX_OUTPUT_TOKENS[\s\S]{0,1200}tengu_amber_wren/);if(t&&t.index!==void 0){let e=t[0].match(/=25000,/);if(e&&e.index!==void 0){let n=t.index+e.index+1;return{startIndex:n,endIndex:n+5}}}let n=[`<system-reminder>`,`tengu_amber_wren`],r=null;for(let t of n){let n=t.replace(/[.*+?^${}()|[\]\\]/g,`\\$&`),i=RegExp(`=25000,([\\s\\S]{0,700})${n}`);if(r=e.match(i),r&&r.index!==void 0)break}if(!r||r.index===void 0)return console.error(`patch: increaseFileReadLimit: failed to find 25000 token limit near known anchor`),null;let i=r.index+1;return{startIndex:i,endIndex:i+5}},wr=e=>{let t=Cr(e);if(!t)return null;let n=`1000000`,r=e.slice(0,t.startIndex)+n+e.slice(t.endIndex);return F(e,r,n,t.startIndex,t.endIndex),r},Tr=e=>{let t=e;for(let[n,r]of[[/"- Results are returned using cat -n format, with line numbers starting at 1"/g,`"- Results are returned as raw file content without line-number prefixes"`],[/`\$\{[$\w]+\}\. Each line is the line number, a single separator \(a tab or `:`\), then the verbatim file content \(including any leading whitespace\)\.`/g,"`Results are raw file content without line-number prefixes.`"]]){let i=t;t=t.replace(n,r),t!==i&&F(e,t,r,0,0)}return t},Er=e=>{let t=e.match(/\{content:([$\w]+),startLine:[$\w]+(?:,tabAwareSeparator:[$\w]+=!1)?\}\)\{if\(!\1\)return"";/);if(t&&t.index!==void 0){let n=t[1],r=t.index+t[0].length,i=e.slice(r).match(/\}(?=function |var |let |const |[$\w]+=[$\w]+\()/);if(i&&i.index!==void 0){let t=r+i.index,a=`return ${n}`,o=e.slice(0,r)+a+e.slice(t);F(e,o,a,r,t);let s=o.match(/function ([$\w]+)\(([$\w]+),[$\w]+,[$\w]+\)\{let [$\w]+=\2\.endsWith\("\\r"\)\?\2\.slice\(0,-1\):\2;return`\$\{[$\w]+\}\$\{[$\w]+\}\$\{[$\w]+\}`\}/);if(s&&s.index!==void 0){let e=`function ${s[1]}(${s[2]}){return ${s[2]}.endsWith("\\r")?${s[2]}.slice(0,-1):${s[2]}}`,t=o;o=o.slice(0,s.index)+e+o.slice(s.index+s[0].length),F(t,o,e,s.index,s.index+s[0].length)}return o=Tr(o),o}}let n=e.match(/if\(([$\w]+)\.length>=\d+\)return`\$\{\1\}(?:→|\\u2192)\$\{([$\w]+)\}`;return`\$\{\1\.padStart\(\d+," "\)\}(?:→|\\u2192)\$\{\2\}`/);if(n&&n.index!==void 0){let t=`return ${n[2]}`,r=e.slice(0,n.index)+t+e.slice(n.index+n[0].length);return F(e,r,t,n.index,n.index+n[0].length),r}return console.error(`patch: suppressLineNumbers: failed to find line number formatter pattern`),null},Dr=e=>{let t=[/\.createElement.{0,500},showAllInTranscript:[$\w]+,agentDefinitions:[$\w]+,onOpenRateLimitOptions:([$\w]+)/g,/\.createElement\([\w$]+,\{messages:[\w$]+,tools:[\w$]+,commands:[\w$]+,verbose:!0,toolJSX:null,inProgressToolUseIDs:[\w$]+,isMessageSelectorVisible:!1,conversationId:[\w$]+,screen:[\w$]+,agentDefinitions:[\w$]+,streamingToolUses:[\w$]+,showAllInTranscript:[\w$]+,onOpenRateLimitOptions:([\w$]+)/g],n=e,r=0;for(let e of t){let t=[...n.matchAll(e)];for(let e of t.reverse()){if(e.index===void 0)continue;let t=e[1],i=e.index+e[0].length-t.length,a=i+t.length,o=`()=>{}`,s=n.slice(0,i)+o+n.slice(a);F(n,s,o,i,a),n=s,r++}}return r===0?(console.error(`patch: suppressRateLimitOptions: failed to find onOpenRateLimitOptions pattern`),null):n},Or=e=>{if(!e.includes(`"tengu_session_memory"`))return U(`patch: sessionMemory: extraction gate already removed in this CC build — no-op`),e;let t=e.match(/function [$\w]+\(\)\{return [$\w]+\("tengu_session_memory"/);if(t&&t.index!==void 0){let n=t.index+t[0].indexOf(`{`)+1,r=`return true;`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i}let n=e.indexOf(`querySource:"extract_memories",forkLabel:"extract_memories"`);if(n!==-1){let t=Math.min(e.length,n+8e3),r=e.slice(n,t).match(/if\(![$\w]+\("tengu_passport_quail",!1\)\)return;/);if(r&&r.index!==void 0){let t=n+r.index,i=t+r[0].length,a=e.slice(0,t)+e.slice(i);return F(e,a,``,t,i),a}}return console.error(`patch: sessionMemory: failed to find extraction gate`),null},kr=e=>{if(!e.includes(`"tengu_coral_fern"`))return U(`patch: sessionMemory: past-sessions gate already removed in this CC build — no-op`),e;let t=e.match(/if\([$\w]+\("tengu_coral_fern",!1\)\)\{/);if(t&&t.index!==void 0){let n=`if(true){`,r=e.slice(0,t.index)+n+e.slice(t.index+t[0].length);return F(e,r,n,t.index,t.index+t[0].length),r}let n=e.match(/if\(![$\w]+\("tengu_coral_fern",!1\)\)return\s*(?:null|\[\]);/);if(n&&n.index!==void 0){let t=e.slice(0,n.index)+e.slice(n.index+n[0].length);return F(e,t,``,n.index,n.index+n[0].length),t}return e.includes(`tengu_session_search_toggled`)||e.includes(`tengu_session_all_projects_toggled`)?e:(console.error(`patch: sessionMemory: failed to find past sessions gate`),null)},Ar=(e,t=!0)=>{if(!e.includes(`# Session Title`))return U(`patch: sessionMemory: token-limit anchor removed in this CC build — no-op`),e;let n=e.match(/(=)2000((?:.|\n){0,15}?=)12000((?:.|\n){0,20}# Session Title)/);if(!n||n.index===void 0)return t&&console.error(`patch: sessionMemory: failed to find token limits pattern`),null;let r=n[1]+`Number(process.env.CC_SM_PER_SECTION_TOKENS??2000)`+n[2]+`Number(process.env.CM_SM_TOTAL_FILE_LIMIT??12000)`+n[3],i=n.index,a=i+n[0].length,o=e.slice(0,i)+r+e.slice(a);return F(e,o,r,i,a),o},jr=(e,t=!0)=>{if(!(e.includes(`minimumMessageTokensToInit`)||e.includes(`minimumTokensBetweenUpdate`)||e.includes(`toolCallsBetweenUpdates`)))return U(`patch: sessionMemory: update threshold props removed in this CC build — no-op`),e;let n=e;return n=I(n,/minimumMessageTokensToInit:1e4\b/g,`minimumMessageTokensToInit:Number(process.env.CC_SM_MINIMUM_MESSAGE_TOKENS_TO_INIT??1e4)`),n=I(n,/minimumTokensBetweenUpdate:5000\b/g,`minimumTokensBetweenUpdate:Number(process.env.CC_SM_MINIMUM_TOKENS_BETWEEN_UPDATE??5000)`),n=I(n,/toolCallsBetweenUpdates:3\b/g,`toolCallsBetweenUpdates:Number(process.env.CC_SM_TOOL_CALLS_BETWEEN_UPDATES??3)`),n===e?(t&&console.error(`patch: sessionMemory: failed to find update thresholds patterns`),null):n},Mr=e=>{let t=Or(e);if(!t)return null;let n=t.includes(`tengu_session_memory`),r=kr(t);if(!r)return null;t=r;let i=t.match(/(function [$\w]+\(\))\{if\(![$\w]+\("tengu_passport_quail",!1\)\)return!1;return![$\w]+\(\)\|\|[$\w]+\("tengu_slate_thimble",!1\)\}/);if(i&&i.index!==void 0){let e=`${i[1]}{return!0}`,n=t;t=t.slice(0,i.index)+e+t.slice(i.index+i[0].length),F(n,t,e,i.index,i.index+i[0].length)}let a=Ar(t,n);if(a)t=a;else if(n)return null;let o=jr(t,n);if(o)t=o;else if(n)return null;return t},Nr=e=>{if(!e.includes(`"tengu_onyx_plover"`))return U(`patch: dreamMode: availability gate already removed in this CC build — no-op`),e;let t=e.match(/function [$\w]+\(\)\{return [$\w]+\("tengu_onyx_plover",null\)\}function [$\w]+\(\)\{/);if(!t||t.index===void 0)return console.error(`patch: dreamMode: failed to find availability gate`),null;let n=t.index+t[0].length;if(e.startsWith(`return!0;`,n))return e;let r=`return!0;`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i},Pr=e=>{if(!e.includes(`"tengu_ochre_finch"`))return U(`patch: leanMemoryTypes: gate already promoted/removed in this CC build — no-op`),e;let t=e.match(/function [$\w]+\(\)\{(?:return!0;)?return [$\w]+\("tengu_ochre_finch",!1\)\}/);if(!t||t.index===void 0)return console.error(`patch: leanMemoryTypes: failed to find statsig gate`),null;let n=t.index+t[0].indexOf(`{`)+1;if(e.startsWith(`return!0;`,n))return e;let r=`return!0;`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i},Fr=e=>{let t=`[A-Za-z_$][\\w$]*`,n=[RegExp(`function\\s+(${t})\\((${t})\\)\\{let\\{files:(${t})\\}=\\2,`),/\{([A-Za-z_$][\w$]*)\(\{name:"claude-in-chrome"/];for(let t of n){let n=e.match(t);if(n)return n[1]}return console.error(`patch: rememberSkill: failed to find skill registration function`),null},Ir=(e,t)=>{let n=RegExp(`function\\s+[$\\w]+\\(\\)\\{${t}\\(\\{name:"update-config"`),r=e.match(n);if(!r||r.index===void 0)return null;let i=e.indexOf(`{`,r.index);if(i===-1)return null;let a=i+1,o=`${t}({name:"remember",description:"Review session memories and update CLAUDE.local.md with learnings from past sessions.",whenToUse:"When the user asks to remember something, save a learning, or review session memories.",userInvocable:!0,isEnabled:()=>!0,async getPromptForCommand(H){let $="# Remember Skill\\n\\nReview the current conversation and any relevant session memory files, then update CLAUDE.local.md with durable learnings that should carry forward to future sessions. Keep entries concise and actionable.";if(H&&H.trim())$+="\\n\\n## User Request\\n"+H.trim();return[{type:"text",text:$}]}});`,s=e.slice(0,a)+o+e.slice(a);return F(e,s,o,a,a),s},Lr=e=>{let t=Fr(e);if(!t)return null;let n=Ir(e,t);if(n)return n;let r=e.match(/(function ([$\w]+)\(.{0,500}\}function [$\w]+\(\)\{)return(\}.{0,10}[, ]([$\w]+)=`# Remember Skill)/);if(!r||r.index===void 0)return console.error(`patch: rememberSkill: failed to find injection point pattern`),null;let[i,a,o,s,c]=r,l=a+`
|
|
691
|
+
`;s=s.slice(0,i)+c+s.slice(i),F(e,s,c,i,i);let l=r+c.length,u=`||tweakccSummaries.has(${a}.uuid)`,d=s.slice(0,l)+u+s.slice(l);return F(s,d,u,l,l),d},hr=e=>{let t=e.match(/description:"Rename the current conversation",isEnabled:\(\)=>!1,/);if(!t)return console.error(`patch: conversationTitle: enableRenameConversationCommand: failed to find pattern`),null;if(t.index===void 0)return console.error(`patch: conversationTitle: enableRenameConversationCommand: match.index is undefined`),null;let n=`description:"Rename the current conversation",isEnabled:()=>!0,`,r=e.replace(`description:"Rename the current conversation",isEnabled:()=>!1,`,n);return r===e?(console.error(`patch: conversationTitle: enableRenameConversationCommand: replacement failed`),null):(F(e,r,n,t.index,t.index+63),r)},gr=e=>{let t=/(([$\w]+)=[$\w]+\(\(\)=>\[)/g,n=null;for(let r of e.matchAll(t)){let t=e.slice(Math.max(0,r.index-12e3),Math.min(e.length,r.index+12e3));if(/name:"[^"]+"[\s\S]{0,1200}description:/.test(t)){n=r;break}}if(!n||n.index===void 0)return null;let r=e.match(/var ([$\w]+)=\{\};[$\w]+\(\1,\{performSetColor:\(\)=>[$\w]+,call:\(\)=>[$\w]+\}\);async function [$\w]+\(([$\w]+),([$\w]+),([$\w]+)\)\{return \2\(await [$\w]+\(\4,\3\),\{display:"system"\}\),null\}/);if(!r||r.index===void 0)return console.error(`patch: conversationTitle: failed to find local command module anchor`),null;let i=e.indexOf(`var `,r.index+r[0].length);if(i===-1)return console.error(`patch: conversationTitle: failed to find local command module end`),null;let a=`var tweakccTitleModule={};${r[0].match(/;([$\w]+)\(/)?.[1]??`P$`}(tweakccTitleModule,{call:()=>tweakccTitleCall});async function tweakccTitleCall(args,context){let title=args?.trim?.()??"";if(!title)return{type:"text",value:"Please specify a conversation title."};context.setAppState?.((state)=>({...state,customTitle:title}));process.env.CLAUDE_CODE_DISABLE_TERMINAL_TITLE="1";if(process.platform==="win32")process.title="Claude: "+title;else process.stdout.write("\\x1B]0;Claude: "+title+"\\x07");let message="Conversation title set to "+title;if(context.options?.isNonInteractiveSession){process.stdout.write(message+"\\n");return{type:"skip"}}return{type:"text",value:message}}`,o=`tweakccTitleCommand={type:"local",name:"title",description:"Set the conversation title",argumentHint:"<title>",supportsNonInteractive:!0,userFacingName(){return"title"},load:()=>Promise.resolve(tweakccTitleModule)},`,s=e.slice(0,i)+a+e.slice(i),c=n.index+n[1].length+(n.index>=i?a.length:0);return s=s.slice(0,c)+o+s.slice(c),F(e,s,a+o,i,i),s},_r=e=>{let t=gr(e);if(t)return t;let n=e;if(n=cr(n),!n)return console.error(`patch: conversationTitle: step 1 failed (writeTitleSlashCommand)`),null;if(n=ur(n),!n)return console.error(`patch: conversationTitle: step 2 failed (writeCustomNamingFunctions)`),null;if(n=fr(n),!n)return console.error(`patch: conversationTitle: step 3 failed (writeAppendEntryInterceptor)`),null;if(n=mr(n),!n)return console.error(`patch: conversationTitle: step 4 failed (writeTweakccSummaryCheck)`),null;let r=hr(n);return r?n=r:console.log(`patch: conversationTitle: step 5 failed (enableRenameConversationCommand)`),n},vr=e=>{let t=e.match(/,[$\w]+\.createElement\([$\w]+,\{isBeforeFirstMessage:!1\}\),/);return t&&t.index!==void 0?{startIndex:t.index,endIndex:t.index+t[0].length}:null},yr=e=>{let t=vr(e);if(t){let n=e.slice(0,t.startIndex)+`,`+e.slice(t.endIndex);return F(e,n,`,`,t.startIndex,t.endIndex),n}for(let t of[/(function [$\w]+\(\)\{)(?=let [$\w]+=[\w$]+\.c\(\d+\),[$\w]+=[\w$]+\(\)\.oauthAccount\?\.displayName\?\?""|let [$\w]+=[\w$]+\(\),[$\w]+=[\w$]+\?\.displayName\?\?"")/,/(function [$\w]+\(\)\{)(?=let [$\w]+=[\w$]+\.c\(\d+\),[$\w]+=[\w$]+\(\),[$\w]+=[\w$]+\?\.displayName\?\?"")/]){let n=e.match(t);if(n&&n.index!==void 0){let t=n.index+n[1].length,r=`return null;`,i=e.slice(0,t)+r+e.slice(t);return F(e,i,r,t,t),i}}let n=/(function ([$\w]+)\(\)\{)(?=[^}]{0,500}Apple_Terminal)/g,r;for(;(r=n.exec(e))!==null;){let t=r.index+r[0].length;if(e.slice(t,t+5e3).includes(`Welcome to Claude Code`)){let n=t,r=`return null;`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i}}return console.error(`patch: hideStartupBanner: failed to find startup banner component`),null},br=e=>{let t=e.match(/if\(([$\w]+&&[$\w]+)\)[$\w]+\("tengu_external_editor_hint_shown",/);if(!t||t.index===void 0)return console.error(`patch: hideCtrlGToEdit: failed to find tengu_external_editor_hint_shown pattern`),null;let n=t[1],r=t.index+3;return{startIndex:r,endIndex:r+n.length,identifiers:[]}},xr=e=>{let t=br(e);if(!t)return null;let n=`false`,r=e.slice(0,t.startIndex)+n+e.slice(t.endIndex);return F(e,r,n,t.startIndex,t.endIndex),r},Sr=e=>{let t=[],n=/▛███▜|\\u259B\\u2588\\u2588\\u2588\\u259C/gi.exec(e);if(!n)return t;let r=n.index,i=Math.max(0,r-2e3),a=e.slice(i,r),o=/function ([$\w]+)\([^)]*\)\{/g,s=null,c;for(;(c=o.exec(a))!==null;)s=c;if(!s)return console.error(`patch: hideStartupClawd: failed to find inner Clawd function`),t;let l=s[1],u=/function ([$\w]+)\([^)]*\)\{/g,d,f=null;for(;(d=u.exec(e))!==null;){let t=d.index+d[0].length,n=e.slice(t,t+500),r=n.indexOf(`createElement(${l},`);if(r===-1)continue;let i=n.indexOf(`function `);if(!(i!==-1&&i<r)){f={index:d.index,length:d[0].length};break}}if(f){let e=f.index+f.length;t.push(e)}else{let e=i+s.index+s[0].length;t.push(e)}return t},Cr=e=>{let t=Sr(e);if(t.length===0)return console.error(`patch: hideStartupClawd: no Clawd components found`),null;let n=[...t].sort((e,t)=>t-e),r=`return null;`,i=e;for(let e of n)i=i.slice(0,e)+r+i.slice(e);if(n.length>0){let t=n[n.length-1];F(e,i,r,t,t)}return i},wr=e=>{let t=e.match(/CLAUDE_CODE_FILE_READ_MAX_OUTPUT_TOKENS[\s\S]{0,1200}tengu_amber_wren/);if(t&&t.index!==void 0){let e=t[0].match(/=25000,/);if(e&&e.index!==void 0){let n=t.index+e.index+1;return{startIndex:n,endIndex:n+5}}}let n=[`<system-reminder>`,`tengu_amber_wren`],r=null;for(let t of n){let n=t.replace(/[.*+?^${}()|[\]\\]/g,`\\$&`),i=RegExp(`=25000,([\\s\\S]{0,700})${n}`);if(r=e.match(i),r&&r.index!==void 0)break}if(!r||r.index===void 0)return console.error(`patch: increaseFileReadLimit: failed to find 25000 token limit near known anchor`),null;let i=r.index+1;return{startIndex:i,endIndex:i+5}},Tr=e=>{let t=wr(e);if(!t)return null;let n=`1000000`,r=e.slice(0,t.startIndex)+n+e.slice(t.endIndex);return F(e,r,n,t.startIndex,t.endIndex),r},Er=e=>{let t=e;for(let[n,r]of[[/"- Results are returned using cat -n format, with line numbers starting at 1"/g,`"- Results are returned as raw file content without line-number prefixes"`],[/`\$\{[$\w]+\}\. Each line is the line number, a single separator \(a tab or `:`\), then the verbatim file content \(including any leading whitespace\)\.`/g,"`Results are raw file content without line-number prefixes.`"]]){let i=t;t=t.replace(n,r),t!==i&&F(e,t,r,0,0)}return t},Dr=e=>{let t=e.match(/\{content:([$\w]+),startLine:[$\w]+(?:,tabAwareSeparator:[$\w]+=!1)?\}\)\{if\(!\1\)return"";/);if(t&&t.index!==void 0){let n=t[1],r=t.index+t[0].length,i=e.slice(r).match(/\}(?=function |var |let |const |[$\w]+=[$\w]+\()/);if(i&&i.index!==void 0){let t=r+i.index,a=`return ${n}`,o=e.slice(0,r)+a+e.slice(t);F(e,o,a,r,t);let s=o.match(/function ([$\w]+)\(([$\w]+),[$\w]+,[$\w]+\)\{let [$\w]+=\2\.endsWith\("\\r"\)\?\2\.slice\(0,-1\):\2;return`\$\{[$\w]+\}\$\{[$\w]+\}\$\{[$\w]+\}`\}/);if(s&&s.index!==void 0){let e=`function ${s[1]}(${s[2]}){return ${s[2]}.endsWith("\\r")?${s[2]}.slice(0,-1):${s[2]}}`,t=o;o=o.slice(0,s.index)+e+o.slice(s.index+s[0].length),F(t,o,e,s.index,s.index+s[0].length)}return o=Er(o),o}}let n=e.match(/if\(([$\w]+)\.length>=\d+\)return`\$\{\1\}(?:→|\\u2192)\$\{([$\w]+)\}`;return`\$\{\1\.padStart\(\d+," "\)\}(?:→|\\u2192)\$\{\2\}`/);if(n&&n.index!==void 0){let t=`return ${n[2]}`,r=e.slice(0,n.index)+t+e.slice(n.index+n[0].length);return F(e,r,t,n.index,n.index+n[0].length),r}return console.error(`patch: suppressLineNumbers: failed to find line number formatter pattern`),null},Or=e=>{let t=[/\.createElement.{0,500},showAllInTranscript:[$\w]+,agentDefinitions:[$\w]+,onOpenRateLimitOptions:([$\w]+)/g,/\.createElement\([\w$]+,\{messages:[\w$]+,tools:[\w$]+,commands:[\w$]+,verbose:!0,toolJSX:null,inProgressToolUseIDs:[\w$]+,isMessageSelectorVisible:!1,conversationId:[\w$]+,screen:[\w$]+,agentDefinitions:[\w$]+,streamingToolUses:[\w$]+,showAllInTranscript:[\w$]+,onOpenRateLimitOptions:([\w$]+)/g],n=e,r=0;for(let e of t){let t=[...n.matchAll(e)];for(let e of t.reverse()){if(e.index===void 0)continue;let t=e[1],i=e.index+e[0].length-t.length,a=i+t.length,o=`()=>{}`,s=n.slice(0,i)+o+n.slice(a);F(n,s,o,i,a),n=s,r++}}return r===0?(console.error(`patch: suppressRateLimitOptions: failed to find onOpenRateLimitOptions pattern`),null):n},kr=e=>{if(!e.includes(`"tengu_session_memory"`))return W(`patch: sessionMemory: extraction gate already removed in this CC build — no-op`),e;let t=e.match(/function [$\w]+\(\)\{return [$\w]+\("tengu_session_memory"/);if(t&&t.index!==void 0){let n=t.index+t[0].indexOf(`{`)+1,r=`return true;`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i}let n=e.indexOf(`querySource:"extract_memories",forkLabel:"extract_memories"`);if(n!==-1){let t=Math.min(e.length,n+8e3),r=e.slice(n,t).match(/if\(![$\w]+\("tengu_passport_quail",!1\)\)return;/);if(r&&r.index!==void 0){let t=n+r.index,i=t+r[0].length,a=e.slice(0,t)+e.slice(i);return F(e,a,``,t,i),a}}return console.error(`patch: sessionMemory: failed to find extraction gate`),null},Ar=e=>{if(!e.includes(`"tengu_coral_fern"`))return W(`patch: sessionMemory: past-sessions gate already removed in this CC build — no-op`),e;let t=e.match(/if\([$\w]+\("tengu_coral_fern",!1\)\)\{/);if(t&&t.index!==void 0){let n=`if(true){`,r=e.slice(0,t.index)+n+e.slice(t.index+t[0].length);return F(e,r,n,t.index,t.index+t[0].length),r}let n=e.match(/if\(![$\w]+\("tengu_coral_fern",!1\)\)return\s*(?:null|\[\]);/);if(n&&n.index!==void 0){let t=e.slice(0,n.index)+e.slice(n.index+n[0].length);return F(e,t,``,n.index,n.index+n[0].length),t}return e.includes(`tengu_session_search_toggled`)||e.includes(`tengu_session_all_projects_toggled`)?e:(console.error(`patch: sessionMemory: failed to find past sessions gate`),null)},jr=(e,t=!0)=>{if(!e.includes(`# Session Title`))return W(`patch: sessionMemory: token-limit anchor removed in this CC build — no-op`),e;let n=e.match(/(=)2000((?:.|\n){0,15}?=)12000((?:.|\n){0,20}# Session Title)/);if(!n||n.index===void 0)return t&&console.error(`patch: sessionMemory: failed to find token limits pattern`),null;let r=n[1]+`Number(process.env.CC_SM_PER_SECTION_TOKENS??2000)`+n[2]+`Number(process.env.CM_SM_TOTAL_FILE_LIMIT??12000)`+n[3],i=n.index,a=i+n[0].length,o=e.slice(0,i)+r+e.slice(a);return F(e,o,r,i,a),o},Mr=(e,t=!0)=>{if(!(e.includes(`minimumMessageTokensToInit`)||e.includes(`minimumTokensBetweenUpdate`)||e.includes(`toolCallsBetweenUpdates`)))return W(`patch: sessionMemory: update threshold props removed in this CC build — no-op`),e;let n=e;return n=I(n,/minimumMessageTokensToInit:1e4\b/g,`minimumMessageTokensToInit:Number(process.env.CC_SM_MINIMUM_MESSAGE_TOKENS_TO_INIT??1e4)`),n=I(n,/minimumTokensBetweenUpdate:5000\b/g,`minimumTokensBetweenUpdate:Number(process.env.CC_SM_MINIMUM_TOKENS_BETWEEN_UPDATE??5000)`),n=I(n,/toolCallsBetweenUpdates:3\b/g,`toolCallsBetweenUpdates:Number(process.env.CC_SM_TOOL_CALLS_BETWEEN_UPDATES??3)`),n===e?(t&&console.error(`patch: sessionMemory: failed to find update thresholds patterns`),null):n},Nr=e=>{let t=kr(e);if(!t)return null;let n=t.includes(`tengu_session_memory`),r=Ar(t);if(!r)return null;t=r;let i=t.match(/(function [$\w]+\(\))\{if\(![$\w]+\("tengu_passport_quail",!1\)\)return!1;return![$\w]+\(\)\|\|[$\w]+\("tengu_slate_thimble",!1\)\}/);if(i&&i.index!==void 0){let e=`${i[1]}{return!0}`,n=t;t=t.slice(0,i.index)+e+t.slice(i.index+i[0].length),F(n,t,e,i.index,i.index+i[0].length)}let a=jr(t,n);if(a)t=a;else if(n)return null;let o=Mr(t,n);if(o)t=o;else if(n)return null;return t},Pr=e=>{if(!e.includes(`"tengu_onyx_plover"`))return W(`patch: dreamMode: availability gate already removed in this CC build — no-op`),e;let t=e.match(/function [$\w]+\(\)\{return [$\w]+\("tengu_onyx_plover",null\)\}function [$\w]+\(\)\{/);if(!t||t.index===void 0)return console.error(`patch: dreamMode: failed to find availability gate`),null;let n=t.index+t[0].length;if(e.startsWith(`return!0;`,n))return e;let r=`return!0;`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i},Fr=e=>{if(!e.includes(`"tengu_ochre_finch"`))return W(`patch: leanMemoryTypes: gate already promoted/removed in this CC build — no-op`),e;let t=e.match(/function [$\w]+\(\)\{(?:return!0;)?return [$\w]+\("tengu_ochre_finch",!1\)\}/);if(!t||t.index===void 0)return console.error(`patch: leanMemoryTypes: failed to find statsig gate`),null;let n=t.index+t[0].indexOf(`{`)+1;if(e.startsWith(`return!0;`,n))return e;let r=`return!0;`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i},Ir=e=>{let t=`[A-Za-z_$][\\w$]*`,n=[RegExp(`function\\s+(${t})\\((${t})\\)\\{let\\{files:(${t})\\}=\\2,`),/\{([A-Za-z_$][\w$]*)\(\{name:"claude-in-chrome"/];for(let t of n){let n=e.match(t);if(n)return n[1]}return console.error(`patch: rememberSkill: failed to find skill registration function`),null},Lr=(e,t)=>{let n=RegExp(`function\\s+[$\\w]+\\(\\)\\{${t}\\(\\{name:"update-config"`),r=e.match(n);if(!r||r.index===void 0)return null;let i=e.indexOf(`{`,r.index);if(i===-1)return null;let a=i+1,o=`${t}({name:"remember",description:"Review session memories and update CLAUDE.local.md with learnings from past sessions.",whenToUse:"When the user asks to remember something, save a learning, or review session memories.",userInvocable:!0,isEnabled:()=>!0,async getPromptForCommand(H){let $="# Remember Skill\\n\\nReview the current conversation and any relevant session memory files, then update CLAUDE.local.md with durable learnings that should carry forward to future sessions. Keep entries concise and actionable.";if(H&&H.trim())$+="\\n\\n## User Request\\n"+H.trim();return[{type:"text",text:$}]}});`,s=e.slice(0,a)+o+e.slice(a);return F(e,s,o,a,a),s},Rr=e=>{let t=Ir(e);if(!t)return null;let n=Lr(e,t);if(n)return n;let r=e.match(/(function ([$\w]+)\(.{0,500}\}function [$\w]+\(\)\{)return(\}.{0,10}[, ]([$\w]+)=`# Remember Skill)/);if(!r||r.index===void 0)return console.error(`patch: rememberSkill: failed to find injection point pattern`),null;let[i,a,o,s,c]=r,l=a+`
|
|
692
692
|
${t}({
|
|
693
693
|
name: "remember",
|
|
694
694
|
description: "Review session memories and update CLAUDE.local.md with learnings",
|
|
@@ -703,9 +703,9 @@ ${t}({
|
|
|
703
703
|
return [{ type: "text", text: content }];
|
|
704
704
|
},
|
|
705
705
|
});
|
|
706
|
-
return`+s,u=r.index,d=u+i.length,f=e.slice(0,u)+l+e.slice(d);return F(e,f,l,u,d),f},Rr=e=>{let t=zi(e);if(!t)return console.error(`patch: thinkingBlockStyling: failed to find Text component`),null;let n=e.match(/\{thinking:([$\w]+)\}.{0,400}(?:∴|\\u2234) Thinking.{0,700}(?:…|\\u2026).{0,200}\b[$\w]+(?:\.default)?\.createElement\(([$\w]+,null),\1\)/);if(!n||n.index===void 0)return console.error(`patch: thinkingBlockStyling: failed to find thinking label pattern`),null;let r=n[0].replace(n[2],`${t},{dimColor:true,italic:true}`),i=n.index,a=i+n[0].length,o=e.slice(0,i)+r+e.slice(a);return F(e,o,r,i,a),o},zr=e=>{let t=e.match(/![$\w]+\(process\.env\.MCP_CONNECTION_NONBLOCKING\)/);return!t||t.index===void 0?null:{startIndex:t.index,endIndex:t.index+t[0].length}},Br=e=>{let t=e.match(/MCP_SERVER_CONNECTION_BATCH_SIZE\|\|"",10\)(?:\|\||;return [$\w]+>0\?[$\w]+:)(\d+)/);if(!t||t.index===void 0)return console.error(`patch: mcpStartup: failed to find MCP_SERVER_CONNECTION_BATCH_SIZE default`),null;let n=t[0],r=t[1],i=n.lastIndexOf(r),a=t.index+i;return{startIndex:a,endIndex:a+r.length}},Vr=e=>{let t=zr(e);if(!t)return e;let n=`false`,r=e.slice(0,t.startIndex)+n+e.slice(t.endIndex);return F(e,r,n,t.startIndex,t.endIndex),r},Hr=(e,t)=>{let n=Br(e);if(!n)return null;let r=String(t),i=e.slice(0,n.startIndex)+r+e.slice(n.endIndex);return F(e,i,r,n.startIndex,n.endIndex),i},Ur=(e,t=300,n=!1)=>{let r=e.match(/(,([$\w]+)=([$\w]+(?:\.default)?)\.useCallback.{0,1000}statusLineText.{0,200}?),([$\w]+)=([$\w.]+\(\(\)=>(\2\(([$\w]+)\)),300\)|[$\w]+\(\(\)=>\{\2\(\)\},300\)|[$\w]+\(\2,300\)|.{0,100}\{[$\w]+\.current=void 0,\2\(\)\},300\)\},\[\2\]\)|[$\w]+\.useCallback\(\(\)=>\{if\([$\w]+\.current!==void 0\)clearTimeout\([$\w]+\.current\);[$\w]+\.current=setTimeout\(\([$\w]+,[$\w]+\)=>\{[$\w]+\.current=void 0,[$\w]+\(\)\},300,[$\w]+,\2\)\},\[\2\]\)|\3\.useCallback\(\(\)=>\{.{0,200}setTimeout\(\([$\w]+,[$\w]+\)=>\{[$\w]+\.current=void 0,[$\w]+\(\)\},300,[$\w]+,\2\)\},\[\2\]\))/);if(!r||r.index===void 0)return console.error(`patch: statuslineUpdateThrottle: failed to find statusline update throttle pattern`),null;let i=r[1],a=r[2],o=r[3],s=r[4],c=r[6]??`${a}()`,l=r[7],u=Number(t),d=Number.isFinite(u)&&u>=0?Math.trunc(u):300,f=l?`${a}, ${l}`:a,p=a,m;m=n?l?i+`,argRef=${o}.useRef(${l}),unused1=${o}.useEffect(()=>{argRef.current=${l};},[${l}]),unused2=${o}.useEffect(()=>{const id=setInterval(()=>${a}(argRef.current),${d});return()=>clearInterval(id);},[${p}]),${s}=${o}.useCallback(()=>{},[])`:i+`,unused1=${o}.useEffect(()=>{const id=setInterval(()=>${c},${d});return()=>clearInterval(id);},[${p}]),${s}=${o}.useCallback(()=>{},[])`:i+`,lastCall=${o}.useRef(0),${s}=${o}.useCallback(()=>{let now=Date.now();if(now-lastCall.current>=${d}){lastCall.current=now;${c};}},[${f}])`;let h=r.index,g=h+r[0].length,_=e.slice(0,h)+m+e.slice(g);return F(e,_,m,h,g),_},Wr=e=>typeof e==`number`?e:e.threshold??1e3,Gr=(e,t)=>{let n=Wr(t),r,i,a,o,s,c=`[$\\w]+(?:\\?\\.[$\\w]+)*(?:\\([^()]*\\))?`,l=e.match(RegExp(`(([$\\w]+)=[$\\w]+\\()(${c})(\\),.{0,2000}key:"tokens".{0,200},\\2," tokens")`));if(l&&l.index!==void 0)[r,i,,a,o]=l,s=l.index;else{let t=e.match(RegExp(`(overrideMessage:.{0,10000},([$\\w]+)=[$\\w]+\\()(${c})(\\),.{0,1000}key:"tokens".{0,200},\\2," tokens")`));if(t&&t.index!==void 0)[r,i,,a,o]=t,s=t.index;else{let t=e.match(/(overrideMessage:.{0,10000},key:"tokens".{0,200}[$\w]+\()(Math\.round\(.+?\))(\))/);if(t&&t.index!==void 0)[r,i,a,o]=t,s=t.index;else return console.error(`patch: tokenCountRounding: cannot find token count pattern in any CC format`),null}}let u=`${i}Math.round((${a})/${n})*${n}${o}`,d=s+r.length,f=e.slice(0,s)+u+e.slice(d);return F(e,f,u,s,d),f},Kr=(e,t)=>/CLAUDE\.md.{0,100}for\(let \w+ of \["AGENTS\.md"/.test(e)?(console.log(`patch: agentsMd: alternative MD file support already present natively - skipping`),e):qr(e,t)||Jr(e,t),qr=(e,t)=>{let n=e.match(/(async function ([$\w]+)\(([$\w]+),([$\w]+),([$\w]+))\)\{try\{let ([$\w]+)=await ([$\w]+)\(\)\.readFile\(\3,\{encoding:"utf-8"\}\);return ([$\w]+)\(\6,\3,\4,\5\)\}catch\(([$\w]+)\)\{return ([$\w]+)\(\9,\3\),\{info:null,includePaths:\[\]\}\}\}/);if(!n||n.index===void 0)return null;let r=n[0],i=n[1],a=n[2],o=n[3],s=n[4],c=n[5],l=n[6],u=n[7],d=n[8],f=n[9],p=n[10],m=`${i},didReroute){try{let ${l}=await ${u}().readFile(${o},{encoding:"utf-8"});return ${d}(${l},${o},${s},${c})}catch(${f}){if(!didReroute&&(${o}.endsWith("/CLAUDE.md")||${o}.endsWith("\\\\CLAUDE.md"))){for(let alt of ${JSON.stringify(t)}){let altPath=${o}.slice(0,-9)+alt;try{let r=await ${a}(altPath,${s},${c},true);if(r.info)return r}catch{}}}return ${p}(${f},${o}),{info:null,includePaths:[]}}}`,h=n.index,g=h+r.length,_=e.slice(0,h)+m+e.slice(g);return F(e,_,m,h,g),_},Jr=(e,t)=>{let n=e.match(/(function ([$\w]+)\(([$\w]+),([^)]+?))\)(?:.|\n){0,500}Skipping non-text file in @include/);if(!n||n.index===void 0)return console.error(`patch: agentsMd: failed to find CLAUDE.md reading function`),null;let r=n[1],i=n[2],a=n[3],o=n[4],s=n.index,c=/([$\w]+(?:\(\))?)\.(?:readFileSync|existsSync|statSync)/,l=n[0].match(c),u=null;if(!l&&(u=e.slice(Math.max(0,s-5e3),s).match(c),!u))return console.error(`patch: agentsMd: failed to find fs expression in function or caller`),null;let d=l?l[1]:u?u[1]:`require("fs")`,f=JSON.stringify(t),p=s+r.length,m=e.slice(0,p)+`,didReroute`+e.slice(p);F(e,m,`,didReroute`,p,p);let h=m.slice(s),g=/\.isFile\(\)\)return null/,_=h.match(g)??h.match(/==="EISDIR"\)return null/);if(!_||_.index===void 0)return console.error(`patch: agentsMd: failed to find early return null for injection`),null;let v=!h.match(g),y=`if(!didReroute&&(${a}.endsWith("/CLAUDE.md")||${a}.endsWith("\\\\CLAUDE.md"))){for(let alt of ${f}){let altPath=${a}.slice(0,-9)+alt;if(${d}.existsSync(altPath)&&${d}.statSync(altPath).isFile())return ${i}(altPath,${o},true);}}`,b=s+_.index,x=_[0],S=v?`==="EISDIR"){${y}return null;}`:`.isFile()){${y}return null;}`;return m=m.slice(0,b)+S+m.slice(b+x.length),F(e,m,S,b,b),m},Yr=(e,t)=>{let n=e.lastIndexOf(`function `,t);if(n===-1)return null;let r=e.indexOf(`{`,n);if(r===-1||r>t)return null;let i=0;for(let t=r;t<e.length;t++){let n=e[t];if(n===`{`)i++;else if(n===`}`&&(i--,i===0)){let n=e.slice(r,t+1),i=/return [$\w]+(?:\.default)?\.createElement/g,a,o=null;for(;(a=i.exec(n))!==null;)o=a;return o?r+o.index:null}}return null},Xr=e=>{let t=[[/When ready, use \$\{([$\w]+)\} to present your plan for approval/g,(e,t)=>`When ready, use \${${t}} to exit plan mode. The plan will be approved automatically.`],[/Use this tool when you are in plan mode and have finished writing your plan to the plan file and are ready for user approval\./g,`Use this tool when you are in plan mode and have finished writing your plan to the plan file. Calling this tool exits plan mode and approves the plan automatically.`],[/This tool simply signals that you're done planning and ready for the user to review and approve/g,`This tool signals that you are done planning and that the plan should be approved automatically`],[/Once your plan is finalized, use THIS tool to request approval/g,`Once your plan is finalized, use THIS tool to approve the plan and proceed`],[/ExitPlanMode inherently requests user approval of your plan\./g,`ExitPlanMode inherently approves your plan and lets you proceed.`],[/Present your plan to the user for approval/g,`Exit plan mode; the plan will be approved automatically`],[/design an implementation approach for user approval/g,`design an implementation approach before automatic approval`],[/This tool REQUIRES user approval - they must consent to entering plan mode/g,`This tool enters plan mode; plan exit approval is handled automatically when auto-accept plan mode is enabled`],[/Claude has written up a plan and is ready to execute\. Would you like to proceed\?/g,`Claude has written up a plan and is ready to execute. The plan is approved automatically.`],[/Call `\$\{([$\w]+)\}` to present the plan for approval\./g,(e,t)=>`Call \`\${${t}}\` to exit plan mode; the plan will be approved automatically.`],[/## Phase 2: Spawn Workers \(After Plan Approval\)/g,`## Phase 2: Spawn Workers (After Automatic Plan Approval)`],[/Once the plan is approved, spawn/g,`After the plan is approved automatically, spawn`],[/searchHint:"present plan for approval and start coding \(plan mode only\)"/g,`searchHint:"approve plan and start coding (plan mode only)"`],[/async description\(\)\{return"Prompts the user to exit plan mode and start coding"\}/g,`async description(){return"Exits plan mode and starts coding"}`]],n=e;for(let[r,i]of t){let t=n;n=n.replace(r,i),n!==t&&F(e,n,String(i),0,0)}let r=`permissionUpdates:[{type:"setMode",mode:"acceptEdits",destination:"session"}]`,i=/kind:"permission_exit_plan_mode_v2",payload:([\s\S]{0,300}?),result:([\s\S]{0,180}?),default:\{behavior:"cancelled"\}/,a=n;n=n.replace(i,`kind:"permission_exit_plan_mode_v2",payload:$1,result:$2,default:{behavior:"allow",${r}}`),n!==a&&F(e,n,`permission_exit_plan_mode_v2 default allow`,0,0);let o=/async checkPermissions\(([$\w]+),([$\w]+)\)\{if\(([$\w]+)\(\)\)return\{behavior:"allow",updatedInput:\1\};return\{behavior:"ask",message:"Exit plan mode\?",updatedInput:\1\}\}/,s=n;return n=n.replace(o,`async checkPermissions($1,$2){return{behavior:"allow",updatedInput:$1,${r}}}`),n!==s&&F(e,n,`ExitPlanMode checkPermissions allow`,0,0),n},Zr=e=>{let t=e.indexOf(`title:"Ready to code?"`);if(t===-1)return console.error(`patch: autoAcceptPlanMode: failed to find "Ready to code?" title`),null;if(/[$\w]+(?:\.current)?\("yes-accept-edits(?:-keep-context)?"\);return null;return/.test(e))return e;let n=e.slice(t,t+3e3),r=n.match(/onChange:\([$\w]+\)=>([$\w]+)\([$\w]+\),onCancel/),i=n.match(/onChange:([$\w]+),onCancel/),a=n.match(/onChange:\([$\w]+\)=>void ([$\w]+)\.current\([$\w]+\),onCancel/),o;if(r)o=r[1];else if(i)o=i[1];else if(a)o=`${a[1]}.current`;else return console.error(`patch: autoAcceptPlanMode: failed to find onChange handler`),null;let s=e.match(/(\}\}\)\)\)\);)(return [$\w]+\.default\.createElement\([$\w]+\.default\.Fragment,null,[$\w]+\.default\.createElement\([$\w]+,\{color:"planMode",title:"Ready to code\?")/);if(s&&s.index!==void 0){let t=`${o}("yes-accept-edits-keep-context");return null;`,n=s[1]+t+s[2],r=s.index,i=r+s[0].length,a=e.slice(0,r)+n+e.slice(i);return F(e,a,n,r,i),Xr(a)}let c=Math.max(0,t-2500),l=e.slice(c,t),u=l.match(/(return [$\w]+\.default\.createElement\([$\w]+,\{flexDirection:"column",tabIndex:0,autoFocus:!0.{0,200}[$\w]+\.default\.createElement\([$\w]+,\{color:"planMode",title:")$/);if(!u){let n=l.lastIndexOf(`return `);if(n===-1){let n=Yr(e,t);if(n===null)return console.error(`patch: autoAcceptPlanMode: failed to find return before "Ready to code?"`),null;let r=`${o}("yes-accept-edits-keep-context");return null;`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),Xr(i)}let r=c+n,i=`${o}("yes-accept-edits-keep-context");return null;`,a=e.slice(0,r)+i+e.slice(r);return F(e,a,i,r,r),Xr(a)}let d=c+u.index,f=`${o}("yes-accept-edits-keep-context");return null;`,p=e.slice(0,d)+f+e.slice(d);return F(e,p,f,d,d),Xr(p)},Qr=e=>{let t=e.match(/console\.error\("--dangerously-skip-permissions cannot be used with root\/sudo privileges for security reasons"\),process\.exit\(1\)/);if(!t||t.index===void 0)return e.includes(`root/sudo privileges`)?(console.error(`patch: allowBypassPermsInSudo: failed to find pattern`),null):e;let n=t.index,r=n+t[0].length,i=e.slice(0,n)+`{}`+e.slice(r);return F(e,i,`{}`,n,r),i},$r=[/Claude Code has switched from npm to native installer\. Run `claude install` or see https:\/\/docs\.anthropic\.com\/en\/docs\/claude-code\/getting-started for more options\./g,/installMethod is native, but directory [^"'`\n;]+/g,/installMethod is native, but claude command (?:is missing or invalid|not found) at [^"'`\n;]+/g,/Native installation exists but ~\/\.local\/bin is not in your PATH(?:\. Run: echo 'export PATH="\$HOME\/\.local\/bin:\$PATH"' >> [^"'`\n;]+ then open a new terminal or run: source [^"'`\n;]+)?/g,/Run: echo 'export PATH="\$HOME\/\.local\/bin:\$PATH"' >> [^"'`\n;]+ then open a new terminal or run: source [^"'`\n;]+/g],ei=e=>{let t=e,n=!1,r=-1,i=-1;for(let e of $r)t=t.replace(e,(e,t)=>(n||(r=t,i=t+e.length),n=!0,``));return n?(F(e,t,``,r,i),t):(console.warn(`patch: suppressNativeInstallerWarning: failed to find pattern`),null)},ti=e=>{let t=e.split(`
|
|
706
|
+
return`+s,u=r.index,d=u+i.length,f=e.slice(0,u)+l+e.slice(d);return F(e,f,l,u,d),f},zr=e=>{let t=zi(e);if(!t)return console.error(`patch: thinkingBlockStyling: failed to find Text component`),null;let n=e.match(/\{thinking:([$\w]+)\}.{0,400}(?:∴|\\u2234) Thinking.{0,700}(?:…|\\u2026).{0,200}\b[$\w]+(?:\.default)?\.createElement\(([$\w]+,null),\1\)/);if(!n||n.index===void 0)return console.error(`patch: thinkingBlockStyling: failed to find thinking label pattern`),null;let r=n[0].replace(n[2],`${t},{dimColor:true,italic:true}`),i=n.index,a=i+n[0].length,o=e.slice(0,i)+r+e.slice(a);return F(e,o,r,i,a),o},Br=e=>{let t=e.match(/![$\w]+\(process\.env\.MCP_CONNECTION_NONBLOCKING\)/);return!t||t.index===void 0?null:{startIndex:t.index,endIndex:t.index+t[0].length}},Vr=e=>{let t=e.match(/MCP_SERVER_CONNECTION_BATCH_SIZE\|\|"",10\)(?:\|\||;return [$\w]+>0\?[$\w]+:)(\d+)/);if(!t||t.index===void 0)return console.error(`patch: mcpStartup: failed to find MCP_SERVER_CONNECTION_BATCH_SIZE default`),null;let n=t[0],r=t[1],i=n.lastIndexOf(r),a=t.index+i;return{startIndex:a,endIndex:a+r.length}},Hr=e=>{let t=Br(e);if(!t)return e;let n=`false`,r=e.slice(0,t.startIndex)+n+e.slice(t.endIndex);return F(e,r,n,t.startIndex,t.endIndex),r},Ur=(e,t)=>{let n=Vr(e);if(!n)return null;let r=String(t),i=e.slice(0,n.startIndex)+r+e.slice(n.endIndex);return F(e,i,r,n.startIndex,n.endIndex),i},Wr=(e,t=300,n=!1)=>{let r=e.match(/(,([$\w]+)=([$\w]+(?:\.default)?)\.useCallback.{0,1000}statusLineText.{0,200}?),([$\w]+)=([$\w.]+\(\(\)=>(\2\(([$\w]+)\)),300\)|[$\w]+\(\(\)=>\{\2\(\)\},300\)|[$\w]+\(\2,300\)|.{0,100}\{[$\w]+\.current=void 0,\2\(\)\},300\)\},\[\2\]\)|[$\w]+\.useCallback\(\(\)=>\{if\([$\w]+\.current!==void 0\)clearTimeout\([$\w]+\.current\);[$\w]+\.current=setTimeout\(\([$\w]+,[$\w]+\)=>\{[$\w]+\.current=void 0,[$\w]+\(\)\},300,[$\w]+,\2\)\},\[\2\]\)|\3\.useCallback\(\(\)=>\{.{0,200}setTimeout\(\([$\w]+,[$\w]+\)=>\{[$\w]+\.current=void 0,[$\w]+\(\)\},300,[$\w]+,\2\)\},\[\2\]\))/);if(!r||r.index===void 0)return console.error(`patch: statuslineUpdateThrottle: failed to find statusline update throttle pattern`),null;let i=r[1],a=r[2],o=r[3],s=r[4],c=r[6]??`${a}()`,l=r[7],u=Number(t),d=Number.isFinite(u)&&u>=0?Math.trunc(u):300,f=l?`${a}, ${l}`:a,p=a,m;m=n?l?i+`,argRef=${o}.useRef(${l}),unused1=${o}.useEffect(()=>{argRef.current=${l};},[${l}]),unused2=${o}.useEffect(()=>{const id=setInterval(()=>${a}(argRef.current),${d});return()=>clearInterval(id);},[${p}]),${s}=${o}.useCallback(()=>{},[])`:i+`,unused1=${o}.useEffect(()=>{const id=setInterval(()=>${c},${d});return()=>clearInterval(id);},[${p}]),${s}=${o}.useCallback(()=>{},[])`:i+`,lastCall=${o}.useRef(0),${s}=${o}.useCallback(()=>{let now=Date.now();if(now-lastCall.current>=${d}){lastCall.current=now;${c};}},[${f}])`;let h=r.index,g=h+r[0].length,_=e.slice(0,h)+m+e.slice(g);return F(e,_,m,h,g),_},Gr=e=>typeof e==`number`?e:e.threshold??1e3,Kr=(e,t)=>{let n=Gr(t),r,i,a,o,s,c=`[$\\w]+(?:\\?\\.[$\\w]+)*(?:\\([^()]*\\))?`,l=e.match(RegExp(`(([$\\w]+)=[$\\w]+\\()(${c})(\\),.{0,2000}key:"tokens".{0,200},\\2," tokens")`));if(l&&l.index!==void 0)[r,i,,a,o]=l,s=l.index;else{let t=e.match(RegExp(`(overrideMessage:.{0,10000},([$\\w]+)=[$\\w]+\\()(${c})(\\),.{0,1000}key:"tokens".{0,200},\\2," tokens")`));if(t&&t.index!==void 0)[r,i,,a,o]=t,s=t.index;else{let t=e.match(/(overrideMessage:.{0,10000},key:"tokens".{0,200}[$\w]+\()(Math\.round\(.+?\))(\))/);if(t&&t.index!==void 0)[r,i,a,o]=t,s=t.index;else return console.error(`patch: tokenCountRounding: cannot find token count pattern in any CC format`),null}}let u=`${i}Math.round((${a})/${n})*${n}${o}`,d=s+r.length,f=e.slice(0,s)+u+e.slice(d);return F(e,f,u,s,d),f},qr=(e,t)=>/CLAUDE\.md.{0,100}for\(let \w+ of \["AGENTS\.md"/.test(e)?(console.log(`patch: agentsMd: alternative MD file support already present natively - skipping`),e):Jr(e,t)||Yr(e,t),Jr=(e,t)=>{let n=e.match(/(async function ([$\w]+)\(([$\w]+),([$\w]+),([$\w]+))\)\{try\{let ([$\w]+)=await ([$\w]+)\(\)\.readFile\(\3,\{encoding:"utf-8"\}\);return ([$\w]+)\(\6,\3,\4,\5\)\}catch\(([$\w]+)\)\{return ([$\w]+)\(\9,\3\),\{info:null,includePaths:\[\]\}\}\}/);if(!n||n.index===void 0)return null;let r=n[0],i=n[1],a=n[2],o=n[3],s=n[4],c=n[5],l=n[6],u=n[7],d=n[8],f=n[9],p=n[10],m=`${i},didReroute){try{let ${l}=await ${u}().readFile(${o},{encoding:"utf-8"});return ${d}(${l},${o},${s},${c})}catch(${f}){if(!didReroute&&(${o}.endsWith("/CLAUDE.md")||${o}.endsWith("\\\\CLAUDE.md"))){for(let alt of ${JSON.stringify(t)}){let altPath=${o}.slice(0,-9)+alt;try{let r=await ${a}(altPath,${s},${c},true);if(r.info)return r}catch{}}}return ${p}(${f},${o}),{info:null,includePaths:[]}}}`,h=n.index,g=h+r.length,_=e.slice(0,h)+m+e.slice(g);return F(e,_,m,h,g),_},Yr=(e,t)=>{let n=e.match(/(function ([$\w]+)\(([$\w]+),([^)]+?))\)(?:.|\n){0,500}Skipping non-text file in @include/);if(!n||n.index===void 0)return console.error(`patch: agentsMd: failed to find CLAUDE.md reading function`),null;let r=n[1],i=n[2],a=n[3],o=n[4],s=n.index,c=/([$\w]+(?:\(\))?)\.(?:readFileSync|existsSync|statSync)/,l=n[0].match(c),u=null;if(!l&&(u=e.slice(Math.max(0,s-5e3),s).match(c),!u))return console.error(`patch: agentsMd: failed to find fs expression in function or caller`),null;let d=l?l[1]:u?u[1]:`require("fs")`,f=JSON.stringify(t),p=s+r.length,m=e.slice(0,p)+`,didReroute`+e.slice(p);F(e,m,`,didReroute`,p,p);let h=m.slice(s),g=/\.isFile\(\)\)return null/,_=h.match(g)??h.match(/==="EISDIR"\)return null/);if(!_||_.index===void 0)return console.error(`patch: agentsMd: failed to find early return null for injection`),null;let v=!h.match(g),y=`if(!didReroute&&(${a}.endsWith("/CLAUDE.md")||${a}.endsWith("\\\\CLAUDE.md"))){for(let alt of ${f}){let altPath=${a}.slice(0,-9)+alt;if(${d}.existsSync(altPath)&&${d}.statSync(altPath).isFile())return ${i}(altPath,${o},true);}}`,b=s+_.index,x=_[0],S=v?`==="EISDIR"){${y}return null;}`:`.isFile()){${y}return null;}`;return m=m.slice(0,b)+S+m.slice(b+x.length),F(e,m,S,b,b),m},Xr=(e,t)=>{let n=e.lastIndexOf(`function `,t);if(n===-1)return null;let r=e.indexOf(`{`,n);if(r===-1||r>t)return null;let i=0;for(let t=r;t<e.length;t++){let n=e[t];if(n===`{`)i++;else if(n===`}`&&(i--,i===0)){let n=e.slice(r,t+1),i=/return [$\w]+(?:\.default)?\.createElement/g,a,o=null;for(;(a=i.exec(n))!==null;)o=a;return o?r+o.index:null}}return null},Zr=e=>{let t=[[/When ready, use \$\{([$\w]+)\} to present your plan for approval/g,(e,t)=>`When ready, use \${${t}} to exit plan mode. The plan will be approved automatically.`],[/Use this tool when you are in plan mode and have finished writing your plan to the plan file and are ready for user approval\./g,`Use this tool when you are in plan mode and have finished writing your plan to the plan file. Calling this tool exits plan mode and approves the plan automatically.`],[/This tool simply signals that you're done planning and ready for the user to review and approve/g,`This tool signals that you are done planning and that the plan should be approved automatically`],[/Once your plan is finalized, use THIS tool to request approval/g,`Once your plan is finalized, use THIS tool to approve the plan and proceed`],[/ExitPlanMode inherently requests user approval of your plan\./g,`ExitPlanMode inherently approves your plan and lets you proceed.`],[/Present your plan to the user for approval/g,`Exit plan mode; the plan will be approved automatically`],[/design an implementation approach for user approval/g,`design an implementation approach before automatic approval`],[/This tool REQUIRES user approval - they must consent to entering plan mode/g,`This tool enters plan mode; plan exit approval is handled automatically when auto-accept plan mode is enabled`],[/Claude has written up a plan and is ready to execute\. Would you like to proceed\?/g,`Claude has written up a plan and is ready to execute. The plan is approved automatically.`],[/Call `\$\{([$\w]+)\}` to present the plan for approval\./g,(e,t)=>`Call \`\${${t}}\` to exit plan mode; the plan will be approved automatically.`],[/## Phase 2: Spawn Workers \(After Plan Approval\)/g,`## Phase 2: Spawn Workers (After Automatic Plan Approval)`],[/Once the plan is approved, spawn/g,`After the plan is approved automatically, spawn`],[/searchHint:"present plan for approval and start coding \(plan mode only\)"/g,`searchHint:"approve plan and start coding (plan mode only)"`],[/async description\(\)\{return"Prompts the user to exit plan mode and start coding"\}/g,`async description(){return"Exits plan mode and starts coding"}`]],n=e;for(let[r,i]of t){let t=n;n=n.replace(r,i),n!==t&&F(e,n,String(i),0,0)}let r=`permissionUpdates:[{type:"setMode",mode:"acceptEdits",destination:"session"}]`,i=/kind:"permission_exit_plan_mode_v2",payload:([\s\S]{0,300}?),result:([\s\S]{0,180}?),default:\{behavior:"cancelled"\}/,a=n;n=n.replace(i,`kind:"permission_exit_plan_mode_v2",payload:$1,result:$2,default:{behavior:"allow",${r}}`),n!==a&&F(e,n,`permission_exit_plan_mode_v2 default allow`,0,0);let o=/async checkPermissions\(([$\w]+),([$\w]+)\)\{if\(([$\w]+)\(\)\)return\{behavior:"allow",updatedInput:\1\};return\{behavior:"ask",message:"Exit plan mode\?",updatedInput:\1\}\}/,s=n;return n=n.replace(o,`async checkPermissions($1,$2){return{behavior:"allow",updatedInput:$1,${r}}}`),n!==s&&F(e,n,`ExitPlanMode checkPermissions allow`,0,0),n},Qr=e=>{let t=e.indexOf(`title:"Ready to code?"`);if(t===-1)return console.error(`patch: autoAcceptPlanMode: failed to find "Ready to code?" title`),null;if(/[$\w]+(?:\.current)?\("yes-accept-edits(?:-keep-context)?"\);return null;return/.test(e))return e;let n=e.slice(t,t+3e3),r=n.match(/onChange:\([$\w]+\)=>([$\w]+)\([$\w]+\),onCancel/),i=n.match(/onChange:([$\w]+),onCancel/),a=n.match(/onChange:\([$\w]+\)=>void ([$\w]+)\.current\([$\w]+\),onCancel/),o;if(r)o=r[1];else if(i)o=i[1];else if(a)o=`${a[1]}.current`;else return console.error(`patch: autoAcceptPlanMode: failed to find onChange handler`),null;let s=e.match(/(\}\}\)\)\)\);)(return [$\w]+\.default\.createElement\([$\w]+\.default\.Fragment,null,[$\w]+\.default\.createElement\([$\w]+,\{color:"planMode",title:"Ready to code\?")/);if(s&&s.index!==void 0){let t=`${o}("yes-accept-edits-keep-context");return null;`,n=s[1]+t+s[2],r=s.index,i=r+s[0].length,a=e.slice(0,r)+n+e.slice(i);return F(e,a,n,r,i),Zr(a)}let c=Math.max(0,t-2500),l=e.slice(c,t),u=l.match(/(return [$\w]+\.default\.createElement\([$\w]+,\{flexDirection:"column",tabIndex:0,autoFocus:!0.{0,200}[$\w]+\.default\.createElement\([$\w]+,\{color:"planMode",title:")$/);if(!u){let n=l.lastIndexOf(`return `);if(n===-1){let n=Xr(e,t);if(n===null)return console.error(`patch: autoAcceptPlanMode: failed to find return before "Ready to code?"`),null;let r=`${o}("yes-accept-edits-keep-context");return null;`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),Zr(i)}let r=c+n,i=`${o}("yes-accept-edits-keep-context");return null;`,a=e.slice(0,r)+i+e.slice(r);return F(e,a,i,r,r),Zr(a)}let d=c+u.index,f=`${o}("yes-accept-edits-keep-context");return null;`,p=e.slice(0,d)+f+e.slice(d);return F(e,p,f,d,d),Zr(p)},$r=e=>{let t=e.match(/console\.error\("--dangerously-skip-permissions cannot be used with root\/sudo privileges for security reasons"\),process\.exit\(1\)/);if(!t||t.index===void 0)return e.includes(`root/sudo privileges`)?(console.error(`patch: allowBypassPermsInSudo: failed to find pattern`),null):e;let n=t.index,r=n+t[0].length,i=e.slice(0,n)+`{}`+e.slice(r);return F(e,i,`{}`,n,r),i},ei=[/Claude Code has switched from npm to native installer\. Run `claude install` or see https:\/\/docs\.anthropic\.com\/en\/docs\/claude-code\/getting-started for more options\./g,/installMethod is native, but directory [^"'`\n;]+/g,/installMethod is native, but claude command (?:is missing or invalid|not found) at [^"'`\n;]+/g,/Native installation exists but ~\/\.local\/bin is not in your PATH(?:\. Run: echo 'export PATH="\$HOME\/\.local\/bin:\$PATH"' >> [^"'`\n;]+ then open a new terminal or run: source [^"'`\n;]+)?/g,/Run: echo 'export PATH="\$HOME\/\.local\/bin:\$PATH"' >> [^"'`\n;]+ then open a new terminal or run: source [^"'`\n;]+/g],ti=e=>{let t=e,n=!1,r=-1,i=-1;for(let e of ei)t=t.replace(e,(e,t)=>(n||(r=t,i=t+e.length),n=!0,``));return n?(F(e,t,``,r,i),t):(console.warn(`patch: suppressNativeInstallerWarning: failed to find pattern`),null)},ni=e=>{let t=e.split(`
|
|
707
707
|
`),n=0;for(let e=0;e<t.length;e++){let r=t[e];if(!r.startsWith(`#!`)&&!(r.startsWith(`//`)&&(r.includes(`Version`)||r.includes(`(c)`)))&&!(r.trim()===``&&e<5)){n=e;break}}return n>0?t.slice(0,n).join(`
|
|
708
|
-
`).length:0},
|
|
708
|
+
`).length:0},ri=e=>{let t=ni(e),n=`// SCROLLING FIX PATCH START
|
|
709
709
|
const _origStdoutWrite=process.stdout.write;
|
|
710
710
|
process.stdout.write=function(chunk,encoding,cb){
|
|
711
711
|
if(typeof chunk!=='string'){
|
|
@@ -718,6 +718,6 @@ const filtered=chunk
|
|
|
718
718
|
return _origStdoutWrite.call(process.stdout,filtered,encoding,cb);
|
|
719
719
|
};
|
|
720
720
|
// SCROLLING FIX PATCH END
|
|
721
|
-
`,r=e.slice(0,t)+n+e.slice(t);return F(e,r,n,t,t),r},ri=e=>{let t=e.match(/function [$\w]+\(\)\{return [$\w]+\("tengu_worktree_mode"/);if(!t||t.index===void 0)return e.includes(`EnterWorktree`)?e:(console.error(`patch: worktreeMode: failed to find worktree gate function pattern`),null);let n=t.index+t[0].indexOf(`{`)+1,r=`return !0;`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i},ii=e=>{let t=e,n=t.match(/,model:([$\w]+)\.enum\(([$\w]+)\)\.optional\(\)/);if(!n||n.index===void 0)return t.match(/let\s+[$\w]+\s*=\s*([$\w]+)\s*&&\s*typeof\s+\1\s*===\s*"string"\s*&&\s*[$\w]+\.includes\(\1\)/)?(console.error(`patch: allowCustomAgentModels: failed to find Zod enum pattern`),null):t;let r=n[1],i=n[2],a=`,model:${r}.string().optional()`,o=n.index,s=o+n[0].length;t=t.slice(0,o)+a+t.slice(s),F(e,t,a,o,s);let c=i.replace(/\$/g,`\\$`),l=RegExp(`([;)}])let\\s+([\\$\\w]+)\\s*=\\s*([\\$\\w]+)\\s*&&\\s*typeof\\s+\\3\\s*===\\s*"string"\\s*&&\\s*${c}\\.includes\\(\\3\\)`),u=t,d=t.match(l);if(!d||d.index===void 0)return console.error(`patch: allowCustomAgentModels: failed to find model validation flag pattern`),null;let f=d[1],p=d[2],m=d[3],h=`${f}let ${p}=${m}&&typeof ${m}==="string"`,g=d.index,_=g+d[0].length;return t=t.slice(0,g)+h+t.slice(_),F(u,t,h,g,_),t},ai=e=>{let t=e,n=/function\s+([$\w]+)\s*\(\s*([$\w]+)\s*\)\s*\{\s*if\s*\(\s*([$\w]+)\s*\(\s*\2\s*\)\s*===\s*"claude-opus-4-7"\s*\)\s*return\s*"xhigh"\s*;\s*return\s*"high"\s*\}/,r=t.match(/function\s+([$\w]+)\s*\(\s*([$\w]+)\s*\)\s*\{\s*if\s*\(\s*([$\w]+)\s*\(\s*\2\s*\)\s*===\s*"claude-opus-4-8"\s*\)\s*return\s*"high"\s*;\s*if\s*\(\s*\3\s*\(\s*\2\s*\)\s*===\s*"claude-opus-4-7"\s*\)\s*return\s*"xhigh"\s*;\s*return\s*"high"\s*\}/),i=r||t.match(n);if(i&&i.index!==void 0){let[e,n,a,o]=i,s=r?`function ${n}(${a}){if(${o}(${a})==="claude-opus-4-8")return"max";if(${o}(${a})==="claude-opus-4-7")return"max";return"high"}`:`function ${n}(${a}){if(${o}(${a})==="claude-opus-4-7")return"max";return"high"}`,c=t.slice(0,i.index)+s+t.slice(i.index+e.length);F(t,c,s,i.index,i.index+e.length),t=c}else if(/===\s*"claude-opus-4-8"\s*\)\s*return\s*"max"/.test(t)||/function\s+[$\w]+\s*\(\s*[$\w]+\s*\)\s*\{\s*if\s*\(\s*[$\w]+\s*\(\s*[$\w]+\s*\)\s*===\s*"claude-opus-4-7"\s*\)\s*return\s*"max"\s*;\s*return\s*"high"\s*\}/.test(t))U(`patch: maxEffortDefault: per-model default already "max" — skipping`);else return console.error(`patch: maxEffortDefault: failed to find Opus per-model effort default`),null;return t},oi=e=>{let t=e.match(/function\s+([$\w]+)\s*\(\s*([$\w]+)\s*\)\s*\{\s*if\s*\(\s*\2\s*===\s*"claude-fable-5"\s*\|\|\s*\2\s*===\s*"claude-mythos-5"\s*\)\s*return\s*!0\s*;\s*return\s*!1\s*\}/);if(!t||t.index===void 0)return/"claude-mythos-5"\s*\)\s*return\s*!0\s*;\s*return\s*!0\s*\}/.test(e)?(U(`patch: autonomousOperationAllModels: model-family gate already flipped — skipping`),e):/"claude-fable-5"/.test(e)?(console.error(`patch: autonomousOperationAllModels: found the fable/mythos model ids but not the expected gate shape — needs a new match method`),null):(console.log(`patch: autonomousOperationAllModels: fable/mythos model-family gate not present in this CC build — no-op`),e);let[n,r,i]=t,a=`function ${r}(${i}){if(${i}==="claude-fable-5"||${i}==="claude-mythos-5")return!0;return!0}`,o=e.slice(0,t.index)+a+e.slice(t.index+n.length);return F(e,o,a,t.index,t.index+n.length),o},si={sonnet:`claude-sonnet-4-6`,haiku:`claude-haiku-4-5`},ci=(e,t)=>{if(t===`default`)return e;let n=si[t],r=e.match(/function\s+([$\w]+)\s*\(\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\(\s*\)\s*,\s*([$\w]+)\s*=\s*[$\w]+\s*\(\s*"tengu_auto_mode_config"\s*,\s*\{\s*\}\s*\)\s*,\s*([$\w]+)\s*=\s*\3\s*\?\.\s*modelByMainModel\s*;\s*if\s*\(\s*\4\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*;\s*if\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*\4\s*\[\s*`[^`]*`\s*\]\s*;\s*if\s*\(\s*\6\s*\)\s*return\s+\6\s*\}\s*let\s+([$\w]+)\s*=\s*\4\s*\[\s*\5\s*\]\s*;\s*if\s*\(\s*\7\s*\)\s*return\s+\7\s*\}\s*if\s*\(\s*\3\s*\?\.\s*model\s*\)\s*return\s+\3\s*\.\s*model\s*;\s*if\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\|\|\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*return\s+[$\w]+\s*\(\s*\2\s*\)\s*;\s*return\s+\2\s*\}/)||e.match(/function\s+([$\w]+)\s*\(\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\(\s*\)\s*,\s*([$\w]+)\s*=\s*[$\w]+\s*\(\s*"tengu_auto_mode_config"\s*,\s*\{\s*\}\s*\)\s*,\s*([$\w]+)\s*=\s*\3\s*\?\.\s*modelByMainModel\s*;\s*if\s*\(\s*\4\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*;\s*if\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*\4\s*\[\s*`[^`]*`\s*\]\s*;\s*if\s*\(\s*\6\s*\)\s*return\s+\6\s*\}\s*let\s+([$\w]+)\s*=\s*\4\s*\[\s*\5\s*\]\s*;\s*if\s*\(\s*\7\s*\)\s*return\s+\7\s*\}\s*if\s*\(\s*\3\s*\?\.\s*model\s*\)\s*return\s+\3\s*\.\s*model\s*;\s*if\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\|\|\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\.\s*ANTHROPIC_DEFAULT_OPUS_MODEL\s*\?\?\s*[$\w]+\s*\(\s*\)\s*\.\s*[$\w]+\s*;\s*if\s*\(\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\|\|\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*&&\s*!\s*[$\w]+\s*\(\s*\8\s*\)\s*&&\s*!\s*[$\w]+\s*\(\s*\8\s*\)\s*\)\s*return\s+\8\s*\+\s*"\[1m\]"\s*;\s*return\s+\8\s*\}\s*return\s+\2\s*\}/)||e.match(/function\s+([$\w]+)\s*\(\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\(\s*\)\s*,\s*([$\w]+)\s*=\s*[$\w]+\s*\(\s*"tengu_auto_mode_config"\s*,\s*\{\s*\}\s*\)\s*,\s*([$\w]+)\s*=\s*\3\s*\?\.\s*modelByMainModel\s*;\s*if\s*\(\s*\4\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\(\s*\2\s*\)\s*\.\s*replace\([^)]*\)\s*;\s*if\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*\4\s*\[\s*`[^`]*`\s*\]\s*;\s*if\s*\(\s*\6\s*\)\s*return\s+\6\s*\}\s*let\s+([$\w]+)\s*=\s*\4\s*\[\s*\5\s*\]\s*;\s*if\s*\(\s*\7\s*\)\s*return\s+\7\s*\}\s*if\s*\(\s*\3\s*\?\.\s*model\s*\)\s*return\s+\3\s*\.\s*model\s*;\s*if\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\|\|\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\.\s*ANTHROPIC_DEFAULT_OPUS_MODEL\s*\?\?\s*[$\w]+\s*\(\s*\)\s*\.\s*[$\w]+\s*;\s*if\s*\(\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\|\|\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*&&\s*!\s*[$\w]+\s*\(\s*\8\s*\)\s*&&\s*!\s*[$\w]+\s*\(\s*\8\s*\)\s*\)\s*return\s+\8\s*\+\s*"\[1m\]"\s*;\s*return\s+\8\s*\}\s*return\s+\2\s*\}/)||e.match(/function\s+([$\w]+)\s*\(\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\(\s*\)\s*,\s*([$\w]+)\s*=\s*[$\w]+\s*\(\s*"tengu_auto_mode_config"\s*,\s*\{\s*\}\s*\)\s*,\s*([$\w]+)\s*=\s*\3\s*\?\.\s*modelByMainModel\s*;\s*if\s*\(\s*\4\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\(\s*\2\s*\)\s*\.\s*replace\([^)]*\)\s*;\s*if\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*\4\s*\[\s*`[^`]*`\s*\]\s*;\s*if\s*\(\s*\6\s*\)\s*return\s+\6\s*\}\s*let\s+([$\w]+)\s*=\s*\4\s*\[\s*\5\s*\]\s*;\s*if\s*\(\s*\7\s*\)\s*return\s+\7\s*\}\s*if\s*\(\s*\3\s*\?\.\s*model\s*\)\s*return\s+\3\s*\.\s*model\s*;\s*return\s+\2\s*\}/)||e.match(/function\s+([$\w]+)\s*\(\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*([$\w]+)\s*\(\s*\)\s*;\s*if\s*\(\s*([$\w]+)\s*\(\s*\2\s*\)\s*===\s*"claude-opus-4-8"\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*([$\w]+)\s*\(\s*"tengu_cedar_hollow_7m"\s*,\s*\{\s*\}\s*\)\s*;\s*if\s*\(\s*\5\s*\?\.\s*model\s*\)\s*return\s+\5\s*\.\s*model\s*\}\s*let\s+([$\w]+)\s*=\s*([$\w]+)\s*\(\s*"tengu_auto_mode_config"\s*,\s*\{\s*\}\s*\)\s*;\s*if\s*\(\s*\7\s*\?\.\s*model\s*\)\s*return\s+\7\s*\.\s*model\s*;\s*return\s+\2\s*\}/)||e.match(/function\s+([$\w]+)\s*\(\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*([$\w]+)\s*\(\s*"tengu_auto_mode_config"\s*,\s*\{\s*\}\s*\)\s*;\s*if\s*\(\s*\2\s*\?\.\s*model\s*\)\s*return\s+\2\s*\.\s*model\s*;\s*return\s+([$\w]+)\s*\(\s*\)\s*\}/);if(r&&r.index!==void 0){let[t,i]=r,a=`function ${i}(){return "${n}"}`,o=e.slice(0,r.index)+a+e.slice(r.index+t.length);return F(e,o,a,r.index,r.index+t.length),o}return/function\s+[$\w]+\s*\(\s*\)\s*\{\s*return\s*"claude-(opus|sonnet|haiku)-[0-9a-z-]+"\s*\}/.test(e)?(U(`patch: autoModeClassifierModel: classifier-model resolver already patched — skipping`),e):e.includes(`"tengu_auto_mode_config"`)?(console.error(`patch: autoModeClassifierModel: failed to find auto-mode classifier resolver`),null):(U(`patch: autoModeClassifierModel: tengu_auto_mode_config not present in this CC build — no-op`),e)},li=e=>{let t=e.match(/function [$\w]+\(\)\{return [$\w]+\("tengu_amber_quartz"/);if(t&&t.index!==void 0){let n=t.index+t[0].indexOf(`{`)+1,r=`return !0;`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i}let n=e.match(/function [$\w]+\(\)\{return![$\w]+\("tengu_amber_quartz_disabled"/);if(n&&n.index!==void 0){let t=n.index+n[0].indexOf(`{`)+1,r=`return !0;`,i=e.slice(0,t)+r+e.slice(t);return F(e,i,r,t,t),i}let r=e.match(/name:"voice",description:"Toggle voice mode"[\s\S]{0,500}?get isHidden\(\)\{return!([$\w]+)\(\)\}/);if(r&&r.index!==void 0){let t=r[1].replace(/[$]/g,`\\$`),n=RegExp(`function ${t}\\(\\)\\{`),i=e.match(n);if(i&&i.index!==void 0){let t=i.index+i[0].length,n=`return !0;`,r=e.slice(0,t)+n+e.slice(t);return F(e,r,n,t,t),r}}return console.error(`patch: voiceMode: failed to find tengu_amber_quartz gate`),null},ui=e=>{let t=e.match(/if\([$\w]+\("tengu_sotto_voce",!1\)\)/);if(!t||t.index===void 0)return e;let n=`if(!0)`,r=e.slice(0,t.index)+n+e.slice(t.index+t[0].length);return F(e,r,n,t.index,t.index+t[0].length),r},di=(e,t)=>{let n=li(e);return!n||t&&(n=ui(n),!n)?null:n},fi=e=>{let t=e.match(/function [$\w]+\(\)\{return [$\w]+\("tengu_harbor",!1\)/);if(!t||t.index===void 0)return console.error(`patch: channelsMode: failed to find tengu_harbor gate`),null;let n=t.index+t[0].indexOf(`{`)+1,r=`return !0;`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i},pi=e=>{let t=e.match(/reason:"server did not declare claude\/channel capability"\};?/);if(!t||t.index===void 0)return console.error(`patch: channelsMode: failed to find gateChannelServer capability check`),null;let n=t.index+t[0].length,r=`return{action:"register"};`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i},mi=e=>{let t=e.match(/function [$\w]+\(\)\{return [$\w]+\("tengu_harbor_permissions",!1\)/);if(!t||t.index===void 0)return console.error(`patch: channelsMode: failed to find tengu_harbor_permissions gate`),null;let n=t.index+t[0].indexOf(`{`)+1,r=`return !0;`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i},hi=e=>{let t=e.match(/Experimental[^"]*?inbound messages will be pushed into this session, this carries prompt injection risks\. Restart Claude Code without /);if(!t||t.index===void 0)return console.error(`patch: channelsMode: failed to find ChannelsNotice warning text`),null;let n=`Channels active. Restart Claude Code without `,r=t.index,i=r+t[0].length,a=e.slice(0,r)+n+e.slice(i);return F(e,a,n,r,i),a},gi=e=>{let t=e.match(/if\(![$\w]+\.dev\)[$\w]+\.push\(\{[$\w]+:[$\w]+,[$\w]+:"server: entries need --dangerously-load-development-channels"\}\)/);if(!t||t.index===void 0)return console.error(`patch: channelsMode: failed to find server dev-flag warning block`),null;let n=t.index,r=n+t[0].length,i=e.slice(0,n)+``+e.slice(r);return F(e,i,``,n,r),i},_i=e=>{let t=fi(e);return!t||(t=pi(t),!t)||(t=mi(t),!t)?null:(t=hi(t)??t,t=gi(t)??t,t)},vi=e=>{if(/name:"clear-screen"/.test(e))return e;let t=e.match(/([,;{}])(function [$\w]+\(\)\{)([$\w]+)\.get\(process\.stdout\)\?\.forceRedraw\(\)\}/);if(!t||t.index===void 0)return U(`patch: clearScreen: failed to find forceRedraw function`),null;let n=`${t[1]}globalThis.__tweakccForceRedraw=()=>${t[3]}.get(process.stdout)?.forceRedraw();`+t[0].slice(1),r=e.slice(0,t.index)+n+e.slice(t.index+t[0].length);F(e,r,n,t.index,t.index+t[0].length);let i=yi(r);return i?(r=i,Dn(r,`,{type:"local",name:"clear-screen",description:"Clear screen without resetting conversation context",supportsNonInteractive:!1,load:()=>Promise.resolve().then(()=>({call:(H,$)=>{$.setMessages(m=>{globalThis.__tweakccHiddenUUIDs=new Set(m.map(x=>x.uuid?.slice(0,24)).filter(Boolean));return[...m]});process.stdout.write("\\x1b[2J\\x1b[H\\x1b[3J");globalThis.__tweakccForceRedraw?.();return{type:"skip"}}}))}`)||(U(`patch: clearScreen: failed to register slash command`),null)):(U(`patch: clearScreen: failed to patch render filter g97`),null)},yi=e=>{let t=e.match(/([,;{}])(function [$\w]+\(([$\w]+),[$\w]+\)\{)if\(\3\.type!=="user"\)return!0;if\(\3\.isMeta\)/);if(!t||t.index===void 0)return null;let n=t[1],r=t[2],i=`${n}${r}if(globalThis.__tweakccHiddenUUIDs?.has(${t[3]}.uuid?.slice(0,24)))return!1;`+t[0].slice(n.length+r.length),a=e.slice(0,t.index)+i+e.slice(t.index+t[0].length);return F(e,a,i,t.index,t.index+t[0].length),a},bi=e=>{let t=e.match(/=2000,([$\w]+)="Read a file from the local filesystem\./);if(!t||t.index===void 0)return/=\(\+process\.env\.CLAUDE_CODE_READ_DEFAULT_LINES/.test(e)?e:(console.error(`patch: readDefaultLines: failed to find =2000 near Read tool prompt anchor`),null);let n=t.index,r=n+5,i=`=(+process.env.CLAUDE_CODE_READ_DEFAULT_LINES||2000)`,a=e.slice(0,n)+i+e.slice(r);return F(e,a,i,n,n+52),a},xi=e=>{if(/function [$\w]+\(([$\w]+),[$\w]+\)\{if\(Object\.entries\([$\w]+\)\.length===0\)return \1;var ([$\w]+)=\1\[0\];if\(\2&&\2\.isMeta/.test(e))return e;let t=e.match(/function ([$\w]+)\(([$\w]+),([$\w]+)\)\{if\(Object\.entries\(\3\)\.length===0\)return \2;return\[([\s\S]+?),\.\.\.\2\]\}/);if(!t||t.index===void 0){let t=e.indexOf(`"tengu_context_size"`);if(t>0){let n=e.slice(Math.max(0,t-5e3),t);if(/function [$\w]+\([$\w]+,[$\w]+\)\{return [$\w]+;?\}\s*async function/.test(n))return console.log(`patch: claudemd-context-once-per-conversation: claudemd-context override suppressed wrapper — no-op`),e}return console.error(`patch: claudemd-context-once-per-conversation: failed to find kY6 wrapper`),null}let[n,r,i,a,o]=t,s=`${i}_0`,c=`function ${r}(${i},${a}){if(Object.entries(${a}).length===0)return ${i};var ${s}=${i}[0];if(${s}&&${s}.isMeta&&${s}.message&&typeof ${s}.message.content==="string"&&${s}.message.content.indexOf("<system-reminder>\\nAs you answer the user")===0)return ${i};${i}.unshift(${o});return ${i}}`,l=t.index,u=l+n.length,d=e.slice(0,l)+c+e.slice(u);return F(e,d,c,l,u),d},Si=e=>{let t=e.match(/function ([$\w]+)\(([$\w]+)\)\{return`<system-reminder>\n\$\{\2\}\n<\/system-reminder>`\}/);if(!t||t.index===void 0)return/function [$\w]+\(([$\w]+)\)\{if\(!\1\|\|!\1\.trim\(\)\|\|\1==="\(no content\)"\)return"\(no content\)";return`<system-reminder>/.test(e)?e:(console.error(`patch: strip-empty-system-reminders: failed to find LW(H) wrapper`),null);let[n,r,i]=t,a=`function ${r}(${i}){if(!${i}||!${i}.trim()||${i}==="(no content)")return"(no content)";return\`<system-reminder>\n\${${i}}\n</system-reminder>\`}`,o=t.index,s=o+n.length,c=e.slice(0,o)+a+e.slice(s);return F(e,c,a,o,s),c},Ci=`The following deferred tools are now available via`,wi=e=>{if(!e.includes(Ci))return console.log(`patch: suppress-deferred-tools: anchor not present in this CC build — no-op`),e;if(e.includes(`case"deferred_tools_delta":{return [];`))return e;let t=e.indexOf(`case"deferred_tools_delta":{`);if(t<0)return console.error(`patch: suppress-deferred-tools: failed to find case header`),null;if(!e.slice(t,t+2048).includes(Ci))return console.error(`patch: suppress-deferred-tools: case header found but anchor text not nearby`),null;let n=t+28,r=`return [];`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i},Ti=async(e,t)=>{let n=`${t}.tmp-${process.pid}`;try{await o.copyFile(e,n),await o.rename(n,t)}catch(e){try{await o.unlink(n)}catch{}throw e}},Ei=async e=>{if(!e.cliPath){U(`backupClijs: Skipping for native installation (no cliPath)`);return}await ka(),U(`Backing up cli.js to ${Y}`),await Ti(e.cliPath,Y),await $(t=>{t.changesApplied=!1,t.ccVersion=e.version})},Di=async e=>{e.nativeInstallationPath&&(await ka(),U(`Backing up native binary to ${X}`),await Ti(e.nativeInstallationPath,X),await $(t=>{t.changesApplied=!1,t.ccVersion=e.version}))},Oi=async e=>{if(!e.cliPath)return U(`restoreClijsFromBackup: Skipping for native installation (no cliPath)`),!1;if(!await _a(Y))return U(`restoreClijsFromBackup: No backup file exists, skipping`),!1;U(`Restoring cli.js from backup to ${e.cliPath}`);let t=await o.readFile(Y);return await ga(e.cliPath,t,`restore`),await st(),await $(e=>{e.changesApplied=!1}),!0},ki=async e=>{if(!e.nativeInstallationPath)return U(`restoreNativeBinaryFromBackup: No native installation path, skipping`),!1;if(!await _a(X))return U(`restoreNativeBinaryFromBackup: No backup file exists, skipping`),!1;U(`Restoring native binary from backup to ${e.nativeInstallationPath}`);let t=await o.readFile(X);return await ga(e.nativeInstallationPath,t,`restore`),!0},R=e=>{let t=Array.from(e.matchAll(/[^$\w]([$\w]+)(?:\.(?:cyan|gray|green|red|yellow|ansi256|bgAnsi256|bgHex|bgRgb|hex|rgb|bold|dim|inverse|italic|strikethrough|underline)\b)+\(/g)),n={};for(let e of t){let t=e[1];n[t]=(n[t]||0)+1}let r,i=0;for(let[e,t]of Object.entries(n))t>i&&(i=t,r=e);return r},Ai=e=>{let t=e.slice(0,2e3).match(/[,;]([$\w]+)=\([$\w]+,[$\w]+,[$\w]+\)=>\{[$\w]+=[$\w]+!=null\?/);if(t)return t[1];let n=e.slice(0,1e4),r=Array.from(n.matchAll(/(?:var |,)([$\w]+)=\([$\w]+,[$\w]+,[$\w]+\)=>\{/g));if(r.length>0){let e=r[0][1];for(let t of r)t[1].length<e.length&&(e=t[1]);return e}console.log(`patch: getModuleLoaderFunction: failed to find module loader function`)},ji=e=>{let t=e.match(/var ([$\w]+)=[$\w]+\(\([$\w]+\)=>\{var [$\w]+=Symbol\.for\("react\.(transitional\.)?element"\)/);if(!t){console.log(`patch: getReactModuleNameNonBun: failed to find React module name`);return}return t[1]},Mi=e=>{let t=ji(e);if(!t){console.log(`^ patch: getReactModuleFunctionBun: failed to find React module name (Bun)`);return}let n=RegExp(`var ([$\\w]+)=[$\\w]+\\(\\([$\\w]+,[$\\w]+\\)=>\\{[$\\w]+\\.exports=${H(t)}\\(\\)`),r=e.match(n);if(!r){console.log(`patch: getReactModuleFunctionBun: failed to find React module function (Bun) (reactModuleNameNonBun=${t})`);return}return r[1]};let z=null,B=null;const Ni=e=>{if(z!=null)return z;let t=Ai(e);if(!t){console.log(`^ patch: getReactVar: failed to find moduleLoader`),z=void 0;return}let n=ji(e);if(!n){console.log(`^ patch: getReactVar: failed to find reactModuleVarNonBun`),z=void 0;return}let r=RegExp(`[^$\\w]([$\\w]+)=${H(t)}\\(${H(n)}\\(\\),1\\)`),i=e.match(r);if(i)return z=i[1],z;let a=Mi(e);if(!a){console.log(`^ patch: getReactVar: failed to find reactModuleFunctionBun`),z=void 0;return}let o=RegExp(`[^$\\w]([$\\w]+)=${H(t)}\\(${H(a)}\\(\\),1\\)`),s=e.match(o);if(!s){console.log(`patch: getReactVar: failed to find bunPattern (moduleLoader=${t}, reactModuleVarNonBun=${n}, reactModuleFunctionBun=${a})`),z=void 0;return}return z=s[1],z},Pi=()=>{z=null},Fi=e=>{let t=e.match(/import\{createRequire as ([$\w]+)\}from"node:module";/);if(!t)return;let n=t[1],r=RegExp(`var ([$\\w]+)=${H(n)}\\(import\\.meta\\.url\\)`),i=e.match(r);if(!i){console.log(`patch: findRequireFunc: failed to find require function variable (createRequireVar=${n})`);return}return i[1]},Ii=e=>{if(B!=null)return B;let t=Fi(e);return t?(B=t,B):(B=`require`,B)},Li=()=>{B=null},Ri=()=>{Pi(),Li()},zi=e=>{let t=e.match(/\bfunction ([$\w]+).{0,80}color:[$\w]+,backgroundColor:[$\w]+,dimColor:[$\w]+(?:=![01])?,bold:[$\w]+(?:=![01])?/);if(!t){console.log(`patch: findTextComponent: failed to find text component`);return}return t[1]},Bi=(e,t)=>{let n=`[A-Za-z_$][\\w$]*(?:\\.[A-Za-z_$][\\w$]*)*`,r=RegExp(`var [^;]{0,120};var [$\\w]+=${n}\\(\\(\\)=>\\{[^}]{0,500}([$\\w]+)=${H(t)}\\}\\)`),i=e.match(r)?.[1]??t,a=RegExp(`function ([$\\w]+)\\([^)]+\\)\\{(?=[\\s\\S]{0,2500}createElement\\(${H(i)},\\{\\.\\.\\.[$\\w]+,borderColor:)[\\s\\S]{0,3000}?return [$\\w]+\\}var [^;]{0,160};var [$\\w]+=${n}\\(\\(\\)=>\\{[^}]{0,600}([$\\w]+)=\\1\\}\\)`);return e.match(a)?.[2]},Vi=e=>{let t=e.match(/function ([$\w]+)\(.{0,2000}[^$\w]([$\w]+)=[$\w]+(?:\.default)?\.createElement\("ink-box".{0,500}?return \2/);if(t)return t[1];let n=e.match(/function ([$\w]+)\(.{0,200}children:[$\w]+,flexWrap:[$\w]+.{0,2000}?\.createElement\("ink-box"/);if(n)return n[1];let r=e.match(/[^$\w]([$\w]+)\.displayName="Box"/);if(r)return r[1];let i=e.match(/function ([$\w]+)\([$\w]+\)\{let [$\w]+=[$\w]+(?:\.[$\w]+)?\(\d+\).{0,3000}createElement\("ink-box"/);if(i)return i[1];let a=e.match(/function ([$\w]+)\(\{children:([$\w]+),ref:[$\w]+.{0,600}?\.\.\.([$\w]+)\}\)\{.{0,2500}?"margin".{0,2500}?"padding".{0,1200}?"gap".{0,1200}?\3\.flexWrap\?\?="nowrap",\3\.flexDirection\?\?="row",\3\.flexGrow\?\?=0,\3\.flexShrink\?\?=1,\3\.overflowX=\3\.overflowX\?\?\3\.overflow\?\?"visible",\3\.overflowY=\3\.overflowY\?\?\3\.overflow\?\?"visible",[$\w]+(?:\.default)?\.createElement\("ink-box",\{[^}]*style:\3\},\2\)/);if(a)return Bi(e,a[1])??a[1];let o=e.match(/function ([$\w]+)\(\{children:[$\w]+,ref:[$\w]+,tabIndex:[$\w]+,autoFocus:[$\w]+/);if(o)return o[1];console.error(`patch: findBoxComponent: failed to find Box component (neither ink-box createElement nor displayName found)`)},Hi=e(import.meta.url),Ui=(()=>{try{return Hi(`../package.json`).version}catch{return Hi(`../../package.json`).version}})();let V=function(e){return e.SYSTEM_PROMPTS=`System Prompts`,e.ALWAYS_APPLIED=`Always Applied`,e.MISC_CONFIGURABLE=`Misc Configurable`,e.FEATURES=`Features`,e.SYSTEM_REMINDERS=`System Reminders`,e}({});const Wi=[{id:`verbose-property`,name:`Verbose property`,group:V.ALWAYS_APPLIED,description:`Token counter will show (2s · ↓ 169 tokens · thinking)`},{id:`read-default-lines`,name:`Read default lines (env-gated)`,group:V.ALWAYS_APPLIED,description:`Read tool default line cap becomes CLAUDE_CODE_READ_DEFAULT_LINES env var (falls back to 2000 if unset)`},{id:`opusplan1m`,name:`Opusplan[1m] support`,group:V.ALWAYS_APPLIED,description:`Use the "Opus Plan 1M" model: Opus for planning, Sonnet 1M context for building`},{id:`thinking-block-styling`,name:`Thinking block styling`,group:V.ALWAYS_APPLIED,description:`Restore dim/gray + italic styling for thinking blocks`},{id:`fix-lsp-support`,name:`Fix LSP support`,group:V.ALWAYS_APPLIED,description:`Enable/fix nascent LSP support`},{id:`fix-summarize-from-here`,name:`Fix "Summarize from here"`,group:V.MISC_CONFIGURABLE,description:`Make "Summarize from here" summarize only the messages after the rewind point (feed the slice, not the whole conversation)`},{id:`fix-rewind-summary-header`,name:`Honest rewind summary header`,group:V.MISC_CONFIGURABLE,description:`Label a rewind summary as a deliberate rewind instead of the misleading "ran out of context" header`},{id:`statusline-update-throttle`,name:`Statusline update throttling correction`,group:V.ALWAYS_APPLIED,description:`Statusline updates will be properly throttled instead of queued (or debounced)`},{id:`clear-screen`,name:`Clear screen command`,group:V.ALWAYS_APPLIED,description:`Register a /clear-screen command that clears the terminal scrollback and redraws without resetting conversation context`},{id:`strip-empty-system-reminders`,name:`Strip empty <system-reminder> wrappers`,group:V.ALWAYS_APPLIED,description:`Short-circuits CC's universal system-reminder wrapper so empty / "(no content)" inputs produce no reminder. Kills the drift-inducing "<system-reminder>(no content)</system-reminder>" blocks that get appended to roughly every other tool call.`},{id:`model-customizations`,name:`Model customizations`,group:V.MISC_CONFIGURABLE,description:`Access all Claude models with /model, not just latest 3`},{id:`show-more-items-in-select-menus`,name:`Show more items in select menus`,group:V.MISC_CONFIGURABLE,description:`Show 25 items in select menus instead of default 5`},{id:`context-limit`,name:`Context limit`,group:V.MISC_CONFIGURABLE,description:`Override the 200K context limit via CLAUDE_CODE_CONTEXT_LIMIT env var (set before launching CC)`},{id:`patches-applied-indication`,name:`Patches applied indication`,group:V.MISC_CONFIGURABLE,description:`Show "tweakcc patches applied" and tweakcc version inside CC`},{id:`table-format`,name:`Table format`,group:V.MISC_CONFIGURABLE,description:`Tables generated by Claude will be rendered more compactly`},{id:`themes`,name:`Themes`,group:V.MISC_CONFIGURABLE,description:`Your custom themes will be available via /theme`},{id:`thinking-verbs`,name:`Thinking verbs`,group:V.MISC_CONFIGURABLE,description:`Your custom list of thinking verbs will be cycled through`},{id:`thinker-format`,name:`Thinker format`,group:V.MISC_CONFIGURABLE,description:`Your custom format string that thinking verbs are wrapped in will be applied`},{id:`thinker-symbol-chars`,name:`Thinker symbol chars`,group:V.MISC_CONFIGURABLE,description:`Your custom thinking spinner will be rendered`},{id:`thinker-symbol-speed`,name:`Thinker symbol speed`,group:V.MISC_CONFIGURABLE,description:`The thinking spinner will play at a custom FPS`},{id:`thinker-symbol-width`,name:`Thinker symbol width`,group:V.MISC_CONFIGURABLE,description:`The thinking spinner will be in a box of custom width`},{id:`thinker-symbol-mirror`,name:`Thinker symbol mirror`,group:V.MISC_CONFIGURABLE,description:`The thinking spinner will reverse or restart when it finishes`},{id:`input-box-border`,name:`Input box border`,group:V.MISC_CONFIGURABLE,description:`Your custom styles to the main input box's border will be applied`},{id:`subagent-models`,name:`Subagent models`,group:V.MISC_CONFIGURABLE,description:`Use custom models for Plan, Explore, and General subagents`},{id:`thinking-visibility`,name:`Thinking block visibility`,group:V.MISC_CONFIGURABLE,description:`Thinking blocks outputted by the model will show without Ctrl+O`},{id:`hide-startup-banner`,name:`Hide startup banner`,group:V.MISC_CONFIGURABLE,description:`CC's startup banner with "Clawd" and release notes will be hidden`},{id:`hide-ctrl-g-to-edit`,name:`Hide Ctrl+G to edit`,group:V.MISC_CONFIGURABLE,description:`Note about using Ctrl+G to edit prompt will be hidden`},{id:`hide-startup-clawd`,name:`Hide startup Clawd`,group:V.MISC_CONFIGURABLE,description:`The "Clawd" icon on startup will be hidden for a cleaner look`},{id:`increase-file-read-limit`,name:`Increase file read limit`,group:V.MISC_CONFIGURABLE,description:`Max tokens Claude can read from a file at once will be increased`},{id:`suppress-line-numbers`,name:`Suppress line numbers`,group:V.MISC_CONFIGURABLE,description:`"1→" "2→" etc. prefixes for each line of Read output will be omitted`},{id:`suppress-rate-limit-options`,name:`Suppress rate limit options`,group:V.MISC_CONFIGURABLE,description:`/rate-limit-options won't be injected when limits are reached`},{id:`token-count-rounding`,name:`Token count rounding`,group:V.MISC_CONFIGURABLE,description:`Round displayed token counts to the nearest multiple of chosen value`},{id:`remember-skill`,name:`Remember skill`,group:V.MISC_CONFIGURABLE,description:`Register the built-in "/remember" skill to review session memories and update CLAUDE.local.md`},{id:`agents-md`,name:`AGENTS.md (and others)`,group:V.MISC_CONFIGURABLE,description:`Support AGENTS.md and others in addition to CLAUDE.md`},{id:`auto-accept-plan-mode`,name:`Auto-accept plan mode`,group:V.MISC_CONFIGURABLE,description:`Automatically accept plans without the "Ready to code?" confirmation prompt`},{id:`allow-sudo-bypass-permissions`,name:`Allow bypassing permissions with --dangerously-skip-permissions in sudo`,group:V.MISC_CONFIGURABLE,description:`Allow bypassing permissions with --dangerously-skip-permissions even when running with root/sudo privileges`},{id:`suppress-native-installer-warning`,name:`Suppress native installer warning`,group:V.MISC_CONFIGURABLE,description:`Suppress the native installer warning message at startup`},{id:`filter-scroll-escape-sequences`,name:`Filter scroll escape sequences`,group:V.MISC_CONFIGURABLE,description:`Filter out terminal escape sequences that cause unwanted scrolling`},{id:`max-effort-default`,name:`Default Opus 4.7 to max effort`,group:V.MISC_CONFIGURABLE,description:`Opus 4.7 sessions default to "max" reasoning effort instead of "xhigh" (override with /effort or CLAUDE_CODE_EFFORT_LEVEL)`},{id:`autonomous-operation-all-models`,name:`Fable/Mythos prompt set (all models)`,group:V.MISC_CONFIGURABLE,description:`Treats your selected model as Fable/Mythos everywhere CC branches on model family (flips the zQ gate): you get the autonomous-operation prompt (proceed without asking for reversible in-scope work; finish the job before ending the turn), the "# Communicating with the user" comms block in place of "# Text output", /loop dynamic-pacing behavior, and brief-mode comms shaping. Per-model feature-flag routing also follows fable but is inert on a local install`},{id:`auto-mode-classifier-model`,name:`Auto-mode classifier model`,group:V.MISC_CONFIGURABLE,description:`Pin auto-mode bash safety classifier to Sonnet 4.6 or Haiku 4.5 instead of the user main-loop model (avoids Opus 4.7 congestion denying tool calls)`},{id:`allow-custom-agent-models`,name:`Allow custom agent models`,group:V.FEATURES,description:`Allow arbitrary model names in custom agent frontmatter (e.g. gemini-2.5-flash)`},{id:`worktree-mode`,name:`Worktree mode`,group:V.FEATURES,description:`Enable the EnterWorktree tool for isolated git worktree sessions`},{id:`session-memory`,name:`Session memory`,group:V.FEATURES,description:`Enable session memory (auto-extraction + past session search)`},{id:`dream-mode`,name:`Dream mode`,group:V.FEATURES,description:`Enable dream (/dream + auto-dream background memory consolidation)`},{id:`lean-memory-types`,name:`Lean memory types`,group:V.FEATURES,description:`Compact "Types of memory" prompt block + on-demand memory-types skill`},{id:`toolsets`,name:`Toolsets`,group:V.FEATURES,description:`Custom toolsets will be registered`},{id:`mcp-non-blocking`,name:`MCP non-blocking`,group:V.FEATURES,description:`If you have MCP servers, CC startup will be much faster`},{id:`mcp-batch-size`,name:`MCP batch size`,group:V.FEATURES,description:`Change the number of MCP servers started in parallel`},{id:`user-message-display`,name:`User message display`,group:V.FEATURES,description:`User messages in the chat history will be styled`},{id:`input-pattern-highlighters`,name:`Input pattern highlighters`,group:V.FEATURES,description:`Custom input highlighters will be registered`},{id:`conversation-title`,name:`Conversation title`,group:V.FEATURES,description:`/title command will be created & enabled`},{id:`voice-mode`,name:`Voice mode`,group:V.FEATURES,description:`Enable /voice command for speech-to-text input (hold Space to record)`},{id:`channels-mode`,name:`Channels mode`,group:V.FEATURES,description:`Enable MCP channel notifications (--channels without allowlist or dev flag)`},{id:`suppress-deferred-tools`,name:`Suppress deferred tools list (DANGEROUS)`,group:V.SYSTEM_REMINDERS,description:`Kill the "deferred tools are now available via ToolSearch" announcement. WARNING: MCP/Cron/EnterPlanMode/WebFetch/Monitor become invisible to the model unless explicitly named.`},{id:`claudemd-context-once-per-conversation`,name:`claudeMd context: once per conversation`,group:V.SYSTEM_REMINDERS,description:`Inject the claudeMd / userEmail / currentDate <system-reminder> only on the first API call per conversation (re-fires after /clear). Default: ON. Toggle OFF for vanilla CC per-turn injection.`}],Gi=()=>[...Wi],H=e=>e.replace(/\$/g,`\\$`),Ki=(e,t,n)=>{let r=[];for(let i of Wi){let a=t[i.id];if(n&&!n.includes(i.id)){r.push({id:i.id,name:i.name,group:i.group,applied:!1,skipped:!0,details:`not in --patches filter`,description:i.description});continue}if(a.condition===!1){r.push({id:i.id,name:i.name,group:i.group,applied:!1,skipped:!0,details:`not enabled`,description:i.description});continue}U(`Applying patch: ${i.name}`);let o=a.fn(e),s=o===null,c=!s&&o!==e;s||(e=o),r.push({id:i.id,name:i.name,group:i.group,applied:c,failed:s,description:i.description})}return{content:e,results:r}},qi=e=>{let t=g(e,[`--version`],{encoding:`utf8`,timeout:15e3}),n=`${t.stdout??``}${t.stderr??``}`;if(t.error||t.status!==0||/Expected CommonJS module|Bun v|TypeError/.test(n)){let t=Error(`Patched native binary failed startup sanity check (${e}).\n`+n.trim());throw t.stack=t.message,t}},Ji=async(e,t,r)=>{let i,o=!1;if(t.nativeInstallationPath){await ki(t);let e=!1;try{await a.stat(X),e=!0}catch{}let n=e?X:t.nativeInstallationPath;U(`Extracting claude.js from ${e?`backup`:`native installation`}: ${n}`);let{data:r,clearBytecode:c,error:u}=await C(n,t.version);if(!r)throw Error(`Failed to extract claude.js from native installation${u?`: ${u}`:``}`);o=c;let d=l.join(q,`native-claudejs-orig.js`);s.writeFileSync(d,r),U(`Saved original extracted JS from native to: ${d}`),i=r.toString(`utf8`)}else{if(await Oi(t),!t.cliPath)throw Error(`cliPath is required for NPM installations`);i=await a.readFile(t.cliPath,{encoding:`utf8`})}let c=[],u=i,d=await bn(i);i=d.content;let f=d.results.filter(e=>e.applied),p=d.results.filter(e=>e.failed);if(d.results.length>0){U(`inlineBlobOverrides: ${f.length} applied, ${p.length} failed`);for(let e of p)console.log(`inline-blob: failed "${e.name}" (${e.filename}): ${e.details}`)}for(let e of d.results)c.push({id:`inline-blob:${e.filename}`,name:e.name,group:V.SYSTEM_PROMPTS,applied:e.applied,failed:e.failed,skipped:e.skipped,details:e.details});let m=await vt(i,t.version??``);i=m.content;for(let e of m.results)c.push({id:`reminder:${e.id}`,name:`Reminder: ${e.name} (${e.state})`,group:V.SYSTEM_REMINDERS,applied:e.applied,failed:e.failed,skipped:e.skipped,details:e.details,description:e.description});let h=await on(i,t.version,void 0,r,u);i=h.newContent;let g=[...h.results].sort((e,t)=>e.name.localeCompare(t.name));c.push(...g);let _=e=>e.replace(/\\/g,`\\\\`).replace(/`/g,"\\`").replace(/\$/g,`\\$`),v=g.filter(e=>e.applied&&e.details).map(e=>_(`${e.name}: ${e.details}`)),y=e.settings.misc?.tableFormat??`default`,b=e.settings.misc?.showTweakccVersion??!0,x=e.settings.misc?.showPatchesApplied??!0,S=e.settings.misc?.enableModelCustomizations??!0,T={"verbose-property":{fn:e=>Oe(e),condition:!t.nativeInstallationPath},"read-default-lines":{fn:e=>bi(e)},"context-limit":{fn:e=>ce(e),condition:!!e.settings.misc?.enableContextLimitOverride},opusplan1m:{fn:e=>Fe(e),condition:S&&!t.nativeInstallationPath},"thinking-block-styling":{fn:e=>Rr(e),condition:t.version==null||Dt(t.version,`2.1.26`)<0},"fix-lsp-support":{fn:e=>Sn(e)},"fix-summarize-from-here":{fn:e=>Cn(e),condition:e.settings.misc?.fixSummarizeFromHere!==!1},"fix-rewind-summary-header":{fn:e=>wn(e),condition:e.settings.misc?.fixRewindSummaryHeader!==!1},"statusline-update-throttle":{fn:t=>Ur(t,e.settings.misc?.statuslineThrottleMs??300,e.settings.misc?.statuslineUseFixedInterval??!1),condition:e.settings.misc?.statuslineThrottleMs!=null},"clear-screen":{fn:e=>vi(e)},"strip-empty-system-reminders":{fn:e=>Si(e)},"patches-applied-indication":{fn:e=>Ge(e,Ui,v,b,x)},"model-customizations":{fn:e=>Zi(e),condition:S},"show-more-items-in-select-menus":{fn:e=>ie(e,25),condition:S},"table-format":{fn:e=>ir(e,y),condition:y!==`default`},themes:{fn:t=>oe(t,e.settings.themes),condition:!!(e.settings.themes&&e.settings.themes.length>0&&JSON.stringify(e.settings.themes)!==JSON.stringify(E.themes))},"thinking-verbs":{fn:t=>be(t,e.settings.thinkingVerbs.verbs),condition:!!e.settings.thinkingVerbs&&JSON.stringify(e.settings.thinkingVerbs.verbs)!==JSON.stringify(E.thinkingVerbs.verbs)},"thinker-format":{fn:t=>de(t,e.settings.thinkingVerbs.format),condition:!!e.settings.thinkingVerbs&&e.settings.thinkingVerbs.format!==E.thinkingVerbs.format},"thinker-symbol-chars":{fn:t=>me(t,e.settings.thinkingStyle.phases),condition:JSON.stringify(e.settings.thinkingStyle.phases)!==JSON.stringify(E.thinkingStyle.phases)},"thinker-symbol-speed":{fn:t=>he(t,e.settings.thinkingStyle.updateInterval),condition:e.settings.thinkingStyle.updateInterval!==E.thinkingStyle.updateInterval&&(t.version==null||Dt(t.version,`2.1.27`)<0)},"thinker-symbol-width":{fn:t=>_e(t,Math.max(...e.settings.thinkingStyle.phases.map(e=>e.length))+1),condition:JSON.stringify(e.settings.thinkingStyle.phases)!==JSON.stringify(E.thinkingStyle.phases)},"thinker-symbol-mirror":{fn:t=>pe(t,e.settings.thinkingStyle.reverseMirror),condition:e.settings.thinkingStyle.reverseMirror!==E.thinkingStyle.reverseMirror},"input-box-border":{fn:t=>le(t,e.settings.inputBox.removeBorder),condition:!!(e.settings.inputBox&&e.settings.inputBox.removeBorder!==E.inputBox.removeBorder)},"subagent-models":{fn:t=>Be(t,e.settings.subagentModels),condition:!!e.settings.subagentModels&&JSON.stringify(e.settings.subagentModels)!==JSON.stringify(E.subagentModels)},"thinking-visibility":{fn:e=>Ie(e),condition:e.settings.misc?.expandThinkingBlocks??!0},"hide-startup-banner":{fn:e=>vr(e),condition:!!e.settings.misc?.hideStartupBanner},"hide-ctrl-g-to-edit":{fn:e=>br(e),condition:!!e.settings.misc?.hideCtrlGToEdit},"hide-startup-clawd":{fn:e=>Sr(e),condition:!!e.settings.misc?.hideStartupClawd},"increase-file-read-limit":{fn:e=>wr(e),condition:!!e.settings.misc?.increaseFileReadLimit},"suppress-line-numbers":{fn:e=>Er(e),condition:!!e.settings.misc?.suppressLineNumbers},"suppress-rate-limit-options":{fn:e=>Dr(e),condition:!!e.settings.misc?.suppressRateLimitOptions},"token-count-rounding":{fn:t=>Gr(t,e.settings.misc.tokenCountRounding),condition:!!e.settings.misc?.tokenCountRounding},"remember-skill":{fn:e=>Lr(e),condition:!!e.settings.misc?.enableRememberSkill},"agents-md":{fn:t=>Kr(t,e.settings.claudeMdAltNames),condition:!!(e.settings.claudeMdAltNames&&e.settings.claudeMdAltNames.length>0)},"auto-accept-plan-mode":{fn:e=>Zr(e),condition:!!e.settings.misc?.autoAcceptPlanMode},"allow-sudo-bypass-permissions":{fn:e=>Qr(e),condition:!!e.settings.misc?.allowBypassPermissionsInSudo},"suppress-native-installer-warning":{fn:e=>ei(e),condition:!!e.settings.misc?.suppressNativeInstallerWarning},"filter-scroll-escape-sequences":{fn:e=>ni(e),condition:!!e.settings.misc?.filterScrollEscapeSequences},"max-effort-default":{fn:e=>ai(e),condition:!!e.settings.misc?.maxEffortDefault},"autonomous-operation-all-models":{fn:e=>oi(e),condition:!!e.settings.misc?.autonomousOperationAllModels},"auto-mode-classifier-model":{fn:t=>ci(t,e.settings.misc?.autoModeClassifierModel??`default`),condition:(e.settings.misc?.autoModeClassifierModel??`default`)!==`default`},"allow-custom-agent-models":{fn:e=>ii(e),condition:!!e.settings.misc?.allowCustomAgentModels},"worktree-mode":{fn:e=>ri(e),condition:!!e.settings.misc?.enableWorktreeMode},"session-memory":{fn:e=>Mr(e),condition:!!e.settings.misc?.enableSessionMemory},"dream-mode":{fn:e=>Nr(e),condition:!!e.settings.misc?.enableDreamMode},"lean-memory-types":{fn:e=>Pr(e),condition:!!e.settings.misc?.enableLeanMemoryTypes},toolsets:{fn:t=>Kn(t,e.settings.toolsets,e.settings.defaultToolset,e.settings.planModeToolset),condition:!!(e.settings.toolsets&&e.settings.toolsets.length>0)},"mcp-non-blocking":{fn:e=>Vr(e),condition:!!e.settings.misc?.mcpConnectionNonBlocking&&(t.version==null||Dt(t.version,`2.1.85`)<0)},"mcp-batch-size":{fn:t=>Hr(t,e.settings.misc.mcpServerBatchSize),condition:!!e.settings.misc?.mcpServerBatchSize},"user-message-display":{fn:t=>Se(t,e.settings.userMessageDisplay),condition:!!(e.settings.userMessageDisplay&&JSON.stringify(e.settings.userMessageDisplay)!==JSON.stringify(E.userMessageDisplay))},"input-pattern-highlighters":{fn:t=>Ee(t,e.settings.inputPatternHighlighters),condition:!!(e.settings.inputPatternHighlighters&&e.settings.inputPatternHighlighters.length>0)},"conversation-title":{fn:e=>gr(e),condition:(e.settings.misc?.enableConversationTitle??!0)&&!t.nativeInstallationPath},"voice-mode":{fn:t=>di(t,e.settings.misc?.enableVoiceConciseOutput??!0),condition:!!e.settings.misc?.enableVoiceMode},"channels-mode":{fn:e=>_i(e),condition:!!e.settings.misc?.enableChannelsMode},"suppress-deferred-tools":{fn:e=>wi(e),condition:!!e.settings.misc?.suppressDeferredTools},"claudemd-context-once-per-conversation":{fn:e=>xi(e),condition:e.settings.misc?.claudemdContextOncePerConversation??!0}},{content:ee,results:te}=Ki(i,T,r);i=ee,c.push(...te);let D=te.filter(e=>e.failed);if(t.nativeInstallationPath&&D.length>0){let e=Error(`Refusing to repack the native binary: ${D.length} binary patch(es) failed (${D.map(e=>e.id).join(`, `)}) on Claude Code ${t.version}. The binary was left unchanged — your Claude Code still works. Each failure’s cause is in the "patch: … failed to …" line(s) above; this usually means Anthropic changed the code shape in CC ${t.version}, so a patch’s pattern no longer matches. Update tweakcc-fixed, or disable the failing optional patch(es) in ~/.tweakcc/config.json, then re-run --apply.`);throw e.stack=e.message,e}if(t.nativeInstallationPath){U(`Repacking modified claude.js into native installation: ${t.nativeInstallationPath}`);let e=l.join(q,`native-claudejs-patched.js`);s.writeFileSync(e,i,`utf8`),U(`Saved patched JS from native to: ${e}`);let r=Buffer.from(i,`utf8`),c=await a.mkdtemp(l.join(n.tmpdir(),`tweakcc-native-`)),u=l.join(c,l.basename(t.nativeInstallationPath));try{await a.copyFile(t.nativeInstallationPath,u),await a.chmod(u,s.statSync(t.nativeInstallationPath).mode),await w(u,r,u,o),qi(u);let e=t.nativeInstallationPath,n=l.join(l.dirname(e),`.${l.basename(e)}.tweakcc-${process.pid}`);try{await a.copyFile(u,n),await a.chmod(n,s.statSync(e).mode),await a.rename(n,e)}catch(e){throw await a.rm(n,{force:!0}),e}}finally{await a.rm(c,{recursive:!0,force:!0})}}else{if(!t.cliPath)throw Error(`cliPath is required for NPM installations`);D.length>0&&console.warn(`tweakcc: ${D.length} patch(es) did not apply on Claude Code ${t.version}: ${D.map(e=>e.id).join(`, `)}. Those feature(s) are skipped; everything else was applied. Each cause is in the "patch: … failed to …" line(s) above — usually a CC version whose code shape a patch does not match yet. Update tweakcc-fixed, or disable the failing optional patch(es) in ~/.tweakcc/config.json.`),await ga(t.cliPath,i,`patch`)}return{config:await $(e=>{e.changesApplied=!0}),results:c}},Yi=[{value:`claude-opus-4-6`,label:`Opus 4.6`,description:`Claude Opus 4.6 (February 2026)`},{value:`claude-sonnet-4-6`,label:`Sonnet 4.6`,description:`Claude Sonnet 4.6 (February 2026)`},{value:`claude-haiku-4-5-20251001`,label:`Haiku 4.5`,description:`Claude Haiku 4.5 (October 2025)`},{value:`claude-opus-4-5-20251101`,label:`Opus 4.5`,description:`Claude Opus 4.5 (November 2025)`},{value:`claude-sonnet-4-5-20250929`,label:`Sonnet 4.5`,description:`Claude Sonnet 4.5 (September 2025)`},{value:`claude-opus-4-1-20250805`,label:`Opus 4.1`,description:`Claude Opus 4.1 (August 2025)`},{value:`claude-opus-4-20250514`,label:`Opus 4`,description:`Claude Opus 4 (May 2025)`},{value:`claude-sonnet-4-20250514`,label:`Sonnet 4`,description:`Claude Sonnet 4 (May 2025)`},{value:`claude-3-7-sonnet-20250219`,label:`Sonnet 3.7`,description:`Claude 3.7 Sonnet (February 2025)`},{value:`claude-3-5-sonnet-20241022`,label:`Sonnet 3.5 (October)`,description:`Claude 3.5 Sonnet (October 2024)`},{value:`claude-3-5-haiku-20241022`,label:`Haiku 3.5`,description:`Claude 3.5 Haiku (October 2024)`},{value:`claude-3-5-sonnet-20240620`,label:`Sonnet 3.5 (June)`,description:`Claude 3.5 Sonnet (June 2024)`},{value:`claude-3-haiku-20240307`,label:`Haiku 3`,description:`Claude 3 Haiku (March 2024)`},{value:`claude-3-opus-20240229`,label:`Opus 3`,description:`Claude 3 Opus (February 2024)`}],Xi=e=>{let t=e.match(/ ([$\w]+)\.push\(\{value:[$\w]+,label:[$\w]+,description:"Custom model"\}\)/);if(!t||t.index===void 0)return console.error(`patch: findCustomModelListInsertionPoint: failed to find custom model push`),null;let n=t[1],r=Math.max(0,t.index-5e3),i=e.slice(r,t.index),a=`(?:(?:let|var|const) |,)${H(n)}=.+?;`,o=RegExp(`function [$\\w]+\\([^)]*\\)\\{[\\s\\S]{0,5000}?${a}`,`g`),s=null,c;for(;(c=o.exec(i))!==null;)s=c;return s?{insertionIndex:r+s.index+s[0].length,modelListVar:n}:(console.error(`patch: findCustomModelListInsertionPoint: failed to find function with ${n}`),null)},Zi=e=>{if(e.includes(`"value":"claude-opus-4-6"`))return console.log(`patch: modelCustomizations: custom models already present — skipping`),e;let t=Xi(e);if(!t)return null;let{insertionIndex:n,modelListVar:r}=t,i=Yi.map(e=>`${r}.push(${JSON.stringify(e)});`).join(``),a=e.slice(0,n)+i+e.slice(n);return F(e,a,i,n,n),a};let Qi=!1,$i=!1,ea=!1;const ta=()=>Qi,na=()=>$i,ra=()=>ea,ia=()=>{Qi=!0},aa=()=>{$i=!0,Qi=!0},oa=()=>{ea=!0},U=(e,...t)=>{ta()&&console.log(e,...t)},W=(e,...t)=>{na()&&console.log(e,...t)},G=e=>e.replace(/[\u0080-\uffff]/g,e=>`\\u`+e.charCodeAt(0).toString(16).padStart(4,`0`));function sa(){try{let e=f.join(p.homedir(),`.claude.json`);return JSON.parse(d.readFileSync(e,`utf8`)).theme||`dark`}catch{}return`dark`}function ca(e){try{let t=f.join(p.homedir(),`.claude.json`),n=JSON.parse(d.readFileSync(t,`utf8`));n.theme=e,d.writeFileSync(t,JSON.stringify(n,null,2))}catch{}}function la(){try{let e=f.join(p.homedir(),`.claude`,`.credentials.json`);switch(JSON.parse(d.readFileSync(e,`utf8`))?.claudeAiOauth?.subscriptionType||`unknown`){case`enterprise`:return`Claude Enterprise`;case`team`:return`Claude Team`;case`max`:return`Claude Max`;case`pro`:return`Claude Pro`}}catch{}return`Claude API`}function ua(){try{let e=f.join(p.homedir(),`.claude`,`settings.json`),t=JSON.parse(d.readFileSync(e,`utf8`))?.model||`default`;if(t===`opus`)return`Opus 4.5`;let n=Yi.find(e=>e.value===t);if(n)return n.label}catch{}return`Opus 4.5`}function da(e){process.platform===`win32`?m.spawn(`explorer`,[e],{detached:!0,stdio:`ignore`}).unref():process.platform===`darwin`?m.spawn(`open`,[e],{detached:!0,stdio:`ignore`}).unref():m.spawn(`xdg-open`,[e],{detached:!0,stdio:`ignore`}).unref()}function fa(e){if(process.platform===`win32`)m.spawn(`explorer`,[`/select,`,e],{detached:!0,stdio:`ignore`}).unref();else if(process.platform===`darwin`)m.spawn(`open`,[`-R`,e],{detached:!0,stdio:`ignore`}).unref();else{let t=f.dirname(e);m.spawn(`xdg-open`,[t],{detached:!0,stdio:`ignore`}).unref()}}function pa(e){if(!e||typeof e!=`string`)return!1;let t=e.trim();if(/^#([a-fA-F0-9]{3}|[a-fA-F0-9]{6})$/.test(t))return!0;if(/^rgb\(\s*\d{1,3}\s*,\s*\d{1,3}\s*,\s*\d{1,3}\s*\)$/.test(t)){let e=t.match(/rgb\((\d+),\s*(\d+),\s*(\d+)\)/);if(e){let[,t,n,r]=e;return parseInt(t)<=255&&parseInt(n)<=255&&parseInt(r)<=255}}if(/^hsl\(\s*\d{1,3}\s*,\s*\d{1,3}%\s*,\s*\d{1,3}%\s*\)$/.test(t)){let e=t.match(/hsl\((\d+),\s*(\d+)%,\s*(\d+)%\)/);if(e){let[,t,n,r]=e;return parseInt(t)<=360&&parseInt(n)<=100&&parseInt(r)<=100}}return!1}function ma(e){if(!pa(e))return e;let t=e.trim();if(t.startsWith(`rgb(`))return t;if(t.startsWith(`#`)){let e=t.slice(1);return e.length===3&&(e=e.split(``).map(e=>e+e).join(``)),`rgb(${parseInt(e.slice(0,2),16)},${parseInt(e.slice(2,4),16)},${parseInt(e.slice(4,6),16)})`}if(t.startsWith(`hsl(`)){let e=t.match(/hsl\((\d+),\s*(\d+)%,\s*(\d+)%\)/);if(e){let t=parseInt(e[1])/360,n=parseInt(e[2])/100,r=parseInt(e[3])/100,i=(e,t,n)=>(n<0&&(n+=1),n>1&&--n,n<1/6?e+(t-e)*6*n:n<1/2?t:n<2/3?e+(t-e)*(2/3-n)*6:e),a=r<.5?r*(1+n):r+n-r*n,o=2*r-a;return`rgb(${Math.round(i(o,a,t+1/3)*255)},${Math.round(i(o,a,t)*255)},${Math.round(i(o,a,t-1/3)*255)})`}}return e}async function ha(e,t=`sha256`,n=64*1024){return new Promise((r,i)=>{let a=h.createHash(t),o=d.createReadStream(e,{highWaterMark:n});o.on(`data`,e=>{a.update(e)}),o.on(`end`,()=>{r(a.digest(`hex`))}),o.on(`error`,e=>{i(e)})})}async function ga(e,t,n=`replace`){let r=493;try{r=(await o.stat(e)).mode,U(`[${n}] Original file mode for ${e}: ${(r&511).toString(8)}`)}catch(t){U(`[${n}] Could not stat ${e} (error: ${t}), using default mode 755`)}try{await o.unlink(e),U(`[${n}] Unlinked ${e} to break hard links`)}catch(t){U(`[${n}] Could not unlink ${e}: ${t}`)}await o.writeFile(e,t),await o.chmod(e,r),U(`[${n}] Restored permissions to ${(r&511).toString(8)}`)}async function _a(e){try{return await o.stat(e),!0}catch(e){if(e instanceof Error&&`code`in e&&(e.code===`ENOENT`||e.code===`ENOTDIR`||e.code===`EACCES`||e.code===`EPERM`))return!1;throw e}}const va=e=>e.startsWith(`~`)?f.join(p.homedir(),e.slice(1)):e,ya=(e,t)=>{let n=e=>{let t=e.split(`.`).map(Number);return[t[0]||0,t[1]||0,t[2]||0]},r=n(e),i=n(t);return r[0]===i[0]?r[1]===i[1]?r[2]-i[2]:r[1]-i[1]:r[0]-i[0]},ba=e=>{let t=e.toString(),n=t.lastIndexOf(`/`);return`new RegExp(${JSON.stringify(t.substring(1,n))}, ${JSON.stringify(t.substring(n+1))})`};function K(e,t){if(e==null)return t;if(typeof t!=`object`||!t)return e;if(Array.isArray(t))return Array.isArray(e)?e:t;let n={...e};for(let e of Object.keys(t)){let r=t[e];e in n?typeof r==`object`&&r&&!Array.isArray(r)&&(n[e]=K(n[e],r)):n[e]=r}return n}const xa=async(e,t=33554432)=>{let n=Number(e.headers.get(`content-length`));if(Number.isFinite(n)&&n>t)throw Error(`Response body too large: ${n} bytes exceeds the ${t}-byte limit.`);let r=e.body;if(!r){let n=await e.text();if(Buffer.byteLength(n,`utf8`)>t)throw Error(`Response body exceeds the ${t}-byte limit.`);return n}let i=r.getReader(),a=[],o=0;for(;;){let{done:e,value:n}=await i.read();if(e)break;if(n){if(o+=n.byteLength,o>t)throw await i.cancel().catch(()=>{}),Error(`Response body exceeds the ${t}-byte limit — aborting download.`);a.push(Buffer.from(n))}}return Buffer.concat(a).toString(`utf8`)},Sa=e=>{let t=e?.settings?.userMessageDisplay;if(!t)return;let n=!!t.prefix,r=`borderStyle`in t,i=`padding`in t,a=`paddingX`in t,o=`fitBoxToContent`in t,s=t.padding;n&&(e.settings.userMessageDisplay={format:(t.prefix?.format||``)+(t.message?.format||`{}`),styling:[...t.prefix?.styling||[],...t.message?.styling||[]],foregroundColor:t.message?.foregroundColor===`rgb(0,0,0)`?`default`:t.message?.foregroundColor||t.prefix?.foregroundColor||`default`,backgroundColor:t.message?.backgroundColor===`rgb(0,0,0)`?null:t.message?.backgroundColor||t.prefix?.backgroundColor||null,borderStyle:`none`,borderColor:`rgb(255,255,255)`,paddingX:0,paddingY:0,fitBoxToContent:!1});let c=e.settings.userMessageDisplay;r||(c.borderStyle=`none`,c.borderColor=`rgb(255,255,255)`),i&&!a?(c.paddingX=s||0,c.paddingY=0,delete c.padding):a||(c.paddingX=0,c.paddingY=0),o||(c.fitBoxToContent=!1)},Ca=e=>{let t=e?.settings?.misc;t&&`hideCtrlGToEditPrompt`in t&&(t.hideCtrlGToEdit=t.hideCtrlGToEditPrompt,delete t.hideCtrlGToEditPrompt)};async function wa(){try{let e=await o.readFile(J,`utf8`),t=JSON.parse(e);return Object.hasOwn(t,`ccInstallationDir`)?(t.ccInstallationDir&&!t.ccInstallationPath&&(t.ccInstallationPath=u.join(t.ccInstallationDir,`cli.js`)),delete t.ccInstallationDir,t.lastModified=new Date().toISOString(),await ka(),await o.writeFile(J,JSON.stringify(t,null,2)),!0):!1}catch(e){if(e instanceof Error&&`code`in e&&e.code===`ENOENT`||e instanceof SyntaxError)return!1;throw e}}const Ta=()=>{let e=process.env.TWEAKCC_CONFIG_DIR?.trim();if(e&&e.length>0)return va(e);let t=u.join(r.homedir(),`.tweakcc`),n=u.join(r.homedir(),`.claude`,`tweakcc`),i=process.env.XDG_CONFIG_HOME;try{if(c.existsSync(t))return t}catch(e){U(`Failed to check if ${t} exists: ${e}`)}try{if(c.existsSync(n))return n}catch(e){U(`Failed to check if ${n} exists: ${e}`)}return i?u.join(i,`tweakcc`):t},q=Ta(),J=u.join(q,`config.json`),Y=u.join(q,`cli.js.backup`),X=u.join(q,`native-binary.backup`),Z=u.join(q,`system-prompts`),Ea=u.join(q,`system-reminders`),Da=u.join(q,`prompt-data-cache`),Oa=()=>{let e=q,n=r.homedir(),i=[u.join(n,`.tweakcc`),u.join(n,`.claude`,`tweakcc`),process.env.XDG_CONFIG_HOME?u.join(process.env.XDG_CONFIG_HOME,`tweakcc`):null].filter(e=>e!==null).filter(t=>{try{return c.existsSync(t)&&t!==e}catch{return!1}});i.length>0&&(console.warn(t.yellow(`
|
|
721
|
+
`,r=e.slice(0,t)+n+e.slice(t);return F(e,r,n,t,t),r},ii=e=>{let t=e.match(/function [$\w]+\(\)\{return [$\w]+\("tengu_worktree_mode"/);if(!t||t.index===void 0)return e.includes(`EnterWorktree`)?e:(console.error(`patch: worktreeMode: failed to find worktree gate function pattern`),null);let n=t.index+t[0].indexOf(`{`)+1,r=`return !0;`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i},ai=e=>{let t=e,n=t.match(/,model:([$\w]+)\.enum\(([$\w]+)\)\.optional\(\)/);if(!n||n.index===void 0)return t.match(/let\s+[$\w]+\s*=\s*([$\w]+)\s*&&\s*typeof\s+\1\s*===\s*"string"\s*&&\s*[$\w]+\.includes\(\1\)/)?(console.error(`patch: allowCustomAgentModels: failed to find Zod enum pattern`),null):t;let r=n[1],i=n[2],a=`,model:${r}.string().optional()`,o=n.index,s=o+n[0].length;t=t.slice(0,o)+a+t.slice(s),F(e,t,a,o,s);let c=i.replace(/\$/g,`\\$`),l=RegExp(`([;)}])let\\s+([\\$\\w]+)\\s*=\\s*([\\$\\w]+)\\s*&&\\s*typeof\\s+\\3\\s*===\\s*"string"\\s*&&\\s*${c}\\.includes\\(\\3\\)`),u=t,d=t.match(l);if(!d||d.index===void 0)return console.error(`patch: allowCustomAgentModels: failed to find model validation flag pattern`),null;let f=d[1],p=d[2],m=d[3],h=`${f}let ${p}=${m}&&typeof ${m}==="string"`,g=d.index,_=g+d[0].length;return t=t.slice(0,g)+h+t.slice(_),F(u,t,h,g,_),t},oi=e=>{let t=e,n=/function\s+([$\w]+)\s*\(\s*([$\w]+)\s*\)\s*\{\s*if\s*\(\s*([$\w]+)\s*\(\s*\2\s*\)\s*===\s*"claude-opus-4-7"\s*\)\s*return\s*"xhigh"\s*;\s*return\s*"high"\s*\}/,r=t.match(/function\s+([$\w]+)\s*\(\s*([$\w]+)\s*\)\s*\{\s*if\s*\(\s*([$\w]+)\s*\(\s*\2\s*\)\s*===\s*"claude-opus-4-8"\s*\)\s*return\s*"high"\s*;\s*if\s*\(\s*\3\s*\(\s*\2\s*\)\s*===\s*"claude-opus-4-7"\s*\)\s*return\s*"xhigh"\s*;\s*return\s*"high"\s*\}/),i=r||t.match(n);if(i&&i.index!==void 0){let[e,n,a,o]=i,s=r?`function ${n}(${a}){if(${o}(${a})==="claude-opus-4-8")return"max";if(${o}(${a})==="claude-opus-4-7")return"max";return"high"}`:`function ${n}(${a}){if(${o}(${a})==="claude-opus-4-7")return"max";return"high"}`,c=t.slice(0,i.index)+s+t.slice(i.index+e.length);F(t,c,s,i.index,i.index+e.length),t=c}else if(/===\s*"claude-opus-4-8"\s*\)\s*return\s*"max"/.test(t)||/function\s+[$\w]+\s*\(\s*[$\w]+\s*\)\s*\{\s*if\s*\(\s*[$\w]+\s*\(\s*[$\w]+\s*\)\s*===\s*"claude-opus-4-7"\s*\)\s*return\s*"max"\s*;\s*return\s*"high"\s*\}/.test(t))W(`patch: maxEffortDefault: per-model default already "max" — skipping`);else return console.error(`patch: maxEffortDefault: failed to find Opus per-model effort default`),null;return t},si=e=>{let t=e.match(/function\s+([$\w]+)\s*\(\s*([$\w]+)\s*\)\s*\{\s*if\s*\(\s*\2\s*===\s*"claude-fable-5"\s*\|\|\s*\2\s*===\s*"claude-mythos-5"\s*\)\s*return\s*!0\s*;\s*return\s*!1\s*\}/);if(!t||t.index===void 0)return/"claude-mythos-5"\s*\)\s*return\s*!0\s*;\s*return\s*!0\s*\}/.test(e)?(W(`patch: autonomousOperationAllModels: model-family gate already flipped — skipping`),e):/"claude-fable-5"/.test(e)?(console.error(`patch: autonomousOperationAllModels: found the fable/mythos model ids but not the expected gate shape — needs a new match method`),null):(console.log(`patch: autonomousOperationAllModels: fable/mythos model-family gate not present in this CC build — no-op`),e);let[n,r,i]=t,a=`function ${r}(${i}){if(${i}==="claude-fable-5"||${i}==="claude-mythos-5")return!0;return!0}`,o=e.slice(0,t.index)+a+e.slice(t.index+n.length);return F(e,o,a,t.index,t.index+n.length),o},ci={sonnet:`claude-sonnet-4-6`,haiku:`claude-haiku-4-5`},li=(e,t)=>{if(t===`default`)return e;let n=ci[t],r=e.match(/function\s+([$\w]+)\s*\(\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\(\s*\)\s*,\s*([$\w]+)\s*=\s*[$\w]+\s*\(\s*"tengu_auto_mode_config"\s*,\s*\{\s*\}\s*\)\s*,\s*([$\w]+)\s*=\s*\3\s*\?\.\s*modelByMainModel\s*;\s*if\s*\(\s*\4\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*;\s*if\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*\4\s*\[\s*`[^`]*`\s*\]\s*;\s*if\s*\(\s*\6\s*\)\s*return\s+\6\s*\}\s*let\s+([$\w]+)\s*=\s*\4\s*\[\s*\5\s*\]\s*;\s*if\s*\(\s*\7\s*\)\s*return\s+\7\s*\}\s*if\s*\(\s*\3\s*\?\.\s*model\s*\)\s*return\s+\3\s*\.\s*model\s*;\s*if\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\|\|\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*return\s+[$\w]+\s*\(\s*\2\s*\)\s*;\s*return\s+\2\s*\}/)||e.match(/function\s+([$\w]+)\s*\(\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\(\s*\)\s*,\s*([$\w]+)\s*=\s*[$\w]+\s*\(\s*"tengu_auto_mode_config"\s*,\s*\{\s*\}\s*\)\s*,\s*([$\w]+)\s*=\s*\3\s*\?\.\s*modelByMainModel\s*;\s*if\s*\(\s*\4\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*;\s*if\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*\4\s*\[\s*`[^`]*`\s*\]\s*;\s*if\s*\(\s*\6\s*\)\s*return\s+\6\s*\}\s*let\s+([$\w]+)\s*=\s*\4\s*\[\s*\5\s*\]\s*;\s*if\s*\(\s*\7\s*\)\s*return\s+\7\s*\}\s*if\s*\(\s*\3\s*\?\.\s*model\s*\)\s*return\s+\3\s*\.\s*model\s*;\s*if\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\|\|\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\.\s*ANTHROPIC_DEFAULT_OPUS_MODEL\s*\?\?\s*[$\w]+\s*\(\s*\)\s*\.\s*[$\w]+\s*;\s*if\s*\(\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\|\|\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*&&\s*!\s*[$\w]+\s*\(\s*\8\s*\)\s*&&\s*!\s*[$\w]+\s*\(\s*\8\s*\)\s*\)\s*return\s+\8\s*\+\s*"\[1m\]"\s*;\s*return\s+\8\s*\}\s*return\s+\2\s*\}/)||e.match(/function\s+([$\w]+)\s*\(\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\(\s*\)\s*,\s*([$\w]+)\s*=\s*[$\w]+\s*\(\s*"tengu_auto_mode_config"\s*,\s*\{\s*\}\s*\)\s*,\s*([$\w]+)\s*=\s*\3\s*\?\.\s*modelByMainModel\s*;\s*if\s*\(\s*\4\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\(\s*\2\s*\)\s*\.\s*replace\([^)]*\)\s*;\s*if\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*\4\s*\[\s*`[^`]*`\s*\]\s*;\s*if\s*\(\s*\6\s*\)\s*return\s+\6\s*\}\s*let\s+([$\w]+)\s*=\s*\4\s*\[\s*\5\s*\]\s*;\s*if\s*\(\s*\7\s*\)\s*return\s+\7\s*\}\s*if\s*\(\s*\3\s*\?\.\s*model\s*\)\s*return\s+\3\s*\.\s*model\s*;\s*if\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\|\|\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\.\s*ANTHROPIC_DEFAULT_OPUS_MODEL\s*\?\?\s*[$\w]+\s*\(\s*\)\s*\.\s*[$\w]+\s*;\s*if\s*\(\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\|\|\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*&&\s*!\s*[$\w]+\s*\(\s*\8\s*\)\s*&&\s*!\s*[$\w]+\s*\(\s*\8\s*\)\s*\)\s*return\s+\8\s*\+\s*"\[1m\]"\s*;\s*return\s+\8\s*\}\s*return\s+\2\s*\}/)||e.match(/function\s+([$\w]+)\s*\(\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\(\s*\)\s*,\s*([$\w]+)\s*=\s*[$\w]+\s*\(\s*"tengu_auto_mode_config"\s*,\s*\{\s*\}\s*\)\s*,\s*([$\w]+)\s*=\s*\3\s*\?\.\s*modelByMainModel\s*;\s*if\s*\(\s*\4\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*[$\w]+\s*\(\s*\2\s*\)\s*\.\s*replace\([^)]*\)\s*;\s*if\s*\(\s*[$\w]+\s*\(\s*\2\s*\)\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*\4\s*\[\s*`[^`]*`\s*\]\s*;\s*if\s*\(\s*\6\s*\)\s*return\s+\6\s*\}\s*let\s+([$\w]+)\s*=\s*\4\s*\[\s*\5\s*\]\s*;\s*if\s*\(\s*\7\s*\)\s*return\s+\7\s*\}\s*if\s*\(\s*\3\s*\?\.\s*model\s*\)\s*return\s+\3\s*\.\s*model\s*;\s*return\s+\2\s*\}/)||e.match(/function\s+([$\w]+)\s*\(\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*([$\w]+)\s*\(\s*\)\s*;\s*if\s*\(\s*([$\w]+)\s*\(\s*\2\s*\)\s*===\s*"claude-opus-4-8"\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*([$\w]+)\s*\(\s*"tengu_cedar_hollow_7m"\s*,\s*\{\s*\}\s*\)\s*;\s*if\s*\(\s*\5\s*\?\.\s*model\s*\)\s*return\s+\5\s*\.\s*model\s*\}\s*let\s+([$\w]+)\s*=\s*([$\w]+)\s*\(\s*"tengu_auto_mode_config"\s*,\s*\{\s*\}\s*\)\s*;\s*if\s*\(\s*\7\s*\?\.\s*model\s*\)\s*return\s+\7\s*\.\s*model\s*;\s*return\s+\2\s*\}/)||e.match(/function\s+([$\w]+)\s*\(\s*\)\s*\{\s*let\s+([$\w]+)\s*=\s*([$\w]+)\s*\(\s*"tengu_auto_mode_config"\s*,\s*\{\s*\}\s*\)\s*;\s*if\s*\(\s*\2\s*\?\.\s*model\s*\)\s*return\s+\2\s*\.\s*model\s*;\s*return\s+([$\w]+)\s*\(\s*\)\s*\}/);if(r&&r.index!==void 0){let[t,i]=r,a=`function ${i}(){return "${n}"}`,o=e.slice(0,r.index)+a+e.slice(r.index+t.length);return F(e,o,a,r.index,r.index+t.length),o}return/function\s+[$\w]+\s*\(\s*\)\s*\{\s*return\s*"claude-(opus|sonnet|haiku)-[0-9a-z-]+"\s*\}/.test(e)?(W(`patch: autoModeClassifierModel: classifier-model resolver already patched — skipping`),e):e.includes(`"tengu_auto_mode_config"`)?(console.error(`patch: autoModeClassifierModel: failed to find auto-mode classifier resolver`),null):(W(`patch: autoModeClassifierModel: tengu_auto_mode_config not present in this CC build — no-op`),e)},ui=e=>{let t=e.match(/function [$\w]+\(\)\{return [$\w]+\("tengu_amber_quartz"/);if(t&&t.index!==void 0){let n=t.index+t[0].indexOf(`{`)+1,r=`return !0;`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i}let n=e.match(/function [$\w]+\(\)\{return![$\w]+\("tengu_amber_quartz_disabled"/);if(n&&n.index!==void 0){let t=n.index+n[0].indexOf(`{`)+1,r=`return !0;`,i=e.slice(0,t)+r+e.slice(t);return F(e,i,r,t,t),i}let r=e.match(/name:"voice",description:"Toggle voice mode"[\s\S]{0,500}?get isHidden\(\)\{return!([$\w]+)\(\)\}/);if(r&&r.index!==void 0){let t=r[1].replace(/[$]/g,`\\$`),n=RegExp(`function ${t}\\(\\)\\{`),i=e.match(n);if(i&&i.index!==void 0){let t=i.index+i[0].length,n=`return !0;`,r=e.slice(0,t)+n+e.slice(t);return F(e,r,n,t,t),r}}return console.error(`patch: voiceMode: failed to find tengu_amber_quartz gate`),null},di=e=>{let t=e.match(/if\([$\w]+\("tengu_sotto_voce",!1\)\)/);if(!t||t.index===void 0)return e;let n=`if(!0)`,r=e.slice(0,t.index)+n+e.slice(t.index+t[0].length);return F(e,r,n,t.index,t.index+t[0].length),r},fi=(e,t)=>{let n=ui(e);return!n||t&&(n=di(n),!n)?null:n},pi=e=>{let t=e.match(/function [$\w]+\(\)\{return [$\w]+\("tengu_harbor",!1\)/);if(!t||t.index===void 0)return console.error(`patch: channelsMode: failed to find tengu_harbor gate`),null;let n=t.index+t[0].indexOf(`{`)+1,r=`return !0;`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i},mi=e=>{let t=e.match(/reason:"server did not declare claude\/channel capability"\};?/);if(!t||t.index===void 0)return console.error(`patch: channelsMode: failed to find gateChannelServer capability check`),null;let n=t.index+t[0].length,r=`return{action:"register"};`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i},hi=e=>{let t=e.match(/function [$\w]+\(\)\{return [$\w]+\("tengu_harbor_permissions",!1\)/);if(!t||t.index===void 0)return console.error(`patch: channelsMode: failed to find tengu_harbor_permissions gate`),null;let n=t.index+t[0].indexOf(`{`)+1,r=`return !0;`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i},gi=e=>{let t=e.match(/Experimental[^"]*?inbound messages will be pushed into this session, this carries prompt injection risks\. Restart Claude Code without /);if(!t||t.index===void 0)return console.error(`patch: channelsMode: failed to find ChannelsNotice warning text`),null;let n=`Channels active. Restart Claude Code without `,r=t.index,i=r+t[0].length,a=e.slice(0,r)+n+e.slice(i);return F(e,a,n,r,i),a},_i=e=>{let t=e.match(/if\(![$\w]+\.dev\)[$\w]+\.push\(\{[$\w]+:[$\w]+,[$\w]+:"server: entries need --dangerously-load-development-channels"\}\)/);if(!t||t.index===void 0)return console.error(`patch: channelsMode: failed to find server dev-flag warning block`),null;let n=t.index,r=n+t[0].length,i=e.slice(0,n)+``+e.slice(r);return F(e,i,``,n,r),i},vi=e=>{let t=pi(e);return!t||(t=mi(t),!t)||(t=hi(t),!t)?null:(t=gi(t)??t,t=_i(t)??t,t)},yi=e=>{if(/name:"clear-screen"/.test(e))return e;let t=e.match(/([,;{}])(function [$\w]+\(\)\{)([$\w]+)\.get\(process\.stdout\)\?\.forceRedraw\(\)\}/);if(!t||t.index===void 0)return W(`patch: clearScreen: failed to find forceRedraw function`),null;let n=`${t[1]}globalThis.__tweakccForceRedraw=()=>${t[3]}.get(process.stdout)?.forceRedraw();`+t[0].slice(1),r=e.slice(0,t.index)+n+e.slice(t.index+t[0].length);F(e,r,n,t.index,t.index+t[0].length);let i=bi(r);return i?(r=i,On(r,`,{type:"local",name:"clear-screen",description:"Clear screen without resetting conversation context",supportsNonInteractive:!1,load:()=>Promise.resolve().then(()=>({call:(H,$)=>{$.setMessages(m=>{globalThis.__tweakccHiddenUUIDs=new Set(m.map(x=>x.uuid?.slice(0,24)).filter(Boolean));return[...m]});process.stdout.write("\\x1b[2J\\x1b[H\\x1b[3J");globalThis.__tweakccForceRedraw?.();return{type:"skip"}}}))}`)||(W(`patch: clearScreen: failed to register slash command`),null)):(W(`patch: clearScreen: failed to patch render filter g97`),null)},bi=e=>{let t=e.match(/([,;{}])(function [$\w]+\(([$\w]+),[$\w]+\)\{)if\(\3\.type!=="user"\)return!0;if\(\3\.isMeta\)/);if(!t||t.index===void 0)return null;let n=t[1],r=t[2],i=`${n}${r}if(globalThis.__tweakccHiddenUUIDs?.has(${t[3]}.uuid?.slice(0,24)))return!1;`+t[0].slice(n.length+r.length),a=e.slice(0,t.index)+i+e.slice(t.index+t[0].length);return F(e,a,i,t.index,t.index+t[0].length),a},xi=e=>{let t=e.match(/=2000,([$\w]+)="Read a file from the local filesystem\./);if(!t||t.index===void 0)return/=\(\+process\.env\.CLAUDE_CODE_READ_DEFAULT_LINES/.test(e)?e:(console.error(`patch: readDefaultLines: failed to find =2000 near Read tool prompt anchor`),null);let n=t.index,r=n+5,i=`=(+process.env.CLAUDE_CODE_READ_DEFAULT_LINES||2000)`,a=e.slice(0,n)+i+e.slice(r);return F(e,a,i,n,n+52),a},Si=e=>{if(/function [$\w]+\(([$\w]+),[$\w]+\)\{if\(Object\.entries\([$\w]+\)\.length===0\)return \1;var ([$\w]+)=\1\[0\];if\(\2&&\2\.isMeta/.test(e))return e;let t=e.match(/function ([$\w]+)\(([$\w]+),([$\w]+)\)\{if\(Object\.entries\(\3\)\.length===0\)return \2;return\[([\s\S]+?),\.\.\.\2\]\}/);if(!t||t.index===void 0){let t=e.indexOf(`"tengu_context_size"`);if(t>0){let n=e.slice(Math.max(0,t-5e3),t);if(/function [$\w]+\([$\w]+,[$\w]+\)\{return [$\w]+;?\}\s*async function/.test(n))return console.log(`patch: claudemd-context-once-per-conversation: claudemd-context override suppressed wrapper — no-op`),e}return console.error(`patch: claudemd-context-once-per-conversation: failed to find kY6 wrapper`),null}let[n,r,i,a,o]=t,s=`${i}_0`,c=`function ${r}(${i},${a}){if(Object.entries(${a}).length===0)return ${i};var ${s}=${i}[0];if(${s}&&${s}.isMeta&&${s}.message&&typeof ${s}.message.content==="string"&&${s}.message.content.indexOf("<system-reminder>\\nAs you answer the user")===0)return ${i};${i}.unshift(${o});return ${i}}`,l=t.index,u=l+n.length,d=e.slice(0,l)+c+e.slice(u);return F(e,d,c,l,u),d},Ci=e=>{let t=e.match(/function ([$\w]+)\(([$\w]+)\)\{return`<system-reminder>\n\$\{\2\}\n<\/system-reminder>`\}/);if(!t||t.index===void 0)return/function [$\w]+\(([$\w]+)\)\{if\(!\1\|\|!\1\.trim\(\)\|\|\1==="\(no content\)"\)return"\(no content\)";return`<system-reminder>/.test(e)?e:(console.error(`patch: strip-empty-system-reminders: failed to find LW(H) wrapper`),null);let[n,r,i]=t,a=`function ${r}(${i}){if(!${i}||!${i}.trim()||${i}==="(no content)")return"(no content)";return\`<system-reminder>\n\${${i}}\n</system-reminder>\`}`,o=t.index,s=o+n.length,c=e.slice(0,o)+a+e.slice(s);return F(e,c,a,o,s),c},wi=`The following deferred tools are now available via`,Ti=e=>{if(!e.includes(wi))return console.log(`patch: suppress-deferred-tools: anchor not present in this CC build — no-op`),e;if(e.includes(`case"deferred_tools_delta":{return [];`))return e;let t=e.indexOf(`case"deferred_tools_delta":{`);if(t<0)return console.error(`patch: suppress-deferred-tools: failed to find case header`),null;if(!e.slice(t,t+2048).includes(wi))return console.error(`patch: suppress-deferred-tools: case header found but anchor text not nearby`),null;let n=t+28,r=`return [];`,i=e.slice(0,n)+r+e.slice(n);return F(e,i,r,n,n),i},Ei=async(e,t)=>{let n=`${t}.tmp-${process.pid}`;try{await o.copyFile(e,n),await o.rename(n,t)}catch(e){try{await o.unlink(n)}catch{}throw e}},Di=async e=>{if(!e.cliPath){W(`backupClijs: Skipping for native installation (no cliPath)`);return}await Aa(),W(`Backing up cli.js to ${Ea}`),await Ei(e.cliPath,Ea),await $(t=>{t.changesApplied=!1,t.ccVersion=e.version})},Oi=async e=>{e.nativeInstallationPath&&(await Aa(),W(`Backing up native binary to ${X}`),await Ei(e.nativeInstallationPath,X),await $(t=>{t.changesApplied=!1,t.ccVersion=e.version}))},ki=async e=>{if(!e.cliPath)return W(`restoreClijsFromBackup: Skipping for native installation (no cliPath)`),!1;if(!await _a(Ea))return W(`restoreClijsFromBackup: No backup file exists, skipping`),!1;W(`Restoring cli.js from backup to ${e.cliPath}`);let t=await o.readFile(Ea);return await ga(e.cliPath,t,`restore`),await ot(),await $(e=>{e.changesApplied=!1}),!0},Ai=async e=>{if(!e.nativeInstallationPath)return W(`restoreNativeBinaryFromBackup: No native installation path, skipping`),!1;if(!await _a(X))return W(`restoreNativeBinaryFromBackup: No backup file exists, skipping`),!1;W(`Restoring native binary from backup to ${e.nativeInstallationPath}`);let t=await o.readFile(X);return await ga(e.nativeInstallationPath,t,`restore`),!0},R=e=>{let t=Array.from(e.matchAll(/[^$\w]([$\w]+)(?:\.(?:cyan|gray|green|red|yellow|ansi256|bgAnsi256|bgHex|bgRgb|hex|rgb|bold|dim|inverse|italic|strikethrough|underline)\b)+\(/g)),n={};for(let e of t){let t=e[1];n[t]=(n[t]||0)+1}let r,i=0;for(let[e,t]of Object.entries(n))t>i&&(i=t,r=e);return r},ji=e=>{let t=e.slice(0,2e3).match(/[,;]([$\w]+)=\([$\w]+,[$\w]+,[$\w]+\)=>\{[$\w]+=[$\w]+!=null\?/);if(t)return t[1];let n=e.slice(0,1e4),r=Array.from(n.matchAll(/(?:var |,)([$\w]+)=\([$\w]+,[$\w]+,[$\w]+\)=>\{/g));if(r.length>0){let e=r[0][1];for(let t of r)t[1].length<e.length&&(e=t[1]);return e}console.log(`patch: getModuleLoaderFunction: failed to find module loader function`)},Mi=e=>{let t=e.match(/var ([$\w]+)=[$\w]+\(\([$\w]+\)=>\{var [$\w]+=Symbol\.for\("react\.(transitional\.)?element"\)/);if(!t){console.log(`patch: getReactModuleNameNonBun: failed to find React module name`);return}return t[1]},Ni=e=>{let t=Mi(e);if(!t){console.log(`^ patch: getReactModuleFunctionBun: failed to find React module name (Bun)`);return}let n=RegExp(`var ([$\\w]+)=[$\\w]+\\(\\([$\\w]+,[$\\w]+\\)=>\\{[$\\w]+\\.exports=${U(t)}\\(\\)`),r=e.match(n);if(!r){console.log(`patch: getReactModuleFunctionBun: failed to find React module function (Bun) (reactModuleNameNonBun=${t})`);return}return r[1]};let z=null,B=null;const V=e=>{if(z!=null)return z;let t=ji(e);if(!t){console.log(`^ patch: getReactVar: failed to find moduleLoader`),z=void 0;return}let n=Mi(e);if(!n){console.log(`^ patch: getReactVar: failed to find reactModuleVarNonBun`),z=void 0;return}let r=RegExp(`[^$\\w]([$\\w]+)=${U(t)}\\(${U(n)}\\(\\),1\\)`),i=e.match(r);if(i)return z=i[1],z;let a=Ni(e);if(!a){console.log(`^ patch: getReactVar: failed to find reactModuleFunctionBun`),z=void 0;return}let o=RegExp(`[^$\\w]([$\\w]+)=${U(t)}\\(${U(a)}\\(\\),1\\)`),s=e.match(o);if(!s){console.log(`patch: getReactVar: failed to find bunPattern (moduleLoader=${t}, reactModuleVarNonBun=${n}, reactModuleFunctionBun=${a})`),z=void 0;return}return z=s[1],z},Pi=()=>{z=null},Fi=e=>{let t=e.match(/import\{createRequire as ([$\w]+)\}from"node:module";/);if(!t)return;let n=t[1],r=RegExp(`var ([$\\w]+)=${U(n)}\\(import\\.meta\\.url\\)`),i=e.match(r);if(!i){console.log(`patch: findRequireFunc: failed to find require function variable (createRequireVar=${n})`);return}return i[1]},Ii=e=>{if(B!=null)return B;let t=Fi(e);return t?(B=t,B):(B=`require`,B)},Li=()=>{B=null},Ri=()=>{Pi(),Li()},zi=e=>{let t=e.match(/\bfunction ([$\w]+).{0,80}color:[$\w]+,backgroundColor:[$\w]+,dimColor:[$\w]+(?:=![01])?,bold:[$\w]+(?:=![01])?/);if(!t){console.log(`patch: findTextComponent: failed to find text component`);return}return t[1]},Bi=(e,t)=>{let n=`[A-Za-z_$][\\w$]*(?:\\.[A-Za-z_$][\\w$]*)*`,r=RegExp(`var [^;]{0,120};var [$\\w]+=${n}\\(\\(\\)=>\\{[^}]{0,500}([$\\w]+)=${U(t)}\\}\\)`),i=e.match(r)?.[1]??t,a=RegExp(`function ([$\\w]+)\\([^)]+\\)\\{(?=[\\s\\S]{0,2500}createElement\\(${U(i)},\\{\\.\\.\\.[$\\w]+,borderColor:)[\\s\\S]{0,3000}?return [$\\w]+\\}var [^;]{0,160};var [$\\w]+=${n}\\(\\(\\)=>\\{[^}]{0,600}([$\\w]+)=\\1\\}\\)`);return e.match(a)?.[2]},Vi=e=>{let t=e.match(/function ([$\w]+)\(.{0,2000}[^$\w]([$\w]+)=[$\w]+(?:\.default)?\.createElement\("ink-box".{0,500}?return \2/);if(t)return t[1];let n=e.match(/function ([$\w]+)\(.{0,200}children:[$\w]+,flexWrap:[$\w]+.{0,2000}?\.createElement\("ink-box"/);if(n)return n[1];let r=e.match(/[^$\w]([$\w]+)\.displayName="Box"/);if(r)return r[1];let i=e.match(/function ([$\w]+)\([$\w]+\)\{let [$\w]+=[$\w]+(?:\.[$\w]+)?\(\d+\).{0,3000}createElement\("ink-box"/);if(i)return i[1];let a=e.match(/function ([$\w]+)\(\{children:([$\w]+),ref:[$\w]+.{0,600}?\.\.\.([$\w]+)\}\)\{.{0,2500}?"margin".{0,2500}?"padding".{0,1200}?"gap".{0,1200}?\3\.flexWrap\?\?="nowrap",\3\.flexDirection\?\?="row",\3\.flexGrow\?\?=0,\3\.flexShrink\?\?=1,\3\.overflowX=\3\.overflowX\?\?\3\.overflow\?\?"visible",\3\.overflowY=\3\.overflowY\?\?\3\.overflow\?\?"visible",[$\w]+(?:\.default)?\.createElement\("ink-box",\{[^}]*style:\3\},\2\)/);if(a)return Bi(e,a[1])??a[1];let o=e.match(/function ([$\w]+)\(\{children:[$\w]+,ref:[$\w]+,tabIndex:[$\w]+,autoFocus:[$\w]+/);if(o)return o[1];console.error(`patch: findBoxComponent: failed to find Box component (neither ink-box createElement nor displayName found)`)},Hi=e(import.meta.url),Ui=(()=>{try{return Hi(`../package.json`).version}catch{return Hi(`../../package.json`).version}})();let H=function(e){return e.SYSTEM_PROMPTS=`System Prompts`,e.ALWAYS_APPLIED=`Always Applied`,e.MISC_CONFIGURABLE=`Misc Configurable`,e.FEATURES=`Features`,e.SYSTEM_REMINDERS=`System Reminders`,e}({});const Wi=[{id:`verbose-property`,name:`Verbose property`,group:H.ALWAYS_APPLIED,description:`Token counter will show (2s · ↓ 169 tokens · thinking)`},{id:`read-default-lines`,name:`Read default lines (env-gated)`,group:H.ALWAYS_APPLIED,description:`Read tool default line cap becomes CLAUDE_CODE_READ_DEFAULT_LINES env var (falls back to 2000 if unset)`},{id:`opusplan1m`,name:`Opusplan[1m] support`,group:H.ALWAYS_APPLIED,description:`Use the "Opus Plan 1M" model: Opus for planning, Sonnet 1M context for building`},{id:`thinking-block-styling`,name:`Thinking block styling`,group:H.ALWAYS_APPLIED,description:`Restore dim/gray + italic styling for thinking blocks`},{id:`fix-lsp-support`,name:`Fix LSP support`,group:H.ALWAYS_APPLIED,description:`Enable/fix nascent LSP support`},{id:`fix-summarize-from-here`,name:`Fix "Summarize from here"`,group:H.MISC_CONFIGURABLE,description:`Make "Summarize from here" summarize only the messages after the rewind point (feed the slice, not the whole conversation)`},{id:`fix-rewind-summary-header`,name:`Honest rewind summary header`,group:H.MISC_CONFIGURABLE,description:`Label a rewind summary as a deliberate rewind instead of the misleading "ran out of context" header`},{id:`statusline-update-throttle`,name:`Statusline update throttling correction`,group:H.ALWAYS_APPLIED,description:`Statusline updates will be properly throttled instead of queued (or debounced)`},{id:`clear-screen`,name:`Clear screen command`,group:H.ALWAYS_APPLIED,description:`Register a /clear-screen command that clears the terminal scrollback and redraws without resetting conversation context`},{id:`strip-empty-system-reminders`,name:`Strip empty <system-reminder> wrappers`,group:H.ALWAYS_APPLIED,description:`Short-circuits CC's universal system-reminder wrapper so empty / "(no content)" inputs produce no reminder. Kills the drift-inducing "<system-reminder>(no content)</system-reminder>" blocks that get appended to roughly every other tool call.`},{id:`model-customizations`,name:`Model customizations`,group:H.MISC_CONFIGURABLE,description:`Access all Claude models with /model, not just latest 3`},{id:`show-more-items-in-select-menus`,name:`Show more items in select menus`,group:H.MISC_CONFIGURABLE,description:`Show 25 items in select menus instead of default 5`},{id:`context-limit`,name:`Context limit`,group:H.MISC_CONFIGURABLE,description:`Override the 200K context limit via CLAUDE_CODE_CONTEXT_LIMIT env var (set before launching CC)`},{id:`patches-applied-indication`,name:`Patches applied indication`,group:H.MISC_CONFIGURABLE,description:`Show "tweakcc patches applied" and tweakcc version inside CC`},{id:`table-format`,name:`Table format`,group:H.MISC_CONFIGURABLE,description:`Tables generated by Claude will be rendered more compactly`},{id:`themes`,name:`Themes`,group:H.MISC_CONFIGURABLE,description:`Your custom themes will be available via /theme`},{id:`thinking-verbs`,name:`Thinking verbs`,group:H.MISC_CONFIGURABLE,description:`Your custom list of thinking verbs will be cycled through`},{id:`thinker-format`,name:`Thinker format`,group:H.MISC_CONFIGURABLE,description:`Your custom format string that thinking verbs are wrapped in will be applied`},{id:`thinker-symbol-chars`,name:`Thinker symbol chars`,group:H.MISC_CONFIGURABLE,description:`Your custom thinking spinner will be rendered`},{id:`thinker-symbol-speed`,name:`Thinker symbol speed`,group:H.MISC_CONFIGURABLE,description:`The thinking spinner will play at a custom FPS`},{id:`thinker-symbol-width`,name:`Thinker symbol width`,group:H.MISC_CONFIGURABLE,description:`The thinking spinner will be in a box of custom width`},{id:`thinker-symbol-mirror`,name:`Thinker symbol mirror`,group:H.MISC_CONFIGURABLE,description:`The thinking spinner will reverse or restart when it finishes`},{id:`input-box-border`,name:`Input box border`,group:H.MISC_CONFIGURABLE,description:`Your custom styles to the main input box's border will be applied`},{id:`subagent-models`,name:`Subagent models`,group:H.MISC_CONFIGURABLE,description:`Use custom models for Plan, Explore, and General subagents`},{id:`thinking-visibility`,name:`Thinking block visibility`,group:H.MISC_CONFIGURABLE,description:`Thinking blocks outputted by the model will show without Ctrl+O`},{id:`hide-startup-banner`,name:`Hide startup banner`,group:H.MISC_CONFIGURABLE,description:`CC's startup banner with "Clawd" and release notes will be hidden`},{id:`hide-ctrl-g-to-edit`,name:`Hide Ctrl+G to edit`,group:H.MISC_CONFIGURABLE,description:`Note about using Ctrl+G to edit prompt will be hidden`},{id:`hide-startup-clawd`,name:`Hide startup Clawd`,group:H.MISC_CONFIGURABLE,description:`The "Clawd" icon on startup will be hidden for a cleaner look`},{id:`increase-file-read-limit`,name:`Increase file read limit`,group:H.MISC_CONFIGURABLE,description:`Max tokens Claude can read from a file at once will be increased`},{id:`suppress-line-numbers`,name:`Suppress line numbers`,group:H.MISC_CONFIGURABLE,description:`"1→" "2→" etc. prefixes for each line of Read output will be omitted`},{id:`suppress-rate-limit-options`,name:`Suppress rate limit options`,group:H.MISC_CONFIGURABLE,description:`/rate-limit-options won't be injected when limits are reached`},{id:`token-count-rounding`,name:`Token count rounding`,group:H.MISC_CONFIGURABLE,description:`Round displayed token counts to the nearest multiple of chosen value`},{id:`remember-skill`,name:`Remember skill`,group:H.MISC_CONFIGURABLE,description:`Register the built-in "/remember" skill to review session memories and update CLAUDE.local.md`},{id:`agents-md`,name:`AGENTS.md (and others)`,group:H.MISC_CONFIGURABLE,description:`Support AGENTS.md and others in addition to CLAUDE.md`},{id:`auto-accept-plan-mode`,name:`Auto-accept plan mode`,group:H.MISC_CONFIGURABLE,description:`Automatically accept plans without the "Ready to code?" confirmation prompt`},{id:`allow-sudo-bypass-permissions`,name:`Allow bypassing permissions with --dangerously-skip-permissions in sudo`,group:H.MISC_CONFIGURABLE,description:`Allow bypassing permissions with --dangerously-skip-permissions even when running with root/sudo privileges`},{id:`suppress-native-installer-warning`,name:`Suppress native installer warning`,group:H.MISC_CONFIGURABLE,description:`Suppress the native installer warning message at startup`},{id:`filter-scroll-escape-sequences`,name:`Filter scroll escape sequences`,group:H.MISC_CONFIGURABLE,description:`Filter out terminal escape sequences that cause unwanted scrolling`},{id:`max-effort-default`,name:`Default Opus 4.7 to max effort`,group:H.MISC_CONFIGURABLE,description:`Opus 4.7 sessions default to "max" reasoning effort instead of "xhigh" (override with /effort or CLAUDE_CODE_EFFORT_LEVEL)`},{id:`autonomous-operation-all-models`,name:`Fable/Mythos prompt set (all models)`,group:H.MISC_CONFIGURABLE,description:`Treats your selected model as Fable/Mythos everywhere CC branches on model family (flips the zQ gate): you get the autonomous-operation prompt (proceed without asking for reversible in-scope work; finish the job before ending the turn), the "# Communicating with the user" comms block in place of "# Text output", /loop dynamic-pacing behavior, and brief-mode comms shaping. Per-model feature-flag routing also follows fable but is inert on a local install`},{id:`auto-mode-classifier-model`,name:`Auto-mode classifier model`,group:H.MISC_CONFIGURABLE,description:`Pin auto-mode bash safety classifier to Sonnet 4.6 or Haiku 4.5 instead of the user main-loop model (avoids Opus 4.7 congestion denying tool calls)`},{id:`allow-custom-agent-models`,name:`Allow custom agent models`,group:H.FEATURES,description:`Allow arbitrary model names in custom agent frontmatter (e.g. gemini-2.5-flash)`},{id:`worktree-mode`,name:`Worktree mode`,group:H.FEATURES,description:`Enable the EnterWorktree tool for isolated git worktree sessions`},{id:`session-memory`,name:`Session memory`,group:H.FEATURES,description:`Enable session memory (auto-extraction + past session search)`},{id:`dream-mode`,name:`Dream mode`,group:H.FEATURES,description:`Enable dream (/dream + auto-dream background memory consolidation)`},{id:`lean-memory-types`,name:`Lean memory types`,group:H.FEATURES,description:`Compact "Types of memory" prompt block + on-demand memory-types skill`},{id:`toolsets`,name:`Toolsets`,group:H.FEATURES,description:`Custom toolsets will be registered`},{id:`mcp-non-blocking`,name:`MCP non-blocking`,group:H.FEATURES,description:`If you have MCP servers, CC startup will be much faster`},{id:`mcp-batch-size`,name:`MCP batch size`,group:H.FEATURES,description:`Change the number of MCP servers started in parallel`},{id:`user-message-display`,name:`User message display`,group:H.FEATURES,description:`User messages in the chat history will be styled`},{id:`input-pattern-highlighters`,name:`Input pattern highlighters`,group:H.FEATURES,description:`Custom input highlighters will be registered`},{id:`conversation-title`,name:`Conversation title`,group:H.FEATURES,description:`/title command will be created & enabled`},{id:`voice-mode`,name:`Voice mode`,group:H.FEATURES,description:`Enable /voice command for speech-to-text input (hold Space to record)`},{id:`channels-mode`,name:`Channels mode`,group:H.FEATURES,description:`Enable MCP channel notifications (--channels without allowlist or dev flag)`},{id:`suppress-deferred-tools`,name:`Suppress deferred tools list (DANGEROUS)`,group:H.SYSTEM_REMINDERS,description:`Kill the "deferred tools are now available via ToolSearch" announcement. WARNING: MCP/Cron/EnterPlanMode/WebFetch/Monitor become invisible to the model unless explicitly named.`},{id:`claudemd-context-once-per-conversation`,name:`claudeMd context: once per conversation`,group:H.SYSTEM_REMINDERS,description:`Inject the claudeMd / userEmail / currentDate <system-reminder> only on the first API call per conversation (re-fires after /clear). Default: ON. Toggle OFF for vanilla CC per-turn injection.`}],Gi=()=>[...Wi],U=e=>e.replace(/\$/g,`\\$`),Ki=(e,t,n)=>{let r=[];for(let i of Wi){let a=t[i.id];if(n&&!n.includes(i.id)){r.push({id:i.id,name:i.name,group:i.group,applied:!1,skipped:!0,details:`not in --patches filter`,description:i.description});continue}if(a.condition===!1){r.push({id:i.id,name:i.name,group:i.group,applied:!1,skipped:!0,details:`not enabled`,description:i.description});continue}W(`Applying patch: ${i.name}`);let o=a.fn(e),s=o===null,c=!s&&o!==e;s||(e=o),r.push({id:i.id,name:i.name,group:i.group,applied:c,failed:s,description:i.description})}return{content:e,results:r}},qi=e=>{let t=g(e,[`--version`],{encoding:`utf8`,timeout:15e3}),n=`${t.stdout??``}${t.stderr??``}`;if(t.error||t.status!==0||/Expected CommonJS module|Bun v|TypeError/.test(n)){let t=Error(`Patched native binary failed startup sanity check (${e}).\n`+n.trim());throw t.stack=t.message,t}},Ji=async(e,t,r)=>{let i,o=!1;if(t.nativeInstallationPath){await Ai(t);let e=!1;try{await a.stat(X),e=!0}catch{}let n=e?X:t.nativeInstallationPath;W(`Extracting claude.js from ${e?`backup`:`native installation`}: ${n}`);let{data:r,clearBytecode:c,error:u}=await C(n,t.version);if(!r)throw Error(`Failed to extract claude.js from native installation${u?`: ${u}`:``}`);o=c;let d=l.join(J,`native-claudejs-orig.js`);s.writeFileSync(d,r),W(`Saved original extracted JS from native to: ${d}`),i=r.toString(`utf8`)}else{if(await ki(t),!t.cliPath)throw Error(`cliPath is required for NPM installations`);i=await a.readFile(t.cliPath,{encoding:`utf8`})}let c=[],u=i,d=await xn(i);i=d.content;let f=d.results.filter(e=>e.applied),p=d.results.filter(e=>e.failed);if(d.results.length>0){W(`inlineBlobOverrides: ${f.length} applied, ${p.length} failed`);for(let e of p)console.log(`inline-blob: failed "${e.name}" (${e.filename}): ${e.details}`)}for(let e of d.results)c.push({id:`inline-blob:${e.filename}`,name:e.name,group:H.SYSTEM_PROMPTS,applied:e.applied,failed:e.failed,skipped:e.skipped,details:e.details});let m=await yt(i,t.version??``);i=m.content;for(let e of m.results)c.push({id:`reminder:${e.id}`,name:`Reminder: ${e.name} (${e.state})`,group:H.SYSTEM_REMINDERS,applied:e.applied,failed:e.failed,skipped:e.skipped,details:e.details,description:e.description});let h=await sn(i,t.version,void 0,r,u);i=h.newContent;let g=[...h.results].sort((e,t)=>e.name.localeCompare(t.name));c.push(...g);let _=e=>e.replace(/\\/g,`\\\\`).replace(/`/g,"\\`").replace(/\$/g,`\\$`),v=g.filter(e=>e.applied&&e.details).map(e=>_(`${e.name}: ${e.details}`)),y=e.settings.misc?.tableFormat??`default`,b=e.settings.misc?.showTweakccVersion??!0,x=e.settings.misc?.showPatchesApplied??!0,S=e.settings.misc?.enableModelCustomizations??!0,T={"verbose-property":{fn:e=>Ee(e),condition:!t.nativeInstallationPath},"read-default-lines":{fn:e=>xi(e)},"context-limit":{fn:e=>oe(e),condition:!!e.settings.misc?.enableContextLimitOverride},opusplan1m:{fn:e=>Ne(e),condition:S&&!t.nativeInstallationPath},"thinking-block-styling":{fn:e=>zr(e),condition:t.version==null||Ot(t.version,`2.1.26`)<0},"fix-lsp-support":{fn:e=>Cn(e)},"fix-summarize-from-here":{fn:e=>wn(e),condition:e.settings.misc?.fixSummarizeFromHere!==!1},"fix-rewind-summary-header":{fn:e=>Tn(e),condition:e.settings.misc?.fixRewindSummaryHeader!==!1},"statusline-update-throttle":{fn:t=>Wr(t,e.settings.misc?.statuslineThrottleMs??300,e.settings.misc?.statuslineUseFixedInterval??!1),condition:e.settings.misc?.statuslineThrottleMs!=null},"clear-screen":{fn:e=>yi(e)},"strip-empty-system-reminders":{fn:e=>Ci(e)},"patches-applied-indication":{fn:e=>We(e,Ui,v,b,x)},"model-customizations":{fn:e=>Zi(e),condition:S},"show-more-items-in-select-menus":{fn:e=>ne(e,25),condition:S},"table-format":{fn:e=>ar(e,y),condition:y!==`default`},themes:{fn:t=>ie(t,e.settings.themes),condition:!!(e.settings.themes&&e.settings.themes.length>0&&JSON.stringify(e.settings.themes)!==JSON.stringify(E.themes))},"thinking-verbs":{fn:t=>ve(t,e.settings.thinkingVerbs.verbs),condition:!!e.settings.thinkingVerbs&&JSON.stringify(e.settings.thinkingVerbs.verbs)!==JSON.stringify(E.thinkingVerbs.verbs)},"thinker-format":{fn:t=>le(t,e.settings.thinkingVerbs.format),condition:!!e.settings.thinkingVerbs&&e.settings.thinkingVerbs.format!==E.thinkingVerbs.format},"thinker-symbol-chars":{fn:t=>fe(t,e.settings.thinkingStyle.phases),condition:JSON.stringify(e.settings.thinkingStyle.phases)!==JSON.stringify(E.thinkingStyle.phases)},"thinker-symbol-speed":{fn:t=>pe(t,e.settings.thinkingStyle.updateInterval),condition:e.settings.thinkingStyle.updateInterval!==E.thinkingStyle.updateInterval&&(t.version==null||Ot(t.version,`2.1.27`)<0)},"thinker-symbol-width":{fn:t=>he(t,Math.max(...e.settings.thinkingStyle.phases.map(e=>e.length))+1),condition:JSON.stringify(e.settings.thinkingStyle.phases)!==JSON.stringify(E.thinkingStyle.phases)},"thinker-symbol-mirror":{fn:t=>de(t,e.settings.thinkingStyle.reverseMirror),condition:e.settings.thinkingStyle.reverseMirror!==E.thinkingStyle.reverseMirror},"input-box-border":{fn:t=>se(t,e.settings.inputBox.removeBorder),condition:!!(e.settings.inputBox&&e.settings.inputBox.removeBorder!==E.inputBox.removeBorder)},"subagent-models":{fn:t=>Re(t,e.settings.subagentModels),condition:!!e.settings.subagentModels&&JSON.stringify(e.settings.subagentModels)!==JSON.stringify(E.subagentModels)},"thinking-visibility":{fn:e=>Pe(e),condition:e.settings.misc?.expandThinkingBlocks??!0},"hide-startup-banner":{fn:e=>yr(e),condition:!!e.settings.misc?.hideStartupBanner},"hide-ctrl-g-to-edit":{fn:e=>xr(e),condition:!!e.settings.misc?.hideCtrlGToEdit},"hide-startup-clawd":{fn:e=>Cr(e),condition:!!e.settings.misc?.hideStartupClawd},"increase-file-read-limit":{fn:e=>Tr(e),condition:!!e.settings.misc?.increaseFileReadLimit},"suppress-line-numbers":{fn:e=>Dr(e),condition:!!e.settings.misc?.suppressLineNumbers},"suppress-rate-limit-options":{fn:e=>Or(e),condition:!!e.settings.misc?.suppressRateLimitOptions},"token-count-rounding":{fn:t=>Kr(t,e.settings.misc.tokenCountRounding),condition:!!e.settings.misc?.tokenCountRounding},"remember-skill":{fn:e=>Rr(e),condition:!!e.settings.misc?.enableRememberSkill},"agents-md":{fn:t=>qr(t,e.settings.claudeMdAltNames),condition:!!(e.settings.claudeMdAltNames&&e.settings.claudeMdAltNames.length>0)},"auto-accept-plan-mode":{fn:e=>Qr(e),condition:!!e.settings.misc?.autoAcceptPlanMode},"allow-sudo-bypass-permissions":{fn:e=>$r(e),condition:!!e.settings.misc?.allowBypassPermissionsInSudo},"suppress-native-installer-warning":{fn:e=>ti(e),condition:!!e.settings.misc?.suppressNativeInstallerWarning},"filter-scroll-escape-sequences":{fn:e=>ri(e),condition:!!e.settings.misc?.filterScrollEscapeSequences},"max-effort-default":{fn:e=>oi(e),condition:!!e.settings.misc?.maxEffortDefault},"autonomous-operation-all-models":{fn:e=>si(e),condition:!!e.settings.misc?.autonomousOperationAllModels},"auto-mode-classifier-model":{fn:t=>li(t,e.settings.misc?.autoModeClassifierModel??`default`),condition:(e.settings.misc?.autoModeClassifierModel??`default`)!==`default`},"allow-custom-agent-models":{fn:e=>ai(e),condition:!!e.settings.misc?.allowCustomAgentModels},"worktree-mode":{fn:e=>ii(e),condition:!!e.settings.misc?.enableWorktreeMode},"session-memory":{fn:e=>Nr(e),condition:!!e.settings.misc?.enableSessionMemory},"dream-mode":{fn:e=>Pr(e),condition:!!e.settings.misc?.enableDreamMode},"lean-memory-types":{fn:e=>Fr(e),condition:!!e.settings.misc?.enableLeanMemoryTypes},toolsets:{fn:t=>qn(t,e.settings.toolsets,e.settings.defaultToolset,e.settings.planModeToolset),condition:!!(e.settings.toolsets&&e.settings.toolsets.length>0)},"mcp-non-blocking":{fn:e=>Hr(e),condition:!!e.settings.misc?.mcpConnectionNonBlocking&&(t.version==null||Ot(t.version,`2.1.85`)<0)},"mcp-batch-size":{fn:t=>Ur(t,e.settings.misc.mcpServerBatchSize),condition:!!e.settings.misc?.mcpServerBatchSize},"user-message-display":{fn:t=>be(t,e.settings.userMessageDisplay),condition:!!(e.settings.userMessageDisplay&&JSON.stringify(e.settings.userMessageDisplay)!==JSON.stringify(E.userMessageDisplay))},"input-pattern-highlighters":{fn:t=>we(t,e.settings.inputPatternHighlighters),condition:!!(e.settings.inputPatternHighlighters&&e.settings.inputPatternHighlighters.length>0)},"conversation-title":{fn:e=>_r(e),condition:(e.settings.misc?.enableConversationTitle??!0)&&!t.nativeInstallationPath},"voice-mode":{fn:t=>fi(t,e.settings.misc?.enableVoiceConciseOutput??!0),condition:!!e.settings.misc?.enableVoiceMode},"channels-mode":{fn:e=>vi(e),condition:!!e.settings.misc?.enableChannelsMode},"suppress-deferred-tools":{fn:e=>Ti(e),condition:!!e.settings.misc?.suppressDeferredTools},"claudemd-context-once-per-conversation":{fn:e=>Si(e),condition:e.settings.misc?.claudemdContextOncePerConversation??!0}},{content:D,results:O}=Ki(i,T,r);i=D,c.push(...O);let k=O.filter(e=>e.failed);if(t.nativeInstallationPath&&k.length>0){let e=Error(`Refusing to repack the native binary: ${k.length} binary patch(es) failed (${k.map(e=>e.id).join(`, `)}) on Claude Code ${t.version}. The binary was left unchanged — your Claude Code still works. Each failure’s cause is in the "patch: … failed to …" line(s) above; this usually means Anthropic changed the code shape in CC ${t.version}, so a patch’s pattern no longer matches. Update tweakcc-fixed, or disable the failing optional patch(es) in ~/.tweakcc/config.json, then re-run --apply.`);throw e.stack=e.message,e}if(t.nativeInstallationPath){W(`Repacking modified claude.js into native installation: ${t.nativeInstallationPath}`);let e=l.join(J,`native-claudejs-patched.js`);s.writeFileSync(e,i,`utf8`),W(`Saved patched JS from native to: ${e}`);let r=Buffer.from(i,`utf8`),c=await a.mkdtemp(l.join(n.tmpdir(),`tweakcc-native-`)),u=l.join(c,l.basename(t.nativeInstallationPath));try{await a.copyFile(t.nativeInstallationPath,u),await a.chmod(u,s.statSync(t.nativeInstallationPath).mode),await w(u,r,u,o),qi(u);let e=t.nativeInstallationPath,n=l.join(l.dirname(e),`.${l.basename(e)}.tweakcc-${process.pid}`);try{await a.copyFile(u,n),await a.chmod(n,s.statSync(e).mode),await a.rename(n,e)}catch(e){throw await a.rm(n,{force:!0}),e}}finally{await a.rm(c,{recursive:!0,force:!0})}}else{if(!t.cliPath)throw Error(`cliPath is required for NPM installations`);k.length>0&&console.warn(`tweakcc: ${k.length} patch(es) did not apply on Claude Code ${t.version}: ${k.map(e=>e.id).join(`, `)}. Those feature(s) are skipped; everything else was applied. Each cause is in the "patch: … failed to …" line(s) above — usually a CC version whose code shape a patch does not match yet. Update tweakcc-fixed, or disable the failing optional patch(es) in ~/.tweakcc/config.json.`),await ga(t.cliPath,i,`patch`)}return{config:await $(e=>{e.changesApplied=!0}),results:c}},Yi=[{value:`claude-opus-4-6`,label:`Opus 4.6`,description:`Claude Opus 4.6 (February 2026)`},{value:`claude-sonnet-4-6`,label:`Sonnet 4.6`,description:`Claude Sonnet 4.6 (February 2026)`},{value:`claude-haiku-4-5-20251001`,label:`Haiku 4.5`,description:`Claude Haiku 4.5 (October 2025)`},{value:`claude-opus-4-5-20251101`,label:`Opus 4.5`,description:`Claude Opus 4.5 (November 2025)`},{value:`claude-sonnet-4-5-20250929`,label:`Sonnet 4.5`,description:`Claude Sonnet 4.5 (September 2025)`},{value:`claude-opus-4-1-20250805`,label:`Opus 4.1`,description:`Claude Opus 4.1 (August 2025)`},{value:`claude-opus-4-20250514`,label:`Opus 4`,description:`Claude Opus 4 (May 2025)`},{value:`claude-sonnet-4-20250514`,label:`Sonnet 4`,description:`Claude Sonnet 4 (May 2025)`},{value:`claude-3-7-sonnet-20250219`,label:`Sonnet 3.7`,description:`Claude 3.7 Sonnet (February 2025)`},{value:`claude-3-5-sonnet-20241022`,label:`Sonnet 3.5 (October)`,description:`Claude 3.5 Sonnet (October 2024)`},{value:`claude-3-5-haiku-20241022`,label:`Haiku 3.5`,description:`Claude 3.5 Haiku (October 2024)`},{value:`claude-3-5-sonnet-20240620`,label:`Sonnet 3.5 (June)`,description:`Claude 3.5 Sonnet (June 2024)`},{value:`claude-3-haiku-20240307`,label:`Haiku 3`,description:`Claude 3 Haiku (March 2024)`},{value:`claude-3-opus-20240229`,label:`Opus 3`,description:`Claude 3 Opus (February 2024)`}],Xi=e=>{let t=e.match(/ ([$\w]+)\.push\(\{value:[$\w]+,label:[$\w]+,description:"Custom model"\}\)/);if(!t||t.index===void 0)return console.error(`patch: findCustomModelListInsertionPoint: failed to find custom model push`),null;let n=t[1],r=Math.max(0,t.index-5e3),i=e.slice(r,t.index),a=`(?:(?:let|var|const) |,)${U(n)}=.+?;`,o=RegExp(`function [$\\w]+\\([^)]*\\)\\{[\\s\\S]{0,5000}?${a}`,`g`),s=null,c;for(;(c=o.exec(i))!==null;)s=c;return s?{insertionIndex:r+s.index+s[0].length,modelListVar:n}:(console.error(`patch: findCustomModelListInsertionPoint: failed to find function with ${n}`),null)},Zi=e=>{if(e.includes(`"value":"claude-opus-4-6"`))return console.log(`patch: modelCustomizations: custom models already present — skipping`),e;let t=Xi(e);if(!t)return null;let{insertionIndex:n,modelListVar:r}=t,i=Yi.map(e=>`${r}.push(${JSON.stringify(e)});`).join(``),a=e.slice(0,n)+i+e.slice(n);return F(e,a,i,n,n),a};let Qi=!1,$i=!1,ea=!1;const ta=()=>Qi,na=()=>$i,ra=()=>ea,ia=()=>{Qi=!0},aa=()=>{$i=!0,Qi=!0},oa=()=>{ea=!0},W=(e,...t)=>{ta()&&console.log(e,...t)},G=(e,...t)=>{na()&&console.log(e,...t)},K=e=>e.replace(/[\u0080-\uffff]/g,e=>`\\u`+e.charCodeAt(0).toString(16).padStart(4,`0`));function sa(){try{let e=f.join(p.homedir(),`.claude.json`);return JSON.parse(d.readFileSync(e,`utf8`)).theme||`dark`}catch{}return`dark`}function ca(e){try{let t=f.join(p.homedir(),`.claude.json`),n=JSON.parse(d.readFileSync(t,`utf8`));n.theme=e,d.writeFileSync(t,JSON.stringify(n,null,2))}catch{}}function la(){try{let e=f.join(p.homedir(),`.claude`,`.credentials.json`);switch(JSON.parse(d.readFileSync(e,`utf8`))?.claudeAiOauth?.subscriptionType||`unknown`){case`enterprise`:return`Claude Enterprise`;case`team`:return`Claude Team`;case`max`:return`Claude Max`;case`pro`:return`Claude Pro`}}catch{}return`Claude API`}function ua(){try{let e=f.join(p.homedir(),`.claude`,`settings.json`),t=JSON.parse(d.readFileSync(e,`utf8`))?.model||`default`;if(t===`opus`)return`Opus 4.5`;let n=Yi.find(e=>e.value===t);if(n)return n.label}catch{}return`Opus 4.5`}function da(e){process.platform===`win32`?m.spawn(`explorer`,[e],{detached:!0,stdio:`ignore`}).unref():process.platform===`darwin`?m.spawn(`open`,[e],{detached:!0,stdio:`ignore`}).unref():m.spawn(`xdg-open`,[e],{detached:!0,stdio:`ignore`}).unref()}function fa(e){if(process.platform===`win32`)m.spawn(`explorer`,[`/select,`,e],{detached:!0,stdio:`ignore`}).unref();else if(process.platform===`darwin`)m.spawn(`open`,[`-R`,e],{detached:!0,stdio:`ignore`}).unref();else{let t=f.dirname(e);m.spawn(`xdg-open`,[t],{detached:!0,stdio:`ignore`}).unref()}}function pa(e){if(!e||typeof e!=`string`)return!1;let t=e.trim();if(/^#([a-fA-F0-9]{3}|[a-fA-F0-9]{6})$/.test(t))return!0;if(/^rgb\(\s*\d{1,3}\s*,\s*\d{1,3}\s*,\s*\d{1,3}\s*\)$/.test(t)){let e=t.match(/rgb\((\d+),\s*(\d+),\s*(\d+)\)/);if(e){let[,t,n,r]=e;return parseInt(t)<=255&&parseInt(n)<=255&&parseInt(r)<=255}}if(/^hsl\(\s*\d{1,3}\s*,\s*\d{1,3}%\s*,\s*\d{1,3}%\s*\)$/.test(t)){let e=t.match(/hsl\((\d+),\s*(\d+)%,\s*(\d+)%\)/);if(e){let[,t,n,r]=e;return parseInt(t)<=360&&parseInt(n)<=100&&parseInt(r)<=100}}return!1}function ma(e){if(!pa(e))return e;let t=e.trim();if(t.startsWith(`rgb(`))return t;if(t.startsWith(`#`)){let e=t.slice(1);return e.length===3&&(e=e.split(``).map(e=>e+e).join(``)),`rgb(${parseInt(e.slice(0,2),16)},${parseInt(e.slice(2,4),16)},${parseInt(e.slice(4,6),16)})`}if(t.startsWith(`hsl(`)){let e=t.match(/hsl\((\d+),\s*(\d+)%,\s*(\d+)%\)/);if(e){let t=parseInt(e[1])/360,n=parseInt(e[2])/100,r=parseInt(e[3])/100,i=(e,t,n)=>(n<0&&(n+=1),n>1&&--n,n<1/6?e+(t-e)*6*n:n<1/2?t:n<2/3?e+(t-e)*(2/3-n)*6:e),a=r<.5?r*(1+n):r+n-r*n,o=2*r-a;return`rgb(${Math.round(i(o,a,t+1/3)*255)},${Math.round(i(o,a,t)*255)},${Math.round(i(o,a,t-1/3)*255)})`}}return e}async function ha(e,t=`sha256`,n=64*1024){return new Promise((r,i)=>{let a=h.createHash(t),o=d.createReadStream(e,{highWaterMark:n});o.on(`data`,e=>{a.update(e)}),o.on(`end`,()=>{r(a.digest(`hex`))}),o.on(`error`,e=>{i(e)})})}async function ga(e,t,n=`replace`){let r=493;try{r=(await o.stat(e)).mode,W(`[${n}] Original file mode for ${e}: ${(r&511).toString(8)}`)}catch(t){W(`[${n}] Could not stat ${e} (error: ${t}), using default mode 755`)}try{await o.unlink(e),W(`[${n}] Unlinked ${e} to break hard links`)}catch(t){W(`[${n}] Could not unlink ${e}: ${t}`)}await o.writeFile(e,t),await o.chmod(e,r),W(`[${n}] Restored permissions to ${(r&511).toString(8)}`)}async function _a(e){try{return await o.stat(e),!0}catch(e){if(e instanceof Error&&`code`in e&&(e.code===`ENOENT`||e.code===`ENOTDIR`||e.code===`EACCES`||e.code===`EPERM`))return!1;throw e}}const va=e=>e.startsWith(`~`)?f.join(p.homedir(),e.slice(1)):e,ya=(e,t)=>{let n=e=>{let t=e.split(`.`).map(Number);return[t[0]||0,t[1]||0,t[2]||0]},r=n(e),i=n(t);return r[0]===i[0]?r[1]===i[1]?r[2]-i[2]:r[1]-i[1]:r[0]-i[0]},ba=e=>{let t=e.toString(),n=t.lastIndexOf(`/`);return`new RegExp(${JSON.stringify(t.substring(1,n))}, ${JSON.stringify(t.substring(n+1))})`};function q(e,t){if(e==null)return t;if(typeof t!=`object`||!t)return e;if(Array.isArray(t))return Array.isArray(e)?e:t;let n={...e};for(let e of Object.keys(t)){let r=t[e];e in n?typeof r==`object`&&r&&!Array.isArray(r)&&(n[e]=q(n[e],r)):n[e]=r}return n}const xa=async(e,t=33554432)=>{let n=Number(e.headers.get(`content-length`));if(Number.isFinite(n)&&n>t)throw Error(`Response body too large: ${n} bytes exceeds the ${t}-byte limit.`);let r=e.body;if(!r){let n=await e.text();if(Buffer.byteLength(n,`utf8`)>t)throw Error(`Response body exceeds the ${t}-byte limit.`);return n}let i=r.getReader(),a=[],o=0;for(;;){let{done:e,value:n}=await i.read();if(e)break;if(n){if(o+=n.byteLength,o>t)throw await i.cancel().catch(()=>{}),Error(`Response body exceeds the ${t}-byte limit — aborting download.`);a.push(Buffer.from(n))}}return Buffer.concat(a).toString(`utf8`)},Sa=e=>{let t=e?.settings?.userMessageDisplay;if(!t)return;let n=!!t.prefix,r=`borderStyle`in t,i=`padding`in t,a=`paddingX`in t,o=`fitBoxToContent`in t,s=t.padding;n&&(e.settings.userMessageDisplay={format:(t.prefix?.format||``)+(t.message?.format||`{}`),styling:[...t.prefix?.styling||[],...t.message?.styling||[]],foregroundColor:t.message?.foregroundColor===`rgb(0,0,0)`?`default`:t.message?.foregroundColor||t.prefix?.foregroundColor||`default`,backgroundColor:t.message?.backgroundColor===`rgb(0,0,0)`?null:t.message?.backgroundColor||t.prefix?.backgroundColor||null,borderStyle:`none`,borderColor:`rgb(255,255,255)`,paddingX:0,paddingY:0,fitBoxToContent:!1});let c=e.settings.userMessageDisplay;r||(c.borderStyle=`none`,c.borderColor=`rgb(255,255,255)`),i&&!a?(c.paddingX=s||0,c.paddingY=0,delete c.padding):a||(c.paddingX=0,c.paddingY=0),o||(c.fitBoxToContent=!1)},Ca=e=>{let t=e?.settings?.misc;t&&`hideCtrlGToEditPrompt`in t&&(t.hideCtrlGToEdit=t.hideCtrlGToEditPrompt,delete t.hideCtrlGToEditPrompt)};async function wa(){try{let e=await o.readFile(Y,`utf8`),t=JSON.parse(e);return Object.hasOwn(t,`ccInstallationDir`)?(t.ccInstallationDir&&!t.ccInstallationPath&&(t.ccInstallationPath=u.join(t.ccInstallationDir,`cli.js`)),delete t.ccInstallationDir,t.lastModified=new Date().toISOString(),await Aa(),await o.writeFile(Y,JSON.stringify(t,null,2)),!0):!1}catch(e){if(e instanceof Error&&`code`in e&&e.code===`ENOENT`||e instanceof SyntaxError)return!1;throw e}}const Ta=()=>{let e=process.env.TWEAKCC_CONFIG_DIR?.trim();if(e&&e.length>0)return va(e);let t=u.join(r.homedir(),`.tweakcc`),n=u.join(r.homedir(),`.claude`,`tweakcc`),i=process.env.XDG_CONFIG_HOME;try{if(c.existsSync(t))return t}catch(e){W(`Failed to check if ${t} exists: ${e}`)}try{if(c.existsSync(n))return n}catch(e){W(`Failed to check if ${n} exists: ${e}`)}return i?u.join(i,`tweakcc`):t},J=Ta(),Y=u.join(J,`config.json`),Ea=u.join(J,`cli.js.backup`),X=u.join(J,`native-binary.backup`),Z=u.join(J,`system-prompts`),Da=u.join(J,`system-reminders`),Oa=u.join(J,`prompt-data-cache`),ka=()=>{let e=J,n=r.homedir(),i=[u.join(n,`.tweakcc`),u.join(n,`.claude`,`tweakcc`),process.env.XDG_CONFIG_HOME?u.join(process.env.XDG_CONFIG_HOME,`tweakcc`):null].filter(e=>e!==null).filter(t=>{try{return c.existsSync(t)&&t!==e}catch{return!1}});i.length>0&&(console.warn(t.yellow(`
|
|
722
722
|
Multiple configuration locations detected:`)),console.warn(t.gray(` Active: ${e}`)),console.warn(t.gray(` Other existing locations:`)),i.forEach(e=>{console.warn(t.gray(` - ${e}`))}),console.warn(t.gray(` Only the active location is used. To switch locations,`)),console.warn(t.gray(` move your config.json to the desired directory.
|
|
723
|
-
`)))},
|
|
723
|
+
`)))},Aa=async()=>{await o.mkdir(J,{recursive:!0}),await o.mkdir(Z,{recursive:!0}),await o.mkdir(Da,{recursive:!0});let e=u.join(J,`.gitignore`);try{await o.stat(e)}catch(t){t instanceof Error&&`code`in t&&t.code===`ENOENT`&&await o.writeFile(e,[`.DS_Store`,`prompt-data-cache`,`cli.js.backup`,`native-binary.backup`,`native-claudejs-orig.js`,`native-claudejs-patched.js`,`systemPromptAppliedHashes.json`,`systemPromptOriginalHashes.json`,`system-prompts/*.diff.html`].join(i)+i)}};let Q=null;const ja=()=>({ccVersion:``,ccInstallationPath:null,lastModified:new Date().toISOString(),changesApplied:!0,settings:E}),Ma=e=>{let t=e?.settings?.thinkingVerbs;t?.punctuation&&(t.format=`{}`+t.punctuation,delete t.punctuation),Sa(e),e.settings=q(e.settings,E),e.settings.inputPatternHighlighters&&(e.settings.inputPatternHighlighters=e.settings.inputPatternHighlighters.map(e=>q(e,D))),e.settings.toolsets&&(e.settings.toolsets=e.settings.toolsets.map(e=>q(e,O))),e.settings.themes&&(e.settings.themes=e.settings.themes.map(e=>q(e,k))),Ca(e),delete e.settings.launchText},Na=async()=>{let e=ja();try{W(`Reading config at ${Y}`),ka();let t=await o.readFile(Y,`utf8`),n={...e,...JSON.parse(t)},r=JSON.stringify(n);Ma(n);let i=await st(Z);return i&&(n.changesApplied=!1),(JSON.stringify(n)!==r||i)&&await Pa(n),Q=n,n}catch(t){if(t instanceof Error&&`code`in t&&t.code===`ENOENT`)return e;if(t instanceof SyntaxError){let t=`${Y}.corrupt-${Date.now()}`;try{await o.rename(Y,t),console.error(`tweakcc: ${Y} was not valid JSON — moved it to ${t} and reset to defaults.`)}catch{console.error(`tweakcc: ${Y} was not valid JSON — falling back to defaults.`)}return e}throw t}},$=async e=>(W(`Updating config at ${Y}`),Q||=await Na(),e(Q),Q.lastModified=new Date().toISOString(),await Pa(Q),Q),Pa=async e=>{e.lastModified=new Date().toISOString(),await Aa();let t=`${Y}.tmp-${process.pid}`;try{await o.writeFile(t,JSON.stringify(e,null,2)),await o.rename(t,Y)}catch(e){try{await o.unlink(t)}catch{}throw console.error(`Error saving config:`,e),e}},Fa=async e=>{W(`Fetching config from URL: ${e}`);let t;try{t=new URL(e)}catch{throw Error(`Invalid URL format: ${e}\n Expected a valid URL like https://example.com/config.json`)}if(![`http:`,`https:`].includes(t.protocol))throw Error(`Unsupported URL protocol: ${t.protocol}\n Only http:// and https:// URLs are supported`);let n;try{let e=await o.readFile(Y,`utf8`);n=JSON.parse(e)}catch{n=ja()}let r;try{r=await fetch(e,{headers:{Accept:`application/json`,"User-Agent":`tweakcc`},signal:AbortSignal.timeout(2e4)})}catch(t){let n=t instanceof Error?t.message:String(t);throw Error(`Failed to fetch config from ${e}\n Network error: ${n}\n Please check your internet connection and try again.`)}if(!r.ok)throw Error(`Failed to fetch config from ${e}\n HTTP ${r.status}: ${r.statusText}\n Please check that the URL is correct and accessible.`);let i;try{let e=await xa(r,8*1024*1024);i=JSON.parse(e)}catch(t){let n=t instanceof Error?t.message:String(t);throw Error(`Failed to parse config from ${e}\n JSON parse error: ${n}\n Please ensure the URL returns valid JSON.`)}let a={sourceUrl:e,dateFetched:new Date().toISOString(),settings:i};await $(e=>{e.remoteConfig=a});let s={...ja(),ccVersion:n.ccVersion||``,ccInstallationPath:n.ccInstallationPath||null,settings:{...E,...i},remoteConfig:a};return Ma(s),W(`Successfully fetched and parsed config from ${e}`),s};export{ot as $,fa as A,ji as B,ta as C,da as D,ma as E,Gi as F,ki as G,Ii as H,Ri as I,F as J,Ai as K,Vi as L,H as M,Ui as N,xa as O,Ji as P,Lt as Q,R,ha as S,pa as T,Di as U,V,Oi as W,Bt as X,Zt as Y,zt as Z,oa as _,Z as a,sa as b,Ta as c,wa as d,E as et,ya as f,ia as g,_a as h,X as i,T as it,ca as j,ga as k,Na as l,q as m,J as n,C as nt,Da as o,W as p,I as q,Y as r,w as rt,Fa as s,Ea as t,k as tt,$ as u,aa as v,ra as w,ua as x,la as y,zi as z};
|