Spaces:
				
			
			
	
			
			
		Runtime error
		
	
	
	
			
			
	
	
	
	
		
		
		Runtime error
		
	file IO
Browse files- .gitignore +1 -0
- crazy_functions/解析项目源代码.py +20 -0
- functional_crazy.py +35 -9
- main.py +12 -8
- requirements.txt +1 -1
- toolbox.py +41 -1
    	
        .gitignore
    CHANGED
    
    | @@ -136,3 +136,4 @@ ssr_conf | |
| 136 | 
             
            config_private.py
         | 
| 137 | 
             
            gpt_log
         | 
| 138 | 
             
            private.md
         | 
|  | 
|  | |
| 136 | 
             
            config_private.py
         | 
| 137 | 
             
            gpt_log
         | 
| 138 | 
             
            private.md
         | 
| 139 | 
            +
            private_upload
         | 
    	
        crazy_functions/解析项目源代码.py
    CHANGED
    
    | @@ -127,3 +127,23 @@ def 解析一个C项目的头文件(txt, top_p, temperature, chatbot, history, s | |
| 127 | 
             
                    return
         | 
| 128 | 
             
                yield from 解析源代码(file_manifest, project_folder, top_p, temperature, chatbot, history, systemPromptTxt)
         | 
| 129 |  | 
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | 
|  | |
| 127 | 
             
                    return
         | 
| 128 | 
             
                yield from 解析源代码(file_manifest, project_folder, top_p, temperature, chatbot, history, systemPromptTxt)
         | 
| 129 |  | 
| 130 | 
            +
            @CatchException
         | 
| 131 | 
            +
            def 解析一个C项目(txt, top_p, temperature, chatbot, history, systemPromptTxt, WEB_PORT):
         | 
| 132 | 
            +
                history = []    # 清空历史,以免输入溢出
         | 
| 133 | 
            +
                import glob, os
         | 
| 134 | 
            +
                if os.path.exists(txt):
         | 
| 135 | 
            +
                    project_folder = txt
         | 
| 136 | 
            +
                else:
         | 
| 137 | 
            +
                    if txt == "": txt = '空空如也的输入栏'
         | 
| 138 | 
            +
                    report_execption(chatbot, history, a = f"解析项目: {txt}", b = f"找不到本地项目或无权访问: {txt}")
         | 
| 139 | 
            +
                    yield chatbot, history, '正常'
         | 
| 140 | 
            +
                    return
         | 
| 141 | 
            +
                file_manifest = [f for f in glob.glob(f'{project_folder}/**/*.h', recursive=True)]  + \
         | 
| 142 | 
            +
                                [f for f in glob.glob(f'{project_folder}/**/*.cpp', recursive=True)] + \
         | 
| 143 | 
            +
                                [f for f in glob.glob(f'{project_folder}/**/*.c', recursive=True)]
         | 
| 144 | 
            +
                if len(file_manifest) == 0:
         | 
| 145 | 
            +
                    report_execption(chatbot, history, a = f"解析项目: {txt}", b = f"找不到任何.h头文件: {txt}")
         | 
| 146 | 
            +
                    yield chatbot, history, '正常'
         | 
| 147 | 
            +
                    return
         | 
| 148 | 
            +
                yield from 解析源代码(file_manifest, project_folder, top_p, temperature, chatbot, history, systemPromptTxt)
         | 
| 149 | 
            +
             | 
    	
        functional_crazy.py
    CHANGED
    
    | @@ -5,25 +5,30 @@ def get_crazy_functionals(): | |
| 5 | 
             
                from crazy_functions.解析项目源代码 import 解析项目本身
         | 
| 6 | 
             
                from crazy_functions.解析项目源代码 import 解析一个Python项目
         | 
| 7 | 
             
                from crazy_functions.解析项目源代码 import 解析一个C项目的头文件
         | 
|  | |
| 8 | 
             
                from crazy_functions.高级功能函数模板 import 高阶功能模板函数
         | 
| 9 |  | 
| 10 | 
             
                return {
         | 
| 11 | 
             
                    "[实验] 请解析并解构此项目本身": {
         | 
| 12 | 
             
                        "Function": 解析项目本身
         | 
| 13 | 
             
                    },
         | 
| 14 | 
            -
                    "[实验] 解析整个py | 
| 15 | 
             
                        "Color": "stop",    # 按钮颜色
         | 
| 16 | 
             
                        "Function": 解析一个Python项目
         | 
| 17 | 
             
                    },
         | 
| 18 | 
            -
                    "[实验] 解析整个C | 
| 19 | 
             
                        "Color": "stop",    # 按钮颜色
         | 
| 20 | 
             
                        "Function": 解析一个C项目的头文件
         | 
| 21 | 
             
                    },
         | 
