You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Note that the $OUT parameter and $1 are slightly different (.../out vs .../other_out), to differentiate between the two in error messages. Running PaSh like this produces the following traceback:
Traceback (most recent call last):
File "/home/nick/pash/compiler/pash_compiler.py", line 96, in compile_ir
ret = compile_optimize_output_script(ir_filename, compiled_script_file, args, compiler_config)
File "/home/nick/pash/compiler/pash_compiler.py", line 112, in compile_optimize_output_script
optimized_ast_or_ir = compile_optimize_df_region(candidate_df_region, args, compiler_config)
File "/home/nick/pash/compiler/pash_compiler.py", line 160, in compile_optimize_df_region
asts_and_irs = compile_candidate_df_region(df_region, config.config)
File "/home/nick/pash/compiler/pash_compiler.py", line 206, in compile_candidate_df_region
compiled_asts = compile_asts(candidate_df_region, fileIdGen, config)
File "/home/nick/pash/compiler/ast_to_ir.py", line 60, in compile_asts
expanded_ast = expand_command(ast_object, exp_state)
File "/home/nick/pash/python_pkgs/sh_expand/expand.py", line 437, in expand_command
return ast_match(command, expand_cases, exp_state)
File "/home/nick/pash/python_pkgs/shasta/ast_node.py", line 824, in ast_match
return cases[type(ast_node).NodeName](*args)(ast_node)
File "/home/nick/pash/python_pkgs/sh_expand/expand.py", line 408, in <lambda>
lambda ast_node: expand_simple(ast_node, exp_state)),
File "/home/nick/pash/python_pkgs/sh_expand/expand.py", line 448, in expand_simple
node.redir_list = expand_redir_list(node.redir_list, exp_state)
File "/home/nick/pash/python_pkgs/sh_expand/expand.py", line 459, in expand_redir_list
redir_list[i] = expand_redir(r, exp_state)
File "/home/nick/pash/python_pkgs/sh_expand/expand.py", line 464, in expand_redir
file_arg = expand_arg(redirection.arg, exp_state)
File "/home/nick/pash/python_pkgs/sh_expand/expand.py", line 304, in expand_arg
new = expand_arg_char(arg_char, quoted, exp_state)
File "/home/nick/pash/python_pkgs/sh_expand/expand.py", line 345, in expand_arg_char
return expand_var(fmt=arg_char.fmt,
File "/home/nick/pash/python_pkgs/sh_expand/expand.py", line 360, in expand_var
_type, value = lookup_variable(var, exp_state)
File "/home/nick/pash/python_pkgs/sh_expand/expand.py", line 215, in lookup_variable
expanded_var = lookup_variable_inner(var, exp_state)
File "/home/nick/pash/python_pkgs/sh_expand/expand.py", line 221, in lookup_variable_inner
value = lookup_variable_inner_core(varname, exp_state)
File "/home/nick/pash/python_pkgs/sh_expand/expand.py", line 231, in lookup_variable_inner_core
value = lookup_variable_inner_unsafe(varname, exp_state)
File "/home/nick/pash/python_pkgs/sh_expand/expand.py", line 240, in lookup_variable_inner_unsafe
_type, value = exp_state.variables.get(varname, [None, None])
ValueError: too many values to unpack (expected 2)
The most recent call is in this function of the expand.py file:
deflookup_variable_inner_unsafe(varname, exp_state: ExpansionState):
## TODO: Is it in there? If we have -u and it is in there._type, value=exp_state.variables.get(varname, [None, None])
returnvalue
Logging the result of the exp_state.variables.get() call (without unpacking into _type and value) shows these two variables:
(None, '61.txt')
So the problem lies with the first parameter passed to pa.sh (the one specified after the script to parallelize), because it doesn't get turned to a 2-tuple as it should, unlike (None, '61.txt'), which is turned into a tuple without a problem.
Running the script with a named variable instead of $1 works without any problems.
The text was updated successfully, but these errors were encountered:
This slightly modified script works for me on Ubuntu 20.04 and 24.04, so it seems fixed. I can’t think of any relevant changes we’ve made to the sh-expand code in the meantime, though.
Trying to run the
1_1.sh
script from thenlp
suite breaks PaSh.I invoke PaSh like this (my
$PASH_TOP
is/home/nick/pash
):Note that the
$OUT
parameter and$1
are slightly different (.../out
vs.../other_out
), to differentiate between the two in error messages. Running PaSh like this produces the following traceback:The most recent call is in this function of the
expand.py
file:Logging the result of the
exp_state.variables.get()
call (without unpacking into_type
andvalue
) shows these two variables:/home/nick/pash/evaluation/benchmarks/nlp/outputs/test/other_out
(None, '61.txt')
So the problem lies with the first parameter passed to
pa.sh
(the one specified after the script to parallelize), because it doesn't get turned to a 2-tuple as it should, unlike(None, '61.txt')
, which is turned into a tuple without a problem.Running the script with a named variable instead of
$1
works without any problems.The text was updated successfully, but these errors were encountered: