Show More
@@ -2253,9 +2253,7 def wdir(repo, subset, x): | |||||
2253 | return baseset([node.wdirrev]) |
|
2253 | return baseset([node.wdirrev]) | |
2254 | return baseset() |
|
2254 | return baseset() | |
2255 |
|
2255 | |||
2256 | # for internal use |
|
2256 | def _orderedlist(repo, subset, x): | |
2257 | @predicate('_list', safe=True) |
|
|||
2258 | def _list(repo, subset, x): |
|
|||
2259 | s = getstring(x, "internal error") |
|
2257 | s = getstring(x, "internal error") | |
2260 | if not s: |
|
2258 | if not s: | |
2261 | return baseset() |
|
2259 | return baseset() | |
@@ -2284,8 +2282,15 def _list(repo, subset, x): | |||||
2284 | return baseset(ls) |
|
2282 | return baseset(ls) | |
2285 |
|
2283 | |||
2286 | # for internal use |
|
2284 | # for internal use | |
2287 |
@predicate('_ |
|
2285 | @predicate('_list', safe=True, takeorder=True) | |
2288 |
def _ |
|
2286 | def _list(repo, subset, x, order): | |
|
2287 | if order == followorder: | |||
|
2288 | # slow path to take the subset order | |||
|
2289 | return subset & _orderedlist(repo, fullreposet(repo), x) | |||
|
2290 | else: | |||
|
2291 | return _orderedlist(repo, subset, x) | |||
|
2292 | ||||
|
2293 | def _orderedintlist(repo, subset, x): | |||
2289 | s = getstring(x, "internal error") |
|
2294 | s = getstring(x, "internal error") | |
2290 | if not s: |
|
2295 | if not s: | |
2291 | return baseset() |
|
2296 | return baseset() | |
@@ -2294,8 +2299,15 def _intlist(repo, subset, x): | |||||
2294 | return baseset([r for r in ls if r in s]) |
|
2299 | return baseset([r for r in ls if r in s]) | |
2295 |
|
2300 | |||
2296 | # for internal use |
|
2301 | # for internal use | |
2297 |
@predicate('_ |
|
2302 | @predicate('_intlist', safe=True, takeorder=True) | |
2298 |
def _ |
|
2303 | def _intlist(repo, subset, x, order): | |
|
2304 | if order == followorder: | |||
|
2305 | # slow path to take the subset order | |||
|
2306 | return subset & _orderedintlist(repo, fullreposet(repo), x) | |||
|
2307 | else: | |||
|
2308 | return _orderedintlist(repo, subset, x) | |||
|
2309 | ||||
|
2310 | def _orderedhexlist(repo, subset, x): | |||
2299 | s = getstring(x, "internal error") |
|
2311 | s = getstring(x, "internal error") | |
2300 | if not s: |
|
2312 | if not s: | |
2301 | return baseset() |
|
2313 | return baseset() | |
@@ -2304,6 +2316,15 def _hexlist(repo, subset, x): | |||||
2304 | s = subset |
|
2316 | s = subset | |
2305 | return baseset([r for r in ls if r in s]) |
|
2317 | return baseset([r for r in ls if r in s]) | |
2306 |
|
2318 | |||
|
2319 | # for internal use | |||
|
2320 | @predicate('_hexlist', safe=True, takeorder=True) | |||
|
2321 | def _hexlist(repo, subset, x, order): | |||
|
2322 | if order == followorder: | |||
|
2323 | # slow path to take the subset order | |||
|
2324 | return subset & _orderedhexlist(repo, fullreposet(repo), x) | |||
|
2325 | else: | |||
|
2326 | return _orderedhexlist(repo, subset, x) | |||
|
2327 | ||||
2307 | methods = { |
|
2328 | methods = { | |
2308 | "range": rangeset, |
|
2329 | "range": rangeset, | |
2309 | "dagrange": dagrange, |
|
2330 | "dagrange": dagrange, |
@@ -1281,11 +1281,12 ordering defined by it. | |||||
1281 | follow) |
|
1281 | follow) | |
1282 | define) |
|
1282 | define) | |
1283 | * set: |
|
1283 | * set: | |
1284 | <baseset [0, 1, 2]> |
|
1284 | <filteredset | |
1285 | 0 |
|
1285 | <spanset- 0:2>, | |
|
1286 | <baseset [0, 1, 2]>> | |||
|
1287 | 2 | |||
1286 | 1 |
|
1288 | 1 | |
1287 |
|
|
1289 | 0 | |
1288 | BROKEN: should be '2 1 0' |
|
|||
1289 |
|
1290 | |||
1290 | 'A + B' should take the ordering of the left expression: |
|
1291 | 'A + B' should take the ordering of the left expression: | |
1291 |
|
1292 | |||
@@ -1350,7 +1351,7 ordering defined by it. | |||||
1350 | * set: |
|
1351 | * set: | |
1351 | <filteredset |
|
1352 | <filteredset | |
1352 | <spanset- 0:2>, |
|
1353 | <spanset- 0:2>, | |
1353 | <baseset [0, 1, 2]>> |
|
1354 | <baseset+ [0, 1, 2]>> | |
1354 | 2 |
|
1355 | 2 | |
1355 | 1 |
|
1356 | 1 | |
1356 | 0 |
|
1357 | 0 | |
@@ -1405,11 +1406,12 ordering defined by it. | |||||
1405 | follow) |
|
1406 | follow) | |
1406 | define) |
|
1407 | define) | |
1407 | * set: |
|
1408 | * set: | |
1408 | <baseset [0, 1, 2]> |
|
1409 | <filteredset | |
1409 | 0 |
|
1410 | <spanset- 0:2>, | |
|
1411 | <baseset [0, 1, 2]>> | |||
|
1412 | 2 | |||
1410 | 1 |
|
1413 | 1 | |
1411 |
|
|
1414 | 0 | |
1412 | BROKEN: should be '2 1 0' |
|
|||
1413 |
|
1415 | |||
1414 | $ trylist --optimize --bin '%ln & 2:0' `hg log -T '{node} ' -r0+2+1` |
|
1416 | $ trylist --optimize --bin '%ln & 2:0' `hg log -T '{node} ' -r0+2+1` | |
1415 | (and |
|
1417 | (and | |
@@ -1436,6 +1438,53 ordering defined by it. | |||||
1436 | 2 |
|
1438 | 2 | |
1437 | 1 |
|
1439 | 1 | |
1438 |
|
1440 | |||
|
1441 | '_list' should not go through the slow follow-order path if order doesn't | |||
|
1442 | matter: | |||
|
1443 | ||||
|
1444 | $ try -p optimized '2:0 & not (0 + 1)' | |||
|
1445 | * optimized: | |||
|
1446 | (difference | |||
|
1447 | (range | |||
|
1448 | ('symbol', '2') | |||
|
1449 | ('symbol', '0') | |||
|
1450 | define) | |||
|
1451 | (func | |||
|
1452 | ('symbol', '_list') | |||
|
1453 | ('string', '0\x001') | |||
|
1454 | any) | |||
|
1455 | define) | |||
|
1456 | * set: | |||
|
1457 | <filteredset | |||
|
1458 | <spanset- 0:2>, | |||
|
1459 | <not | |||
|
1460 | <baseset [0, 1]>>> | |||
|
1461 | 2 | |||
|
1462 | ||||
|
1463 | $ try -p optimized '2:0 & not (0:2 & (0 + 1))' | |||
|
1464 | * optimized: | |||
|
1465 | (difference | |||
|
1466 | (range | |||
|
1467 | ('symbol', '2') | |||
|
1468 | ('symbol', '0') | |||
|
1469 | define) | |||
|
1470 | (and | |||
|
1471 | (range | |||
|
1472 | ('symbol', '0') | |||
|
1473 | ('symbol', '2') | |||
|
1474 | any) | |||
|
1475 | (func | |||
|
1476 | ('symbol', '_list') | |||
|
1477 | ('string', '0\x001') | |||
|
1478 | any) | |||
|
1479 | any) | |||
|
1480 | define) | |||
|
1481 | * set: | |||
|
1482 | <filteredset | |||
|
1483 | <spanset- 0:2>, | |||
|
1484 | <not | |||
|
1485 | <baseset [0, 1]>>> | |||
|
1486 | 2 | |||
|
1487 | ||||
1439 |
|
|
1488 | 'present()' should do nothing other than suppressing an error: | |
1440 |
|
1489 | |||
1441 |
$ |
|
1490 | $ try --optimize '2:0 & present(0 + 1 + 2)' | |
@@ -1662,9 +1711,10 ordering defined by it. | |||||
1662 |
|
|
1711 | <spanset- 0:2>> | |
1663 | 1 |
|
1712 | 1 | |
1664 |
|
1713 | |||
1665 |
|
|
1714 | 'A & B' can be rewritten as 'B & A' by weight, but that's fine as long as | |
1666 | be determined before the optimization (i.e. 'B' should take the ordering of |
|
1715 | the ordering rule is determined before the rewrite; in this example, | |
1667 | 'A'): |
|
1716 | 'B' follows the order of the initial set, which is the same order as 'A' | |
|
1717 | since 'A' also follows the order: | |||
1668 |
|
1718 | |||
1669 | $ try --optimize 'contains("glob:*") & (2 + 0 + 1)' |
|
1719 | $ try --optimize 'contains("glob:*") & (2 + 0 + 1)' | |
1670 | (and |
|
1720 | (and | |
@@ -1690,12 +1740,14 ordering defined by it. | |||||
1690 | define) |
|
1740 | define) | |
1691 | * set: |
|
1741 | * set: | |
1692 | <filteredset |
|
1742 | <filteredset | |
1693 |
<baseset [ |
|
1743 | <baseset+ [0, 1, 2]>, | |
1694 | <contains 'glob:*'>> |
|
1744 | <contains 'glob:*'>> | |
1695 | 2 |
|
|||
1696 | 0 |
|
1745 | 0 | |
1697 | 1 |
|
1746 | 1 | |
1698 | BROKEN: should be '0 1 2' |
|
1747 | 2 | |
|
1748 | ||||
|
1749 | and in this example, 'A & B' is rewritten as 'B & A', but 'A' overrides | |||
|
1750 | the order appropriately: | |||
1699 |
|
1751 | |||
1700 | $ try --optimize 'reverse(contains("glob:*")) & (0 + 2 + 1)' |
|
1752 | $ try --optimize 'reverse(contains("glob:*")) & (0 + 2 + 1)' | |
1701 | (and |
|
1753 | (and | |
@@ -1726,12 +1778,11 ordering defined by it. | |||||
1726 | define) |
|
1778 | define) | |
1727 | * set: |
|
1779 | * set: | |
1728 | <filteredset |
|
1780 | <filteredset | |
1729 |
<baseset [1, 2 |
|
1781 | <baseset- [0, 1, 2]>, | |
1730 | <contains 'glob:*'>> |
|
1782 | <contains 'glob:*'>> | |
|
1783 | 2 | |||
1731 | 1 |
|
1784 | 1 | |
1732 | 2 |
|
|||
1733 | 0 |
|
1785 | 0 | |
1734 | BROKEN: should be '2 1 0' |
|
|||
1735 |
|
1786 | |||
1736 | test sort revset |
|
1787 | test sort revset | |
1737 | -------------------------------------------- |
|
1788 | -------------------------------------------- |
General Comments 0
You need to be logged in to leave comments.
Login now