A platform for high-performance distributed tool and library development written in C++. It can be deployed in two different cluster modes: standalone or distributed. API for v0.5.0, released on June 13, 2018.
Main Page
Namespaces
Classes
Files
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
ComputeSink.h
Go to the documentation of this file.
1
/*****************************************************************************
2
* *
3
* Copyright 2018 Rice University *
4
* *
5
* Licensed under the Apache License, Version 2.0 (the "License"); *
6
* you may not use this file except in compliance with the License. *
7
* You may obtain a copy of the License at *
8
* *
9
* http://www.apache.org/licenses/LICENSE-2.0 *
10
* *
11
* Unless required by applicable law or agreed to in writing, software *
12
* distributed under the License is distributed on an "AS IS" BASIS, *
13
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *
14
* See the License for the specific language governing permissions and *
15
* limitations under the License. *
16
* *
17
*****************************************************************************/
18
19
#ifndef COMPUTE_SINK_H
20
#define COMPUTE_SINK_H
21
22
#include "
Object.h
"
23
#include "
TupleSet.h
"
24
25
namespace
pdb {
26
27
class
ComputeSink
;
28
typedef
std::shared_ptr<ComputeSink>
ComputeSinkPtr
;
29
30
// this class encapsulates a destination for a set of TupleSet objects. It may represent
31
// a hash table that a bunch of objects are being written to, or it may represent secondary
32
// storage where we are writing the output of a query
33
class
ComputeSink
{
34
35
public
:
36
// this creates and returns a new output containter to write to
37
virtual
Handle<Object>
createNewOutputContainer
() = 0;
38
39
// this writes the tuple set into the output container
40
virtual
void
writeOut
(
TupleSetPtr
writeMe,
Handle<Object>
& writeToMe) = 0;
41
42
virtual
~ComputeSink
() {}
43
};
44
}
45
46
#endif
pdb::ComputeSink
Definition:
ComputeSink.h:33
pdb::ComputeSink::~ComputeSink
virtual ~ComputeSink()
Definition:
ComputeSink.h:42
pdb::ComputeSinkPtr
std::shared_ptr< ComputeSink > ComputeSinkPtr
Definition:
ComputeSink.h:27
pdb::TupleSetPtr
std::shared_ptr< TupleSet > TupleSetPtr
Definition:
TupleSet.h:64
Object.h
pdb::ComputeSink::createNewOutputContainer
virtual Handle< Object > createNewOutputContainer()=0
pdb::ComputeSink::writeOut
virtual void writeOut(TupleSetPtr writeMe, Handle< Object > &writeToMe)=0
TupleSet.h
pdb::Handle
Definition:
Allocator.h:399
plinycompute
pdb
src
pipeline
headers
ComputeSink.h
Generated on Mon Jun 18 2018 18:10:36 by
1.8.6