-
-
Notifications
You must be signed in to change notification settings - Fork 184
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
all exercises should include headers #743
base: main
Are you sure you want to change the base?
Conversation
I did remove the enumerable definitions for the resistor exercises in case that was giving away a bit too much. |
I think we previously discussed if we should add Stubb's and decided only to have them for the earlier exercises. Open to discuss the idea again, but there should be some opinions here before this is merged I feel. |
But that's NOT the case at all, it's all over the map. Being consistent is one thing, but it's just random. Quite a few early exercises are missing them, a lot of hard exercises have them... (at least I could discern no pattern) So if there are criteria lets decide and then perhaps document that in the README for future reference - and also then fix any remaining inconsistencies between what we have now and what the actual policy is going to be. |
Sorry, I just saw the issue related to this that you raised. Good to continue the discussion there and keep the PR comments more related to the code. I will copy my comment there for others to discuss. |
What's the policy for this PR? Does this just add prototypes to all headers that were missing them or is it more nuanced? |
I realised this is "all over the map" because the track's curriculum changed from branched to linear with the change to v3. |
As someone who just tried exercism out to refresh syntax a bit, I find the exercises without stubs super annoying. I much prefer solving problems over having to read through all the tests just to first figure out what functions I'm even supposed to implement. |
One should be able to start the exercise without having to peek into the test section. Therefore, all exercises should include headers. |
Hi @dm-alexi |
Nobody doing TDD is handed a bunch of tests where someone else have already decided on the interface and reverse engineer it from those, so I don't really buy that this somehow teaches TDD more than offering up stubs. Of course, I can only offer up my own experience for people to decide on whether this tradeoff ("learning to write header files") is worth it: I stopped doing exercism pretty quickly because it was tiresome reversing types and function signatures all the time. |
Personally, I think it would be better to see in the header file all types used in the exercise, than recover them from the source. The empty header file looks like accidentally pushed without commits. |
Tha ks for adding your thoughts @vladimir-popov. To help with this specific example we could either:
I guess those already on this issue will advocate for 1, but any thoughts on 2? |
@wolf99 my thought is that the ideal state is we have a mix of exercises with and without headers with the exercises without headers coming later in the track. Before we do this we probably need to work on the exercise ordering since it's at least partly accidental right now. Thoughts? |
I'm ok with this @ryanplusplus . |
Same 😞 |
@wolf99 could you share an example of the exercise, where reverse engineering of the header file is reasonable, please. I think I don't get your point well. |
No description provided.