|  | import gradio as gr | 
					
						
						|  | import os | 
					
						
						|  | import subprocess | 
					
						
						|  | import sys | 
					
						
						|  | import shutil | 
					
						
						|  | import uuid | 
					
						
						|  | import platform | 
					
						
						|  | import time | 
					
						
						|  | from pathlib import Path | 
					
						
						|  | import tempfile | 
					
						
						|  | import glob | 
					
						
						|  | import traceback | 
					
						
						|  | import threading | 
					
						
						|  | import queue | 
					
						
						|  | import re | 
					
						
						|  |  | 
					
						
						|  | def ensure_dir(dir_path): | 
					
						
						|  | """Ensure directory exists""" | 
					
						
						|  | Path(dir_path).mkdir(parents=True, exist_ok=True) | 
					
						
						|  |  | 
					
						
						|  | def check_dependencies(): | 
					
						
						|  | """Check if required dependencies are available""" | 
					
						
						|  | missing_deps = [] | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | try: | 
					
						
						|  | result = subprocess.run([sys.executable, "-m", "nuitka", "--version"], capture_output=True, text=True) | 
					
						
						|  | if result.returncode != 0: | 
					
						
						|  | missing_deps.append("nuitka") | 
					
						
						|  | except: | 
					
						
						|  | missing_deps.append("nuitka") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | mingw_compilers = [ | 
					
						
						|  | "x86_64-w64-mingw32-gcc", | 
					
						
						|  | "i686-w64-mingw32-gcc" | 
					
						
						|  | ] | 
					
						
						|  |  | 
					
						
						|  | found_mingw = False | 
					
						
						|  | for compiler in mingw_compilers: | 
					
						
						|  | result = subprocess.run(["which", compiler], capture_output=True) | 
					
						
						|  | if result.returncode == 0: | 
					
						
						|  | found_mingw = True | 
					
						
						|  | break | 
					
						
						|  |  | 
					
						
						|  | if not found_mingw: | 
					
						
						|  | missing_deps.append("mingw-w64") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | result = subprocess.run(["which", "patchelf"], capture_output=True) | 
					
						
						|  | if result.returncode != 0: | 
					
						
						|  | missing_deps.append("patchelf") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | result = subprocess.run(["which", "gcc"], capture_output=True) | 
					
						
						|  | if result.returncode != 0: | 
					
						
						|  | missing_deps.append("gcc") | 
					
						
						|  |  | 
					
						
						|  | return missing_deps | 
					
						
						|  |  | 
					
						
						|  | def check_static_libpython(): | 
					
						
						|  | """Check if static libpython is available""" | 
					
						
						|  | try: | 
					
						
						|  |  | 
					
						
						|  | result = subprocess.run( | 
					
						
						|  | [sys.executable, "-c", "import sysconfig; print(sysconfig.get_config_var('LIBDIR'))"], | 
					
						
						|  | capture_output=True, text=True | 
					
						
						|  | ) | 
					
						
						|  | if result.returncode == 0: | 
					
						
						|  | libdir = result.stdout.strip() | 
					
						
						|  |  | 
					
						
						|  | static_libs = glob.glob(os.path.join(libdir, "libpython*.a")) | 
					
						
						|  | return len(static_libs) > 0 | 
					
						
						|  | except: | 
					
						
						|  | pass | 
					
						
						|  | return False | 
					
						
						|  |  | 
					
						
						|  | def get_current_python_version(): | 
					
						
						|  | """Get the current Python version for compatibility notes""" | 
					
						
						|  | return f"{sys.version_info.major}.{sys.version_info.minor}.{sys.version_info.micro}" | 
					
						
						|  |  | 
					
						
						|  | def get_nuitka_version(): | 
					
						
						|  | """Get the current Nuitka version to handle different command line options""" | 
					
						
						|  | try: | 
					
						
						|  | result = subprocess.run([sys.executable, "-m", "nuitka", "--version"], | 
					
						
						|  | capture_output=True, text=True) | 
					
						
						|  | if result.returncode == 0: | 
					
						
						|  | version_line = result.stdout.strip().split('\n')[0] | 
					
						
						|  |  | 
					
						
						|  | version = version_line.split()[-1] | 
					
						
						|  | return version | 
					
						
						|  | return "not installed" | 
					
						
						|  | except: | 
					
						
						|  | return "not installed" | 
					
						
						|  |  | 
					
						
						|  | def create_progress_bar(progress, status_text="", show_percentage=True): | 
					
						
						|  | """Create an HTML progress bar""" | 
					
						
						|  | percentage = max(0, min(100, progress * 100)) | 
					
						
						|  |  | 
					
						
						|  | color = "bg-green-500" if percentage == 100 else ("bg-yellow-500" if percentage > 50 else "bg-blue-500") | 
					
						
						|  |  | 
					
						
						|  | html = f""" | 
					
						
						|  | <div style="width: 100%; background-color: #f0f0f0; border-radius: 10px; padding: 3px; box-shadow: inset 0 2px 4px rgba(0,0,0,0.1);"> | 
					
						
						|  | <div style="width: {percentage}%; background: linear-gradient(90deg, #4CAF50 0%, #45a049 100%); | 
					
						
						|  | height: 25px; border-radius: 8px; transition: width 0.3s ease-in-out; display: flex; align-items: center; justify-content: center;"> | 
					
						
						|  | <span style="color: white; font-weight: bold; font-size: 12px;"> | 
					
						
						|  | {f'{percentage:.1f}%' if show_percentage else ''} | 
					
						
						|  | </span> | 
					
						
						|  | </div> | 
					
						
						|  | </div> | 
					
						
						|  | <div style="margin-top: 8px; text-align: center; color: #333; font-size: 14px; font-weight: 500;"> | 
					
						
						|  | {status_text} | 
					
						
						|  | </div> | 
					
						
						|  | """ | 
					
						
						|  | return html | 
					
						
						|  |  | 
					
						
						|  | def install_system_packages(packages_content, progress_callback=None): | 
					
						
						|  | """Note about system packages in HF Spaces - they cannot be installed""" | 
					
						
						|  | if not packages_content.strip(): | 
					
						
						|  | return "No system packages specified." | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | packages_list = [line.strip() for line in packages_content.strip().split('\n') | 
					
						
						|  | if line.strip() and not line.strip().startswith('#')] | 
					
						
						|  |  | 
					
						
						|  | if packages_list: | 
					
						
						|  | return f"β System packages cannot be installed in Hugging Face Spaces:\n{', '.join(packages_list)}\n\nβΉοΈ HF Spaces runs in a containerized environment without sudo access.\nThese packages need to be pre-installed in the Docker image or available as Python packages." | 
					
						
						|  | return "No system packages specified." | 
					
						
						|  |  | 
					
						
						|  | def install_nuitka_if_missing(): | 
					
						
						|  | """Try to install Nuitka if it's missing""" | 
					
						
						|  | try: | 
					
						
						|  |  | 
					
						
						|  | result = subprocess.run([sys.executable, "-m", "nuitka", "--version"], capture_output=True) | 
					
						
						|  | if result.returncode == 0: | 
					
						
						|  | return True, "Nuitka is already installed" | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | print("Installing Nuitka...") | 
					
						
						|  | result = subprocess.run([sys.executable, "-m", "pip", "install", "nuitka"], | 
					
						
						|  | capture_output=True, text=True) | 
					
						
						|  |  | 
					
						
						|  | if result.returncode == 0: | 
					
						
						|  | return True, "Nuitka installed successfully" | 
					
						
						|  | else: | 
					
						
						|  | return False, f"Failed to install Nuitka: {result.stderr}" | 
					
						
						|  | except Exception as e: | 
					
						
						|  | return False, f"Error installing Nuitka: {str(e)}" | 
					
						
						|  |  | 
					
						
						|  | def check_mingw_installation(): | 
					
						
						|  | """Check if MinGW-w64 is properly installed""" | 
					
						
						|  | mingw_compilers = [ | 
					
						
						|  | ("x86_64-w64-mingw32-gcc", "64-bit"), | 
					
						
						|  | ("x86_64-w64-mingw32-g++", "64-bit"), | 
					
						
						|  | ("x86_64-w64-mingw32-ld", "64-bit"), | 
					
						
						|  | ("i686-w64-mingw32-gcc", "32-bit"), | 
					
						
						|  | ("i686-w64-mingw32-g++", "32-bit"), | 
					
						
						|  | ("i686-w64-mingw32-ld", "32-bit") | 
					
						
						|  | ] | 
					
						
						|  |  | 
					
						
						|  | available = [] | 
					
						
						|  | missing = [] | 
					
						
						|  |  | 
					
						
						|  | for compiler, arch in mingw_compilers: | 
					
						
						|  | result = subprocess.run(["which", compiler], capture_output=True) | 
					
						
						|  | if result.returncode == 0: | 
					
						
						|  | available.append((compiler, arch)) | 
					
						
						|  | else: | 
					
						
						|  | missing.append((compiler, arch)) | 
					
						
						|  |  | 
					
						
						|  | return missing, available | 
					
						
						|  |  | 
					
						
						|  | def find_compiled_binary(output_dir, output_filename): | 
					
						
						|  | """Find the compiled binary, checking different possible paths""" | 
					
						
						|  |  | 
					
						
						|  | direct_path = os.path.join(output_dir, output_filename) | 
					
						
						|  | if os.path.exists(direct_path): | 
					
						
						|  | return direct_path | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | dist_path = os.path.join(output_dir, "user_script.dist", output_filename) | 
					
						
						|  | if os.path.exists(dist_path): | 
					
						
						|  | return dist_path | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | patterns = [ | 
					
						
						|  | os.path.join(output_dir, "**", output_filename), | 
					
						
						|  | os.path.join(output_dir, "**", "user_script"), | 
					
						
						|  | os.path.join(output_dir, "**", "user_script.exe"), | 
					
						
						|  | os.path.join(output_dir, "**", "*.bin"), | 
					
						
						|  | os.path.join(output_dir, "**", "*.exe"), | 
					
						
						|  | ] | 
					
						
						|  |  | 
					
						
						|  | for pattern in patterns: | 
					
						
						|  | matches = glob.glob(pattern, recursive=True) | 
					
						
						|  | if matches: | 
					
						
						|  | return matches[0] | 
					
						
						|  |  | 
					
						
						|  | return None | 
					
						
						|  |  | 
					
						
						|  | def load_script_from_file(file): | 
					
						
						|  | """Load Python script from uploaded file""" | 
					
						
						|  | if file is None: | 
					
						
						|  | return "" | 
					
						
						|  |  | 
					
						
						|  | try: | 
					
						
						|  |  | 
					
						
						|  | with open(file.name, 'r', encoding='utf-8') as f: | 
					
						
						|  | content = f.read() | 
					
						
						|  | return content | 
					
						
						|  | except UnicodeDecodeError: | 
					
						
						|  |  | 
					
						
						|  | try: | 
					
						
						|  | with open(file.name, 'r', encoding='latin-1') as f: | 
					
						
						|  | content = f.read() | 
					
						
						|  | return content | 
					
						
						|  | except Exception as e: | 
					
						
						|  | return f"# Error reading file: {str(e)}\n# Please ensure the file is a valid text file." | 
					
						
						|  | except Exception as e: | 
					
						
						|  | return f"# Error reading file: {str(e)}" | 
					
						
						|  |  | 
					
						
						|  | def create_improved_version_wrappers(wrapper_dir, log_queue=None): | 
					
						
						|  | """Create improved wrapper scripts that handle version parsing correctly""" | 
					
						
						|  | ensure_dir(wrapper_dir) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | tools = ["gcc", "g++", "ar", "nm", "strip", "ranlib", "objcopy", "objdump", "readelf", "size", "strings"] | 
					
						
						|  |  | 
					
						
						|  | for tool in tools: | 
					
						
						|  | wrapper_path = os.path.join(wrapper_dir, f"x86_64-w64-mingw32-{tool}") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | wrapper_content = f'''#!/bin/bash | 
					
						
						|  | # Advanced wrapper for x86_64-w64-mingw32-{tool} | 
					
						
						|  |  | 
					
						
						|  | # Handle version queries specially | 
					
						
						|  | if [ "$1" = "--version" ] || [ "$1" = "-dumpversion" ]; then | 
					
						
						|  | # Try to get version from the actual tool | 
					
						
						|  | version_output=$(/usr/bin/x86_64-w64-mingw32-{tool} --version 2>/dev/null | head -1) | 
					
						
						|  |  | 
					
						
						|  | # Extract version number using regex | 
					
						
						|  | if [[ $version_output =~ ([0-9]+)\.([0-9]+)\.?([0-9]*) ]]; then | 
					
						
						|  | # Found a standard version format | 
					
						
						|  | major="${{BASH_REMATCH[1]}}" | 
					
						
						|  | minor="${{BASH_REMATCH[2]}}" | 
					
						
						|  | patch="${{BASH_REMATCH[3]:-0}}" | 
					
						
						|  | echo "${{major}}.${{minor}}.${{patch}}" | 
					
						
						|  | elif [[ $version_output =~ ([0-9]+)[^0-9] ]]; then | 
					
						
						|  | # Found just a major version number | 
					
						
						|  | major="${{BASH_REMATCH[1]}}" | 
					
						
						|  | echo "${{major}}.0.0" | 
					
						
						|  | else | 
					
						
						|  | # Fallback to a generic version that Nuitka can parse | 
					
						
						|  | echo "12.0.0" | 
					
						
						|  | fi | 
					
						
						|  | exit 0 | 
					
						
						|  | fi | 
					
						
						|  |  | 
					
						
						|  | # For all other commands, pass through to the real tool | 
					
						
						|  | exec /usr/bin/x86_64-w64-mingw32-{tool} "$@" | 
					
						
						|  | ''' | 
					
						
						|  |  | 
					
						
						|  | with open(wrapper_path, "w") as f: | 
					
						
						|  | f.write(wrapper_content) | 
					
						
						|  | os.chmod(wrapper_path, 0o755) | 
					
						
						|  |  | 
					
						
						|  | if log_queue: | 
					
						
						|  | log_queue.put(f"Created advanced wrapper for {tool}\n") | 
					
						
						|  |  | 
					
						
						|  | return True | 
					
						
						|  |  | 
					
						
						|  | def compile_with_nuitka(code, requirements, packages, compilation_mode, output_extension, log_queue, progress_callback=None): | 
					
						
						|  | """Compile Python code with Nuitka""" | 
					
						
						|  |  | 
					
						
						|  | current_python = get_current_python_version() | 
					
						
						|  | nuitka_version = get_nuitka_version() | 
					
						
						|  |  | 
					
						
						|  | try: | 
					
						
						|  |  | 
					
						
						|  | if progress_callback: | 
					
						
						|  | progress_callback(0, "Starting compilation process...") | 
					
						
						|  |  | 
					
						
						|  | if log_queue: | 
					
						
						|  | log_queue.put("=== Starting Nuitka Compilation ===\n") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | nuitka_installed, nuitka_msg = install_nuitka_if_missing() | 
					
						
						|  | if not nuitka_installed: | 
					
						
						|  | error_summary = f"""# β Nuitka Not Available | 
					
						
						|  |  | 
					
						
						|  | ## Error: | 
					
						
						|  | {nuitka_msg} | 
					
						
						|  |  | 
					
						
						|  | ## Solution: | 
					
						
						|  | Nuitka needs to be installed first. In Hugging Face Spaces, this should be done in the requirements.txt file: | 
					
						
						|  |  | 
					
						
						|  | ``` | 
					
						
						|  | nuitka | 
					
						
						|  | ``` | 
					
						
						|  |  | 
					
						
						|  | Add this to your requirements.txt and redeploy the space.""" | 
					
						
						|  | return error_summary, None, nuitka_msg, False | 
					
						
						|  |  | 
					
						
						|  | if progress_callback: | 
					
						
						|  | progress_callback(0.05, "Checking environment...") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | has_static_libpython = check_static_libpython() | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | missing_deps = check_dependencies() | 
					
						
						|  |  | 
					
						
						|  | if progress_callback: | 
					
						
						|  | progress_callback(0.1, "Setting up compilation directories...") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | job_id = str(uuid.uuid4()) | 
					
						
						|  | base_dir = os.path.join(os.getcwd(), "user_code") | 
					
						
						|  | job_dir = os.path.join(base_dir, job_id) | 
					
						
						|  | output_dir = os.path.join(os.getcwd(), "compiled_output", job_id) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | ensure_dir(job_dir) | 
					
						
						|  | ensure_dir(output_dir) | 
					
						
						|  |  | 
					
						
						|  | if progress_callback: | 
					
						
						|  | progress_callback(0.15, "Processing packages...") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | packages_result = install_system_packages(packages) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | script_path = os.path.join(job_dir, "user_script.py") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | enhanced_code = f""" | 
					
						
						|  | # Enhanced error handling for network dependencies | 
					
						
						|  | import sys | 
					
						
						|  | import os | 
					
						
						|  |  | 
					
						
						|  | # Handle network timeout errors gracefully | 
					
						
						|  | def handle_network_error(): | 
					
						
						|  | print("\\nβ οΈ  Network Error Detected") | 
					
						
						|  | print("This application appears to require internet access.") | 
					
						
						|  | print("Common causes:") | 
					
						
						|  | print("1. Hugging Face model downloads") | 
					
						
						|  | print("2. API calls to online services") | 
					
						
						|  | print("3. Data downloads from remote sources") | 
					
						
						|  | print("\\nIn a standalone executable, these operations require:") | 
					
						
						|  | print("- Pre-downloaded models/data") | 
					
						
						|  | print("- Cache configuration") | 
					
						
						|  | print("- Offline mode settings") | 
					
						
						|  | print("\\nPlease modify your code to work offline or handle network errors.") | 
					
						
						|  | return 1 | 
					
						
						|  |  | 
					
						
						|  | # Monkey patch urllib for better error handling | 
					
						
						|  | try: | 
					
						
						|  | import urllib.request | 
					
						
						|  | import urllib.error | 
					
						
						|  | original_urlopen = urllib.request.urlopen | 
					
						
						|  |  | 
					
						
						|  | def enhanced_urlopen(url, *args, **kwargs): | 
					
						
						|  | try: | 
					
						
						|  | return original_urlopen(url, *args, **kwargs) | 
					
						
						|  | except urllib.error.URLError as e: | 
					
						
						|  | if hasattr(e, 'reason') and 'could not resolve host' in str(e.reason).lower(): | 
					
						
						|  | print(f"\\nβ DNS Resolution Error: {{e.reason}}") | 
					
						
						|  | handle_network_error() | 
					
						
						|  | sys.exit(6)  # Exit with the same code for consistency | 
					
						
						|  | raise | 
					
						
						|  |  | 
					
						
						|  | urllib.request.urlopen = enhanced_urlopen | 
					
						
						|  | except ImportError: | 
					
						
						|  | pass | 
					
						
						|  |  | 
					
						
						|  | # Your original code starts here | 
					
						
						|  | {code} | 
					
						
						|  | """ | 
					
						
						|  |  | 
					
						
						|  | with open(script_path, "w") as f: | 
					
						
						|  | f.write(enhanced_code) | 
					
						
						|  |  | 
					
						
						|  | if progress_callback: | 
					
						
						|  | progress_callback(0.2, "Installing Python requirements...") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | install_result = "No Python requirements specified." | 
					
						
						|  | if requirements.strip(): | 
					
						
						|  | req_path = os.path.join(job_dir, "requirements.txt") | 
					
						
						|  | with open(req_path, "w") as f: | 
					
						
						|  | f.write(requirements) | 
					
						
						|  |  | 
					
						
						|  | try: | 
					
						
						|  | if log_queue: | 
					
						
						|  | log_queue.put("Installing Python requirements...\n") | 
					
						
						|  |  | 
					
						
						|  | install_process = subprocess.run( | 
					
						
						|  | [sys.executable, "-m", "pip", "install", "--no-cache-dir", "-r", req_path], | 
					
						
						|  | capture_output=True, | 
					
						
						|  | text=True | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  | if install_process.returncode == 0: | 
					
						
						|  | install_result = "β
 Python requirements installed successfully." | 
					
						
						|  | if log_queue: | 
					
						
						|  | log_queue.put("β
 Requirements installed successfully\n") | 
					
						
						|  | else: | 
					
						
						|  | install_result = f"β οΈ Installation completed with warnings. Return code: {install_process.returncode}\n{install_process.stderr}" | 
					
						
						|  | if log_queue: | 
					
						
						|  | log_queue.put(f"β οΈ Installation warnings:\n{install_process.stderr}\n") | 
					
						
						|  | except Exception as e: | 
					
						
						|  | install_result = f"β Error installing requirements: {str(e)}" | 
					
						
						|  | if log_queue: | 
					
						
						|  | log_queue.put(f"β Error installing requirements: {str(e)}\n") | 
					
						
						|  | return install_result, None, f"Error: {str(e)}", False | 
					
						
						|  |  | 
					
						
						|  | if progress_callback: | 
					
						
						|  | progress_callback(0.3, "Building compilation command...") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | if compilation_mode == "Maximum Compatibility (Recommended)": | 
					
						
						|  | cmd = [ | 
					
						
						|  | sys.executable, "-m", "nuitka", | 
					
						
						|  | "--standalone", | 
					
						
						|  | "--onefile", | 
					
						
						|  | "--show-progress", | 
					
						
						|  | "--remove-output", | 
					
						
						|  | "--follow-imports", | 
					
						
						|  | "--assume-yes-for-downloads", | 
					
						
						|  | "--python-flag=no_site", | 
					
						
						|  | "--python-flag=no_warnings", | 
					
						
						|  | script_path, | 
					
						
						|  | f"--output-dir={output_dir}" | 
					
						
						|  | ] | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | if has_static_libpython and output_extension != ".exe": | 
					
						
						|  | cmd.append("--static-libpython=yes") | 
					
						
						|  |  | 
					
						
						|  | mode_name = "Maximum Compatibility Binary" | 
					
						
						|  |  | 
					
						
						|  | elif compilation_mode == "Portable Binary": | 
					
						
						|  | cmd = [ | 
					
						
						|  | sys.executable, "-m", "nuitka", | 
					
						
						|  | "--show-progress", | 
					
						
						|  | "--remove-output", | 
					
						
						|  | "--assume-yes-for-downloads", | 
					
						
						|  | "--python-flag=no_site", | 
					
						
						|  | "--python-flag=no_warnings", | 
					
						
						|  | script_path, | 
					
						
						|  | f"--output-dir={output_dir}" | 
					
						
						|  | ] | 
					
						
						|  | mode_name = "Portable Non-Standalone" | 
					
						
						|  |  | 
					
						
						|  | else: | 
					
						
						|  | cmd = [ | 
					
						
						|  | sys.executable, "-m", "nuitka", | 
					
						
						|  | "--standalone", | 
					
						
						|  | "--onefile", | 
					
						
						|  | "--show-progress", | 
					
						
						|  | "--remove-output", | 
					
						
						|  | "--assume-yes-for-downloads", | 
					
						
						|  | "--python-flag=no_site", | 
					
						
						|  | "--python-flag=no_warnings", | 
					
						
						|  | script_path, | 
					
						
						|  | f"--output-dir={output_dir}" | 
					
						
						|  | ] | 
					
						
						|  | mode_name = "Standalone Binary" | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | env = os.environ.copy() | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | if progress_callback: | 
					
						
						|  | progress_callback(0.4, "Executing Nuitka compilation...") | 
					
						
						|  |  | 
					
						
						|  | if log_queue: | 
					
						
						|  | log_queue.put(f"Final compilation command: {' '.join(cmd)}\n") | 
					
						
						|  | log_queue.put("Starting compilation...\n") | 
					
						
						|  |  | 
					
						
						|  | process = subprocess.Popen( | 
					
						
						|  | cmd, | 
					
						
						|  | stdout=subprocess.PIPE, | 
					
						
						|  | stderr=subprocess.STDOUT, | 
					
						
						|  | text=True, | 
					
						
						|  | bufsize=1, | 
					
						
						|  | universal_newlines=True, | 
					
						
						|  | env=env | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | compile_output = "" | 
					
						
						|  | line_count = 0 | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | for line in iter(process.stdout.readline, ''): | 
					
						
						|  | compile_output += line | 
					
						
						|  | line_count += 1 | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | if log_queue: | 
					
						
						|  | log_queue.put(line) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | progress_val = 0.4 + (min(line_count / 200, 0.55) * 0.5) | 
					
						
						|  | status_text = "Compiling..." | 
					
						
						|  |  | 
					
						
						|  | if "INFO:" in line: | 
					
						
						|  | status_text = f"INFO: {line.strip()[:60]}..." | 
					
						
						|  | elif "PROCESSING" in line: | 
					
						
						|  | status_text = f"Processing: {line.strip()[:60]}..." | 
					
						
						|  | elif "Optimizing" in line: | 
					
						
						|  | status_text = f"Optimizing: {line.strip()[:60]}..." | 
					
						
						|  | elif "Creating" in line: | 
					
						
						|  | status_text = f"Creating: {line.strip()[:60]}..." | 
					
						
						|  | elif "MinGW" in line or "gcc" in line: | 
					
						
						|  | status_text = f"MinGW: {line.strip()[:60]}..." | 
					
						
						|  | elif "version" in line.lower(): | 
					
						
						|  | status_text = f"Version Check: {line.strip()[:60]}..." | 
					
						
						|  |  | 
					
						
						|  | if progress_callback: | 
					
						
						|  | progress_callback(progress_val, status_text) | 
					
						
						|  |  | 
					
						
						|  | process.wait() | 
					
						
						|  |  | 
					
						
						|  | if progress_callback: | 
					
						
						|  | progress_callback(0.9, "Finalizing compilation...") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | output_filename = f"user_script{output_extension}" | 
					
						
						|  | binary_path = find_compiled_binary(output_dir, output_filename) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | if not binary_path: | 
					
						
						|  |  | 
					
						
						|  | patterns = [ | 
					
						
						|  | os.path.join(output_dir, "user_script"), | 
					
						
						|  | os.path.join(output_dir, "user_script.bin"), | 
					
						
						|  | os.path.join(output_dir, "user_script.exe"), | 
					
						
						|  | os.path.join(output_dir, "**", "user_script"), | 
					
						
						|  | os.path.join(output_dir, "**", "*.bin"), | 
					
						
						|  | os.path.join(output_dir, "**", "*.exe"), | 
					
						
						|  | ] | 
					
						
						|  |  | 
					
						
						|  | for pattern in patterns: | 
					
						
						|  | matches = glob.glob(pattern, recursive=True) | 
					
						
						|  | if matches: | 
					
						
						|  | binary_path = matches[0] | 
					
						
						|  | break | 
					
						
						|  |  | 
					
						
						|  | if log_queue: | 
					
						
						|  | log_queue.put(f"Compilation finished with exit code: {process.returncode}\n") | 
					
						
						|  |  | 
					
						
						|  | if process.returncode == 0 and binary_path: | 
					
						
						|  |  | 
					
						
						|  | try: | 
					
						
						|  | file_process = subprocess.run(["file", binary_path], capture_output=True, text=True) | 
					
						
						|  | binary_info = file_process.stdout | 
					
						
						|  | if log_queue: | 
					
						
						|  | log_queue.put(f"Binary info: {binary_info}\n") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | if "ELF" in binary_info: | 
					
						
						|  | if "64-bit" in binary_info: | 
					
						
						|  | arch_info = "Linux 64-bit" | 
					
						
						|  | elif "32-bit" in binary_info: | 
					
						
						|  | arch_info = "Linux 32-bit" | 
					
						
						|  | else: | 
					
						
						|  | arch_info = "Linux" | 
					
						
						|  | else: | 
					
						
						|  | arch_info = "unknown" | 
					
						
						|  |  | 
					
						
						|  | log_queue.put(f"Detected architecture: {arch_info}\n") | 
					
						
						|  |  | 
					
						
						|  | except: | 
					
						
						|  | binary_info = "Binary file (unable to get detailed info)" | 
					
						
						|  | arch_info = "unknown" | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | try: | 
					
						
						|  | ldd_process = subprocess.run(["ldd", binary_path], capture_output=True, text=True) | 
					
						
						|  | if "not a dynamic executable" in ldd_process.stderr or "statically linked" in ldd_process.stdout: | 
					
						
						|  | linking_info = "β
 Statically linked - fully portable!" | 
					
						
						|  | else: | 
					
						
						|  |  | 
					
						
						|  | if ldd_process.returncode == 0: | 
					
						
						|  | libs = ldd_process.stdout.count("=>") | 
					
						
						|  | linking_info = f"π Dynamically linked ({libs} libraries) - designed for maximum compatibility" | 
					
						
						|  | else: | 
					
						
						|  | linking_info = "βΉοΈ Compiled binary - should work on compatible systems" | 
					
						
						|  | except: | 
					
						
						|  | linking_info = "βΉοΈ Compiled binary created successfully" | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | if output_extension in ['.bin', '.sh'] and not binary_path.endswith(output_extension): | 
					
						
						|  | new_binary_path = binary_path + output_extension | 
					
						
						|  | shutil.move(binary_path, new_binary_path) | 
					
						
						|  | binary_path = new_binary_path | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | os.chmod(binary_path, 0o755) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | static_status = "Yes" if has_static_libpython else "No" | 
					
						
						|  | file_size = os.path.getsize(binary_path) / 1024 | 
					
						
						|  | binary_basename = os.path.basename(binary_path) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | result_summary = f"""# β
 Compilation Successful! | 
					
						
						|  |  | 
					
						
						|  | ## Compilation Details: | 
					
						
						|  | - **Mode**: {mode_name} | 
					
						
						|  | - **Nuitka Version**: {nuitka_version} | 
					
						
						|  | - **Exit Code**: {process.returncode} | 
					
						
						|  | - **Output Path**: {binary_path} | 
					
						
						|  | - **File Size**: {file_size:.2f} KB | 
					
						
						|  | - **Compiled with Python**: {current_python} | 
					
						
						|  | - **Static Libpython Available**: {static_status} | 
					
						
						|  | - **Linking**: {linking_info} | 
					
						
						|  | - **Target Platform**: Linux | 
					
						
						|  | - **Architecture**: {arch_info} | 
					
						
						|  |  | 
					
						
						|  | ## Environment Results: | 
					
						
						|  | **System Packages**: {packages_result} | 
					
						
						|  | **Python Requirements**: {install_result} | 
					
						
						|  |  | 
					
						
						|  | ## Binary Information: | 
					
						
						|  | {binary_info} | 
					
						
						|  |  | 
					
						
						|  | ## π Usage Instructions: | 
					
						
						|  | ```bash | 
					
						
						|  | chmod +x {binary_basename} | 
					
						
						|  | ./{binary_basename} | 
					
						
						|  | ``` | 
					
						
						|  |  | 
					
						
						|  | ## π Network Dependencies: | 
					
						
						|  | - Binary includes enhanced error handling for network issues | 
					
						
						|  | - Will provide helpful messages if DNS resolution fails | 
					
						
						|  | - Exits with code 6 for network errors (same as original issue) | 
					
						
						|  | - Consider pre-downloading models/data for offline usage | 
					
						
						|  |  | 
					
						
						|  | ## π§ͺ Testing: | 
					
						
						|  | Run directly on compatible Linux systems: | 
					
						
						|  | ```bash | 
					
						
						|  | ./{binary_basename} | 
					
						
						|  | ``` | 
					
						
						|  |  | 
					
						
						|  | ## π§ Technical Details: | 
					
						
						|  | - Native compilation optimized for compatibility | 
					
						
						|  | - Network error handling added for better runtime diagnostics | 
					
						
						|  | - Enhanced error messages for common issues""" | 
					
						
						|  |  | 
					
						
						|  | if progress_callback: | 
					
						
						|  | progress_callback(1.0, f"Compilation successful! Created {arch_info} executable π") | 
					
						
						|  |  | 
					
						
						|  | if log_queue: | 
					
						
						|  | log_queue.put("β
 Compilation completed successfully!\n") | 
					
						
						|  | log_queue.put("π§ Enhanced with network error handling!\n") | 
					
						
						|  |  | 
					
						
						|  | return result_summary, binary_path, compile_output, True | 
					
						
						|  | else: | 
					
						
						|  |  | 
					
						
						|  | error_summary = f"""# β Compilation Failed | 
					
						
						|  |  | 
					
						
						|  | ## Error Details: | 
					
						
						|  | - **Exit Code**: {process.returncode} | 
					
						
						|  | - **Mode Attempted**: {mode_name} | 
					
						
						|  | - **Target**: Linux | 
					
						
						|  |  | 
					
						
						|  | ## Environment Results: | 
					
						
						|  | **System Packages**: {packages_result} | 
					
						
						|  | **Python Requirements**: {install_result} | 
					
						
						|  |  | 
					
						
						|  | ## Compilation Output: | 
					
						
						|  | ``` | 
					
						
						|  | {compile_output} | 
					
						
						|  | ``` | 
					
						
						|  |  | 
					
						
						|  | ## Possible Solutions: | 
					
						
						|  | 1. Check your code for syntax errors | 
					
						
						|  | 2. Ensure all imports are available in requirements.txt | 
					
						
						|  | 3. Try a different compilation mode | 
					
						
						|  | 4. Review the compilation logs above | 
					
						
						|  |  | 
					
						
						|  | ## Missing Dependencies: | 
					
						
						|  | {', '.join(missing_deps) if missing_deps else 'None detected'} | 
					
						
						|  |  | 
					
						
						|  | ## Environment Info: | 
					
						
						|  | - **Nuitka Version**: {nuitka_version} | 
					
						
						|  | - **Python Version**: {current_python} | 
					
						
						|  | - **Platform**: {platform.platform()}""" | 
					
						
						|  | if progress_callback: | 
					
						
						|  | progress_callback(1.0, "Compilation failed β") | 
					
						
						|  |  | 
					
						
						|  | if log_queue: | 
					
						
						|  | log_queue.put("β Compilation failed!\n") | 
					
						
						|  |  | 
					
						
						|  | return error_summary, None, compile_output, False | 
					
						
						|  |  | 
					
						
						|  | except Exception as e: | 
					
						
						|  |  | 
					
						
						|  | error_trace = traceback.format_exc() | 
					
						
						|  | error_summary = f"""# β Compilation Error | 
					
						
						|  |  | 
					
						
						|  | ## Error: | 
					
						
						|  | {str(e)} | 
					
						
						|  |  | 
					
						
						|  | ## Full Error Trace: | 
					
						
						|  | ``` | 
					
						
						|  | {error_trace} | 
					
						
						|  | ``` | 
					
						
						|  |  | 
					
						
						|  | ## Environment Status: | 
					
						
						|  | - **Nuitka Version**: {get_nuitka_version()} | 
					
						
						|  | - **Python Version**: {current_python} | 
					
						
						|  | - **Working Directory**: {os.getcwd()} | 
					
						
						|  |  | 
					
						
						|  | ## Troubleshooting Steps: | 
					
						
						|  | 1. Check if Nuitka is properly installed | 
					
						
						|  | 2. Verify your code syntax | 
					
						
						|  | 3. Check available disk space | 
					
						
						|  | 4. Try with simpler code first""" | 
					
						
						|  | if progress_callback: | 
					
						
						|  | progress_callback(1.0, "Error occurred β") | 
					
						
						|  |  | 
					
						
						|  | if log_queue: | 
					
						
						|  | log_queue.put(f"β Error: {str(e)}\n") | 
					
						
						|  |  | 
					
						
						|  | return error_summary, None, f"Error: {str(e)}\n\n{error_trace}", False | 
					
						
						|  |  | 
					
						
						|  | def run_compiled_binary(binary_path): | 
					
						
						|  | """Run the compiled binary and return the output""" | 
					
						
						|  | if not binary_path or not os.path.exists(binary_path): | 
					
						
						|  | return "β No binary available to run." | 
					
						
						|  |  | 
					
						
						|  | try: | 
					
						
						|  |  | 
					
						
						|  | os.chmod(binary_path, 0o755) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | process = subprocess.run( | 
					
						
						|  | [binary_path], | 
					
						
						|  | capture_output=True, | 
					
						
						|  | text=True, | 
					
						
						|  | timeout=30, | 
					
						
						|  | cwd=os.path.dirname(binary_path) | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  | output = "" | 
					
						
						|  | if process.stdout: | 
					
						
						|  | output += f"## [STDOUT]\n```\n{process.stdout}\n```\n" | 
					
						
						|  | if process.stderr: | 
					
						
						|  | output += f"## [STDERR]\n```\n{process.stderr}\n```\n" | 
					
						
						|  | if process.returncode != 0: | 
					
						
						|  | output += f"## [EXIT CODE]\n{process.returncode}\n" | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | if process.returncode == 6: | 
					
						
						|  | output += f"\n## β οΈ Network Error Detected\n" | 
					
						
						|  | output += f"Exit code 6 indicates a DNS resolution error.\n" | 
					
						
						|  | output += f"This is likely due to the application trying to access huggingface.co or similar services.\n" | 
					
						
						|  | output += f"The compiled executable includes error handling for this scenario.\n" | 
					
						
						|  |  | 
					
						
						|  | if not output: | 
					
						
						|  | output = "β
 Binary executed successfully with no output." | 
					
						
						|  | else: | 
					
						
						|  | output = "## π§ͺ Execution Results\n" + output | 
					
						
						|  |  | 
					
						
						|  | return output | 
					
						
						|  | except subprocess.TimeoutExpired: | 
					
						
						|  | return "β±οΈ **Execution timed out after 30 seconds.**\n\nThis might indicate:\n- The program is waiting for input\n- An infinite loop\n- Long-running computation\n- Network operations taking too long" | 
					
						
						|  | except Exception as e: | 
					
						
						|  | return f"β **Error running the binary:**\n\n```\n{str(e)}\n```" | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | with gr.Blocks(title="Nuitka Python Compiler for Linux", theme=gr.themes.Soft()) as app: | 
					
						
						|  | gr.Markdown("# π Nuitka Python Compiler") | 
					
						
						|  | gr.Markdown("Convert your Python code into portable Linux executables using Nuitka, with enhanced network error handling.") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | has_static = check_static_libpython() | 
					
						
						|  | missing_deps = check_dependencies() | 
					
						
						|  |  | 
					
						
						|  | if "nuitka" in missing_deps: | 
					
						
						|  | gr.Markdown("β οΈ **Nuitka is not installed!** Add 'nuitka' to your requirements.txt file.") | 
					
						
						|  |  | 
					
						
						|  | if has_static: | 
					
						
						|  | gr.Markdown("π― **Static Libpython Available!** Maximum portability enabled.") | 
					
						
						|  | else: | 
					
						
						|  | gr.Markdown("π§ **Using alternative portable options.** Static libpython not available.") | 
					
						
						|  |  | 
					
						
						|  | if [dep for dep in missing_deps if dep != "nuitka"]: | 
					
						
						|  | gr.Markdown(f"β οΈ **Other missing dependencies:** {', '.join([dep for dep in missing_deps if dep != 'nuitka'])}") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | gr.Markdown(""" | 
					
						
						|  | > βΉοΈ **Enhanced Linux Binary Compilation + Network Error Handling**: | 
					
						
						|  | > - Native Linux compilation with maximum compatibility options | 
					
						
						|  | > - **Enhanced network error handling** for runtime issues | 
					
						
						|  | > - Intelligent error messages for common problems | 
					
						
						|  | > - **Exit code 6 handling** for DNS resolution failures | 
					
						
						|  | """) | 
					
						
						|  |  | 
					
						
						|  | with gr.Tabs(): | 
					
						
						|  | with gr.TabItem("π§ Compiler"): | 
					
						
						|  | with gr.Row(): | 
					
						
						|  | with gr.Column(scale=1): | 
					
						
						|  | gr.Markdown("### π Python Code Input") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | with gr.Group(): | 
					
						
						|  | input_method = gr.Radio( | 
					
						
						|  | choices=["Type Code", "Upload File"], | 
					
						
						|  | value="Type Code", | 
					
						
						|  | label="Choose input method", | 
					
						
						|  | info="Select how you want to provide your Python code" | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | with gr.Group(visible=False) as file_upload_group: | 
					
						
						|  | uploaded_file = gr.File( | 
					
						
						|  | label="Upload Python File (.py)", | 
					
						
						|  | file_types=[".py", ".txt"] | 
					
						
						|  | ) | 
					
						
						|  | load_file_btn = gr.Button("Load File", variant="secondary") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | with gr.Group(visible=True) as code_editor_group: | 
					
						
						|  | code_input = gr.Code( | 
					
						
						|  | value="""# Your Python code here | 
					
						
						|  | print('Hello from compiled Python!') | 
					
						
						|  | print('This portable binary was created with Nuitka!') | 
					
						
						|  |  | 
					
						
						|  | # This will work with automatic compatibility detection | 
					
						
						|  | import os, sys | 
					
						
						|  | print(f'Running from: {os.getcwd()}') | 
					
						
						|  | print(f'Python executable: {sys.executable}') | 
					
						
						|  | print(f'Platform: {sys.platform}') | 
					
						
						|  |  | 
					
						
						|  | # Example with user input | 
					
						
						|  | try: | 
					
						
						|  | name = input('What is your name? ') | 
					
						
						|  | print(f'Hello, {name}!') | 
					
						
						|  | except KeyboardInterrupt: | 
					
						
						|  | print('\\nOperation cancelled by user') | 
					
						
						|  | sys.exit(0) | 
					
						
						|  |  | 
					
						
						|  | # Simple calculation | 
					
						
						|  | def fibonacci(n): | 
					
						
						|  | if n <= 1: | 
					
						
						|  | return n | 
					
						
						|  | return fibonacci(n-1) + fibonacci(n-2) | 
					
						
						|  |  | 
					
						
						|  | print(f'Fibonacci of 10: {fibonacci(10)}') | 
					
						
						|  |  | 
					
						
						|  | # Wait for user before closing | 
					
						
						|  | input('\\nPress Enter to exit...')""", | 
					
						
						|  | language="python", | 
					
						
						|  | label="Enter your Python code", | 
					
						
						|  | lines=50, | 
					
						
						|  | max_lines=100, | 
					
						
						|  | show_label=False | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | with gr.Row(): | 
					
						
						|  | clear_code_btn = gr.Button("Clear Code", variant="secondary", size="sm") | 
					
						
						|  | format_code_btn = gr.Button("Format Code", variant="secondary", size="sm") | 
					
						
						|  | fullscreen_btn = gr.Button("Expand Editor", variant="secondary", size="sm") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | file_info = gr.Markdown(visible=False) | 
					
						
						|  |  | 
					
						
						|  | with gr.Column(scale=1): | 
					
						
						|  | gr.Markdown("### βοΈ Configuration") | 
					
						
						|  |  | 
					
						
						|  | with gr.Tabs(): | 
					
						
						|  | with gr.TabItem("Python Requirements"): | 
					
						
						|  | requirements_input = gr.Textbox( | 
					
						
						|  | placeholder="""# Add your Python dependencies here | 
					
						
						|  | # Example: | 
					
						
						|  | # numpy==1.24.0 | 
					
						
						|  | # pandas==2.0.0 | 
					
						
						|  | # requests>=2.28.0 | 
					
						
						|  | # matplotlib | 
					
						
						|  | # pillow | 
					
						
						|  |  | 
					
						
						|  | # Keep dependencies minimal for better compatibility""", | 
					
						
						|  | lines=10, | 
					
						
						|  | max_lines=20, | 
					
						
						|  | label="requirements.txt content" | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  | with gr.TabItem("System Packages"): | 
					
						
						|  | gr.Markdown("β οΈ **System packages cannot be installed in HF Spaces**") | 
					
						
						|  | packages_input = gr.Textbox( | 
					
						
						|  | placeholder="""# System packages (for reference only) | 
					
						
						|  | # These should be pre-installed in HF Spaces | 
					
						
						|  | # Example: | 
					
						
						|  | # build-essential | 
					
						
						|  | # libssl-dev""", | 
					
						
						|  | lines=10, | 
					
						
						|  | max_lines=20, | 
					
						
						|  | label="System packages (Reference Only)", | 
					
						
						|  | interactive=True | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | with gr.Group(): | 
					
						
						|  | gr.Markdown("### π οΈ Compilation Options") | 
					
						
						|  |  | 
					
						
						|  | compilation_mode = gr.Dropdown( | 
					
						
						|  | choices=[ | 
					
						
						|  | "Maximum Compatibility (Recommended)", | 
					
						
						|  | "Portable Binary", | 
					
						
						|  | "Standalone Binary" | 
					
						
						|  | ], | 
					
						
						|  | value="Maximum Compatibility (Recommended)", | 
					
						
						|  | label="Compilation Mode", | 
					
						
						|  | info="Choose the type of binary to create" | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  | output_extension = gr.Dropdown( | 
					
						
						|  | choices=[".bin", ".sh"], | 
					
						
						|  | value=".bin", | 
					
						
						|  | label="Output File Extension", | 
					
						
						|  | info="File extension for the compiled binary" | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | with gr.Group(): | 
					
						
						|  | gr.Markdown("### π Environment Status") | 
					
						
						|  | gr.Markdown(f"π **Python Version**: {get_current_python_version()}") | 
					
						
						|  | gr.Markdown(f"π **Nuitka Version**: {get_nuitka_version()}") | 
					
						
						|  |  | 
					
						
						|  | if check_static_libpython(): | 
					
						
						|  | gr.Markdown("π **Static libpython available for maximum portability!**") | 
					
						
						|  | else: | 
					
						
						|  | gr.Markdown("π§ **Using portable compilation flags**") | 
					
						
						|  |  | 
					
						
						|  | gr.Markdown("π **Enhanced**: Network error handling included") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | compile_btn = gr.Button("π Compile with Nuitka", variant="primary", size="lg") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | with gr.Column(visible=False) as progress_section: | 
					
						
						|  | gr.Markdown("### π Compilation Progress") | 
					
						
						|  | progress_bar = gr.HTML(create_progress_bar(0, "Ready to compile...")) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | with gr.Column(visible=False) as logs_section: | 
					
						
						|  | gr.Markdown("### π Real-time Compilation Logs") | 
					
						
						|  | real_time_logs = gr.Textbox( | 
					
						
						|  | label="Compilation Logs", | 
					
						
						|  | lines=20, | 
					
						
						|  | max_lines=50, | 
					
						
						|  | value="Logs will appear here during compilation...", | 
					
						
						|  | interactive=False | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | with gr.Column(visible=False) as results_section: | 
					
						
						|  | with gr.Accordion("π Compilation Results", open=True): | 
					
						
						|  | result_summary = gr.Markdown() | 
					
						
						|  | with gr.Accordion("π Complete Compilation Logs", open=False): | 
					
						
						|  | compile_logs = gr.Textbox( | 
					
						
						|  | label="Complete Compilation Output", | 
					
						
						|  | lines=20, | 
					
						
						|  | max_lines=50 | 
					
						
						|  | ) | 
					
						
						|  | download_file = gr.File(label="π₯ Download Compiled Binary", visible=False) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | with gr.Row(): | 
					
						
						|  | run_btn = gr.Button("π§ͺ Test Run Binary", variant="secondary") | 
					
						
						|  | run_output = gr.Markdown(label="Execution Output") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | current_binary_path = gr.State(None) | 
					
						
						|  | compilation_success = gr.State(False) | 
					
						
						|  | log_queue = gr.State(None) | 
					
						
						|  |  | 
					
						
						|  | def update_progress_display(progress, status): | 
					
						
						|  | """Update the progress bar display""" | 
					
						
						|  | return gr.update(value=create_progress_bar(progress, status)) | 
					
						
						|  |  | 
					
						
						|  | def handle_input_method_change(method): | 
					
						
						|  | """Handle switching between typing and file upload""" | 
					
						
						|  | if method == "Upload File": | 
					
						
						|  | return gr.update(visible=False), gr.update(visible=True) | 
					
						
						|  | else: | 
					
						
						|  | return gr.update(visible=True), gr.update(visible=False) | 
					
						
						|  |  | 
					
						
						|  | def handle_file_load(file): | 
					
						
						|  | """Handle loading code from uploaded file""" | 
					
						
						|  | if file is None: | 
					
						
						|  | return "", gr.update(visible=False) | 
					
						
						|  |  | 
					
						
						|  | code = load_script_from_file(file) | 
					
						
						|  | file_size = os.path.getsize(file.name) / 1024 | 
					
						
						|  | file_info_text = f"π **Loaded file**: {os.path.basename(file.name)} ({file_size:.1f} KB)" | 
					
						
						|  | return code, gr.update(value=file_info_text, visible=True) | 
					
						
						|  |  | 
					
						
						|  | def clear_code(): | 
					
						
						|  | """Clear the code editor""" | 
					
						
						|  | return "" | 
					
						
						|  |  | 
					
						
						|  | def format_code(code): | 
					
						
						|  | """Try to format the code using black if available""" | 
					
						
						|  | try: | 
					
						
						|  | import black | 
					
						
						|  | try: | 
					
						
						|  | formatted = black.format_str(code, mode=black.FileMode()) | 
					
						
						|  | return formatted | 
					
						
						|  | except: | 
					
						
						|  |  | 
					
						
						|  | return code | 
					
						
						|  | except ImportError: | 
					
						
						|  |  | 
					
						
						|  | return code | 
					
						
						|  |  | 
					
						
						|  | def expand_editor(): | 
					
						
						|  | """This is a placeholder - the actual expansion happens through CSS/JS""" | 
					
						
						|  | return gr.update(lines=100, max_lines=200) | 
					
						
						|  |  | 
					
						
						|  | def handle_compilation(code, requirements, packages, mode, extension): | 
					
						
						|  | try: | 
					
						
						|  |  | 
					
						
						|  | log_q = queue.Queue() | 
					
						
						|  | current_logs = "" | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | yield ( | 
					
						
						|  | gr.update(visible=True), | 
					
						
						|  | gr.update(value=create_progress_bar(0, "Initializing compilation...")), | 
					
						
						|  | gr.update(visible=True), | 
					
						
						|  | gr.update(value="=== Starting Compilation ===\n"), | 
					
						
						|  | gr.update(visible=False), | 
					
						
						|  | gr.update(), | 
					
						
						|  | gr.update(), | 
					
						
						|  | gr.update(visible=False), | 
					
						
						|  | None, | 
					
						
						|  | False, | 
					
						
						|  | log_q | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | def progress_callback(progress, status): | 
					
						
						|  | pass | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | def compile_thread(): | 
					
						
						|  | return compile_with_nuitka( | 
					
						
						|  | code, requirements, packages, mode, extension, log_q, progress_callback | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | compilation_thread = threading.Thread(target=compile_thread) | 
					
						
						|  | compilation_result = [None] | 
					
						
						|  |  | 
					
						
						|  | def get_result(): | 
					
						
						|  | compilation_result[0] = compile_with_nuitka( | 
					
						
						|  | code, requirements, packages, mode, extension, log_q, progress_callback | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  | thread = threading.Thread(target=get_result) | 
					
						
						|  | thread.start() | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | progress_steps = [ | 
					
						
						|  | (0.1, "Checking Nuitka installation..."), | 
					
						
						|  | (0.15, "Checking environment..."), | 
					
						
						|  | (0.2, "Adding network error handling..."), | 
					
						
						|  | (0.3, "Installing requirements..."), | 
					
						
						|  | (0.4, "Starting compilation..."), | 
					
						
						|  | (0.5, "Processing imports..."), | 
					
						
						|  | (0.6, "Optimizing code..."), | 
					
						
						|  | (0.7, f"Creating {extension} binary..."), | 
					
						
						|  | (0.8, "Finalizing..."), | 
					
						
						|  | ] | 
					
						
						|  |  | 
					
						
						|  | for progress, status in progress_steps: | 
					
						
						|  |  | 
					
						
						|  | while not log_q.empty(): | 
					
						
						|  | try: | 
					
						
						|  | new_line = log_q.get_nowait() | 
					
						
						|  | current_logs += new_line | 
					
						
						|  | except queue.Empty: | 
					
						
						|  | break | 
					
						
						|  |  | 
					
						
						|  | yield ( | 
					
						
						|  | gr.update(visible=True), | 
					
						
						|  | gr.update(value=create_progress_bar(progress, status)), | 
					
						
						|  | gr.update(visible=True), | 
					
						
						|  | gr.update(value=current_logs), | 
					
						
						|  | gr.update(visible=False), | 
					
						
						|  | gr.update(), | 
					
						
						|  | gr.update(), | 
					
						
						|  | gr.update(visible=False), | 
					
						
						|  | None, | 
					
						
						|  | False, | 
					
						
						|  | log_q | 
					
						
						|  | ) | 
					
						
						|  | time.sleep(0.5) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | thread.join() | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | while not log_q.empty(): | 
					
						
						|  | try: | 
					
						
						|  | new_line = log_q.get_nowait() | 
					
						
						|  | current_logs += new_line | 
					
						
						|  | except queue.Empty: | 
					
						
						|  | break | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | summary, binary_path, logs, success = compilation_result[0] | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | final_status = "β
 Compilation successful!" if success else "β Compilation failed" | 
					
						
						|  | if success: | 
					
						
						|  | final_status += " + Network Error Handling" | 
					
						
						|  |  | 
					
						
						|  | yield ( | 
					
						
						|  | gr.update(visible=True), | 
					
						
						|  | gr.update(value=create_progress_bar(1.0, final_status)), | 
					
						
						|  | gr.update(visible=True), | 
					
						
						|  | gr.update(value=current_logs), | 
					
						
						|  | gr.update(visible=True), | 
					
						
						|  | gr.update(value=summary), | 
					
						
						|  | gr.update(value=logs), | 
					
						
						|  | gr.update(visible=False), | 
					
						
						|  | None, | 
					
						
						|  | False, | 
					
						
						|  | log_q | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  | if success and binary_path: | 
					
						
						|  |  | 
					
						
						|  | download_filename = f"compiled_program{extension}" | 
					
						
						|  | download_path = os.path.join(os.path.dirname(binary_path), download_filename) | 
					
						
						|  | shutil.copy2(binary_path, download_path) | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | yield ( | 
					
						
						|  | gr.update(visible=True), | 
					
						
						|  | gr.update(value=create_progress_bar(1.0, f"β
 {extension} compilation successful! Ready to download.")), | 
					
						
						|  | gr.update(visible=True), | 
					
						
						|  | gr.update(value=current_logs), | 
					
						
						|  | gr.update(visible=True), | 
					
						
						|  | gr.update(value=summary), | 
					
						
						|  | gr.update(value=logs), | 
					
						
						|  | gr.update(value=download_path, visible=True), | 
					
						
						|  | binary_path, | 
					
						
						|  | True, | 
					
						
						|  | log_q | 
					
						
						|  | ) | 
					
						
						|  | else: | 
					
						
						|  |  | 
					
						
						|  | yield ( | 
					
						
						|  | gr.update(visible=True), | 
					
						
						|  | gr.update(value=create_progress_bar(1.0, "β Compilation failed. Check logs for details.")), | 
					
						
						|  | gr.update(visible=True), | 
					
						
						|  | gr.update(value=current_logs), | 
					
						
						|  | gr.update(visible=True), | 
					
						
						|  | gr.update(value=summary), | 
					
						
						|  | gr.update(value=logs), | 
					
						
						|  | gr.update(visible=False), | 
					
						
						|  | None, | 
					
						
						|  | False, | 
					
						
						|  | log_q | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  | except Exception as e: | 
					
						
						|  | error_trace = traceback.format_exc() | 
					
						
						|  | error_summary = f"""# β Unexpected Error in Compilation Handler | 
					
						
						|  |  | 
					
						
						|  | ## Error: | 
					
						
						|  | {str(e)} | 
					
						
						|  |  | 
					
						
						|  | ## Full Trace: | 
					
						
						|  | ``` | 
					
						
						|  | {error_trace} | 
					
						
						|  | ```""" | 
					
						
						|  | yield ( | 
					
						
						|  | gr.update(visible=True), | 
					
						
						|  | gr.update(value=create_progress_bar(1.0, "β Error occurred during compilation")), | 
					
						
						|  | gr.update(visible=True), | 
					
						
						|  | gr.update(value=f"Error: {str(e)}\n{error_trace}"), | 
					
						
						|  | gr.update(visible=True), | 
					
						
						|  | gr.update(value=error_summary), | 
					
						
						|  | gr.update(value=f"Error: {str(e)}"), | 
					
						
						|  | gr.update(visible=False), | 
					
						
						|  | None, | 
					
						
						|  | False, | 
					
						
						|  | log_q | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  | def handle_run(binary_path): | 
					
						
						|  | if binary_path: | 
					
						
						|  | output = run_compiled_binary(binary_path) | 
					
						
						|  | return gr.update(value=output) | 
					
						
						|  | else: | 
					
						
						|  | return gr.update(value="β No binary available to run.") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | input_method.change( | 
					
						
						|  | handle_input_method_change, | 
					
						
						|  | inputs=[input_method], | 
					
						
						|  | outputs=[code_editor_group, file_upload_group] | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  | load_file_btn.click( | 
					
						
						|  | handle_file_load, | 
					
						
						|  | inputs=[uploaded_file], | 
					
						
						|  | outputs=[code_input, file_info] | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  | clear_code_btn.click( | 
					
						
						|  | clear_code, | 
					
						
						|  | outputs=[code_input] | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  | format_code_btn.click( | 
					
						
						|  | format_code, | 
					
						
						|  | inputs=[code_input], | 
					
						
						|  | outputs=[code_input] | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  | fullscreen_btn.click( | 
					
						
						|  | expand_editor, | 
					
						
						|  | outputs=[code_input] | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  | compile_btn.click( | 
					
						
						|  | handle_compilation, | 
					
						
						|  | inputs=[code_input, requirements_input, packages_input, compilation_mode, output_extension], | 
					
						
						|  | outputs=[progress_section, progress_bar, logs_section, real_time_logs, results_section, result_summary, compile_logs, download_file, current_binary_path, compilation_success, log_queue] | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  | run_btn.click( | 
					
						
						|  | handle_run, | 
					
						
						|  | inputs=[current_binary_path], | 
					
						
						|  | outputs=[run_output] | 
					
						
						|  | ) | 
					
						
						|  |  | 
					
						
						|  | with gr.TabItem("π How to Use"): | 
					
						
						|  | gr.Markdown(""" | 
					
						
						|  | ## π― Enhanced Linux Compilation with Improved Code Input | 
					
						
						|  |  | 
					
						
						|  | **Multiple Ways to Input Large Python Scripts** | 
					
						
						|  |  | 
					
						
						|  | This app now provides better support for large Python scripts with: | 
					
						
						|  | - **Larger code editor** (50+ lines visible, expandable to 100+ lines) | 
					
						
						|  | - **File upload option** for existing .py files | 
					
						
						|  | - **Clear and format buttons** for code management | 
					
						
						|  | - **Expand editor button** for even larger scripts | 
					
						
						|  | - **Enhanced network error handling** for runtime issues | 
					
						
						|  |  | 
					
						
						|  | ## π Code Input Methods | 
					
						
						|  |  | 
					
						
						|  | ### 1. Type Code Directly | 
					
						
						|  | - Use the large code editor (50 lines visible by default) | 
					
						
						|  | - Auto-expanding up to 100+ lines as you type | 
					
						
						|  | - Syntax highlighting for Python | 
					
						
						|  | - Easy to scroll through long scripts | 
					
						
						|  |  | 
					
						
						|  | ### 2. Upload Python Files | 
					
						
						|  | - Switch to "Upload File" mode | 
					
						
						|  | - Upload .py or .txt files | 
					
						
						|  | - Automatically loads the content into the editor | 
					
						
						|  | - Shows file size and name | 
					
						
						|  |  | 
					
						
						|  | ### 3. Code Management Tools | 
					
						
						|  | - **Clear Code**: Remove all content instantly | 
					
						
						|  | - **Format Code**: Auto-format using black (if available) | 
					
						
						|  | - **Expand Editor**: Increase visible lines for very large scripts | 
					
						
						|  |  | 
					
						
						|  | ## π Usage Instructions for Large Scripts | 
					
						
						|  |  | 
					
						
						|  | ### Option 1: File Upload | 
					
						
						|  | 1. Switch input method to "Upload File" | 
					
						
						|  | 2. Click "Choose File" and select your .py file | 
					
						
						|  | 3. Click "Load File" to import the content | 
					
						
						|  | 4. Configure requirements and compilation options | 
					
						
						|  | 5. Click "Compile with Nuitka" | 
					
						
						|  |  | 
					
						
						|  | ### Option 2: Direct Editing | 
					
						
						|  | 1. Keep input method as "Type Code" | 
					
						
						|  | 2. Start typing or paste your large script | 
					
						
						|  | 3. Use the code editor's scroll bar for navigation | 
					
						
						|  | 4. Click "Expand Editor" if you need more visible lines | 
					
						
						|  | 5. Configure and compile as usual | 
					
						
						|  |  | 
					
						
						|  | ## π§ Tips for Large Scripts | 
					
						
						|  |  | 
					
						
						|  | **Organization:** | 
					
						
						|  | 1. **Break down large scripts** into functions and classes | 
					
						
						|  | 2. **Add comments** to help navigate your code | 
					
						
						|  | 3. **Use consistent indentation** for readability | 
					
						
						|  | 4. **Group imports at the top** of your script | 
					
						
						|  |  | 
					
						
						|  | **Performance:** | 
					
						
						|  | 1. **Minimize dependencies** for faster compilation | 
					
						
						|  | 2. **Avoid complex nested structures** when possible | 
					
						
						|  | 3. **Use efficient algorithms** for better runtime performance | 
					
						
						|  | 4. **Test smaller parts** before compiling the full script | 
					
						
						|  |  | 
					
						
						|  | **Error Handling:** | 
					
						
						|  | 1. **Add try/except blocks** for robust error handling | 
					
						
						|  | 2. **Handle user input gracefully** with validation | 
					
						
						|  | 3. **Include network error handling** (automatically added) | 
					
						
						|  | 4. **Provide clear error messages** for users | 
					
						
						|  |  | 
					
						
						|  | ## π Network Error Handling for Large Scripts | 
					
						
						|  |  | 
					
						
						|  | Even with large scripts, the network error handling remains effective: | 
					
						
						|  | ```python | 
					
						
						|  | # Automatically added to all compiled scripts | 
					
						
						|  | try: | 
					
						
						|  | # Your network operations | 
					
						
						|  | response = urllib.request.urlopen('https://api.example.com') | 
					
						
						|  | except urllib.error.URLError as e: | 
					
						
						|  | if 'could not resolve host' in str(e.reason).lower(): | 
					
						
						|  | print("β Network error detected and handled gracefully") | 
					
						
						|  | sys.exit(6)  # Consistent exit code | 
					
						
						|  | ``` | 
					
						
						|  |  | 
					
						
						|  | ## π Code Editor Features | 
					
						
						|  |  | 
					
						
						|  | **Enhanced Layout:** | 
					
						
						|  | - **50 lines visible** by default (vs 20-28 in typical editors) | 
					
						
						|  | - **Auto-expansion** up to 100+ lines as needed | 
					
						
						|  | - **Scrollable interface** for unlimited script size | 
					
						
						|  | - **Syntax highlighting** for Python code | 
					
						
						|  | - **Line numbers** for easy navigation | 
					
						
						|  |  | 
					
						
						|  | **Management Tools:** | 
					
						
						|  | - **File upload support** for existing scripts | 
					
						
						|  | - **One-click clearing** for starting fresh | 
					
						
						|  | - **Code formatting** (if black is available) | 
					
						
						|  | - **Editor expansion** for very large scripts | 
					
						
						|  | - **File information display** when uploading | 
					
						
						|  |  | 
					
						
						|  | ## π Best Practices for Large Scripts | 
					
						
						|  |  | 
					
						
						|  | **Before Compilation:** | 
					
						
						|  | 1. **Test your script locally** to ensure it works | 
					
						
						|  | 2. **Verify all imports** are included in requirements.txt | 
					
						
						|  | 3. **Check for syntax errors** using the editor | 
					
						
						|  | 4. **Consider script size** - larger scripts take longer to compile | 
					
						
						|  |  | 
					
						
						|  | **During Compilation:** | 
					
						
						|  | 1. **Monitor progress** through the real-time logs | 
					
						
						|  | 2. **Watch for errors** in the compilation output | 
					
						
						|  | 3. **Be patient** - large scripts need more time | 
					
						
						|  | 4. **Check requirements** if compilation fails | 
					
						
						|  |  | 
					
						
						|  | **After Compilation:** | 
					
						
						|  | 1. **Download the binary** immediately | 
					
						
						|  | 2. **Test on a clean system** if possible | 
					
						
						|  | 3. **Verify network error handling** works | 
					
						
						|  | 4. **Document any dependencies** for users | 
					
						
						|  |  | 
					
						
						|  | ## β οΈ Limitations and Workarounds | 
					
						
						|  |  | 
					
						
						|  | **File Size Limits:** | 
					
						
						|  | - Gradio may have upload size limits | 
					
						
						|  | - **Workaround**: Break very large scripts into modules | 
					
						
						|  |  | 
					
						
						|  | **Memory Usage:** | 
					
						
						|  | - Large scripts use more compilation memory | 
					
						
						|  | - **Workaround**: Use "Portable Binary" mode for lighter builds | 
					
						
						|  |  | 
					
						
						|  | **Compilation Time:** | 
					
						
						|  | - Large scripts take longer to compile | 
					
						
						|  | - **Workaround**: Test with smaller versions first | 
					
						
						|  |  | 
					
						
						|  | **Browser Performance:** | 
					
						
						|  | - Very large code may slow the interface | 
					
						
						|  | - **Workaround**: Use file upload for scripts >1000 lines | 
					
						
						|  | """) | 
					
						
						|  |  | 
					
						
						|  | with gr.TabItem("βΉοΈ About"): | 
					
						
						|  | gr.Markdown(f""" | 
					
						
						|  | ## π§  Enhanced Code Input + Compilation | 
					
						
						|  |  | 
					
						
						|  | **Major Improvements for Large Scripts:** | 
					
						
						|  |  | 
					
						
						|  | ### 1. Flexible Input Methods | 
					
						
						|  | ```python | 
					
						
						|  | # Two main input approaches: | 
					
						
						|  | # 1. Direct typing with expandable editor | 
					
						
						|  | # 2. File upload for existing scripts | 
					
						
						|  | ``` | 
					
						
						|  |  | 
					
						
						|  | ### 2. Enhanced Code Editor | 
					
						
						|  | - **50+ lines visible** by default (expandable to 100+) | 
					
						
						|  | - **Auto-scrolling interface** for unlimited script size | 
					
						
						|  | - **Syntax highlighting** and line numbers | 
					
						
						|  | - **Multiple management tools** (clear, format, expand) | 
					
						
						|  |  | 
					
						
						|  | ### 3. File Upload System | 
					
						
						|  | ```python | 
					
						
						|  | # Supports multiple file types: | 
					
						
						|  | # - .py files (Python scripts) | 
					
						
						|  | # - .txt files (text-based scripts) | 
					
						
						|  | # - Automatic encoding detection | 
					
						
						|  | # - File size and name display | 
					
						
						|  | ``` | 
					
						
						|  |  | 
					
						
						|  | ## β
 Complete Solution for Large Scripts | 
					
						
						|  |  | 
					
						
						|  | **Input Handling:** | 
					
						
						|  | - β
 **Large editor** with 50+ visible lines | 
					
						
						|  | - β
 **File upload support** for existing scripts | 
					
						
						|  | - β
 **Auto-expansion** up to 100+ lines | 
					
						
						|  | - β
 **Code management tools** (clear/format/expand) | 
					
						
						|  | - β
 **Multiple encoding support** for text files | 
					
						
						|  |  | 
					
						
						|  | **Compilation Features:** | 
					
						
						|  | - β
 **Native Linux compilation** optimized for all script sizes | 
					
						
						|  | - β
 **Progress monitoring** with real-time logs | 
					
						
						|  | - β
 **Memory-efficient processing** for large scripts | 
					
						
						|  | - β
 **Error detection** with helpful feedback | 
					
						
						|  | - β
 **Network error handling** automatically added | 
					
						
						|  |  | 
					
						
						|  | ## βοΈ Environment Status | 
					
						
						|  |  | 
					
						
						|  | ``` | 
					
						
						|  | Platform: {platform.platform()} | 
					
						
						|  | Architecture: {platform.architecture()[0]} | 
					
						
						|  | Python Version: {get_current_python_version()} | 
					
						
						|  | Nuitka Version: {get_nuitka_version()} | 
					
						
						|  |  | 
					
						
						|  | Code Input Enhancements: | 
					
						
						|  | β
 Large editor support: 50+ lines visible | 
					
						
						|  | β
 File upload capability: .py and .txt files | 
					
						
						|  | β
 Auto-expansion: Up to 100+ lines | 
					
						
						|  | β
 Management tools: Clear, format, expand | 
					
						
						|  | β
 Encoding detection: UTF-8 and latin-1 | 
					
						
						|  |  | 
					
						
						|  | Compilation Features: | 
					
						
						|  | β
 Native Linux targeting: Maximum compatibility | 
					
						
						|  | β
 Network error handling: Exit code 6 support | 
					
						
						|  | β
 Progress tracking: Real-time logs and status | 
					
						
						|  | β
 Error guidance: Helpful troubleshooting | 
					
						
						|  | ``` | 
					
						
						|  |  | 
					
						
						|  | ## π Technical Implementation | 
					
						
						|  |  | 
					
						
						|  | **Code Editor Improvements:** | 
					
						
						|  | ```python | 
					
						
						|  | # Enhanced Gradio Code component: | 
					
						
						|  | gr.Code( | 
					
						
						|  | lines=50,          # 50 visible lines (vs 20-28 default) | 
					
						
						|  | max_lines=100,     # Expandable to 100+ lines | 
					
						
						|  | language="python", # Syntax highlighting | 
					
						
						|  | autofocus=True     # Focus on load | 
					
						
						|  | ) | 
					
						
						|  | ``` | 
					
						
						|  |  | 
					
						
						|  | **File Upload Handler:** | 
					
						
						|  | ```python | 
					
						
						|  | def load_script_from_file(file): | 
					
						
						|  | # Handles multiple encodings automatically | 
					
						
						|  | # UTF-8 primary, latin-1 fallback | 
					
						
						|  | # Error handling for corrupted files | 
					
						
						|  | # File size reporting | 
					
						
						|  | ``` | 
					
						
						|  |  | 
					
						
						|  | **Management Tools:** | 
					
						
						|  | ```python | 
					
						
						|  | # Clear code: Instant reset | 
					
						
						|  | def clear_code(): | 
					
						
						|  | return "" | 
					
						
						|  |  | 
					
						
						|  | # Format code: Using black if available | 
					
						
						|  | def format_code(code): | 
					
						
						|  | try: | 
					
						
						|  | import black | 
					
						
						|  | return black.format_str(code, mode=black.FileMode()) | 
					
						
						|  | except: | 
					
						
						|  | return code  # Graceful fallback | 
					
						
						|  | ``` | 
					
						
						|  |  | 
					
						
						|  | ## π§ Advanced Features | 
					
						
						|  |  | 
					
						
						|  | **Smart Input Detection:** | 
					
						
						|  | - Radio button to switch between typing and upload | 
					
						
						|  | - Dynamic visibility of input methods | 
					
						
						|  | - File information display when uploading | 
					
						
						|  | - Automatic code loading from files | 
					
						
						|  |  | 
					
						
						|  | **Enhanced Text Areas:** | 
					
						
						|  | - Requirements editor: 10+ lines (vs 8 default) | 
					
						
						|  | - Log display: 20+ lines (vs 15 default) | 
					
						
						|  | - All areas support expansion up to 50+ lines | 
					
						
						|  | - Better scrolling for long content | 
					
						
						|  |  | 
					
						
						|  | **User Experience:** | 
					
						
						|  | - Instant feedback on file uploads | 
					
						
						|  | - Clear visual separation of input methods | 
					
						
						|  | - Helper buttons for common operations | 
					
						
						|  | - Progress indication during operations | 
					
						
						|  |  | 
					
						
						|  | ## π Performance Optimizations | 
					
						
						|  |  | 
					
						
						|  | **Memory Management:** | 
					
						
						|  | - Efficient text handling for large files | 
					
						
						|  | - Stream processing for compilation logs | 
					
						
						|  | - Garbage collection for temporary files | 
					
						
						|  | - Minimal memory footprint during operations | 
					
						
						|  |  | 
					
						
						|  | **UI Responsiveness:** | 
					
						
						|  | - Asynchronous file loading | 
					
						
						|  | - Progressive updates during compilation | 
					
						
						|  | - Non-blocking editor operations | 
					
						
						|  | - Smooth transitions between modes | 
					
						
						|  |  | 
					
						
						|  | **Code Processing:** | 
					
						
						|  | - Lazy loading of large scripts | 
					
						
						|  | - Incremental syntax checking | 
					
						
						|  | - Efficient string operations | 
					
						
						|  | - Optimized regex patterns | 
					
						
						|  |  | 
					
						
						|  | This ensures a **complete solution** for handling Python scripts of any size, from small utilities to large applications, with comprehensive compilation support and intelligent error handling. | 
					
						
						|  | """) | 
					
						
						|  |  | 
					
						
						|  | gr.Markdown("---") | 
					
						
						|  | gr.Markdown("π€ Created by Claude 3.7 Sonnet | π Powered by Nuitka | π Enhanced for Large Scripts + Network Error Handling") | 
					
						
						|  |  | 
					
						
						|  | if __name__ == "__main__": | 
					
						
						|  |  | 
					
						
						|  | ensure_dir("user_code") | 
					
						
						|  | ensure_dir("compiled_output") | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  | if "nuitka" in check_dependencies(): | 
					
						
						|  | print("WARNING: Nuitka is not installed. Please add 'nuitka' to your requirements.txt file.") | 
					
						
						|  |  | 
					
						
						|  | print("\nπ ENHANCED CODE INPUT + LINUX COMPILATION READY!") | 
					
						
						|  | print("New features for large scripts:") | 
					
						
						|  | print("- 50+ lines visible in code editor") | 
					
						
						|  | print("- File upload support for .py and .txt files") | 
					
						
						|  | print("- Code management tools (clear, format, expand)") | 
					
						
						|  | print("- Auto-expanding text areas up to 100+ lines") | 
					
						
						|  | print("- Enhanced network error handling") | 
					
						
						|  | print("- Real-time compilation logs") | 
					
						
						|  |  | 
					
						
						|  | app.launch() |