lnav/test/drive_sequencer.cc

137 lines
2.5 KiB
C++
Raw Normal View History

2011-06-01 14:28:46 +00:00
#include "config.h"
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <sys/types.h>
#include <sys/stat.h>
2011-06-06 02:05:46 +00:00
#include <fcntl.h>
2011-06-01 14:28:46 +00:00
#include <unistd.h>
#include <string.h>
#include <openssl/sha.h>
#include <map>
#include <list>
#include <vector>
#include <algorithm>
#include "pcrepp.hh"
#include "logfile.hh"
2011-06-06 02:05:46 +00:00
#include "sequence_sink.hh"
#include "sequence_matcher.hh"
2011-06-01 14:28:46 +00:00
using namespace std;
2011-06-06 02:05:46 +00:00
class my_source : public grep_proc_source {
2011-06-01 14:28:46 +00:00
public:
2011-06-06 02:05:46 +00:00
my_source(auto_fd &fd) : ms_offset(0) {
this->ms_buffer.set_fd(fd);
};
2011-06-01 14:28:46 +00:00
2011-06-06 02:05:46 +00:00
bool grep_value_for_line(int line_number, string &value_out) {
bool retval = false;
2011-06-01 14:28:46 +00:00
2011-06-06 02:05:46 +00:00
try {
size_t len;
char *line;
if ((line = this->ms_buffer.read_line(this->ms_offset,
len)) != NULL) {
value_out = string(line, len);
retval = true;
}
}
catch (line_buffer::error &e) {
fprintf(stderr,
"error: source buffer error %d %s\n",
this->ms_buffer.get_fd(),
strerror(e.e_err));
}
return retval;
2011-06-01 14:28:46 +00:00
};
2011-06-06 02:05:46 +00:00
private:
line_buffer ms_buffer;
off_t ms_offset;
2011-06-01 14:28:46 +00:00
2011-06-06 02:05:46 +00:00
};
2011-06-01 14:28:46 +00:00
2011-06-06 02:05:46 +00:00
int main(int argc, char *argv[])
{
int c, retval = EXIT_SUCCESS;
const char *errptr;
auto_fd fd;
pcre *code;
int eoff;
if (argc < 3) {
fprintf(stderr, "error: expecting pattern and file arguments\n");
retval = EXIT_FAILURE;
}
else if ((fd = open(argv[2], O_RDONLY)) == -1) {
perror("open");
retval = EXIT_FAILURE;
}
else if ((code = pcre_compile(argv[1],
PCRE_CASELESS,
&errptr,
&eoff,
NULL)) == NULL) {
fprintf(stderr, "error: invalid pattern -- %s\n", errptr);
}
else {
my_source ms(fd);
fd_set read_fds;
int maxfd;
sequence_matcher::field_col_t fc;
fc.resize(2);
sequence_matcher::field_row_t &frf = fc.front();
frf.resize(2);
frf[0] = "eth0";
frf[1] = "eth0";
2011-06-01 14:28:46 +00:00
2011-06-06 02:05:46 +00:00
sequence_matcher::field_row_t &frb = fc.back();
frb.resize(2);
frb[0] = "up";
frb[1] = "down";
2011-06-01 14:28:46 +00:00
2011-06-06 02:05:46 +00:00
static bookmark_type_t SEQUENCE;
sequence_matcher sm(fc);
bookmarks bm;
sequence_sink ss(sm, bm[&SEQUENCE]);
FD_ZERO(&read_fds);
grep_proc gp(code, ms, maxfd, read_fds);
gp.queue_request();
gp.start();
gp.set_sink(&ss);
2011-06-01 14:28:46 +00:00
2011-06-06 02:05:46 +00:00
while (bm[&SEQUENCE].size() == 0) {
fd_set rfds = read_fds;
2011-06-01 14:28:46 +00:00
2011-06-06 02:05:46 +00:00
select(maxfd + 1, &rfds, NULL, NULL, NULL);
gp.check_fd_set(rfds);
2011-06-01 14:28:46 +00:00
}
2011-06-06 02:05:46 +00:00
for (bookmark_vector::iterator iter = bm[&SEQUENCE].begin();
iter != bm[&SEQUENCE].end();
++iter) {
printf("%d\n", (const int)*iter);
}
}
2011-06-01 14:28:46 +00:00
2011-06-06 02:05:46 +00:00
return retval;
2011-06-01 14:28:46 +00:00
}