Reviewed by Maciej
[WebKit-https.git] / JavaScriptCore / kjs / operations.h
1 // -*- c-basic-offset: 2 -*-
2 /*
3  *  This file is part of the KDE libraries
4  *  Copyright (C) 1999-2000 Harri Porten (porten@kde.org)
5  *
6  *  This library is free software; you can redistribute it and/or
7  *  modify it under the terms of the GNU Library General Public
8  *  License as published by the Free Software Foundation; either
9  *  version 2 of the License, or (at your option) any later version.
10  *
11  *  This library is distributed in the hope that it will be useful,
12  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  *  Library General Public License for more details.
15  *
16  *  You should have received a copy of the GNU Library General Public License
17  *  along with this library; see the file COPYING.LIB.  If not, write to
18  *  the Free Software Foundation, Inc., 51 Franklin Steet, Fifth Floor,
19  *  Boston, MA 02110-1301, USA.
20  *
21  */
22
23 #ifndef _KJS_OPERATIONS_H_
24 #define _KJS_OPERATIONS_H_
25
26 namespace KJS {
27
28   class ExecState;
29   class JSValue;
30
31 #if __APPLE__
32   inline bool isNaN(double d) { return isnan(d); }
33   inline bool isInf(double d) { return isinf(d); }
34   inline bool isPosInf(double d) { return isinf(d) && d > 0; }
35   inline bool isNegInf(double d) { return isinf(d) && d < 0; }
36 #else
37   /**
38    * @return True if d is not a number (platform support required).
39    */
40   bool isNaN(double d);
41   /**
42    * @return True if d is infinite (platform support required).
43    */
44   bool isInf(double d);
45   bool isPosInf(double d);
46   bool isNegInf(double d);
47 #endif
48
49   bool equal(ExecState *exec, JSValue *v1, JSValue *v2);
50   bool strictEqual(ExecState *exec, JSValue *v1, JSValue *v2);
51   /**
52    * This operator performs an abstract relational comparison of the two
53    * arguments that can be of arbitrary type. If possible, conversions to the
54    * string or number type will take place before the comparison.
55    *
56    * @return 1 if v1 is "less-than" v2, 0 if the relation is "greater-than-or-
57    * equal". -1 if the result is undefined.
58    */
59   int relation(ExecState *exec, JSValue *v1, JSValue *v2);
60   int maxInt(int d1, int d2);
61   int minInt(int d1, int d2);
62   /**
63    * Additive operator. Either performs an addition or substraction of v1
64    * and v2.
65    * @param oper '+' or '-' for an addition or substraction, respectively.
66    * @return The result of the operation.
67    */
68   JSValue *add(ExecState *exec, JSValue *v1, JSValue *v2, char oper);
69   /**
70    * Multiplicative operator. Either multiplies/divides v1 and v2 or
71    * calculates the remainder from an division.
72    * @param oper '*', '/' or '%' for a multiplication, division or
73    * modulo operation.
74    * @return The result of the operation.
75    */
76   JSValue *mult(ExecState *exec, JSValue *v1, JSValue *v2, char oper);
77
78 }
79
80 #endif