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!