jarvis-ai-assistant 0.1.45__py3-none-any.whl → 0.1.46__py3-none-any.whl

Sign up to get free protection for your applications and to get access to all the features.
jarvis/utils.py CHANGED
@@ -13,23 +13,25 @@ from prompt_toolkit.formatted_text import FormattedText
13
13
  # 初始化colorama
14
14
  colorama.init()
15
15
 
16
+
16
17
  class OutputType(Enum):
17
18
  SYSTEM = "system" # AI助手消息
18
19
  CODE = "code" # 代码相关
19
20
  RESULT = "result" # 工具执行结果
20
21
  ERROR = "error" # 错误信息
21
22
  INFO = "info" # 系统提示
22
- PLANNING = "planning" # 任务规划
23
- PROGRESS = "progress" # 执行进度
23
+ PLANNING = "planning" # 任务规划
24
+ PROGRESS = "progress" # 执行进度
24
25
  SUCCESS = "success" # 成功信息
25
26
  WARNING = "warning" # 警告信息
26
27
  DEBUG = "debug" # 调试信息
27
28
  USER = "user" # 用户输入
28
29
  TOOL = "tool" # 工具调用
29
30
 
31
+
30
32
  class PrettyOutput:
31
33
  """美化输出类"""
32
-
34
+
33
35
  # 颜色方案 - 只使用前景色
34
36
  COLORS = {
35
37
  OutputType.SYSTEM: Fore.CYAN, # 青色 - AI助手
@@ -37,7 +39,7 @@ class PrettyOutput:
37
39
  OutputType.RESULT: Fore.BLUE, # 蓝色 - 结果
38
40
  OutputType.ERROR: Fore.RED, # 红色 - 错误
39
41
  OutputType.INFO: Fore.YELLOW, # 黄色 - 提示
40
- OutputType.PLANNING: Fore.MAGENTA, # 紫色 - 规划
42
+ OutputType.PLANNING: Fore.MAGENTA, # 紫色 - 规划
41
43
  OutputType.PROGRESS: Fore.WHITE, # 白色 - 进度
42
44
  OutputType.SUCCESS: Fore.GREEN, # 绿色 - 成功
43
45
  OutputType.WARNING: Fore.YELLOW, # 黄色 - 警告
@@ -45,7 +47,7 @@ class PrettyOutput:
45
47
  OutputType.USER: Fore.GREEN, # 绿色 - 用户
46
48
  OutputType.TOOL: Fore.YELLOW, # 黄色 - 工具
47
49
  }
48
-
50
+
49
51
  # 图标方案
50
52
  ICONS = {
51
53
  OutputType.SYSTEM: "🤖", # 机器人 - AI助手
@@ -61,7 +63,7 @@ class PrettyOutput:
61
63
  OutputType.USER: "👤", # 用户 - 用户
62
64
  OutputType.TOOL: "🔧", # 扳手 - 工具
63
65
  }
64
-
66
+
65
67
  # 前缀方案
66
68
  PREFIXES = {
67
69
  OutputType.SYSTEM: "Assistant",
@@ -79,18 +81,20 @@ class PrettyOutput:
79
81
  }
80
82
 
81
83
  @staticmethod
82
- def format(text: str, output_type: OutputType, timestamp: bool = True) -> str:
84
+ def format(text: str, output_type: OutputType,
85
+ timestamp: bool = True) -> str:
83
86
  """格式化输出文本"""
84
87
  color = PrettyOutput.COLORS.get(output_type, "")
85
88
  icon = PrettyOutput.ICONS.get(output_type, "")
86
89
  prefix = PrettyOutput.PREFIXES.get(output_type, "")
87
-
90
+
88
91
  # 添加时间戳 - 使用白色
89
92
  time_str = f"{Fore.WHITE}[{datetime.now().strftime('%H:%M:%S')}]{ColoramaStyle.RESET_ALL} " if timestamp else ""
90
-
93
+
91
94
  # 格式化输出
92
- formatted_text = f"{time_str}{color}{icon} {prefix}: {text}{ColoramaStyle.RESET_ALL}"
93
-
95
+ formatted_text = f"{time_str}{color}{icon} {prefix}: {text}{
96
+ ColoramaStyle.RESET_ALL}"
97
+
94
98
  return formatted_text
95
99
 
96
100
  @staticmethod
@@ -99,7 +103,10 @@ class PrettyOutput:
99
103
  print(PrettyOutput.format(text, output_type, timestamp))
