Skip to content

Commit

Permalink
[7.2.0] Add sep keyword argument to fail (#22004)
Browse files Browse the repository at this point in the history
The argument was already available on 'print' and is necessary for full
control over the formatting of error messages that rely on
StarlarkValue's `debugPrint`.

Work towards #20486

Closes #21961.

PiperOrigin-RevId: 625022818
Change-Id: I895b5844d8543f936fc31d367b12bc6291a10bf8

Commit
6b2e0db

Co-authored-by: Fabian Meumertzheim <[email protected]>
  • Loading branch information
bazel-io and fmeum authored Apr 15, 2024
1 parent 81fc95f commit 80a3dbe
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 5 deletions.
17 changes: 12 additions & 5 deletions src/main/java/net/starlark/java/eval/MethodLibrary.java
Original file line number Diff line number Diff line change
Expand Up @@ -812,16 +812,23 @@ public StarlarkList<?> dir(Object object, StarlarkThread thread) throws EvalExce
"Deprecated. Causes an optional prefix containing this string to be added to the"
+ " error message.",
positional = false,
named = true)
named = true),
@Param(
name = "sep",
defaultValue = "\" \"",
named = true,
positional = false,
doc = "The separator string between the objects, default is space (\" \").")
},
extraPositionals =
@Param(
name = "args",
doc =
"A list of values, formatted with debugPrint (which is equivalent to str by"
+ " default) and joined with spaces, that appear in the error message."),
+ " default) and joined with sep (defaults to \" \"), that appear in the"
+ " error message."),
useStarlarkThread = true)
public void fail(Object msg, Object attr, Tuple args, StarlarkThread thread)
public void fail(Object msg, Object attr, String sep, Tuple args, StarlarkThread thread)
throws EvalException {
Printer printer = new Printer();
boolean needSeparator = false;
Expand All @@ -832,14 +839,14 @@ public void fail(Object msg, Object attr, Tuple args, StarlarkThread thread)
// msg acts like a leading element of args.
if (msg != Starlark.NONE) {
if (needSeparator) {
printer.append(" ");
printer.append(sep);
}
printer.debugPrint(msg, thread.getSemantics());
needSeparator = true;
}
for (Object arg : args) {
if (needSeparator) {
printer.append(" ");
printer.append(sep);
}
printer.debugPrint(arg, thread.getSemantics());
needSeparator = true;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -755,6 +755,7 @@ ev.new Scenario()
.testIfErrorContains("abc", "fail('abc')")
.testIfErrorContains("18", "fail(18)")
.testIfErrorContains("1 2 3", "fail(1, 2, 3)")
.testIfErrorContains("1, 2, 3", "fail(1, 2, 3, sep=', ')")
.testIfErrorContains("attribute foo: 1 2 3", "fail(1, 2, 3, attr='foo')") // deprecated
.testIfErrorContains("0 1 2 3", "fail(1, 2, 3, msg=0)"); // deprecated
}
Expand Down

0 comments on commit 80a3dbe

Please sign in to comment.