forked from VowpalWabbit/vowpal_wabbit
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathparser.h
62 lines (50 loc) · 1.69 KB
/
parser.h
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
/*
Copyright (c) 2009 Yahoo! Inc. All rights reserved. The copyrights
embodied in the content of this file are licensed under the BSD
(revised) open source license
*/
#ifndef SCE
#define SCE
#include "io.h"
#include "global_data.h"
#include "parse_primitives.h"
#include "example.h"
struct label_parser {
void (*default_label)(void*);
void (*parse_label)(void*, v_array<substring>&);
void (*cache_label)(void*, io_buf& cache);
size_t (*read_cached_label)(void*, io_buf& cache);
void (*delete_label)(void*);
size_t label_size;
};
struct parser {
v_array<substring> channels;//helper(s) for text parsing
v_array<substring> words;
v_array<substring> name;
const label_parser* lp;
io_buf input; //Input source(s)
int (*reader)(parser* p, void* ae);
bool resettable; //Whether or not the input can be reset.
io_buf output; //Where to output the cache.
bool write_cache;
v_array<partial_example> pes;//partial examples
v_array<size_t> ids; //unique ids for sources
v_array<size_t> counts; //partial examples received from sources
size_t finished_count;//the number of finished examples;
int label_sock;
int max_fd;
};
parser* new_parser(const label_parser* lp);
#include <boost/program_options.hpp>
namespace po = boost::program_options;
void parse_source_args(po::variables_map& vm, parser* par, bool quiet, size_t passes);
//parser control
void start_parser(size_t num_threads, parser* pf);
void end_parser(parser* pf);
example* get_example(size_t thread_num);
void finish_example(example* ec);
//source control functions
bool inconsistent_cache(size_t numbits, io_buf& cache);
void reset_source(size_t numbits, parser* source);
void finalize_source(parser* source);
#endif