- Notifications
You must be signed in to change notification settings - Fork5
Commit2f153dd
committed
Refactor to reduce code duplication for function property checking.
As noted by Andres Freund, we'd accumulated quite a few similar functionsin clauses.c that examine all functions in an expression tree to see ifthey satisfy some boolean test. Reduce the duplication by inventing afunction check_functions_in_node() that applies a simple callback functionto each SQL function OID appearing in a given expression node. This alsofixes some arguable oversights; for example, contain_mutable_functions()did not check aggregate or window functions for mutability. I doubt thatthat represents a live bug at the moment, because we don't really considermutability for aggregates; but it might someday be one.I chose to put check_functions_in_node() in nodeFuncs.c because it seemedlike other modules might wish to use it in future. That in turn forcedmoving set_opfuncid() et al into nodeFuncs.c, as the alternative was fornodeFuncs.c to depend on optimizer/setrefs.c which didn't seem very clean.In passing, teach contain_leaked_vars_walker() about a few more expressionnode types it can safely look through, and improve the rather messy andundercommented code in has_parallel_hazard_walker().Discussion: <20160527185853.ziol2os2zskahl7v@alap3.anarazel.de>1 parent13761bc commit2f153dd
File tree
7 files changed
+371
-575
lines changed- src
- backend
- nodes
- optimizer
- plan
- util
- utils/cache
- include
- nodes
- optimizer
7 files changed
+371
-575
lines changedLines changed: 178 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
27 | 27 |
| |
28 | 28 |
| |
29 | 29 |
| |
| 30 | + | |
30 | 31 |
| |
31 | 32 |
| |
32 | 33 |
| |
| |||
1559 | 1560 |
| |
1560 | 1561 |
| |
1561 | 1562 |
| |
| 1563 | + | |
| 1564 | + | |
| 1565 | + | |
| 1566 | + | |
| 1567 | + | |
| 1568 | + | |
| 1569 | + | |
| 1570 | + | |
| 1571 | + | |
| 1572 | + | |
| 1573 | + | |
| 1574 | + | |
| 1575 | + | |
| 1576 | + | |
| 1577 | + | |
| 1578 | + | |
| 1579 | + | |
| 1580 | + | |
| 1581 | + | |
| 1582 | + | |
| 1583 | + | |
| 1584 | + | |
| 1585 | + | |
| 1586 | + | |
| 1587 | + | |
| 1588 | + | |
| 1589 | + | |
| 1590 | + | |
| 1591 | + | |
| 1592 | + | |
| 1593 | + | |
| 1594 | + | |
| 1595 | + | |
| 1596 | + | |
| 1597 | + | |
| 1598 | + | |
| 1599 | + | |
| 1600 | + | |
| 1601 | + | |
| 1602 | + | |
| 1603 | + | |
| 1604 | + | |
| 1605 | + | |
| 1606 | + | |
| 1607 | + | |
| 1608 | + | |
| 1609 | + | |
| 1610 | + | |
| 1611 | + | |
| 1612 | + | |
| 1613 | + | |
| 1614 | + | |
| 1615 | + | |
| 1616 | + | |
| 1617 | + | |
| 1618 | + | |
| 1619 | + | |
| 1620 | + | |
| 1621 | + | |
| 1622 | + | |
| 1623 | + | |
| 1624 | + | |
| 1625 | + | |
| 1626 | + | |
| 1627 | + | |
| 1628 | + | |
| 1629 | + | |
| 1630 | + | |
| 1631 | + | |
| 1632 | + | |
| 1633 | + | |
| 1634 | + | |
| 1635 | + | |
| 1636 | + | |
| 1637 | + | |
| 1638 | + | |
| 1639 | + | |
| 1640 | + | |
| 1641 | + | |
| 1642 | + | |
| 1643 | + | |
| 1644 | + | |
| 1645 | + | |
| 1646 | + | |
| 1647 | + | |
| 1648 | + | |
| 1649 | + | |
| 1650 | + | |
| 1651 | + | |
| 1652 | + | |
| 1653 | + | |
| 1654 | + | |
| 1655 | + | |
| 1656 | + | |
| 1657 | + | |
| 1658 | + | |
| 1659 | + | |
| 1660 | + | |
| 1661 | + | |
| 1662 | + | |
| 1663 | + | |
| 1664 | + | |
| 1665 | + | |
| 1666 | + | |
| 1667 | + | |
| 1668 | + | |
| 1669 | + | |
| 1670 | + | |
| 1671 | + | |
| 1672 | + | |
| 1673 | + | |
| 1674 | + | |
| 1675 | + | |
| 1676 | + | |
| 1677 | + | |
| 1678 | + | |
| 1679 | + | |
| 1680 | + | |
| 1681 | + | |
| 1682 | + | |
| 1683 | + | |
| 1684 | + | |
| 1685 | + | |
| 1686 | + | |
| 1687 | + | |
| 1688 | + | |
| 1689 | + | |
| 1690 | + | |
| 1691 | + | |
| 1692 | + | |
| 1693 | + | |
| 1694 | + | |
| 1695 | + | |
| 1696 | + | |
| 1697 | + | |
| 1698 | + | |
| 1699 | + | |
| 1700 | + | |
| 1701 | + | |
| 1702 | + | |
| 1703 | + | |
| 1704 | + | |
| 1705 | + | |
| 1706 | + | |
| 1707 | + | |
| 1708 | + | |
| 1709 | + | |
| 1710 | + | |
| 1711 | + | |
| 1712 | + | |
| 1713 | + | |
| 1714 | + | |
| 1715 | + | |
| 1716 | + | |
| 1717 | + | |
| 1718 | + | |
| 1719 | + | |
| 1720 | + | |
| 1721 | + | |
| 1722 | + | |
| 1723 | + | |
| 1724 | + | |
| 1725 | + | |
| 1726 | + | |
| 1727 | + | |
| 1728 | + | |
| 1729 | + | |
| 1730 | + | |
| 1731 | + | |
| 1732 | + | |
| 1733 | + | |
| 1734 | + | |
| 1735 | + | |
| 1736 | + | |
| 1737 | + | |
| 1738 | + | |
| 1739 | + | |
1562 | 1740 |
| |
1563 | 1741 |
| |
1564 | 1742 |
| |
|
Lines changed: 0 additions & 63 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
147 | 147 |
| |
148 | 148 |
| |
149 | 149 |
| |
150 |
| - | |
151 | 150 |
| |
152 | 151 |
| |
153 | 152 |
| |
| |||
2556 | 2555 |
| |
2557 | 2556 |
| |
2558 | 2557 |
| |
2559 |
| - | |
2560 |
| - | |
2561 |
| - | |
2562 |
| - | |
2563 |
| - | |
2564 |
| - | |
2565 |
| - | |
2566 |
| - | |
2567 |
| - | |
2568 |
| - | |
2569 |
| - | |
2570 |
| - | |
2571 |
| - | |
2572 |
| - | |
2573 |
| - | |
2574 |
| - | |
2575 |
| - | |
2576 |
| - | |
2577 |
| - | |
2578 |
| - | |
2579 |
| - | |
2580 |
| - | |
2581 |
| - | |
2582 |
| - | |
2583 |
| - | |
2584 |
| - | |
2585 |
| - | |
2586 |
| - | |
2587 |
| - | |
2588 |
| - | |
2589 |
| - | |
2590 |
| - | |
2591 |
| - | |
2592 |
| - | |
2593 |
| - | |
2594 |
| - | |
2595 |
| - | |
2596 |
| - | |
2597 |
| - | |
2598 |
| - | |
2599 |
| - | |
2600 |
| - | |
2601 |
| - | |
2602 |
| - | |
2603 |
| - | |
2604 |
| - | |
2605 |
| - | |
2606 |
| - | |
2607 |
| - | |
2608 |
| - | |
2609 |
| - | |
2610 |
| - | |
2611 |
| - | |
2612 |
| - | |
2613 |
| - | |
2614 |
| - | |
2615 |
| - | |
2616 |
| - | |
2617 |
| - | |
2618 |
| - | |
2619 |
| - | |
2620 |
| - | |
2621 | 2558 |
| |
2622 | 2559 |
| |
2623 | 2560 |
| |
|
0 commit comments
Comments
(0)