Spaces:
Running
Running
File size: 7,598 Bytes
229e250 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 |
---
title: Pro Code Playground
emoji: π»
colorFrom: indigo
colorTo: blue
sdk: streamlit
sdk_version: 1.47.0
app_file: app.py
pinned: true
---
# π» Pro Code Playground
**Pro Code Playground** is an interactive, multi-language coding environment with a built-in AI assistant and live execution β all accessible directly from your browser.
Powered by Hugging Face Spaces, Streamlit, and Groqβs LLaMA 3.3β70B, this project merges code editing, language support, AI debugging, and even narration in a single clean, responsive app. No installations. No setup. Just code, ask, listen, and learn.
---
## π₯ Features
- π§ AI-powered Code Assistant via **Groq + LangChain**
- βοΈ Support for **Python, Java, C++, C, JavaScript, C#**
- π€ File upload with **auto language detection**
- π₯ Stdin simulation for programs needing user input
- π **Voice narration** of assistant responses (Edge TTS)
- π¬ Scrollable chatbot with memory and summarization
- π **Dark/light theme toggle** with instant styling
- πΎ One-click code download with proper extension
- π§ͺ Runtime stats (execution time, memory used)
---
## π Try It Live
π [Click here to run it](https://huggingface.co/spaces/vsj0702/Code_editor)
No login or install required β it runs right in your browser.
---
# π Usage Guide
### π 1. Toggle Light/Dark Theme
- Click the theme button (π or βοΈ) on the top-right to switch between dark and light modes.
- Styling is fully dynamic and applies instantly to all components including the code editor and chat.
---
### π§βπ» 2. Select a Language
- Choose from: Python, Java, C, C++, JavaScript, or C#
- Language auto-switches when uploading supported files
---
### π 3. Write or Upload Code
- Start writing code directly in the editor
- Or upload a file: `.py`, `.cpp`, `.c`, `.java`, `.js`, `.cs`, `.txt`
- The editor auto-switches to the detected language
---
### π§ͺ 4. Input (stdin)
- Use the **Input (stdin)** text box for user inputs
- Inputs are passed line-by-line to your code
---
### βΆοΈ 5. Run the Code
- Hit **βΆοΈ Run**
- Output is shown in a result panel
- Errors are displayed separately in red
- Runtime and memory stats appear below the result
---
### π¬ 6. Ask the AI Assistant
- Use the chat sidebar to ask anything about your code
- The AI uses full context (code, input, output, errors, history)
- Great for debugging, refactoring, or learning
---
### π 7. Narrate Responses
- Click "π Narrate" to generate a voice explanation of the AIβs answer
- Plays using Edge TTS voices
- You can replay the audio or skip it
---
### πΎ 8. Download Your Code
- Download the edited code anytime
- File is automatically named with the correct extension
---
# π³ File Structure: Think of It Like a Tree
Imagine your app like a growing tree.
At the **trunk**, thereβs `app.py` β the brain of your app. Everything connects to it, and it sends life (data, layout, session state) to all other components. From this trunk, other files branch out like **modules**, each handling a specific responsibility. The result? A modular, clean, powerful structure that makes debugging and extending your app a breeze.
---
### π² `app.py` β The Trunk of the Tree
This is the **entry point** of the application β the first file Streamlit runs. Think of it as the control center. Its responsibilities include:
- Setting page layout and title
- Initializing theme and session state
- Dividing the screen into columns
- Calling the editor module (`code_editor.py`) on the left
- Calling the chatbot module (`chatbot.py`) on the right
**Without this file, nothing would render.** It acts as the coordinator, delegating tasks to the appropriate submodules like a team lead.
---
### πΏ `code_editor.py` β The Code Branch
This file handles everything related to writing and running code. Itβs like the **workbench** where users type, upload, and execute their programs.
Key responsibilities:
- Displaying the code editor using `streamlit_ace`
- Handling file uploads and auto-detecting language
- Taking user input (stdin)
- Running code via the backend (local or OneCompiler API)
- Showing output, errors, runtime, and memory stats
- Offering code download with the correct extension
Itβs tightly integrated with `utils.py`, which handles the actual logic for compiling and executing the code.
---
### πΏ `chatbot.py` β The Smart Brain Branch
This file gives your app its **AI assistant powers**. It's responsible for:
- Talking to Groq's LLaMA 3.3 model via LangChain
- Generating code explanations, debugging suggestions, and summaries
- Managing a memory-aware chat history
- Handling narration of responses using Edge TTS
- Controlling how chatbot responses are shown (Markdown + CSS)
- Making sure your assistant sounds human-like, helpful, and context-aware
Itβs the most dynamic and intelligent part of the app β and beautifully modular.
---
### πΏ `layout.py` β The Skin and Styling Layer
This file controls the **aesthetic** of your app. It defines:
- Light and dark themes
- Custom CSS injected into Streamlit
- Fonts, button styles, scroll behavior, sidebar visuals
- Consistent layout feel across components
Whenever the user toggles dark mode, `layout.py` updates everything instantly. It makes your app look polished and consistent, like a professionally built product.
---
### πΏ `utils.py` β The Engine Room
This is your appβs **execution engine**.
It abstracts the messy stuff β compiling, running, capturing outputs, handling errors β so that the rest of the app stays clean.
Responsibilities include:
- Executing Python code using `exec()` with stdin override
- Compiling and running C/C++ code via `gcc`/`g++`
- Sending Java, JavaScript, and C# code to OneCompiler API
- Gracefully falling back between API keys if one fails
- Returning outputs, stderr, and exceptions for display
If `code_editor.py` is the workbench, this file is the **machine under the hood**.
---
### πΏ `requirements.txt` β The DNA
This file contains all the dependencies needed to run the app.
From Streamlit to LangChain, Edge TTS to Groqβs SDK β this file ensures your app has all the tools it needs to function.
---
### π± Summary: A Living, Breathing System
Every file has a job. Every module connects like a healthy tree:
- `app.py` = Trunk (controls everything)
- `layout.py` = Skin and theme
- `code_editor.py` = Workbench for code
- `utils.py` = Engine for execution
- `chatbot.py` = Brain for intelligence
- `requirements.txt` = Genetic blueprint
This modular structure lets you:
- Debug easily
- Extend individual parts without breaking others
- Understand how data flows
- Keep your code organized and clean
---
If youβre reading this to understand or contribute β welcome aboard! The structure is made for developers like you.
Feel free to explore each module and give feedback π
---
## π€ Author
**Vaibhav Shankar (vsj0702)**
π§ Email: [vsj0702@gmail.com](mailto:vsj0702@gmail.com)
π LinkedIn: [vaibhavshankar](https://www.linkedin.com/in/vaibhavshankar?utm_source=share&utm_campaign=share_via&utm_content=profile&utm_medium=android_app)
π€ Hugging Face: [@vsj0702](https://huggingface.co/vsj0702)
---
## π License
This project is licensed under the **GNU General Public License v3.0 (GVL-3)**.
You are free to use, modify, and distribute the project under the terms of this license.
---
Thanks for exploring **Pro Code Playground** π»
Let me know what you build with it! |