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

Fix failing test and the false negative CI #19

Merged
merged 3 commits into from
Jun 30, 2020
Merged

Conversation

zhsj
Copy link
Contributor

@zhsj zhsj commented Jun 25, 2020

No description provided.

@@ -1,3 +1,4 @@
.SHELLFLAGS = -ec
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🤔 isn't that usually the default? Is that some weird configuration in GH Actions?

edit: ah! interesting https://www.gnu.org/software/make/manual/html_node/Choosing-the-Shell.html

The default value of .SHELLFLAGS is -c normally, or -ec in POSIX-conforming mode.

Copy link
Member

@thaJeztah thaJeztah left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@kolyshkin PTAL

@SamWhited
Copy link
Member

Would setting .POSIX: also fix this? I normally stick this at the top of my makefiles since it's portable between GNU Make and NetBSD Make (though that doesn't really matter here).

@zhsj
Copy link
Contributor Author

zhsj commented Jun 26, 2020

Would setting .POSIX: also fix this? I normally stick this at the top of my makefiles since it's portable between GNU Make and NetBSD Make (though that doesn't really matter here).

I just know this .POSIX: syntax.. However IMO it's less clear than .SHELLFLAGS.

@@ -194,7 +194,7 @@ func unescape(path string) (string, error) {
v := c - '0'
for j := 2; j < 4; j++ { // one digit already; two more
x := s[j] - '0'
if x < 0 || x > 7 {
if x > 7 {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

OK I think the correct thing to do would be

if s[j] < '0' || s[j] > '7' {
  return "", fmt.Errorf("bad escape sequence %q: not a digit", s[:3])
}
x := s[j] - '0'

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This won't fix anything (we will still catch underflow in case s[j] is less than '0'), but it's a tad cleaner code with no ambiguity.

@kolyshkin
Copy link
Collaborator

Thank you for the fixes! Can you please split it into 3 commits:

  • Fixing the test case
  • Fixing the is-octal-digit check
  • fixing the make flags

with a brief commit message describing the reason for the change.

Otherwise it won't be easy to follow the git history

zhsj added 3 commits July 1, 2020 03:01
Add -e to .SHELLFLAGS, so for loop can fail correctly

Signed-off-by: Shengjing Zhu <[email protected]>
Align the test result after:

0b171c2
mountinfo: also unescape fstype and source

Signed-off-by: Shengjing Zhu <[email protected]>
The old check is always true when comparing with 0, since x is byte type

Signed-off-by: Shengjing Zhu <[email protected]>
@zhsj
Copy link
Contributor Author

zhsj commented Jun 30, 2020

Thank you for the fixes! Can you please split it into 3 commits:

  • Fixing the test case
  • Fixing the is-octal-digit check
  • fixing the make flags

with a brief commit message describing the reason for the change.

Otherwise it won't be easy to follow the git history

done

Copy link
Member

@thaJeztah thaJeztah left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM, thanks!

@kolyshkin PTAL

Copy link
Collaborator

@kolyshkin kolyshkin left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants