This issue is going to be a tracking issue for what we’re doing to get a new Rust Syllabus built. I’m really excited about getting the it launch and also about trying a more collaborative approach to syllabus building at Exercism! Rather than adding too much noise to this issue, please consider opening new issues for specific questions.
Here are a few key points to note:
The Exercism staff (specifically me, @ErikSchierboom and @jonathanmiddleton) are going to lead this project, but try and avoid doing any actual coding/writing/reviewing. We want to empower and knowledge-share with the people involved.
We’re going to loosely follow the syllabus of the Rust Book,
Someone should be able to learn Rust through this syllabus.
We want to get people writing Rust code as quickly as possible using their existing knowledge, so the first set of exercises won’t have too much Rust-specific stuff in.
When a student gets to Rust-specific exercises, they should be able learn in bitesized chunks and feel confident without needing to read other websites.
The project is going to be structured like this:
Build out the first few exercises that don’t require Rust-specific concepts (effectively chapter 3 of the Rust book). A lot of this work has already been done by @isDineshHere - we now need to go through and get those merged.
For each Rust-specific topic, discuss in a dedicated thread: firstly agreeing an exemplar exercise, then agreeing (in bullet points) the topics to cover in the introduction and the about, then agreeing the exercise/tasks. Then someone will go and turn that into an Exercise and Concepts.
Connect the right Practice Exercises to each Concept
Do a refinement pass on everything
Launch!
We’re going to take an optimistic merging approach, where if something is pretty much there, we merge it, then in the final phase, we’ll tidy things up.
This is a list of the official forum topics for each of the steps above (WIP):
I’d like to contribute to the rust track and reached out to @senekor, who it turns out isn’t the Rust maintainer after all, which I assumed because of the previous thread’s opening comment.
Also, there are a few open PRs which @iHiD said would be reviewed and merged almost two months ago. Further updates in the thread includes Remo requesting a PR to be opened, and @isDineshHere opened a few PRs and seemingly isn’t here. I’ve pinged him in Discord, and will update - but he hasn’t been seen there for a month either.
I also understand the Exercism’s team has been busy with Premium and Insiders, so I expect this (rightly) fell down in the priorities. As I see it, there was a lot of activity over the Rust syllabus thing, and it all kinda broke down.
What say we use this thread to a) sign up people who’re explicitly able and willing to contribute over the next few months, b) make a plan of maximum say 10 exercises and sort them out to different folks, and c) review and merge them? That’d be a start to the syllabus, after which things will hopefully carry on by themselves.
Syllabuses are rather difficult to create and take a bunch of time. And more or less always need a person who is stubborn and has time to manage the development of the syllabus.
I will ping him. Don’t know if this could be something for him. Pretty busy, too. And it’s really not so easy to contribute (on a syllabus). I still didn’t provide any progress for my Go track contributions, since it was so hard to find my way through all the documentation and different files. Pretty frustrating. So I did way more mentoring, since this “just work”. I will give feedback.
I am getting started with Rustlings, which probably means there is not anything I can do to assist (I’ve looked at the 5 Issues tagged Good First Issues, which seems to confirm this).
I could be wrong, but I don’t see an opening to (say), iterate going through lessons (easily set up) and flag problems or gaps.
Probably all I can do now is level up my Rust, and follow this thread.
slightly OT: I recently did the Golang Concept tree, alongside a Go book…
…I actually had to STOP reading the book because it was slowing me down.
(now, I’m still going catching-up on the book, which shouldn’t be skipped, but it’s now so much easier thanks to Exercism). That would be amazing for Rust.
I wouldn’t bother going through what’s currently present in terms of a syllabus in the repo. I think for the work on it to continue, there needs to be a new comprehensive vision for it. Which means what’s present right now would be reworked significantly. I’m the only active maintainer on the Rust track right now and I don’t have immediate plans to work on the syllabus. I have plenty of maintenance-type work I wanna do first.
The Good First Issues are probably mostly outdated, I’ll have to cleanup the backlog of issues from the maintainers who preceded me to close what doesn’t make sense anymore.
I do hope you stay in the loop. Consider subscribing to the topic Rust, and posting about your experience on the track and ideas to improve it. As a maintainer, I’m further removed from student’s experiences than I would like. Don’t hesitate to tag me, here or on discord.
And most importantly, I hope you have fun learning Rust!
Thanks @senekor for your reply. Even from what little I know, it’s apparent this is a ton of work. So, double thanks for maintaining
I’m now subscribed to Rust, and follow this thread. If this is the canonical thread, it might help to “bump” it every few months with some kind of status. Just for outside observers.
I will post about the Rust track (but not for a while… since I need to use enough outside material to meet the bar for practice).
Hey all, I thought I might resurrect this old thing.
I’ve been looking at getting back into Rust lately, and getting more deeply involved generally. If there’s any interest for this I would be happy to do the research and writing and come up with a syllabus from scratch? (from reading the discussion, that seems to be the course we recommend taking)
Please let me know if I should start working toward this! I wouldn’t want to step on the toes of someone else who has taken this up upon themselves.
I currently do not have time to help with this. That means I also cannot do the amount of reviews that would be required. If there are other people willing and able to do that work then feel free to do it without me. @iHiD probably has opinions on how the process would have to look like to have a chance at being successful.
I saw that Jeremy was advising to trust the Exercism template, and not stray too far off it. I don’t imagine he has the time to do reviews, but for what it’s worth I was inclined to follow his suggestions.
I’ll might try to do some work and see if it piques any interest on the topic, try and get enough eyes on it without having to take up even more of your time.
Unrelated to this thread, once I’m more intimately familiar with the exercism stack I might try for maintainer of the Rust track, lighten your load a little.
I’d be very happy to see you do this. Thanks for offering!
My strong suggestion would be to choose a track that’s got a similar structure to the one you’d like to follow for Rust and then fork their exercises and change the text/stubs/examplars to Rust. You might need some extra exercises early to explain some Rust things, but try to keep Rust-specific topics till after you’ve covered some basic topics that the student will already have a mental grasp of.
We want to glue Rust onto their existing Neurons. If they already know how to do arithmetic from another programming language, then showing them how to do arithmetic in Rust is a good way of them finding the commonalities in the languages. If you focus on those then the scary/exciting new bits won’t seem so overwhelming and a lot of them will sink in via osmosis. The more scary/unfamiliar the teaching topics are, the more they’ll run off. And also the more you’ll find yourself try to carve a totally new path through a syllabus, which will likely overwhelm you too!
I was thinking of looking into Elixir. It seems to be something of a darling in Exercism and it (also) has a lot of idiosyncrasies.
I’ll bear in mind your advice for teaching commonalities first.
For now I’ll shut up and create a thread once I have something to show, hopefully within the next few weeks. Don’t want to waste your time and create work about doing work.