Jakub Narębski <jnareb@xxxxxxxxx> writes: > Subject: [PATCH] gitweb(1): Document query parameters > > The gitweb manpage includes description of gitweb URL structure, > but it was limited to passing parameters in the path part of URL > ('path info'), and it didn't include explanation of query parameters. > --- I think this weather-balloon patch adds the missing info at the most natural place in the flow of the document. An earlier part talks about a GitWeb URL having <repo>, <action>, <revision>, <path> and followed by what is called <arguments> after a question mark '?', but what <arguments> part means and how to formulate it are left unsaid. By the way, the title of the section 'Actions, and URLs' needs to lose the comma, I would think. > Documentation/gitweb.txt | 37 +++++++++++++++++++++++++++++++++++++ > 1 file changed, 37 insertions(+) > > diff --git a/Documentation/gitweb.txt b/Documentation/gitweb.txt > index 96156e5..301003f 100644 > --- a/Documentation/gitweb.txt > +++ b/Documentation/gitweb.txt > @@ -395,6 +395,43 @@ atom:: > Generates an RSS (or Atom) feed of changes to repository. > > > +Query parameters: > +~~~~~~~~~~~~~~~~~ > +In some cases gitweb cannot pass a parameter in path part of URL, for > +example if a filename contains double dots ('..') inside. All parameters > +that cannot be passed in that way are put as a query parameter, that is > +after '?'. Until this point, the reader hasn't even been told about "filename" is one of the potential things that can be given to "control the behaviour of the action", and is left wondering if she has a filename that does not have double-dots, how it can be passed "in path part of URL" after reading the first sentence. Then the second sentence adds more to the mystery by starting with "All parameters that cannot be passed" "in that way": what are the possible things that the users may want to pass? what exactly is "in that way", which probably means "encoded as part of the <path>", but it is unclear how that encoding works (is it just to "concatenate"?). Or is "filename in the revision" the ONLY thing the above paragraph talks about, and is the ONLY purpose of the "<path> part" to represent that "filename in the revision" in the URL? .../gitweb.cgi/<repo>/<action>/<revision>:/<path>?<arguments> The above syntax (taken from the first paragraph of the section) suggests that <path> cannot be used to hold filename with a colon, too. Perhaps "for example if a filename contains double-dots" needs to become an exhaustive description somewhere, i.e. "(see below for the exact rules)" added to that sentence? > +By default gitweb would generate links using query parameters, unless > +the original URL was using path part, or gitweb was configured to use > +pathinfo with the 'pathinfo' feature. All gitweb installations recognize > +URL in either format, so you can use one that is better for you when > +interacting with gitweb (handcrafting or editing URLs, or creating > +a program interacting with gitweb installation). > + > +Here is the list of some of query parameters, together with their > +long names (which should help remembering the short name of > +each parameter): > + > +'a' (action):: > + The action that will be run. > + > +'p' (project):: > + The project repository that will be displayed. > + > +'h' (hash):: > + The object id of displayed object (commit, tag, tree, blob). > + In case of files 'hb' (hash_base) and 'f' (filename) might be > + used instead. > + > +'hp' (hash_parent):: > +'fp' (file_parent):: > +'hpb' (hash_parent_base):: > + Those parameters define the second object for diff-like actions, > + the object gitweb is comparing againts. There is no mention of "filename" or "path" here, which further confuses a reader who was told in the first paragraph that these query-parameters are used when <path> part cannot hold a certain filename. Also it is unclear if <revision> corresponds to 'h'ash in the above. > + > + > + > WEBSERVER CONFIGURATION > ----------------------- > This section explains how to configure some common webservers to run gitweb. In -- 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