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 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125
|
// Copyright (C) 2011, 2012, 2015 D. V. Wiebe
//
///////////////////////////////////////////////////////////////////////////
//
// This file is part of the GetData project.
//
// GetData is free software; you can redistribute it and/or modify it under
// the terms of the GNU Lesser General Public License as published by the
// Free Software Foundation; either version 2.1 of the License, or (at your
// option) any later version.
//
// GetData is distributed in the hope that it will be useful, but WITHOUT
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
// FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
// License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with GetData; if not, write to the Free Software Foundation, Inc.,
// 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
//
#include "internal.h"
WindowEntry::WindowEntry(const char* field_code, const char* in_field,
const char* check, WindOpType windop, gd_triplet_t threshold,
int fragment_index) : Entry()
{
dtrace("\"%s\", \"%s\", \"%s\", %i, {%g,%" PRIX64 ",%" PRId64 "}, %i",
field_code, in_field, check, (unsigned)windop, threshold.r, threshold.u,
threshold.i, fragment_index);
E.field = strdup(field_code);
E.field_type = GD_WINDOW_ENTRY;
E.in_fields[0] = strdup(in_field);
E.in_fields[1] = strdup(check);
E.scalar[0] = 0;
E.u.window.windop = (gd_windop_t)windop;
E.u.window.threshold = threshold;
E.fragment_index = fragment_index;
dreturnvoid();
}
int WindowEntry::SetInput(const char* field, int index)
{
if (index < 0 || index > 1)
return -1;
char* ptr = strdup(field);
if (ptr == NULL)
return -1;
free(E.in_fields[index]);
E.in_fields[index] = ptr;
if (D != NULL)
return gd_alter_entry(D->D, E.field, &E, 0);
return 0;
}
int WindowEntry::SetWindOp(WindOpType windop)
{
int ret = 0;
dtrace("0x%X", (unsigned)windop);
E.u.window.windop = (gd_windop_t)windop;
if (D != NULL)
ret = gd_alter_entry(D->D, E.field, &E, 0);
dreturn("%i", ret);
return ret;
}
int WindowEntry::SetThreshold(gd_triplet_t threshold)
{
int ret = 0;
dtrace("{%g,%" PRIX64 ",%" PRId64 "}", threshold.r, threshold.u, threshold.i);
E.u.window.threshold = threshold;
if (D != NULL)
ret = gd_alter_entry(D->D, E.field, &E, 0);
dreturn("%i", ret);
return ret;
}
int WindowEntry::SetThreshold(const char *threshold)
{
int r = 0;
dtrace("\"%s\"", threshold);
SetScalar(0, threshold);
if (D != NULL) {
r = gd_alter_entry(D->D, E.field, &E, 0);
if (!r) {
switch(E.u.window.windop) {
case GD_WINDOP_EQ:
case GD_WINDOP_NE:
r = gd_get_constant(D->D, threshold, GD_INT64,
&E.u.window.threshold.i);
break;
case GD_WINDOP_SET:
case GD_WINDOP_CLR:
r = gd_get_constant(D->D, threshold, GD_UINT64,
&E.u.window.threshold.u);
break;
default:
r = gd_get_constant(D->D, threshold, GD_FLOAT64,
&E.u.window.threshold.r);
break;
}
}
}
dreturn("%i", r);
return r;
}
|