Mercurial Templating

It’s possible to customize how the log output looks like using hg.
We can use inline templates as in:

hg log --template "{rev}"

{rev} is called a “keyword” and it gets replaced by the actual value when we do hg log. The list of keywords can be seen here.

Alternatively we can define our style in a separate file, e.g. ~/.hg/

changeset = 'changeset: {rev}:{node|short}'

We specify the style using --style=/home/unixname/.hg/ or setting the default style in .hgrc:


Other settings


We can change the font-colors of the text by using ANSI escape codes

Basically we specify \x1B[3<i>m where <i> is a number from 0 to 7 (see the wikipedia page for the color mapping). And \x1B[0m resets the color.

Files in multiple lines

We can add the following line that configures the formatting of a file entry (when using the {files} keyword)

file = ' {file}\n'

Date in my timezone

We can use




2048 CLI in python

I’ve decided to code a simple CLI version of the 2048 game in python:

Some details of the implementation:

* I’ve handled only the “up” move. For the others I do a rotation of either 90, 180 or 270 degrees the matrix representing the board.
* The core of the algorithm is apply “gravity”, perform the merge with adjacent element with same number and then apply the “gravity” again because my merge function can leave empty spaces.

[bash] Move and change directory (mv & cd)

In many cases when I move one or more files to a directory I want to change to that directory afterwards. I did a little search and found this discussion, which resulted in the following bash script function:

function mvcd () 
     num_of_files=$(($# - 1))
     for i in $(eval echo {1..$num_of_files})
         eval mv \${$i} \${$#}
     eval cd \${$#}


mkdir c
touch a.txt b.txt
mvcd a.txt b.txt c