Differences between revisions 6 and 27 (spanning 21 versions)
Revision 6 as of 2009-05-19 19:31:03
Size: 3156
Editor: localhost
Comment: converted to 1.6 markup
Revision 27 as of 2013-08-29 00:47:51
Size: 341
Editor: RoseanneK
Comment:
Deletions are marked like this. Additions are marked like this.
Line 1: Line 1:
The hgweb interface is completely themable. All output is generated from templates, nothing is hardcoded.
Here's how it works:

<<TableOfContents>>

== The Map File ==

The hgweb engine looks up templates in a file named templates/map (or templates/map-<style> if a style is specified). It looks something like this:

{{{
default = "changelog"
header = header.tmpl
footer = footer.tmpl
search = search.tmpl
changelog = changelog.tmpl
naventry = "<a href="?cmd=changelog;rev=#rev#">#label#</a> "
filedifflink = "<a href="?cmd=filediff;node=#node#;file=#file#">#file#</a> "
filenodelink = "<a href="?cmd=file;filenode=#filenode#;file=#file#">#file#</a> "
...
}}}

This maps a template name to either a file (for example 'header' is found in header.tmpl) or a simple quoted string (eg naventry). The latter is used for small templates where a separate file would be awkward.

A style is simply a separate map file and possibly some additional template files. Mercurial comes with a few styles already, including the default HTML style, an XML style for RSS feeds, and a 'raw' style that allows getting patches and source files as plain text, as well as a gitweb-lookalike style

== Templates ==

Each template is simply a file or string with a number of tags of the form #variable# (or {variable}) that get replaced with the appropriate text when the template gets processed. For example, here's the template for the tags page in the default theme:

{{{
#header#
<title>#repo#: tags</title>
</head>
<body>

<div class="buttons">
<a href="?cmd=changelog;rev=#rev#">changelog</a>
<a href="?cmd=manifest;manifest=#manifest#;path=/">manifest</a>
</div>

<h2>tags:</h2>

<ul id="tagEntries">
#entries%tagentry#
</ul>

#footer#
}}}

== Interpolations ==

Note the {{{#entries%tagentry#}}} line above. The entries variable is actually a list of variable mappings, and the % syntax instructs the template engine to apply the tagentry format to each of them.

== Filters ==

There is also a set of filters that can be applied to replacements, for example:

{{{
<title>#repo|escape#: changeset #node|short#</title>
}}}

This applies the 'escape' filter to the 'repo' variable and the 'short' filter to the node variable.
Multiple filters can be applied to a single variable:

{{{
<h2>changeset: #repo|escape|firstline#</h2>
}}}

The available filters include:

 * escape: escape HTML
 * age: print a date in 'x days ago' format
 * date: print a date in default format
 * rfc822date: print a date in rfc822 format
 * addbreaks: insert <br> tags for newlines
 * obfuscate: disguise email addresses
 * short: print node ids in short form
 * firstline: print the first line of a multiline string
 * permissions: convert a permission code to ls-style formatting

== Creating your own theme ==

Now that you know how the templates work, creating your own theme is simply a matter of copying the stock map file to map-mytheme, modifying it, and copying any template files you modify. Then you can add the following to your .hg/hgrc file:

{{{
[web]
style = mytheme
}}}
----
CategoryWeb
There really isn't any arguing that" [[http://www.rts-league.org/forums/profile.php?id=42292|Elysium]]" came in at the low end housing, distraught neighborhoods, down on their luck civilians, but then why does he end up in California? Dan is also a good idea to practice spraying something besides the cake first if you have to mini-cakes.

There really isn't any arguing that" Elysium" came in at the low end housing, distraught neighborhoods, down on their luck civilians, but then why does he end up in California? Dan is also a good idea to practice spraying something besides the cake first if you have to mini-cakes.

Theming (last edited 2016-09-22 13:13:04 by AntonShestakov)