Spaces:
Build error
Build error
交互优化
Browse files- config.py +1 -3
- functional_crazy.py +2 -2
- main.py +4 -4
- toolbox.py +23 -12
config.py
CHANGED
@@ -16,15 +16,13 @@ if USE_PROXY:
|
|
16 |
"http": "socks5h://localhost:11284",
|
17 |
"https": "socks5h://localhost:11284",
|
18 |
}
|
19 |
-
print('网络代理状态:运行。')
|
20 |
else:
|
21 |
proxies = None
|
22 |
-
print('网络代理状态:未配置。无代理状态下很可能无法访问。')
|
23 |
|
24 |
|
25 |
# [step 3]>> 以下配置可以优化体验,但大部分场合下并不需要修改
|
26 |
# 对话窗的高度
|
27 |
-
CHATBOT_HEIGHT =
|
28 |
|
29 |
# 发送请求到OpenAI后,等待多久判定为超时
|
30 |
TIMEOUT_SECONDS = 25
|
|
|
16 |
"http": "socks5h://localhost:11284",
|
17 |
"https": "socks5h://localhost:11284",
|
18 |
}
|
|
|
19 |
else:
|
20 |
proxies = None
|
|
|
21 |
|
22 |
|
23 |
# [step 3]>> 以下配置可以优化体验,但大部分场合下并不需要修改
|
24 |
# 对话窗的高度
|
25 |
+
CHATBOT_HEIGHT = 1116
|
26 |
|
27 |
# 发送请求到OpenAI后,等待多久判定为超时
|
28 |
TIMEOUT_SECONDS = 25
|
functional_crazy.py
CHANGED
@@ -18,7 +18,7 @@ def get_crazy_functionals():
|
|
18 |
from crazy_functions.代码重写为全英文_多线程 import 全项目切换英文
|
19 |
|
20 |
function_plugins = {
|
21 |
-
"
|
22 |
"AsButton": False, # 加入下拉菜单中
|
23 |
"Function": 解析项目本身
|
24 |
},
|
@@ -30,7 +30,7 @@ def get_crazy_functionals():
|
|
30 |
"Color": "stop", # 按钮颜色
|
31 |
"Function": 解析一个C项目的头文件
|
32 |
},
|
33 |
-
"解析整个C
|
34 |
"Color": "stop", # 按钮颜色
|
35 |
"AsButton": False, # 加入下拉菜单中
|
36 |
"Function": 解析一个C项目
|
|
|
18 |
from crazy_functions.代码重写为全英文_多线程 import 全项目切换英文
|
19 |
|
20 |
function_plugins = {
|
21 |
+
"请解析并解构此项目本身(源码自译解)": {
|
22 |
"AsButton": False, # 加入下拉菜单中
|
23 |
"Function": 解析项目本身
|
24 |
},
|
|
|
30 |
"Color": "stop", # 按钮颜色
|
31 |
"Function": 解析一个C项目的头文件
|
32 |
},
|
33 |
+
"解析整个C++项目(.cpp/.h)": {
|
34 |
"Color": "stop", # 按钮颜色
|
35 |
"AsButton": False, # 加入下拉菜单中
|
36 |
"Function": 解析一个C项目
|
main.py
CHANGED
@@ -54,7 +54,7 @@ with gr.Blocks(theme=set_theme, analytics_enabled=False, css=advanced_css) as de
|
|
54 |
stopBtn = gr.Button("停止", variant="secondary"); stopBtn.style(size="sm")
|
55 |
with gr.Row():
|
56 |
from check_proxy import check_proxy
|
57 |
-
|
58 |
with gr.Accordion("基础功能区", open=True) as area_basic_fn:
|
59 |
with gr.Row():
|
60 |
for k in functional:
|
@@ -93,8 +93,8 @@ with gr.Blocks(theme=set_theme, analytics_enabled=False, css=advanced_css) as de
|
|
93 |
checkboxes.select(fn_area_visibility, [checkboxes], [area_basic_fn, area_crazy_fn] )
|
94 |
# 整理反复出现的控件句柄组合
|
95 |
input_combo = [txt, top_p, temperature, chatbot, history, system_prompt]
|
96 |
-
output_combo = [chatbot, history,
|
97 |
-
predict_args = dict(fn=predict, inputs=input_combo, outputs=output_combo
|
98 |
empty_txt_args = dict(fn=lambda: "", inputs=[], outputs=[txt]) # 用于在提交后清空输入栏
|
99 |
# 提交按钮、重置按钮
|
100 |
cancel_handles.append(txt.submit(**predict_args)) #; txt.submit(**empty_txt_args) 在提交后清空输入栏
|
@@ -102,7 +102,7 @@ with gr.Blocks(theme=set_theme, analytics_enabled=False, css=advanced_css) as de
|
|
102 |
resetBtn.click(lambda: ([], [], "已重置"), None, output_combo)
|
103 |
# 基础功能区的回调函数注册
|
104 |
for k in functional:
|
105 |
-
click_handle = functional[k]["Button"].click(predict, [*input_combo, gr.State(True), gr.State(k)], output_combo
|
106 |
cancel_handles.append(click_handle)
|
107 |
# 文件上传区,接收文件后与chatbot的互动
|
108 |
file_upload.upload(on_file_uploaded, [file_upload, chatbot, txt], [chatbot, txt])
|
|
|
54 |
stopBtn = gr.Button("停止", variant="secondary"); stopBtn.style(size="sm")
|
55 |
with gr.Row():
|
56 |
from check_proxy import check_proxy
|
57 |
+
status = gr.Markdown(f"Tip: 按Enter提交, 按Shift+Enter换行。当前模型: {LLM_MODEL} \n {check_proxy(proxies)}")
|
58 |
with gr.Accordion("基础功能区", open=True) as area_basic_fn:
|
59 |
with gr.Row():
|
60 |
for k in functional:
|
|
|
93 |
checkboxes.select(fn_area_visibility, [checkboxes], [area_basic_fn, area_crazy_fn] )
|
94 |
# 整理反复出现的控件句柄组合
|
95 |
input_combo = [txt, top_p, temperature, chatbot, history, system_prompt]
|
96 |
+
output_combo = [chatbot, history, status]
|
97 |
+
predict_args = dict(fn=predict, inputs=input_combo, outputs=output_combo)
|
98 |
empty_txt_args = dict(fn=lambda: "", inputs=[], outputs=[txt]) # 用于在提交后清空输入栏
|
99 |
# 提交按钮、重置按钮
|
100 |
cancel_handles.append(txt.submit(**predict_args)) #; txt.submit(**empty_txt_args) 在提交后清空输入栏
|
|
|
102 |
resetBtn.click(lambda: ([], [], "已重置"), None, output_combo)
|
103 |
# 基础功能区的回调函数注册
|
104 |
for k in functional:
|
105 |
+
click_handle = functional[k]["Button"].click(predict, [*input_combo, gr.State(True), gr.State(k)], output_combo)
|
106 |
cancel_handles.append(click_handle)
|
107 |
# 文件上传区,接收文件后与chatbot的互动
|
108 |
file_upload.upload(on_file_uploaded, [file_upload, chatbot, txt], [chatbot, txt])
|
toolbox.py
CHANGED
@@ -1,6 +1,6 @@
|
|
1 |
import markdown, mdtex2html, threading, importlib, traceback, importlib, inspect, re
|
2 |
from show_math import convert as convert_math
|
3 |
-
from functools import wraps
|
4 |
|
5 |
def get_reduce_token_percent(text):
|
6 |
try:
|
@@ -289,22 +289,33 @@ def on_report_generated(files, chatbot):
|
|
289 |
chatbot.append(['汇总报告如何远程获取?', '汇总报告已经添加到右侧“文件上传区”(可能处于折叠状态),请查收。'])
|
290 |
return report_files, chatbot
|
291 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
292 |
def get_conf(*args):
|
293 |
# 建议您复制一个config_private.py放自己的秘密, 如API和代理网址, 避免不小心传github被别人看到
|
294 |
res = []
|
295 |
for arg in args:
|
296 |
-
|
297 |
-
except: r = getattr(importlib.import_module('config'), arg)
|
298 |
res.append(r)
|
299 |
-
# 在读取API_KEY时,检查一下是不是忘了改config
|
300 |
-
if arg=='API_KEY':
|
301 |
-
# 正确的 API_KEY 是 "sk-" + 48 位大小写字母数字的组合
|
302 |
-
API_MATCH = re.match(r"sk-[a-zA-Z0-9]{48}$", r)
|
303 |
-
if API_MATCH:
|
304 |
-
print(f"您的 API_KEY 是: {r[:15]}*** \nAPI_KEY 导入成功")
|
305 |
-
else:
|
306 |
-
assert False, "正确的 API_KEY 是 'sk-' + '48 位大小写字母数字' 的组合,请在config文件中修改API密钥, 添加海外代理之后再运行。" + \
|
307 |
-
"(如果您刚更新过代码,请确保旧版config_private文件中没有遗留任何新增键值)"
|
308 |
return res
|
309 |
|
310 |
def clear_line_break(txt):
|
|
|
1 |
import markdown, mdtex2html, threading, importlib, traceback, importlib, inspect, re
|
2 |
from show_math import convert as convert_math
|
3 |
+
from functools import wraps, lru_cache
|
4 |
|
5 |
def get_reduce_token_percent(text):
|
6 |
try:
|
|
|
289 |
chatbot.append(['汇总报告如何远程获取?', '汇总报告已经添加到右侧“文件上传区”(可能处于折叠状态),请查收。'])
|
290 |
return report_files, chatbot
|
291 |
|
292 |
+
@lru_cache
|
293 |
+
def read_single_conf_with_lru_cache(arg):
|
294 |
+
try: r = getattr(importlib.import_module('config_private'), arg)
|
295 |
+
except: r = getattr(importlib.import_module('config'), arg)
|
296 |
+
# 在读取API_KEY时,检查一下是不是忘了改config
|
297 |
+
if arg=='API_KEY':
|
298 |
+
# 正确的 API_KEY 是 "sk-" + 48 位大小写字母数字的组合
|
299 |
+
API_MATCH = re.match(r"sk-[a-zA-Z0-9]{48}$", r)
|
300 |
+
if API_MATCH:
|
301 |
+
print(f"[API_KEY] 您的 API_KEY 是: {r[:15]}*** API_KEY 导入成功")
|
302 |
+
else:
|
303 |
+
assert False, "正确的 API_KEY 是 'sk-' + '48 位大小写字母数字' 的组合,请在config文件中修改API密钥, 添加海外代理之后再运行。" + \
|
304 |
+
"(如果您刚更新过代码,请确保旧版config_private文件中没有遗留任何新增键值)"
|
305 |
+
if arg=='proxies':
|
306 |
+
if r is None:
|
307 |
+
print('[PROXY] 网络代理状态:未配置。无代理状态下很可能无法访问。建议:检查USE_PROXY选项是否修改。')
|
308 |
+
else:
|
309 |
+
print('[PROXY] 网络代理状态:已配置。配置信息如下:', r)
|
310 |
+
assert isinstance(r, dict), 'proxies格式错误,请注意proxies选项的格式,不要遗漏括号。'
|
311 |
+
return r
|
312 |
+
|
313 |
def get_conf(*args):
|
314 |
# 建议您复制一个config_private.py放自己的秘密, 如API和代理网址, 避免不小心传github被别人看到
|
315 |
res = []
|
316 |
for arg in args:
|
317 |
+
r = read_single_conf_with_lru_cache(arg)
|
|
|
318 |
res.append(r)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
319 |
return res
|
320 |
|
321 |
def clear_line_break(txt):
|