100
104
  if output_type == OutputType.ERROR:
101
105
  import traceback
102
- PrettyOutput.print(f"错误追踪: {traceback.format_exc()}", OutputType.INFO)
106
+ PrettyOutput.print(
107
+ f"错误追踪: {
108
+ traceback.format_exc()}",
109
+ OutputType.INFO)
103
110
 
104
111
  @staticmethod
105
112
  def section(title: str, output_type: OutputType = OutputType.INFO):
@@ -107,7 +114,11 @@ class PrettyOutput:
107
114
  width = 60
108
115
  color = PrettyOutput.COLORS.get(output_type, "")
109
116
  print(f"\n{color}" + "=" * width + f"{ColoramaStyle.RESET_ALL}")
110
- PrettyOutput.print(title.center(width - 10), output_type, timestamp=False)
117
+ PrettyOutput.print(
118
+ title.center(
119
+ width - 10),
120
+ output_type,
121
+ timestamp=False)
111
122
  print(f"{color}" + "=" * width + f"{ColoramaStyle.RESET_ALL}\n")
112
123
 
113
124
  @staticmethod
@@ -123,18 +134,19 @@ class PrettyOutput:
123
134
  sys.stdout.write("\n")
124
135
  sys.stdout.flush()
125
136
 
137
+
126
138
  def get_multiline_input(tip: str) -> str:
127
139
  """获取多行输入,支持方向键、历史记录等功能"""
128
140
  PrettyOutput.print(tip + "\n", OutputType.INFO)
129
-
141
+
130
142
  # 创建输入会话,启用历史记录
131
143
  session = PromptSession(history=None) # 使用默认历史记录
132
-
144
+
133
145
  # 定义提示符样式
134
146
  style = PromptStyle.from_dict({
135
147
  'prompt': 'ansicyan',
136
148
  })
137
-
149
+
138
150
  lines = []
139
151
  try:
140
152
  while True:
@@ -142,31 +154,32 @@ def get_multiline_input(tip: str) -> str:
142
154
  prompt = FormattedText([
143
155
  ('class:prompt', '... ' if lines else '>>> ')
144
156
  ])
145
-
157
+
146
158
  # 获取输入
147
159
  line = session.prompt(
148
160
  prompt,
149
161
  style=style,
150
162
  ).strip()
151
-
163
+
152
164
  # 空行处理
153
165
  if not line:
154
166
  if not lines: # 第一行就输入空行
155
167
  return ""
156
168
  break # 结束多行输入
157
-
169
+
158
170
  lines.append(line)
159
-
171
+
160
172
  except KeyboardInterrupt:
161
173
  PrettyOutput.print("\n输入已取消", OutputType.ERROR)
162
174
  return "__interrupt__"
163
-
175
+
164
176
  return "\n".join(lines)
165
177
 
178
+
166
179
  def load_env_from_file():
167
180
  """从~/.jarvis_env加载环境变量"""
168
181
  env_file = Path.home() / ".jarvis_env"
169
-
182
+
170
183
  if env_file.exists():
171
184
  try:
172
185
  with open(env_file, "r", encoding="utf-8") as f:
@@ -175,22 +188,29 @@ def load_env_from_file():
175
188
  if line and not line.startswith("#"):
176
189
  try:
177
190
  key, value = line.split("=", 1)
178
- os.environ[key.strip()] = value.strip().strip("'").strip('"')
191
+ os.environ[key.strip()] = value.strip().strip(
192
+ "'").strip('"')
179
193
  except ValueError:
180
194
  continue
181
195
  except Exception as e:
182
- PrettyOutput.print(f"Warning: Failed to read ~/.jarvis_env: {e}", OutputType.WARNING)
183
-
184
-
196
+ PrettyOutput.print(
197
+ f"Warning: Failed to read ~/.jarvis_env: {e}",
198
+ OutputType.WARNING)
199
+
200
+
185
201
  def while_success(func, sleep_time: float = 0.1):
186
202
  while True:
187
203
  try:
188
204
  return func()
189
205
  except Exception as e:
190
- PrettyOutput.print(f"执行失败: {str(e)}, {sleep_time}s后重试...", OutputType.ERROR)
206
+ PrettyOutput.print(
207
+ f"执行失败: {
208
+ str(e)}, {sleep_time}s后重试...",
209
+ OutputType.ERROR)
191
210
  time.sleep(sleep_time)
192
211
  continue
193
212
 
213
+
194
214
  def while_true(func, sleep_time: float = 0.1):
