ci: fix `v self`, `v up` and other tools

pull/9441/head
Delyan Angelov 2021-03-23 15:30:08 +02:00
parent a4690e4ce2
commit 7101d53d74
No known key found for this signature in database
GPG Key ID: 66886C0F12D595ED
1 changed files with 23 additions and 4 deletions

View File

@ -48,10 +48,29 @@ pub fn (mut p Preferences) fill_with_defaults() {
}
target_dir := if os.is_dir(rpath) { rpath } else { os.dir(rpath) }
p.out_name = os.join_path(target_dir, base)
// TODO (maybe)
// If no "-o" was supplied, create the binary in the current
// directory. This is the behavior of Go, Clang, GCC, etc.
p.out_name = os.join_path(os.getwd(), base)
// Do *NOT* be tempted to generate binaries in the current work folder,
// when -o is not given by default, like Go, Clang, GCC etc do.
//
// These compilers also are frequently used with an external build system,
// in part because of that shortcoming, to ensure that they work in a
// predictable work folder/environment.
//
// In comparison, with V, building an executable by default places it
// next to its source code, so that it can be used directly with
// functions like `os.resource_abs_path()` and `os.executable()` to
// locate resources relative to it. That enables running examples like
// this:
// `./v run examples/flappylearning/`
// instead of:
// `./v -o examples/flappylearning/flappylearning run examples/flappylearning/`
// This topic comes up periodically from time to time on Discord, and
// many CI breakages already happened, when someone decides to make V
// behave in this aspect similarly to the dumb behaviour of other
// compilers.
//
// If you do decide to break it, please *at the very least*, test it
// extensively, and make a PR about it, instead of commiting directly
// and breaking the CI, VC, and users doing `v up`.
if rpath == '$p.vroot/cmd/v' && os.is_dir('vlib/compiler') {
// Building V? Use v2, since we can't overwrite a running
// executable on Windows + the precompiled V is more