~ubuntu-branches/ubuntu/trusty/monodevelop/trusty-proposed

« back to all changes in this revision

Viewing changes to external/Newtonsoft.Json/Src/Newtonsoft.Json/Utilities/MathUtils.cs

  • Committer: Package Import Robot
  • Author(s): Jo Shields
  • Date: 2013-05-12 09:46:03 UTC
  • mto: This revision was merged to the branch mainline in revision 29.
  • Revision ID: package-import@ubuntu.com-20130512094603-mad323bzcxvmcam0
Tags: upstream-4.0.5+dfsg
ImportĀ upstreamĀ versionĀ 4.0.5+dfsg

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#region License
 
2
// Copyright (c) 2007 James Newton-King
 
3
//
 
4
// Permission is hereby granted, free of charge, to any person
 
5
// obtaining a copy of this software and associated documentation
 
6
// files (the "Software"), to deal in the Software without
 
7
// restriction, including without limitation the rights to use,
 
8
// copy, modify, merge, publish, distribute, sublicense, and/or sell
 
9
// copies of the Software, and to permit persons to whom the
 
10
// Software is furnished to do so, subject to the following
 
11
// conditions:
 
12
//
 
13
// The above copyright notice and this permission notice shall be
 
14
// included in all copies or substantial portions of the Software.
 
15
//
 
16
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 
17
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
 
18
// OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
 
19
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
 
20
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
 
21
// WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 
22
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
 
23
// OTHER DEALINGS IN THE SOFTWARE.
 
24
#endregion
 
25
 
 
26
using System;
 
27
using System.Collections.Generic;
 
28
using System.Text;
 
29
 
 
30
namespace Newtonsoft.Json.Utilities
 
31
{
 
32
  internal class MathUtils
 
33
  {
 
34
    public static int IntLength(int i)
 
35
    {
 
36
      if (i < 0)
 
37
        throw new ArgumentOutOfRangeException();
 
38
 
 
39
      if (i == 0)
 
40
        return 1;
 
41
 
 
42
      return (int)Math.Floor(Math.Log10(i)) + 1;
 
43
    }
 
44
 
 
45
    public static char IntToHex(int n)
 
46
    {
 
47
      if (n <= 9)
 
48
        return (char)(n + 48);
 
49
 
 
50
      return (char)((n - 10) + 97);
 
51
    }
 
52
 
 
53
    public static int? Min(int? val1, int? val2)
 
54
    {
 
55
      if (val1 == null)
 
56
        return val2;
 
57
      if (val2 == null)
 
58
        return val1;
 
59
 
 
60
      return Math.Min(val1.Value, val2.Value);
 
61
    }
 
62
 
 
63
    public static int? Max(int? val1, int? val2)
 
64
    {
 
65
      if (val1 == null)
 
66
        return val2;
 
67
      if (val2 == null)
 
68
        return val1;
 
69
 
 
70
      return Math.Max(val1.Value, val2.Value);
 
71
    }
 
72
 
 
73
    public static double? Max(double? val1, double? val2)
 
74
    {
 
75
      if (val1 == null)
 
76
        return val2;
 
77
      if (val2 == null)
 
78
        return val1;
 
79
 
 
80
      return Math.Max(val1.Value, val2.Value);
 
81
    }
 
82
 
 
83
    public static bool ApproxEquals(double d1, double d2)
 
84
    {
 
85
      const double epsilon = 2.2204460492503131E-16;
 
86
 
 
87
      if (d1 == d2)
 
88
        return true;
 
89
 
 
90
      double tolerance = ((Math.Abs(d1) + Math.Abs(d2)) + 10.0) * epsilon;
 
91
      double difference = d1 - d2;
 
92
 
 
93
      return (-tolerance < difference && tolerance > difference);
 
94
    }
 
95
  }
 
96
}
 
 
b'\\ No newline at end of file'