| 22 | 
            -
                    "[实验]  | 
|  | |
|  | |
|  | |
|  | |
| 23 | 
             
                        "Color": "stop",    # 按钮颜色
         | 
| 24 | 
             
                        "Function": 读文章写摘要
         | 
| 25 | 
             
                    },
         | 
| 26 | 
            -
                    "[实验]  | 
| 27 | 
             
                        "Color": "stop",    # 按钮颜色
         | 
| 28 | 
             
                        "Function": 批量生成函数注释
         | 
| 29 | 
             
                    },
         | 
| @@ -33,8 +38,29 @@ def get_crazy_functionals(): | |
| 33 | 
             
                    },
         | 
| 34 | 
             
                }
         | 
| 35 |  | 
| 36 | 
            -
            def on_file_uploaded( | 
| 37 | 
            -
                 | 
| 38 | 
            -
             | 
| 39 | 
            -
                 | 
| 40 | 
            -
                pass
         | 
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | 
|  | |
| 5 | 
             
                from crazy_functions.解析项目源代码 import 解析项目本身
         | 
| 6 | 
             
                from crazy_functions.解析项目源代码 import 解析一个Python项目
         | 
| 7 | 
             
                from crazy_functions.解析项目源代码 import 解析一个C项目的头文件
         | 
| 8 | 
            +
                from crazy_functions.解析项目源代码 import 解析一个C项目
         | 
| 9 | 
             
                from crazy_functions.高级功能函数模板 import 高阶功能模板函数
         | 
| 10 |  | 
| 11 | 
             
                return {
         | 
| 12 | 
             
                    "[实验] 请解析并解构此项目本身": {
         | 
| 13 | 
             
                        "Function": 解析项目本身
         | 
| 14 | 
             
                    },
         | 
| 15 | 
            +
                    "[实验] 解析整个py项目(配合input输入框)": {
         | 
| 16 | 
             
                        "Color": "stop",    # 按钮颜色
         | 
| 17 | 
             
                        "Function": 解析一个Python项目
         | 
| 18 | 
             
                    },
         | 
| 19 | 
            +
                    "[实验] 解析整个C++项目头文件(配合input输入框)": {
         | 
| 20 | 
             
                        "Color": "stop",    # 按钮颜色
         | 
| 21 | 
             
                        "Function": 解析一个C项目的头文件
         | 
| 22 | 
             
                    },
         | 
| 23 | 
            +
                    "[实验] 解析整个C++项目(配合input输入框)": {
         | 
| 24 | 
            +
                        "Color": "stop",    # 按钮颜色
         | 
| 25 | 
            +
                        "Function": 解析一个C项目
         | 
| 26 | 
            +
                    },
         | 
| 27 | 
            +
                    "[实验] 读tex论文写摘要(配合input输入框)": {
         | 
| 28 | 
             
                        "Color": "stop",    # 按钮颜色
         | 
| 29 | 
             
                        "Function": 读文章写摘要
         | 
| 30 | 
             
                    },
         | 
| 31 | 
            +
                    "[实验] 批量生成函数注释(配合input输入框)": {
         | 
| 32 | 
             
                        "Color": "stop",    # 按钮颜色
         | 
| 33 | 
             
                        "Function": 批量生成函数注释
         | 
| 34 | 
             
                    },
         | 
|  | |
| 38 | 
             
                    },
         | 
| 39 | 
             
                }
         | 
| 40 |  | 
| 41 | 
            +
            def on_file_uploaded(files, chatbot, txt):
         | 
