~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/function/math/multiply.cc

  • Committer: Lee
  • Date: 2009-01-01 03:07:33 UTC
  • mto: (758.1.3 devel)
  • mto: This revision was merged to the branch mainline in revision 759.
  • Revision ID: lbieber@lbieber-desktop-20090101030733-fb411b55f07vij8q
more header file cleanup

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
2
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3
3
 *
4
 
 *  Copyright (C) 2008 Sun Microsystems, Inc.
 
4
 *  Copyright (C) 2008 Sun Microsystems
5
5
 *
6
6
 *  This program is free software; you can redistribute it and/or modify
7
7
 *  it under the terms of the GNU General Public License as published by
17
17
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
18
18
 */
19
19
 
20
 
#include <config.h>
21
 
 
 
20
#include <drizzled/server_includes.h>
 
21
#include CSTDINT_H
22
22
#include <drizzled/function/math/multiply.h>
23
23
 
24
 
#include <algorithm>
25
 
 
26
 
using namespace std;
27
 
 
28
 
namespace drizzled
29
 
{
30
24
 
31
25
double Item_func_mul::real_op()
32
26
{
50
44
 
51
45
/** See Item_func_plus::decimal_op for comments. */
52
46
 
53
 
type::Decimal *Item_func_mul::decimal_op(type::Decimal *decimal_value)
 
47
my_decimal *Item_func_mul::decimal_op(my_decimal *decimal_value)
54
48
{
55
 
  type::Decimal value1, *val1;
56
 
  type::Decimal value2, *val2;
 
49
  my_decimal value1, *val1;
 
50
  my_decimal value2, *val2;
57
51
  val1= args[0]->val_decimal(&value1);
58
52
  if ((null_value= args[0]->null_value))
59
53
    return 0;
60
54
  val2= args[1]->val_decimal(&value2);
61
55
  if (!(null_value= (args[1]->null_value ||
62
 
                     (class_decimal_mul(E_DEC_FATAL_ERROR, decimal_value, val1,
 
56
                     (my_decimal_mul(E_DEC_FATAL_ERROR, decimal_value, val1,
63
57
                                    val2) > 3))))
64
58
    return decimal_value;
65
59
  return 0;
73
67
    unsigned_flag= args[0]->unsigned_flag | args[1]->unsigned_flag;
74
68
  else
75
69
    unsigned_flag= args[0]->unsigned_flag & args[1]->unsigned_flag;
76
 
 
77
 
  decimals= min(args[0]->decimals + args[1]->decimals, DECIMAL_MAX_SCALE);
78
 
  int precision= min(args[0]->decimal_precision() + args[1]->decimal_precision(),
 
70
  decimals= cmin(args[0]->decimals + args[1]->decimals, DECIMAL_MAX_SCALE);
 
71
  int precision= cmin(args[0]->decimal_precision() + args[1]->decimal_precision(),
79
72
                     (unsigned int)DECIMAL_MAX_PRECISION);
80
 
  max_length= class_decimal_precision_to_length(precision, decimals,unsigned_flag);
 
73
  max_length= my_decimal_precision_to_length(precision, decimals,unsigned_flag);
81
74
}
82
75
 
83
 
} /* namespace drizzled */
 
76