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

feat: getsolc binary to locate or download Solidity compiler #1244

Draft
wants to merge 1 commit into
base: arr4n/precompile-go-tests
Choose a base branch
from

Conversation

ARR4N
Copy link
Contributor

@ARR4N ARR4N commented Jul 18, 2024

Why this should be merged

How this works

How this was tested

How is this documented

TODO before review

  • Embed list.json files instead of downloading them (trusted hashes)
  • Check the hash of the downloaded file

Copy link

@marun marun left a comment

Choose a reason for hiding this comment

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

Nice work! Questions inline are more for my edification, and I'd be happy to have this merged in its current form.

return fmt.Errorf("unsupported OS %q", goos)
}

// solc only provides amd64 binaries, but this can be ignored if there is a
Copy link

Choose a reason for hiding this comment

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

(No action required) I guess rosetta is fine, but what is up with automated release procedures not being updated to create arm64 binaries? I guess it's an indication that most people are using a package manager that does ship arm64.

}
defer jsonList.Body.Close()
var list solcList
if err := json.NewDecoder(jsonList.Body).Decode(&list); err != nil {
Copy link

Choose a reason for hiding this comment

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

(No action required) Is there an advantage to using Decode vs Unmarshal where the data is in-memory (as I'm assuming is the case here)?

return "", false
}

which := exec.CommandContext(ctx, "which", "solc")
Copy link

Choose a reason for hiding this comment

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

(No action required) Maybe prefer command as per https://www.shellcheck.net/wiki/SC2230? It is optional and a bit pedantic, but its been enforced on me before.

I guess a slight con of using golang over bash for scripting is that we don't benefit from a scripting-centric linter? Not a deal-breaker by any means, but we'll inevitably have shell interaction in golang scripts and in the absence of a linter we'll have to rely on review.

// succesful location of a matching binary.
func (c *config) bestEffortFindInPATH(ctx context.Context) (string, bool) {
solc := exec.CommandContext(ctx, "solc", "--version")
out, err := solc.CombinedOutput()
Copy link

Choose a reason for hiding this comment

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

(No action required) For general-purpose scripting in golang, maybe we'll want a standard way to invoke commands so that we can replicate the behavior of set -x for the whole script? Or maybe I'm just scarred from too much bash and should get used to the idea of using a debugger instead... 😄

return err
}

fmt.Fprintf(os.Stderr, "Keccak256 of download: %#x\n", hash.Sum(nil))
Copy link

Choose a reason for hiding this comment

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

(No action required) Best practice for the use of stderr vs stdout? I've defaulted to thinkiing of stderr as for error conditions - which isn't the case here - but I recall that a more nuanced view is prevalent among experts.

flag.Parse()

if err := c.run(context.Background()); err != nil {
fmt.Fprintln(os.Stderr, err)
Copy link

Choose a reason for hiding this comment

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

(No action required) Thoughts on using panic in a script to provide immediate feedback and a stack trace? I've heard it suggested that getting a stack trace in the context of a script can be preferential to passing errors around, but its use would probably have to be limited to main entrypoints or reusability of library functionality would be compromised.

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.

2 participants