| 42 | 
            +
                import shutil, os, time, glob
         | 
| 43 | 
            +
                from toolbox import extract_archive
         | 
| 44 | 
            +
                try: shutil.rmtree('./private_upload/')
         | 
| 45 | 
            +
                except: pass
         | 
| 46 | 
            +
                time_tag = time.strftime("%Y-%m-%d-%H-%M-%S", time.localtime())
         | 
| 47 | 
            +
                os.makedirs(f'private_upload/{time_tag}', exist_ok=True)
         | 
| 48 | 
            +
                for file in files:
         | 
| 49 | 
            +
                    file_origin_name = os.path.basename(file.orig_name)
         | 
| 50 | 
            +
                    shutil.copy(file.name, f'private_upload/{time_tag}/{file_origin_name}')
         | 
| 51 | 
            +
                    extract_archive(f'private_upload/{time_tag}/{file_origin_name}', 
         | 
| 52 | 
            +
                                    dest_dir=f'private_upload/{time_tag}/{file_origin_name}.extract')
         | 
| 53 | 
            +
                moved_files = [fp for fp in glob.glob('private_upload/**/*', recursive=True)]
         | 
| 54 | 
            +
                txt = f'private_upload/{time_tag}'
         | 
| 55 | 
            +
                moved_files_str = '\t\n\n'.join(moved_files)
         | 
| 56 | 
            +
                chatbot.append(['我上传了文件,请查收', 
         | 
| 57 | 
            +
                                f'[Local Message] 收到以下文件: \n\n{moved_files_str}\n\n调用路径参数已自动修正到: \n\n{txt}\n\n现在您可以直接选择任意实现性功能'])
         | 
| 58 | 
            +
                return chatbot, txt
         | 
| 59 | 
            +
             | 
| 60 | 
            +
            def on_report_generated(files, chatbot):
         | 
| 61 | 
            +
                from toolbox import find_recent_files
         | 
| 62 | 
            +
                report_files = find_recent_files('gpt_log')
         | 
| 63 | 
            +
                # files.extend(report_files)
         | 
| 64 | 
            +
                chatbot.append(['汇总报告如何远程获取?', '汇总报告已经添加到右侧文件上传区,请查收。'])
         | 
| 65 | 
            +
                return report_files, chatbot
         | 
| 66 | 
            +
             | 
    	
        main.py
    CHANGED
    
    | @@ -25,7 +25,7 @@ from functional import get_functionals | |
| 25 | 
             
            functional = get_functionals()
         | 
| 26 |  | 
| 27 | 
             
            # 对一些丧心病狂的实验性功能模块进行测试
         | 
| 28 | 
            -
            from functional_crazy import get_crazy_functionals, on_file_uploaded
         | 
| 29 | 
             
            crazy_functional = get_crazy_functionals()
         | 
| 30 |  | 
| 31 | 
             
            # 处理markdown文本格式的转变
         | 
| @@ -59,15 +59,15 @@ with gr.Blocks(theme=set_theme, analytics_enabled=False) as demo: | |
| 59 | 
             
                                variant = functional[k]["Color"] if "Color" in functional[k] else "secondary"
         | 
| 60 | 
             
                                functional[k]["Button"] = gr.Button(k, variant=variant)
         | 
| 61 | 
             
                        with gr.Row():
         | 
