Loading...
Searching...
No Matches
compare.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2003-2023, John Wiegley. All rights reserved.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
6 * met:
7 *
8 * - Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 *
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 *
15 * - Neither the name of New Artisans LLC nor the names of its
16 * contributors may be used to endorse or promote products derived from
17 * this software without specific prior written permission.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
23 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 */
31
42#pragma once
43
44#include "expr.h"
45
46namespace ledger {
47
48class post_t;
49class account_t;
50class report_t;
51
52void push_sort_value(std::list<sort_value_t>& sort_values,
54
55template <typename T>
57{
58 expr_t sort_order;
59 report_t& report;
60
62
63public:
65 sort_order(_sort_order), report(_report) {
66 TRACE_CTOR(compare_items, "const value_expr&, report_t&");
67 }
69 sort_order(other.sort_order), report(other.report) {
71 }
75
76 void find_sort_values(std::list<sort_value_t>& sort_values, scope_t& scope);
77
78 bool operator()(T * left, T * right);
79};
80
82
83template <typename T>
84bool compare_items<T>::operator()(T * left, T * right)
85{
86 assert(left); assert(right);
87 return sort_value_is_less_than(find_sort_values(left),
88 find_sort_values(right));
89}
90
91template <>
93template <>
95 account_t * right);
96
97} // namespace ledger
#define TRACE_DTOR(cls)
Definition utils.h:144
#define TRACE_CTOR(cls, args)
Definition utils.h:143
#define assert(x)
Definition utils.h:92
sort_value_t calc_sort_value(const expr_t::ptr_op_t op)
void push_sort_value(std::list< sort_value_t > &sort_values, expr_t::ptr_op_t node, scope_t &scope)
T & downcast(U &object)
Definition utils.h:468
bool sort_value_is_less_than(const std::list< sort_value_t > &left_values, const std::list< sort_value_t > &right_values)
bool operator()(T *left, T *right)
Definition compare.h:84
void find_sort_values(std::list< sort_value_t > &sort_values, scope_t &scope)
compare_items(const compare_items &other)
Definition compare.h:68
compare_items(const expr_t &_sort_order, report_t &_report)
Definition compare.h:64
intrusive_ptr< op_t > ptr_op_t
Definition expr.h:57