Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Repo: Restructure to group exercises based on curriculum structure #533

Open
4 of 12 tasks
MaoShizhong opened this issue Mar 17, 2025 · 0 comments
Open
4 of 12 tasks
Labels
Status: Needs Review This issue/PR needs an initial or additional review

Comments

@MaoShizhong
Copy link
Contributor

MaoShizhong commented Mar 17, 2025

Prerequisites

  • I have thoroughly read and understand The Odin Project Contributing Guide
  • I have searched the existing issues to ensure this improvement hasn't been suggested before (please have a look through our open issues list to make sure)
  • The title of this issue follows the <Location of the improvement>: <Brief description of the improvement> format, e.g. Exercises: Add exercise on XYZ
  • (Optional) I am interested in working on this issue and would like to be assigned to it

Improvement Description

Very big proposal and certainly not urgent by any means.

In a similar vein to TheOdinProject/css-exercises#593, I'm proposing a restructure of this repo so the existing exercises are grouped into a foundations directory. They could be further grouped into subdirectories but I actually think they're fine just all together in a foundations dir.

With the open PRs adding new exercises as a part of TheOdinProject/curriculum#27265, this repo won't be exclusive to the Foundations course. If further exercises are added to this repo, they may not be appropriate to add to the end, but putting them earlier will require many files to be renamed with an appropriate number. This can be minimised if exercises are appropriately grouped. New groups can have a new dir made, leaving other exercise dirs untouched, and if any new exercises do have to be slotted inbetween existing exercises in a group, it'll potentially reduce the number of files/dirs that'd need to be changed.

An example structure would be

├── computer_science
│   └── recursion
│       └── <put all the open PR recursion exercises here when approved>
└── foundations
    ├── 01_helloWorld
    ├── 02_repeatString
    ├── 03_reverseString
    ├── 04_removeFromArray
    ├── 05_sumAll
    ├── 06_leapYears
    ├── 07_tempConversion
    ├── 08_calculator
    ├── 09_palindromes
    ├── 10_fibonacci
    ├── 11_getTheTitles
    └── 12_findTheOldest

Acceptance Criteria

  • All 12 foundations JS exercises are moved into a top-level foundations/ directory.
  • Rephrase any relevant parts of the repo's README.md to account for the new structure.
  • The "Arrays and Loops" and "Object Basics" lessons' assignments rephrased to reference the foundations/ exercises dir and link to it (similar to how this was handled in All HTML/CSS assignments: Update lessons to reflect restructured css-exercises repo curriculum#28922.
  • Amend generators/ and plopFile.js to allow adding new directories and exercises as necessary (probably going to be the most complex part Edit: a fair few plop.setGenerator changes but I've played around and got this working as desired).
  • Amend CONTRIBUTING.md with updated plop prompts instructions.
  • Discord server announcement made regarding the restructure, providing git commands for community members to update their forks, similar to the CSS exercises repo restructure announcement.

If this is approved, depending on whether the open recursion exercises PRs gets merged first or not, one of either:

  • The open recursion exercises PRs are amended to place the exercises in computer_science/recursion/ and renumber the exercises.
  • The merged exercises 13-onwards are moved into a computer-science/recursion/ directory and renumbered.

(Optional) Additional Comments

No response

@MaoShizhong MaoShizhong added the Status: Needs Review This issue/PR needs an initial or additional review label Mar 17, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Status: Needs Review This issue/PR needs an initial or additional review
Projects
None yet
Development

No branches or pull requests

1 participant