-
Notifications
You must be signed in to change notification settings - Fork 218
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
Allow load statements in conditionals and loops #553
Comments
Regarding the spec:
Why can't you move the load statement to the top level? Do you need conditional loads? |
We're already at the top level.
This seems to be allowed in this project by the
Exactly. Our use-case is gracefully falling back to using a stub identifier when loading of the module that contains a non-stub identifier is not possible (e.g. due to lack of permissions, or just the lack of module itself). Here's an example that is demonstrates this for module existence: # .cirrus.star
load("cirrus", "fs")
if fs.exists("private.star"):
load("private.star", "greeting")
else:
def greeting():
return "Goodbye, cruel World!"
def main(ctx):
print(greeting())
return [] # private.star
def greeting():
return "Hello, World!" Frankly, having the Another way we've tried to work around this is to return a |
As @laurentlb points out, this is a misreading of the spec; the intended behavior is clear from the portions he quoted, and the rationale is clearly expressed in #275.
Reading the attached Tilt issue, it would appear that they found an alternative approach some years ago and don't actually need this feature. Have you explored the approach they took?
We try hard to avoid adding new options that change the language semantics. Most that exist were necessary to enable compatibility between different implementations and gradual harmonization; many that used to exist (e.g. float, nesteddef, bitwise, lambda) have become obsolete due to spec standardization. Some exist to support the REPL. Ideally we would never add more. Since this is a proposal to change the core semantics of the language, it should be proposed at bazelbuild/starlark. |
@edigaryev Did you ever file this as an issue to Also in the meantime: are you maintaining a fork that re-enables load statements in conditions/loops? |
Actually it seems pretty trivial for consumers to implement dynamic loading themselves if they need it. Here's the implementation I came up with: https://gist.github.com/discentem/b6afae321df6821326f0675630b9eb6b Not sure if it's possible to dynamically load symbols, as I don't need it. |
The commit cd131d1 disables the load statements in conditionals and loops, saying that:
Looking at the official spec, namely, the Load statements and Grammar reference sections, nothing prevents the load statement to be in a conditional or a loop.
We need this feature at Cirrus Labs for our Starlark tasks, and it seems that fellows at Tilt need it too for their core product's
Tiltfile
.Since this is the current behavior for almost 4 years now, perhaps a good compromise would be giving the users of this package an option to re-enable this behavior using the
syntax.FileOptions
.The text was updated successfully, but these errors were encountered: