]> granicus.if.org Git - icinga2/blobdiff - plugins/thresholds.h
Change B/s unit to B to comply with Nagios plugin spec
[icinga2] / plugins / thresholds.h
index d55ed38c419f9b8cc82b4e79c310d8bd9e7af29a..039b22d584432308b5bfc858d1a1fcada8405217 100644 (file)
@@ -1,83 +1,70 @@
 /******************************************************************************
- * Icinga 2                                                                   *
- * Copyright (C) 2012-2014 Icinga Development Team (http://www.icinga.org)    *
- *                                                                            *
- * This program is free software; you can redistribute it and/or              *
- * modify it under the terms of the GNU General Public License                *
- * as published by the Free Software Foundation; either version 2             *
- * of the License, or (at your option) any later version.                     *
- *                                                                            *
- * This program 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 General Public License for more details.                               *
- *                                                                            *
- * You should have received a copy of the GNU General Public License          *
- * along with this program; if not, write to the Free Software Foundation     *
- * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.             *
- ******************************************************************************/
+* Icinga 2                                                                   *
+* Copyright (C) 2012-2015 Icinga Development Team (http://www.icinga.org)    *
+*                                                                            *
+* This program is free software; you can redistribute it and/or              *
+* modify it under the terms of the GNU General Public License                *
+* as published by the Free Software Foundation; either version 2             *
+* of the License, or (at your option) any later version.                     *
+*                                                                            *
+* This program 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 General Public License for more details.                               *
+*                                                                            *
+* You should have received a copy of the GNU General Public License          *
+* along with this program; if not, write to the Free Software Foundation     *
+* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.             *
+******************************************************************************/
 #ifndef THRESHOLDS_H
 #define THRESHOLDS_H
 #include <string>
+#include <Windows.h>
+#include <vector>
 
-enum Bunit { BunitB = 0, BunitkB = 1, BunitMB = 2, BunitGB = 3, BunitTB = 4 };
-enum Tunit { TunitMS, TunitS, TunitM, TunitH };
-enum state { OK = 0, WARNING = 1, CRITICAL = 2 };
+enum Bunit
+{
+       BunitB = 0, BunitkB = 1, BunitMB = 2, BunitGB = 3, BunitTB = 4
+};
+
+enum Tunit
+{
+       TunitMS, TunitS, TunitM, TunitH
+};
+
+enum state
+{
+       OK = 0, WARNING = 1, CRITICAL = 2
+};
 
 class threshold
 {
 public:
-       double lower, upper;
+       //DOUBLEs are always enough for ANY 64 bit value
+       DOUBLE lower, upper;
        //TRUE means everything BELOW upper/outside [lower-upper] is fine
-       bool legal, perc, set;
+       BOOL legal, perc, set;
+
+       threshold();
 
-       threshold(bool l = true)
-               : set(false), legal(l) {}
+       threshold(CONST DOUBLE v, CONST DOUBLE c, BOOL l = TRUE, BOOL p = FALSE);
 
-       threshold(const double v, const double c, bool l = true, bool p = false)
-               : lower(v), upper(c), legal(l), perc(p), set(true) {}
+       threshold(CONST std::wstring&);
 
        //return TRUE if the threshold is broken
-       bool rend(const double b)
-       {
-               if (!set)
-                       return set;
-               if (lower == upper)
-                       return b > upper == legal;
-               else
-                       return (b < lower || upper < b) != legal;
-       }
+       BOOL rend(CONST DOUBLE val, CONST DOUBLE max = 100.0);
 
        //returns a printable string of the threshold
-       std::wstring pString()
-       {
-               if (!set)
-                       return L"0";
+       std::wstring pString(CONST DOUBLE max = 100.0);
 
-               std::wstring s;
-               if (!legal)
-                       s.append(L"!");
-
-               if (lower != upper) {
-                       if (perc)
-                               s.append(L"[").append(std::to_wstring(lower)).append(L"%").append(L"-")
-                               .append(std::to_wstring(upper)).append(L"%").append(L"]");
-                       else
-                               s.append(L"[").append(std::to_wstring(lower)).append(L"-")
-                               .append(std::to_wstring(upper)).append(L"]");
-               } else {
-                       if (perc)
-                               s = std::to_wstring(lower).append(L"%");
-                       else
-                               s = std::to_wstring(lower);
-               }
-               return s;
-       }
 };
+std::wstring removeZero(DOUBLE);
+std::vector<std::wstring> splitMultiOptions(std::wstring);
+
+Bunit parseBUnit(CONST std::wstring&);
+std::wstring BunitStr(CONST Bunit&);
+Tunit parseTUnit(CONST std::wstring&);
+std::wstring TunitStr(CONST Tunit&);
 
-threshold parse(const std::wstring&);
-Bunit parseBUnit(const std::wstring&);
-std::wstring BunitStr(const Bunit&);
-Tunit parseTUnit(const std::wstring&);
-std::wstring TunitStr(const Tunit&);
+VOID die(DWORD err = 0);
 #endif
\ No newline at end of file