-
Notifications
You must be signed in to change notification settings - Fork 69
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
samples: Make winapi samples unmount drives before finishing execution #421
base: master
Are you sure you want to change the base?
Conversation
2337f43
to
d8e7826
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Left a few more review comments. When you make changes to your PR, I recommend to also leave a comment or respond to the feedback comments, it makes it easier to see that you changed something and which feedback you addressed. When you just quietly push changes, they might go unnoticed.
Fixed the indentation and added gotos and labels |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You seem to have had a bit of trouble understanding how exactly goto
works or how my review comment was meant, so let me try to explain a bit further.
goto
is like a jump instruction, whenever it executes, it simply jumps to the place where the label is located, it's not like function call, there is no returning back to where the goto is.
My idea of handling the errors is something like this (pseudo-code):
if(mount C fails) {
print error;
goto done;
}
if(mount E fails) {
print error;
goto unmount_c;
}
if(something else fails) {
print error;
goto unmount_e;
}
do whatever the sample is intended to do
unmount_e:
unmount E here
unmount_c:
unmount C here
while(1) {
Sleep(2000);
}
return 0;
Notice how C is mounted first, but unmounted last. This is important because a goto unmount_e;
will first unmount E, and execution will then "fall through" to unmount_c
, so both drives will get unmounted, but a goto unmount_c
will only unmount C, not E.
When no error happens, execution will simply continue normally, never executing a goto, but still running the code after the labels, so the drives will get unmounted, too.
samples/winapi_drivelist/main.c
Outdated
error = GetLastError(); | ||
debugPrint("\nCouldn't unmount E: drive! Error code: %x\n", error); | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You seem to have accidentally removed a newline at the end here.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm almost certain this was fixed before, but now the newline is removed again.
b849d74
to
ca09cdd
Compare
Changes made, hope it's all good now |
samples/winapi_drivelist/main.c
Outdated
|
||
unmount_e: | ||
ret = nxUnmountDrive('E'); | ||
// If there was an error while unmounting |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This comment adds nothing in my opinion.
The "GetLastError" in combination with !ret
strongly implies that this is error-checking.
@@ -10,10 +10,15 @@ int main(void) | |||
{ | |||
XVideoSetMode(640, 480, 32, REFRESH_DEFAULT); | |||
|
|||
// Create a variable for WinAPI error checking | |||
DWORD error; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This can be a highly local variable, I don't see a benefit for putting it at function scope?
If you declare it where it's used it also won't require any additional comment.
If the variable is redeclared, you should use different names to differentiate them; in this particular sample this only seems to happen after FindNextFile
, so you could probably do DWORD findFileError = GetLastError()
in that instance.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This wasn't done everywhere
ca09cdd
to
c7b5269
Compare
I just applied all the suggested changes, ready to make more if needed |
c7b5269
to
f9e1ed2
Compare
Building failed previously, tired me forgot to test before pushing haha. Errors fixed and building of both samples tested to work fine. |
return 1; | ||
error = GetLastError(); | ||
debugPrint("Failed to mount E: drive! Error code: %x\n", error); | ||
goto unmount_c; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This code makes little sense to me; mounting E failed, so it jumps to unmounting C?
The labels should be named more appropriately.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I believe that this specific label should stay as unmount_c, it's a good enough name IMO.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@JayFoxRox What would you suggest? Personally, it doesn't bother me, imho it looks just like when a function is freeing a previous allocation before returning due to an error.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not sure; I'd probably cause a fatal error if anything fails to init (to avoid having to do conditional cleanup).
If conditional cleanup is mandatory I'd probably have a boolean which stores which drives were mounted correctly (mountedC
/ mountedE
), I'd then have a generic cleanup function at the end of the scope which unmounts it (a single label called cleanup
, which would conditionally deal with cleanup).
In a real application I'd probably have something like atexit
/ destructors which deal with this (= no labels); also ensures proper order of destruction without having to think about it.
Probably not practical for a sample because it adds too much complexity.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Especially with a generic label such as cleanup
now, I think this should use booleans / keep track of it and handle everything in cleanup
.
No, you didn't. And it's very hard to keep track of what you did or how you resolved things. I suggest to leave a comment on each review comment, telling the reviewer what you did to resolve it. This is also taking up a lot of reviewer time and too many iterations for such a small change.
This also confirms why it's taking so much time: to little testing locally, and too little reflection / review on your own work. Because this PR discussion is getting hard to follow (too much review feedback), I'd even consider starting a new PR if this doesn't reach an acceptable state in the next iteration. |
f9e1ed2
to
39c32b1
Compare
Changed what I could and tested. If anything more is left I'd also gladly move it to a new PR (even though I know that I should have got it right a looooong time ago and that opening even this 2nd PR is a bit absurd) |
I believe this is ready for a review and hopefully it's (at least one of the) final iteration(s). |
Removal of |
d4171ea
to
026da0f
Compare
I believe I have solved the merge conflicts, so this might be in the clear. |
64d0dec
to
4db54c3
Compare
1ccc6cb
to
6d7deb7
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There are some review comments still unaddressed, and a couple of issues that seem to be new - newlines are getting removed again, the commit author is incorrect, and somehow f2c634f got mixed in.
This is also branching off a rather old version of nxdk now and imho should be rebased onto current master to make sure there aren't any conflicts.
lib/usb/libusbohci_xbox/xid_driver.c
Outdated
static void free_xid_device(xid_dev_t *xid_dev) { | ||
//Find the device head in the linked list | ||
xid_dev_t *head = pxid_list; | ||
|
||
//If the xid is at the head of the list, remove now. | ||
if (xid_dev == head) | ||
{ | ||
pxid_list = head->next; | ||
head = NULL; | ||
} | ||
|
||
//Find the device head in the linked list | ||
while (head != NULL && head->next != xid_dev) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What is this change doing here? (f2c634f)
samples/winapi_drivelist/main.c
Outdated
error = GetLastError(); | ||
debugPrint("\nCouldn't unmount E: drive! Error code: %x\n", error); | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm almost certain this was fixed before, but now the newline is removed again.
samples/winapi_filefind/main.c
Outdated
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This newline should not get removed.
6d7deb7
to
535e842
Compare
This PR fixes issue #381. While I had previously opened a PR for this (#382), it was getting bloated, so I am opening this new one after I improved upon all the suggestions in the other PR.