| 62 | 
            -
                            gr.Markdown(" | 
| 63 | 
             
                        with gr.Row():
         | 
| 64 | 
             
                            for k in crazy_functional:
         | 
| 65 | 
             
                                variant = crazy_functional[k]["Color"] if "Color" in crazy_functional[k] else "secondary"
         | 
| 66 | 
             
                                crazy_functional[k]["Button"] = gr.Button(k, variant=variant)
         | 
| 67 | 
             
                        with gr.Row():
         | 
| 68 | 
            -
                            gr.Markdown(" | 
| 69 | 
             
                        with gr.Row():
         | 
| 70 | 
            -
                            file_upload = gr.Files(file_count="multiple")
         | 
| 71 |  | 
| 72 | 
             
                        from check_proxy import check_proxy
         | 
| 73 | 
             
                        statusDisplay = gr.Markdown(f"{check_proxy(proxies)}")
         | 
| @@ -82,11 +82,15 @@ with gr.Blocks(theme=set_theme, analytics_enabled=False) as demo: | |
| 82 | 
             
                for k in functional:
         | 
| 83 | 
             
                    functional[k]["Button"].click(predict, 
         | 
| 84 | 
             
                        [txt, top_p, temperature, chatbot, history, systemPromptTxt, TRUE, gr.State(k)], [chatbot, history, statusDisplay], show_progress=True)
         | 
|  | |
| 85 | 
             
                for k in crazy_functional:
         | 
| 86 | 
            -
                    crazy_functional[k]["Button"].click(crazy_functional[k]["Function"], 
         | 
| 87 | 
            -
                        [txt, top_p, temperature, chatbot, history, systemPromptTxt, gr.State(PORT)], [chatbot, history, statusDisplay] | 
| 88 | 
            -
             | 
| 89 | 
            -
             | 
|  | |
|  | |
|  | |
| 90 | 
             
            # 延迟函数,做一些准备工作,最后尝试打开浏览器
         | 
| 91 | 
             
            def auto_opentab_delay():
         | 
| 92 | 
             
                import threading, webbrowser, time
         | 
|  | |
| 25 | 
             
            functional = get_functionals()
         | 
| 26 |  | 
| 27 | 
             
            # 对一些丧心病狂的实验性功能模块进行测试
         | 
| 28 | 
            +
            from functional_crazy import get_crazy_functionals, on_file_uploaded, on_report_generated
         | 
| 29 | 
             
            crazy_functional = get_crazy_functionals()
         | 
| 30 |  | 
| 31 | 
             
            # 处理markdown文本格式的转变
         | 
|  | |
| 59 | 
             
                                variant = functional[k]["Color"] if "Color" in functional[k] else "secondary"
         | 
| 60 | 
             
                                functional[k]["Button"] = gr.Button(k, variant=variant)
         | 
| 61 | 
             
                        with gr.Row():
         | 
| 62 | 
            +
                            gr.Markdown("以下部分实验性功能需读取路径.")
         | 
| 63 | 
             
                        with gr.Row():
         | 
| 64 | 
             
                            for k in crazy_functional:
         | 
| 65 | 
             
                                variant = crazy_functional[k]["Color"] if "Color" in crazy_functional[k] else "secondary"
         | 
| 66 | 
             
                                crazy_functional[k]["Button"] = gr.Button(k, variant=variant)
         | 
| 67 | 
             
                        with gr.Row():
         | 
| 68 | 
            +
                            gr.Markdown("上传本地文件,调用实验函数.")
         | 
| 69 | 
             
                        with gr.Row():
         | 
| 70 | 
            +
                            file_upload = gr.Files(label='任何文件,但推荐上传压缩文件(zip, tar)', file_count="multiple")
         | 
| 71 |  | 
| 72 | 
             
                        from check_proxy import check_proxy
         | 
| 73 | 
             
                        statusDisplay = gr.Markdown(f"{check_proxy(proxies)}")
         | 
|  | |
| 82 | 
             
                for k in functional:
         | 
| 83 | 
             
                    functional[k]["Button"].click(predict, 
         | 
| 84 | 
             
                        [txt, top_p, temperature, chatbot, history, systemPromptTxt, TRUE, gr.State(k)], [chatbot, history, statusDisplay], show_progress=True)
         | 
| 85 | 
            +
                file_upload.upload(on_file_uploaded, [file_upload, chatbot, txt], [chatbot, txt])
         | 
| 86 | 
             
                for k in crazy_functional:
         | 
| 87 | 
            +
                    click_handle = crazy_functional[k]["Button"].click(crazy_functional[k]["Function"], 
         | 
| 88 | 
            +
                        [txt, top_p, temperature, chatbot, history, systemPromptTxt, gr.State(PORT)], [chatbot, history, statusDisplay]
         | 
| 89 | 
            +
                    )
         | 
| 90 | 
            +
                    try: click_handle.then(on_report_generated, [file_upload, chatbot], [file_upload, chatbot])
         | 
| 91 | 
            +
                    except: pass
         | 
| 92 | 
            +
             | 
| 93 | 
            +
             | 
| 94 | 
             
            # 延迟函数,做一些准备工作,最后尝试打开浏览器
         | 
| 95 | 
             
            def auto_opentab_delay():
         | 
| 96 | 
             
                import threading, webbrowser, time
         | 
    	
        requirements.txt
    CHANGED
    
    | @@ -1,3 +1,3 @@ | |
| 1 | 
            -
            gradio
         | 
| 2 | 
             
            requests[socks]
         | 
| 3 | 
             
            mdtex2html
         | 
|  | |
| 1 | 
            +
            gradio>=3.23
         | 
| 2 | 
             
            requests[socks]
         | 
| 3 | 
             
            mdtex2html
         | 
    	
        toolbox.py
    CHANGED
    
    | @@ -142,4 +142,44 @@ def find_free_port(): | |
| 142 | 
             
                with closing(socket.socket(socket.AF_INET, socket.SOCK_STREAM)) as s:
         | 
| 143 | 
             
                    s.bind(('', 0))
         | 
| 144 | 
             
                    s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
         | 
| 145 | 
            -
                    return s.getsockname()[1]
         | 
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | 
|  | |
| 142 | 
             
                with closing(socket.socket(socket.AF_INET, socket.SOCK_STREAM)) as s:
         | 
| 143 | 
             
                    s.bind(('', 0))
         | 
| 144 | 
             
                    s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
         | 
| 145 | 
            +
                    return s.getsockname()[1]
         | 
| 146 | 
            +
                
         | 
| 147 | 
            +
             | 
| 148 | 
            +
            def extract_archive(file_path, dest_dir):
         | 
| 149 | 
            +
                import zipfile
         | 
| 150 | 
            +
                import tarfile
         | 
| 151 | 
            +
                import os
         | 
| 152 | 
            +
                # Get the file extension of the input file
         | 
| 153 | 
            +
                file_extension = os.path.splitext(file_path)[1]
         | 
| 154 | 
            +
             | 
| 155 | 
            +
                # Extract the archive based on its extension
         | 
| 156 | 
            +
                if file_extension == '.zip':
         | 
| 157 | 
            +
                    with zipfile.ZipFile(file_path, 'r') as zipobj:
         | 
| 158 | 
            +
                        zipobj.extractall(path=dest_dir)
         | 
| 159 | 
            +
                        print("Successfully extracted zip archive to {}".format(dest_dir))
         | 
| 160 | 
            +
             | 
| 161 | 
            +
                elif file_extension in ['.tar', '.gz', '.bz2']:
         | 
| 162 | 
            +
                    with tarfile.open(file_path, 'r:*') as tarobj:
         | 
| 163 | 
            +
                        tarobj.extractall(path=dest_dir)
         | 
| 164 | 
            +
                        print("Successfully extracted tar archive to {}".format(dest_dir))
         | 
| 165 | 
            +
                else:
         | 
| 166 | 
            +
                    return
         | 
| 167 | 
            +
                
         | 
| 168 | 
            +
            def find_recent_files(directory):
         | 
| 169 | 
            +
                """
         | 
| 170 | 
            +
                    me: find files that is created with in one minutes under a directory with python, write a function
         | 
| 171 | 
            +
                    gpt: here it is!
         | 
| 172 | 
            +
                """
         | 
| 173 | 
            +
                import os
         | 
| 174 | 
            +
                import time
         | 
| 175 | 
            +
                current_time = time.time()
         | 
| 176 | 
            +
                one_minute_ago = current_time - 60
         | 
| 177 | 
            +
                recent_files = []
         | 
| 178 | 
            +
             | 
| 179 | 
            +
                for filename in os.listdir(directory):
         | 
| 180 | 
            +
                    file_path = os.path.join(directory, filename)
         | 
| 181 | 
            +
                    created_time = os.path.getctime(file_path)
         | 
| 182 | 
            +
                    if created_time >= one_minute_ago:
         | 
| 183 | 
            +
                        recent_files.append(file_path)
         | 
| 184 | 
            +
             | 
| 185 | 
            +
                return recent_files
         | 
