blob: 97dd6418e4812cd6baca562a49c8d4f9592d0d82 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
// Copyright 2017 Yahoo Holdings. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
#pragma once
#include "simplequerystackitem.h"
#include <vespa/searchlib/util/rawbuf.h>
#include <vespa/vespalib/stllike/string.h>
namespace search {
/**
* A stack of SimpleQueryStackItems.
*
* A simple stack consisting of a list of SimpleQueryStackItems.
* It is able to generate a binary encoding of itself
* to a RawBuf.
*/
class SimpleQueryStack
{
private:
/** The number of items on the stack. */
uint32_t _numItems;
/** The top of the stack.
* Warning: FastQT_ProximityEmul currently assumes this is the head
* of a singly linked list (linked with _next).
*/
SimpleQueryStackItem *_stack;
public:
SimpleQueryStack(const SimpleQueryStack &) = delete;
SimpleQueryStack& operator=(const SimpleQueryStack &) = delete;
/**
* Constructor for SimpleQueryStack.
*/
SimpleQueryStack();
/**
* Destructor for SimpleQueryStack.
*/
~SimpleQueryStack();
/**
* Push an item on the stack.
* @param item The SimpleQueryStackItem to push.
*/
void Push(SimpleQueryStackItem *item);
/**
* Encode the contents of the stack in a binary buffer.
* @param buf Pointer to a buffer containing the encoded contents.
*/
void AppendBuffer(RawBuf *buf) const;
/**
* Return the number of items on the stack.
* @return The number of items on the stack.
*/
uint32_t GetSize();
/**
* Set the number of items on the stack.
* This can be used by QTs that change the stack
* under the hood. Use with care!
* @param numItems The number of items on the stack.
*/
void SetSize(uint32_t numItems) { _numItems = numItems; }
};
} // namespace search
|