| Code Review ExtensionWelcome to the Prairielearn Code Review Extension! The Code Review Extension is a helpful Visual Studio Code (VS Code) tool built for instructors, teaching assistants, and developers who use PrairieLearn. It makes giving feedback on code easier by letting educators highlight sections, ask questions, and leave comments right inside VS Code. Students and developers can then respond, discuss improvements, and learn from the feedback. The extension also helps instructors quickly turn code reviews into quizzes and assignments on PrairieLearn, saving time and making lessons more interactive—all without switching between different apps. 
 FeaturesHow to Use The Extension:
Highlight a code snippet in the editor.Ask Practice QuestionAnswer Practice QuestionView Practice Questions and AnswersAdd Quiz QuestionView Quiz QuestionsGenerate Quiz Questions 1. Highlight a code snippet in the editor.
How to Use:
The "Highlight a Code Snippet in the Editor" feature works by first validating an active text editor and a non-empty selection. When triggered, it captures the selected code range and applies a visual highlight using VS Code’s TextEditorDecorationType. The highlight persists in the editor but does not modify the actual file content, serving purely as a temporary visual marker for user reference. The feature relies on VS Code’s built-in decoration API to manage the highlight’s appearance and removal. 2. Ask Practice Question
How to Use: 
Open the Command Palette (Ctrl+Shift+P or Cmd+Shift+P) and select "Ask Practice Question".Select a code snippet in the active editor (must be a valid, non-empty selection).A panel will open where you can:
View the selected code (editable before submission).Type your question about the code.Submit the question, which will be saved in questionsData.json.The question will be stored with metadata including:
The file path where the question was asked.The exact code range (line numbers and characters).The highlighted code snippet.The question text. 
Note
Questions can later be answered via the "Answer Question" command.All questions are visible in the "View Questions and Answers" panel.Works per-student if used in a structured workspace (e.g., CIS500/student_name/). 3. Answer Practice Question
How to Use:
Open the Command Palette (Ctrl+Shift+P or Cmd+Shift+P) and select "Answer Practice Question".A list of all unanswered questions will appear in a Quick Pick menu.Select a question to answer.A panel will open showing: 
The original question.The highlighted code snippet.A text area to type your answer.A copy and paste feature that can copy the entire highlighted code snippet and paste it in the text box 
Submit your answer to save it. 
What Happens:
The answer is stored with the question in questionsData.json.The question is marked as answered and can be viewed later.If the workspace has student-specific folders (e.g., CIS500/student_name/), the answer is saved in both:The global questionsData.json (for instructor reference).The student's questionsData.json (for personalized tracking).Notes:
Answers can be viewed or exported via "View Questions and Answers".Supports rich text formatting in answers.Questions can be filtered by student or file in structured workspaces. 4. View Practice Questions and Answers
How to Use:
Open the Command Palette (Ctrl+Shift+P or Cmd+Shift+P) and select "View Questions and Answers".A webview panel will open displaying: 
A sortable table of all questions and answers.Columns showing:
Question numberSource file path (shortened for readability)Highlighted code snippetFull question textGiven answer (if available) 
Key Features: 
Export Capability: Click the "Export to CSV" button to save all Q&A data for record-keeping.Smart Filtering:
Questions are automatically grouped by student in structured workspacesUnanswered questions appear highlightedCode Display:
Syntax-highlighted code snippetsFull code visibility with horizontal scrollingData Management:
Pulls from both:
Central questionsData.json (all questions)Student-specific files (in individual folders)Maintains original formatting of questions and answers 5. Add Quiz Question
How to Use:
Open the Command Palette (Ctrl+Shift+P/Cmd+Shift+P) and select "Add Quiz Question".Highlight the relevant code snippet in your editor (must be non-empty).An interactive panel opens with: 
Editable code display (modify the snippet before creating question)Question input field (supports markdown formatting)Quick-action buttons:
"Copy Code to Question" (auto-formats with code fences)"Save as Draft" (stores unfinished questions)
What Happens: 
When you use the "Add Quiz Question" feature: 
Your selected code snippet is captured and displayed in an editable panel.
- Your question text is saved with:
The original file pathExact code range (start/end lines)The highlighted code itself
- The question gets stored in personalizedQuestions.json in your workspace.
- You can later:View all questions using "View Personalized Questions"Include them in quizzes with "Generate Personalized Quiz" 6. View Quiz Questions
How to Use:
Open the Command Palette (Ctrl+Shift+P/Cmd+Shift+P) and select "View Personalized Questions".A panel opens showing all saved quiz questions in a table format.What You See: 
Each question displays:
The source file location (shortened path)The actual code snippet referencedThe full question textAn "Exclude from Quiz" checkboxInteractive controls to:
Edit question text or code snippetDelete unwanted questionsToggle exclusion from future quizzes 
Key Notes: 
Changes save automatically when you close the panelExcluded questions remain stored but won't appear in generated quizzesPlain text display without extra formatting or metadata 7. Generate Quiz Questions
How to Use: 
Open the Command Palette (Ctrl+Shift+P/Cmd+Shift+P) and select "Generate Personalized Quiz".Select a config file (cqlc.config.json) when prompted. Below is a sample of the config fileThe system automatically: 
Collects all non-excluded questions from personalizedQuestions.jsonGroups them by student based on file pathsGenerates individual quiz folders for each student 
What Gets Created: 
For each student:
A question bank folder with:
question.html files (containing question text + code snippets)info.json files (with unique IDs and basic metadata)An assessment folder with:
infoAssessment.json (quiz settings like time limits and access dates) 
Configuration File Sample 
Below is an example configuration file used in the extension: {
    "title": "Dass",
    "topic": "dayyy",
    "folder": "osei",
    "pl_root": "/Users/benedictoseisefa/Desktop/pl-gvsu-cis500dev-master",
    "pl_question_root": "PersonalQuiz",
    "pl_assessment_root": "courseInstances/TemplateCourseInstance/assessments",
    "set": "Custom Quiz",
    "number": "2",
    "points_per_question": 10,
    "startDate": "2025-03-22T10:30:00",
    "endDate": "2025-03-22T16:30:40",
    "timeLimitMin": 30,
    "daysForGrading": 7,
    "reviewEndDate": "2025-04-21T23:59:59",
    "password": "letMeIn",
    "language": "python"
}
 
Output Location: 
Creates structured folders under:
prairielearn/questions/ (for question content)prairielearn/assessments/ (for quiz settings)Important Notes:
Only includes questions NOT marked "exclude from quiz"Preserves original code formatting from student submissions 
 Installation
Open Visual Studio Code.Go to the Extensions Marketplace (Ctrl+Shift+XorCmd+Shift+Xon Mac).Search for Prairielearn Code Review Extension.Click Install. Commands and Shortcuts
| Command | Shortcut | Context Menu Option |  
| Ask Practice Question | Ctrl+Shift+P | Yes |  
| Answer Practice Question | Ctrl+Shift+P | Yes |  
| View Practice Questions and Answers | Ctrl+Shift+P | No |  
| Add Quiz Question | Ctrl+Shift+P | No |  
| View Quiz Questions | Ctrl+Shift+P | No |  
| Generate Quiz Questions | Ctrl+Shift+P | Non |  
 ContributingIf you find a bug or have an idea for an improvement, feel free to contribute! 
Fork this repository.Create a new branch (git checkout -b feature/my-feature).Commit your changes (git commit -am 'Add some feature').Push to the branch (git push origin feature/my-feature).Open a pull request. 
 LicenseThis extension is licensed under the MIT License. |  |