... | ... |
@@ -12,29 +12,47 @@ |
12 | 12 |
SET(LEMON_VERSION $ENV{LEMON_VERSION} CACHE STRING "LEMON version string.") |
13 | 13 |
ELSE() |
14 | 14 |
EXECUTE_PROCESS( |
15 |
COMMAND |
|
15 |
COMMAND |
|
16 |
hg log -r. --template "{latesttag}" |
|
16 | 17 |
WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} |
17 |
OUTPUT_VARIABLE |
|
18 |
OUTPUT_VARIABLE HG_REVISION_TAG |
|
18 | 19 |
ERROR_QUIET |
19 | 20 |
OUTPUT_STRIP_TRAILING_WHITESPACE |
20 | 21 |
) |
21 | 22 |
EXECUTE_PROCESS( |
22 |
COMMAND |
|
23 |
COMMAND |
|
24 |
hg log -r. --template "{latesttagdistance}" |
|
23 | 25 |
WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} |
24 |
OUTPUT_VARIABLE |
|
26 |
OUTPUT_VARIABLE HG_REVISION_DIST |
|
25 | 27 |
ERROR_QUIET |
26 | 28 |
OUTPUT_STRIP_TRAILING_WHITESPACE |
27 | 29 |
) |
28 |
|
|
30 |
EXECUTE_PROCESS( |
|
31 |
COMMAND |
|
32 |
hg log -r. --template "{node|short}" |
|
33 |
WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} |
|
34 |
OUTPUT_VARIABLE HG_REVISION_ID |
|
35 |
ERROR_QUIET |
|
36 |
OUTPUT_STRIP_TRAILING_WHITESPACE |
|
37 |
) |
|
38 |
|
|
39 |
IF(HG_REVISION_TAG STREQUAL "") |
|
29 | 40 |
SET(HG_REVISION_ID "hg-tip") |
30 | 41 |
ELSE() |
31 |
IF(HG_REVISION_PATH STREQUAL "") |
|
32 |
SET(HG_REVISION_ID ${HG_REVISION}) |
|
42 |
IF(HG_REVISION_TAG STREQUAL "null") |
|
43 |
SET(HG_REVISION_TAG "trunk") |
|
44 |
ELSEIF(HG_REVISION_TAG MATCHES "^r") |
|
45 |
STRING(SUBSTRING ${HG_REVISION_TAG} 1 -1 HG_REVISION_TAG) |
|
46 |
ENDIF() |
|
47 |
IF(HG_REVISION_DIST STREQUAL "0") |
|
48 |
SET(HG_REVISION ${HG_REVISION_TAG}) |
|
33 | 49 |
ELSE() |
34 |
SET( |
|
50 |
SET(HG_REVISION |
|
51 |
"${HG_REVISION_TAG}+${HG_REVISION_DIST}-${HG_REVISION_ID}") |
|
35 | 52 |
ENDIF() |
36 | 53 |
ENDIF() |
37 |
|
|
54 |
|
|
55 |
SET(LEMON_VERSION ${HG_REVISION} CACHE STRING "LEMON version string.") |
|
38 | 56 |
ENDIF() |
39 | 57 |
|
40 | 58 |
SET(PROJECT_VERSION ${LEMON_VERSION}) |
1 |
#! /usr/bin/env python |
|
2 |
# |
|
3 |
# This file is a part of LEMON, a generic C++ optimization library. |
|
4 |
# |
|
5 |
# Copyright (C) 2003-2009 |
|
6 |
# Egervary Jeno Kombinatorikus Optimalizalasi Kutatocsoport |
|
7 |
# (Egervary Research Group on Combinatorial Optimization, EGRES). |
|
8 |
# |
|
9 |
# Permission to use, modify and distribute this software is granted |
|
10 |
# provided that this copyright notice appears in all copies. For |
|
11 |
# precise terms see the accompanying LICENSE file. |
|
12 |
# |
|
13 |
# This software is provided "AS IS" with no warranty of any kind, |
|
14 |
# express or implied, and with no claim as to its suitability for any |
|
15 |
# purpose. |
|
16 |
|
|
17 |
import sys |
|
18 |
|
|
19 |
from mercurial import ui, hg |
|
20 |
from mercurial import util |
|
21 |
|
|
22 |
util.rcpath = lambda : [] |
|
23 |
|
|
24 |
if len(sys.argv)>1 and sys.argv[1] in ["-h","--help"]: |
|
25 |
print """ |
|
26 |
This utility just prints the length of the longest path |
|
27 |
in the revision graph from revison 0 to the current one. |
|
28 |
""" |
|
29 |
exit(0) |
|
30 |
|
|
31 |
u = ui.ui() |
|
32 |
r = hg.repository(u, ".") |
|
33 |
N = r.changectx(".").rev() |
|
34 |
lengths=[0]*(N+1) |
|
35 |
for i in range(N+1): |
|
36 |
p=r.changectx(i).parents() |
|
37 |
if p[0]: |
|
38 |
p0=lengths[p[0].rev()] |
|
39 |
else: |
|
40 |
p0=-1 |
|
41 |
if len(p)>1 and p[1]: |
|
42 |
p1=lengths[p[1].rev()] |
|
43 |
else: |
|
44 |
p1=-1 |
|
45 |
lengths[i]=max(p0,p1)+1 |
|
46 |
print lengths[N] |
0 comments (0 inline)