Show More
@@ -92,7 +92,7 o (0) root | |||||
92 | > if opts.get('print_revset'): |
|
92 | > if opts.get('print_revset'): | |
93 | > expr = graphlog.revset(repo, pats, opts)[0] |
|
93 | > expr = graphlog.revset(repo, pats, opts)[0] | |
94 | > tree = revset.parse(expr)[0] |
|
94 | > tree = revset.parse(expr)[0] | |
95 | > ui.write(tree, "\n") |
|
95 | > ui.write(revset.prettyformat(tree), "\n") | |
96 | > return 0 |
|
96 | > return 0 | |
97 | > return orig(ui, repo, *pats, **opts) |
|
97 | > return orig(ui, repo, *pats, **opts) | |
98 | > entry = extensions.wrapcommand(commands.table, 'log', printrevset) |
|
98 | > entry = extensions.wrapcommand(commands.table, 'log', printrevset) | |
@@ -1430,7 +1430,19 Test log -G options | |||||
1430 | glog always reorders nodes which explains the difference with log |
|
1430 | glog always reorders nodes which explains the difference with log | |
1431 |
|
1431 | |||
1432 | $ testlog -r 27 -r 25 -r 21 -r 34 -r 32 -r 31 |
|
1432 | $ testlog -r 27 -r 25 -r 21 -r 34 -r 32 -r 31 | |
1433 | ('group', ('group', ('or', ('or', ('or', ('or', ('or', ('symbol', '27'), ('symbol', '25')), ('symbol', '21')), ('symbol', '34')), ('symbol', '32')), ('symbol', '31')))) |
|
1433 | (group | |
|
1434 | (group | |||
|
1435 | (or | |||
|
1436 | (or | |||
|
1437 | (or | |||
|
1438 | (or | |||
|
1439 | (or | |||
|
1440 | ('symbol', '27') | |||
|
1441 | ('symbol', '25')) | |||
|
1442 | ('symbol', '21')) | |||
|
1443 | ('symbol', '34')) | |||
|
1444 | ('symbol', '32')) | |||
|
1445 | ('symbol', '31')))) | |||
1434 | --- log.nodes * (glob) |
|
1446 | --- log.nodes * (glob) | |
1435 | +++ glog.nodes * (glob) |
|
1447 | +++ glog.nodes * (glob) | |
1436 | @@ -1,6 +1,6 @@ |
|
1448 | @@ -1,6 +1,6 @@ | |
@@ -1445,26 +1457,84 glog always reorders nodes which explain | |||||
1445 | +nodetag 21 |
|
1457 | +nodetag 21 | |
1446 | [1] |
|
1458 | [1] | |
1447 | $ testlog -u test -u not-a-user |
|
1459 | $ testlog -u test -u not-a-user | |
1448 | ('group', ('group', ('or', ('func', ('symbol', 'user'), ('string', 'test')), ('func', ('symbol', 'user'), ('string', 'not-a-user'))))) |
|
1460 | (group | |
|
1461 | (group | |||
|
1462 | (or | |||
|
1463 | (func | |||
|
1464 | ('symbol', 'user') | |||
|
1465 | ('string', 'test')) | |||
|
1466 | (func | |||
|
1467 | ('symbol', 'user') | |||
|
1468 | ('string', 'not-a-user'))))) | |||
1449 | $ testlog -b not-a-branch |
|
1469 | $ testlog -b not-a-branch | |
1450 | ('group', ('group', ('func', ('symbol', 'branch'), ('string', 'not-a-branch')))) |
|
1470 | (group | |
|
1471 | (group | |||
|
1472 | (func | |||
|
1473 | ('symbol', 'branch') | |||
|
1474 | ('string', 'not-a-branch')))) | |||
1451 | abort: unknown revision 'not-a-branch'! |
|
1475 | abort: unknown revision 'not-a-branch'! | |
1452 | abort: unknown revision 'not-a-branch'! |
|
1476 | abort: unknown revision 'not-a-branch'! | |
1453 | $ testlog -b default -b branch --only-branch branch |
|
1477 | $ testlog -b default -b branch --only-branch branch | |
1454 | ('group', ('group', ('or', ('or', ('func', ('symbol', 'branch'), ('string', 'default')), ('func', ('symbol', 'branch'), ('string', 'branch'))), ('func', ('symbol', 'branch'), ('string', 'branch'))))) |
|
1478 | (group | |
|
1479 | (group | |||
|
1480 | (or | |||
|
1481 | (or | |||
|
1482 | (func | |||
|
1483 | ('symbol', 'branch') | |||
|
1484 | ('string', 'default')) | |||
|
1485 | (func | |||
|
1486 | ('symbol', 'branch') | |||
|
1487 | ('string', 'branch'))) | |||
|
1488 | (func | |||
|
1489 | ('symbol', 'branch') | |||
|
1490 | ('string', 'branch'))))) | |||
1455 | $ testlog -k expand -k merge |
|
1491 | $ testlog -k expand -k merge | |
1456 | ('group', ('group', ('or', ('func', ('symbol', 'keyword'), ('string', 'expand')), ('func', ('symbol', 'keyword'), ('string', 'merge'))))) |
|
1492 | (group | |
|
1493 | (group | |||
|
1494 | (or | |||
|
1495 | (func | |||
|
1496 | ('symbol', 'keyword') | |||
|
1497 | ('string', 'expand')) | |||
|
1498 | (func | |||
|
1499 | ('symbol', 'keyword') | |||
|
1500 | ('string', 'merge'))))) | |||
1457 | $ testlog --only-merges |
|
1501 | $ testlog --only-merges | |
1458 | ('group', ('func', ('symbol', 'merge'), None)) |
|
1502 | (group | |
|
1503 | (func | |||
|
1504 | ('symbol', 'merge') | |||
|
1505 | None)) | |||
1459 | $ testlog --no-merges |
|
1506 | $ testlog --no-merges | |
1460 | ('group', ('not', ('func', ('symbol', 'merge'), None))) |
|
1507 | (group | |
|
1508 | (not | |||
|
1509 | (func | |||
|
1510 | ('symbol', 'merge') | |||
|
1511 | None))) | |||
1461 | $ testlog --date '2 0 to 4 0' |
|
1512 | $ testlog --date '2 0 to 4 0' | |
1462 | ('group', ('func', ('symbol', 'date'), ('string', '2 0 to 4 0'))) |
|
1513 | (group | |
|
1514 | (func | |||
|
1515 | ('symbol', 'date') | |||
|
1516 | ('string', '2 0 to 4 0'))) | |||
1463 | $ hg log -G -d 'brace ) in a date' |
|
1517 | $ hg log -G -d 'brace ) in a date' | |
1464 | abort: invalid date: 'brace ) in a date' |
|
1518 | abort: invalid date: 'brace ) in a date' | |
1465 | [255] |
|
1519 | [255] | |
1466 | $ testlog --prune 31 --prune 32 |
|
1520 | $ testlog --prune 31 --prune 32 | |
1467 | ('group', ('group', ('and', ('not', ('group', ('or', ('string', '31'), ('func', ('symbol', 'ancestors'), ('string', '31'))))), ('not', ('group', ('or', ('string', '32'), ('func', ('symbol', 'ancestors'), ('string', '32')))))))) |
|
1521 | (group | |
|
1522 | (group | |||
|
1523 | (and | |||
|
1524 | (not | |||
|
1525 | (group | |||
|
1526 | (or | |||
|
1527 | ('string', '31') | |||
|
1528 | (func | |||
|
1529 | ('symbol', 'ancestors') | |||
|
1530 | ('string', '31'))))) | |||
|
1531 | (not | |||
|
1532 | (group | |||
|
1533 | (or | |||
|
1534 | ('string', '32') | |||
|
1535 | (func | |||
|
1536 | ('symbol', 'ancestors') | |||
|
1537 | ('string', '32')))))))) | |||
1468 |
|
1538 | |||
1469 | Dedicated repo for --follow and paths filtering. The g is crafted to |
|
1539 | Dedicated repo for --follow and paths filtering. The g is crafted to | |
1470 | have 2 filelog topological heads in a linear changeset graph. |
|
1540 | have 2 filelog topological heads in a linear changeset graph. | |
@@ -1507,19 +1577,55 have 2 filelog topological heads in a li | |||||
1507 |
|
1577 | |||
1508 |
|
1578 | |||
1509 | $ testlog a |
|
1579 | $ testlog a | |
1510 | ('group', ('group', ('func', ('symbol', 'filelog'), ('string', 'a')))) |
|
1580 | (group | |
|
1581 | (group | |||
|
1582 | (func | |||
|
1583 | ('symbol', 'filelog') | |||
|
1584 | ('string', 'a')))) | |||
1511 | $ testlog a b |
|
1585 | $ testlog a b | |
1512 | ('group', ('group', ('or', ('func', ('symbol', 'filelog'), ('string', 'a')), ('func', ('symbol', 'filelog'), ('string', 'b'))))) |
|
1586 | (group | |
|
1587 | (group | |||
|
1588 | (or | |||
|
1589 | (func | |||
|
1590 | ('symbol', 'filelog') | |||
|
1591 | ('string', 'a')) | |||
|
1592 | (func | |||
|
1593 | ('symbol', 'filelog') | |||
|
1594 | ('string', 'b'))))) | |||
1513 |
|
1595 | |||
1514 | Test falling back to slow path for non-existing files |
|
1596 | Test falling back to slow path for non-existing files | |
1515 |
|
1597 | |||
1516 | $ testlog a c |
|
1598 | $ testlog a c | |
1517 | ('group', ('group', ('func', ('symbol', '_matchfiles'), ('list', ('list', ('string', 'r:'), ('string', 'p:a')), ('string', 'p:c'))))) |
|
1599 | (group | |
|
1600 | (group | |||
|
1601 | (func | |||
|
1602 | ('symbol', '_matchfiles') | |||
|
1603 | (list | |||
|
1604 | (list | |||
|
1605 | ('string', 'r:') | |||
|
1606 | ('string', 'p:a')) | |||
|
1607 | ('string', 'p:c'))))) | |||
1518 |
|
1608 | |||
1519 | Test multiple --include/--exclude/paths |
|
1609 | Test multiple --include/--exclude/paths | |
1520 |
|
1610 | |||
1521 | $ testlog --include a --include e --exclude b --exclude e a e |
|
1611 | $ testlog --include a --include e --exclude b --exclude e a e | |
1522 | ('group', ('group', ('func', ('symbol', '_matchfiles'), ('list', ('list', ('list', ('list', ('list', ('list', ('string', 'r:'), ('string', 'p:a')), ('string', 'p:e')), ('string', 'i:a')), ('string', 'i:e')), ('string', 'x:b')), ('string', 'x:e'))))) |
|
1612 | (group | |
|
1613 | (group | |||
|
1614 | (func | |||
|
1615 | ('symbol', '_matchfiles') | |||
|
1616 | (list | |||
|
1617 | (list | |||
|
1618 | (list | |||
|
1619 | (list | |||
|
1620 | (list | |||
|
1621 | (list | |||
|
1622 | ('string', 'r:') | |||
|
1623 | ('string', 'p:a')) | |||
|
1624 | ('string', 'p:e')) | |||
|
1625 | ('string', 'i:a')) | |||
|
1626 | ('string', 'i:e')) | |||
|
1627 | ('string', 'x:b')) | |||
|
1628 | ('string', 'x:e'))))) | |||
1523 |
|
1629 | |||
1524 | Test glob expansion of pats |
|
1630 | Test glob expansion of pats | |
1525 |
|
1631 | |||
@@ -1530,7 +1636,11 Test glob expansion of pats | |||||
1530 | > else |
|
1636 | > else | |
1531 | > testlog a*; |
|
1637 | > testlog a*; | |
1532 | > fi; |
|
1638 | > fi; | |
1533 | ('group', ('group', ('func', ('symbol', 'filelog'), ('string', 'aa')))) |
|
1639 | (group | |
|
1640 | (group | |||
|
1641 | (func | |||
|
1642 | ('symbol', 'filelog') | |||
|
1643 | ('string', 'aa')))) | |||
1534 |
|
1644 | |||
1535 | Test --follow on a directory |
|
1645 | Test --follow on a directory | |
1536 |
|
1646 | |||
@@ -1557,26 +1667,42 Test --follow on a single rename | |||||
1557 |
|
1667 | |||
1558 | $ hg up -q 2 |
|
1668 | $ hg up -q 2 | |
1559 | $ testlog -f a |
|
1669 | $ testlog -f a | |
1560 | ('group', ('group', ('func', ('symbol', 'follow'), ('string', 'a')))) |
|
1670 | (group | |
|
1671 | (group | |||
|
1672 | (func | |||
|
1673 | ('symbol', 'follow') | |||
|
1674 | ('string', 'a')))) | |||
1561 |
|
1675 | |||
1562 | Test --follow and multiple renames |
|
1676 | Test --follow and multiple renames | |
1563 |
|
1677 | |||
1564 | $ hg up -q tip |
|
1678 | $ hg up -q tip | |
1565 | $ testlog -f e |
|
1679 | $ testlog -f e | |
1566 | ('group', ('group', ('func', ('symbol', 'follow'), ('string', 'e')))) |
|
1680 | (group | |
|
1681 | (group | |||
|
1682 | (func | |||
|
1683 | ('symbol', 'follow') | |||
|
1684 | ('string', 'e')))) | |||
1567 |
|
1685 | |||
1568 | Test --follow and multiple filelog heads |
|
1686 | Test --follow and multiple filelog heads | |
1569 |
|
1687 | |||
1570 | $ hg up -q 2 |
|
1688 | $ hg up -q 2 | |
1571 | $ testlog -f g |
|
1689 | $ testlog -f g | |
1572 | ('group', ('group', ('func', ('symbol', 'follow'), ('string', 'g')))) |
|
1690 | (group | |
|
1691 | (group | |||
|
1692 | (func | |||
|
1693 | ('symbol', 'follow') | |||
|
1694 | ('string', 'g')))) | |||
1573 | $ cat log.nodes |
|
1695 | $ cat log.nodes | |
1574 | nodetag 2 |
|
1696 | nodetag 2 | |
1575 | nodetag 1 |
|
1697 | nodetag 1 | |
1576 | nodetag 0 |
|
1698 | nodetag 0 | |
1577 | $ hg up -q tip |
|
1699 | $ hg up -q tip | |
1578 | $ testlog -f g |
|
1700 | $ testlog -f g | |
1579 | ('group', ('group', ('func', ('symbol', 'follow'), ('string', 'g')))) |
|
1701 | (group | |
|
1702 | (group | |||
|
1703 | (func | |||
|
1704 | ('symbol', 'follow') | |||
|
1705 | ('string', 'g')))) | |||
1580 | $ cat log.nodes |
|
1706 | $ cat log.nodes | |
1581 | nodetag 3 |
|
1707 | nodetag 3 | |
1582 | nodetag 2 |
|
1708 | nodetag 2 | |
@@ -1585,7 +1711,15 Test --follow and multiple filelog heads | |||||
1585 | Test --follow and multiple files |
|
1711 | Test --follow and multiple files | |
1586 |
|
1712 | |||
1587 | $ testlog -f g e |
|
1713 | $ testlog -f g e | |
1588 | ('group', ('group', ('or', ('func', ('symbol', 'follow'), ('string', 'g')), ('func', ('symbol', 'follow'), ('string', 'e'))))) |
|
1714 | (group | |
|
1715 | (group | |||
|
1716 | (or | |||
|
1717 | (func | |||
|
1718 | ('symbol', 'follow') | |||
|
1719 | ('string', 'g')) | |||
|
1720 | (func | |||
|
1721 | ('symbol', 'follow') | |||
|
1722 | ('string', 'e'))))) | |||
1589 | $ cat log.nodes |
|
1723 | $ cat log.nodes | |
1590 | nodetag 4 |
|
1724 | nodetag 4 | |
1591 | nodetag 3 |
|
1725 | nodetag 3 | |
@@ -1605,12 +1739,19 Test --follow-first | |||||
1605 | $ echo merge > e |
|
1739 | $ echo merge > e | |
1606 | $ hg ci -m "merge 5 and 4" |
|
1740 | $ hg ci -m "merge 5 and 4" | |
1607 | $ testlog --follow-first |
|
1741 | $ testlog --follow-first | |
1608 | ('group', ('func', ('symbol', '_followfirst'), None)) |
|
1742 | (group | |
|
1743 | (func | |||
|
1744 | ('symbol', '_followfirst') | |||
|
1745 | None)) | |||
1609 |
|
1746 | |||
1610 | Cannot compare with log --follow-first FILE as it never worked |
|
1747 | Cannot compare with log --follow-first FILE as it never worked | |
1611 |
|
1748 | |||
1612 | $ hg log -G --print-revset --follow-first e |
|
1749 | $ hg log -G --print-revset --follow-first e | |
1613 | ('group', ('group', ('func', ('symbol', '_followfirst'), ('string', 'e')))) |
|
1750 | (group | |
|
1751 | (group | |||
|
1752 | (func | |||
|
1753 | ('symbol', '_followfirst') | |||
|
1754 | ('string', 'e')))) | |||
1614 | $ hg log -G --follow-first e --template '{rev} {desc|firstline}\n' |
|
1755 | $ hg log -G --follow-first e --template '{rev} {desc|firstline}\n' | |
1615 | @ 6 merge 5 and 4 |
|
1756 | @ 6 merge 5 and 4 | |
1616 | |\ |
|
1757 | |\ | |
@@ -1639,18 +1780,47 Test "set:..." and parent revision | |||||
1639 |
|
1780 | |||
1640 | $ hg up -q 4 |
|
1781 | $ hg up -q 4 | |
1641 | $ testlog "set:copied()" |
|
1782 | $ testlog "set:copied()" | |
1642 | ('group', ('group', ('func', ('symbol', '_matchfiles'), ('list', ('string', 'r:'), ('string', 'p:set:copied()'))))) |
|
1783 | (group | |
|
1784 | (group | |||
|
1785 | (func | |||
|
1786 | ('symbol', '_matchfiles') | |||
|
1787 | (list | |||
|
1788 | ('string', 'r:') | |||
|
1789 | ('string', 'p:set:copied()'))))) | |||
1643 | $ testlog --include "set:copied()" |
|
1790 | $ testlog --include "set:copied()" | |
1644 | ('group', ('group', ('func', ('symbol', '_matchfiles'), ('list', ('string', 'r:'), ('string', 'i:set:copied()'))))) |
|
1791 | (group | |
|
1792 | (group | |||
|
1793 | (func | |||
|
1794 | ('symbol', '_matchfiles') | |||
|
1795 | (list | |||
|
1796 | ('string', 'r:') | |||
|
1797 | ('string', 'i:set:copied()'))))) | |||
1645 | $ testlog -r "sort(file('set:copied()'), -rev)" |
|
1798 | $ testlog -r "sort(file('set:copied()'), -rev)" | |
1646 | ('group', ('group', ('func', ('symbol', 'sort'), ('list', ('func', ('symbol', 'file'), ('string', 'set:copied()')), ('negate', ('symbol', 'rev')))))) |
|
1799 | (group | |
|
1800 | (group | |||
|
1801 | (func | |||
|
1802 | ('symbol', 'sort') | |||
|
1803 | (list | |||
|
1804 | (func | |||
|
1805 | ('symbol', 'file') | |||
|
1806 | ('string', 'set:copied()')) | |||
|
1807 | (negate | |||
|
1808 | ('symbol', 'rev')))))) | |||
1647 |
|
1809 | |||
1648 | Test --removed |
|
1810 | Test --removed | |
1649 |
|
1811 | |||
1650 | $ testlog --removed |
|
1812 | $ testlog --removed | |
1651 | ('func', ('symbol', 'all'), None) |
|
1813 | (func | |
|
1814 | ('symbol', 'all') | |||
|
1815 | None) | |||
1652 | $ testlog --removed a |
|
1816 | $ testlog --removed a | |
1653 | ('group', ('group', ('func', ('symbol', '_matchfiles'), ('list', ('string', 'r:'), ('string', 'p:a'))))) |
|
1817 | (group | |
|
1818 | (group | |||
|
1819 | (func | |||
|
1820 | ('symbol', '_matchfiles') | |||
|
1821 | (list | |||
|
1822 | ('string', 'r:') | |||
|
1823 | ('string', 'p:a'))))) | |||
1654 | $ testlog --removed --follow a |
|
1824 | $ testlog --removed --follow a | |
1655 | abort: can only follow copies/renames for explicit filenames |
|
1825 | abort: can only follow copies/renames for explicit filenames | |
1656 | abort: can only follow copies/renames for explicit filenames |
|
1826 | abort: can only follow copies/renames for explicit filenames |
General Comments 0
You need to be logged in to leave comments.
Login now