Jakub Narębski, Mon, Jun 27, 2016 19:28:07 +0200: > On 2016-06-27, Alex Riesen wrote: > > > This adds a FILENAMES environment variable, which contains the repository > > pathnames of all selected files the list. > > The variable contains the names separated by spaces. > > Why not separate filenames with end-of-line character (LF)? It would still > be broken for some filenames, but only for unportable ones. Filenames with > internal space (common on MS Windows) would work then. > > http://www.dwheeler.com/essays/filenames-in-shell.html > Done. Thanks for the reference, BTW. > If Tcl allows it, you could separate filenames in FILENAMES environment > variable with NUL ("\0") character... It allows using of NUL to join the file names. The problem is that the shell does not know that the variable $FILENAMES doesn't end at the first NUL. Looks like the script should do the expansion (and quoting!) on its own for this. Or implement another syntax for custom tools, which will allow for, i.e. passing the list of files on stdin. LF or NUL separated than. > > Similar to the FILENAME it is broken yet, if the names contain spaces. > > Could you clarify? Did you meant that FILENAMES environment variable is > similar to existing FILENAME variable, but broken for filenames which contain > spaces, or did you mean that both FILENAME (how?) and FILENAMES are broken > for filenames with spaces in them? Passing a filename with spaces plainly $FILENAME into the command (i.e. without quoting) produces multiple arguments instead of one. The new $FILENAMES produces incorrect number of arguments for files with spaces for the same reason. > > Note that the file marked and diffed immediately after starting the GUI up, > > is not actually selected. One must click on it once to really select it. > > I'm not that familiar with git-gui / gitk; what do you mean by this sentence? The git-gui (its completely different from gitk) keeps two variables for current files: a scalar variable for the file diff of which is displayed in the lower right pane, and a Tcl array (more like a string-to-int map, if I understand the code) with the names of the files selected in the file list. The array is populated every time you click on a name in the file list, and can contain multiple entries if you hold "Ctrl" while clicking. > Could you summarize how FILENAME and FILENAMES work, please? These are just environment variables set before running the tool command. They are unset immediately after starting the command. The tool command is unconditionally run using "sh -c <command>", so the references to the environment variables are expanded by "sh". Regards, Alex --- Diese E-Mail wurde von Avast Antivirus-Software auf Viren geprüft. https://www.avast.com/antivirus -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html