195
215
  """循环执行函数,直到函数返回True"""
196
216
  while True:
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.2
2
2
  Name: jarvis-ai-assistant
3
- Version: 0.1.45
3
+ Version: 0.1.46
4
4
  Summary: Jarvis: An AI assistant that uses tools to interact with the system
5
5
  Home-page: https://github.com/skyfireitdiy/Jarvis
6
6
  Author: skyfire
@@ -0,0 +1,25 @@
1
+ jarvis/__init__.py,sha256=HiOdrOkDAfqQOFrFVCKd96C_U-XMAI6wE1pX3GjE8Yk,50
2
+ jarvis/agent.py,sha256=omq58Bo4u-oEwpOuHnZTTE_3JeXG5Ow-1bhhJt6RlBs,12339
3
+ jarvis/main.py,sha256=Zd1aoq7EXNZMZrZl6n-2OB8UIC202sIPcQEJGuJJkpE,6087
4
+ jarvis/utils.py,sha256=CQo_V7qA_oGVvR4RrbfL9cd98lXzbE9tp1EB9S0ppIc,7469
5
+ jarvis/models/__init__.py,sha256=8uX1dj3YLL-i2Q5AIz1V0GtrROb6BJmRRRzxrexj-aE,59
6
+ jarvis/models/ai8.py,sha256=LEgtAZ7SZj94RoUuNlclXes_u-eh_vx5pxZ8kwSQG78,12658
7
+ jarvis/models/base.py,sha256=Drotowk47m3s30BPYspEL1MZlo2MyCaLev0v-oaqszY,1211
8
+ jarvis/models/kimi.py,sha256=ghL1g2iq9jnUNBB1flyV2wd0JKs7i7q0CpKr2-6kF3U,18570
9
+ jarvis/models/openai.py,sha256=vh_4J7imSlqWi0J8xBrVhv6mpPXj6UqvD_xVlKayiXg,4330
10
+ jarvis/models/oyi.py,sha256=pi4wD-TMz2Q6olkwQ5Vw5GCPKwL-KyTR8SNbrXiXvuo,14513
11
+ jarvis/models/registry.py,sha256=RgzbCLJM6-FlQYuhaXnEmQASshur3FR5u0z3UBJtBgQ,8137
12
+ jarvis/tools/__init__.py,sha256=ZXnUzaenBd2yX6xRI7T7tOjG7Hv2PjzcMva455VStgA,70
13
+ jarvis/tools/base.py,sha256=UnYlIpkKLAZDVxLyIZy2imHLSqF5xQXAVg5sKrQgTFw,668
14
+ jarvis/tools/file_ops.py,sha256=tuyeEg9gGcUBXiCL6WwO5IVtl2TRaNRJn1VYBkquFTs,3756
15
+ jarvis/tools/generator.py,sha256=fKTx6KbCPZAo2LZixWV51uZZWwVSj_UmDo1b8Lq5Y-c,5945
16
+ jarvis/tools/methodology.py,sha256=hpejF0ElrrMaCg90WBOrVRvCekfYkyiiQbAH13kC1ys,4995
17
+ jarvis/tools/registry.py,sha256=eMRW0geKeNsaYhGBQB73bbRBkQMGUDORWy69rmjs3Hk,7201
18
+ jarvis/tools/shell.py,sha256=NixHMaM2yF4XcDXxsgD3tAtdO1rZ3PxS_0_LlzjCpd8,2457
19
+ jarvis/tools/sub_agent.py,sha256=m0H6dWIeI0VeK2cNETfI0uqWxlot8f70mW4o9aBMXYo,2620
20
+ jarvis_ai_assistant-0.1.46.dist-info/LICENSE,sha256=AGgVgQmTqFvaztRtCAXsAMryUymB18gZif7_l2e1XOg,1063
21
+ jarvis_ai_assistant-0.1.46.dist-info/METADATA,sha256=DLFgc6On2RrSRKOtXgFuefCkMuxgsya7ZvWP0TmcJO0,10015
22
+ jarvis_ai_assistant-0.1.46.dist-info/WHEEL,sha256=In9FTNxeP60KnTkGw7wk6mJPYd_dQSjEZmXdBdMCI-8,91
23
+ jarvis_ai_assistant-0.1.46.dist-info/entry_points.txt,sha256=iKu7OMfew9dtfGhW71gIMTg4wvafuPqKb4wyQOnMAGU,44
24
+ jarvis_ai_assistant-0.1.46.dist-info/top_level.txt,sha256=1BOxyWfzOP_ZXj8rVTDnNCJ92bBGB0rwq8N1PCpoMIs,7
25
+ jarvis_ai_assistant-0.1.46.dist-info/RECORD,,
@@ -1,25 +0,0 @@
1
- jarvis/__init__.py,sha256=tEoUs2JTv57mPQLFhni4PQnMq5TsT-xG51MiMvafDWY,50
2
- jarvis/agent.py,sha256=5GmC9iAOerTR4JoxzrfgLSspoz6qRm1E6xEIWLTR2OI,12222
3
- jarvis/main.py,sha256=3kpohHORc13A5RBjTSHYF7cdnc6W15hO23R78Iqnz8w,5843
4
- jarvis/utils.py,sha256=JlkuC9RtspXH2VWDmj9nR0vnb8ie1gIsKc4vC7WRco8,7321
5
- jarvis/models/__init__.py,sha256=mrOt67nselz_H1gX9wdAO4y2DY5WPXzABqJbr5Des8k,63
6
- jarvis/models/ai8.py,sha256=9i7n_-TPbvq0AaRILs9ERQ7Vy5tDyoibXkiPsJvwQio,12520
7
- jarvis/models/base.py,sha256=eeNJJbv9ikPVTtV_E7mgW8LZzVgjQ-OzxlHF6slYrHw,1237
8
- jarvis/models/kimi.py,sha256=N0bPQ1ugx0RwjR96jLchmOPvCmws-fXyA0mnOAdo2k4,17161
9
- jarvis/models/openai.py,sha256=pB7AaZuorHlmudTPaUnEbFOyl51Fy6uhU9KQBm98Ov8,4156
10
- jarvis/models/oyi.py,sha256=12jskOgo77LWtXq4u-LX7s_sYomBJSlry4oONtdmVCU,14443
11
- jarvis/models/registry.py,sha256=iVBjN9ImEvGHcz8WR-z8pPMJQZI907o_nccVOFANhak,7951
12
- jarvis/tools/__init__.py,sha256=Kj1bKj34lwRDKMKHLOrLyQElf2lHbqA2tDgP359eaDo,71
13
- jarvis/tools/base.py,sha256=EGRGbdfbLXDLwtyoWdvp9rlxNX7bzc20t0Vc2VkwIEY,652
14
- jarvis/tools/file_ops.py,sha256=h8g0eT9UvlJf4kt0DLXvdSsjcPj7x19lxWdDApeDfpg,3842
15
- jarvis/tools/generator.py,sha256=vVP3eN5cCDpRXf_fn0skETkPXAW1XZFWx9pt2_ahK48,5999
16
- jarvis/tools/methodology.py,sha256=G3cOaHTMujGZBhDLhQEqyCV2NISizO3MXRuho1KfI6Y,5223
17
- jarvis/tools/registry.py,sha256=NbH7A4A2lyN2IoyZGFwa5Ghed2dpzbJWCAd1Dg95WBI,7183
18
- jarvis/tools/shell.py,sha256=UPKshPyOaUwTngresUw-ot1jHjQIb4wCY5nkJqa38lU,2520
19
- jarvis/tools/sub_agent.py,sha256=rEtAmSVY2ZjFOZEKr5m5wpACOQIiM9Zr_3dT92FhXYU,2621
20
- jarvis_ai_assistant-0.1.45.dist-info/LICENSE,sha256=AGgVgQmTqFvaztRtCAXsAMryUymB18gZif7_l2e1XOg,1063
21
- jarvis_ai_assistant-0.1.45.dist-info/METADATA,sha256=0ShAmks8D_nMGSoTH5b-mqtlr0s-aG5O5R5tclKMYQo,10015
22
- jarvis_ai_assistant-0.1.45.dist-info/WHEEL,sha256=In9FTNxeP60KnTkGw7wk6mJPYd_dQSjEZmXdBdMCI-8,91
23
- jarvis_ai_assistant-0.1.45.dist-info/entry_points.txt,sha256=iKu7OMfew9dtfGhW71gIMTg4wvafuPqKb4wyQOnMAGU,44
24
- jarvis_ai_assistant-0.1.45.dist-info/top_level.txt,sha256=1BOxyWfzOP_ZXj8rVTDnNCJ92bBGB0rwq8N1PCpoMIs,7
25
- jarvis_ai_assistant-0.1.45.dist-info/RECORD,,