~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/function/time/date.cc

  • Committer: brian
  • Date: 2008-06-25 05:29:13 UTC
  • Revision ID: brian@localhost.localdomain-20080625052913-6upwo0jsrl4lnapl
clean slate

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
 
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3
 
 *
4
 
 *  Copyright (C) 2008 Sun Microsystems
5
 
 *
6
 
 *  This program is free software; you can redistribute it and/or modify
7
 
 *  it under the terms of the GNU General Public License as published by
8
 
 *  the Free Software Foundation; version 2 of the License.
9
 
 *
10
 
 *  This program is distributed in the hope that it will be useful,
11
 
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
 
 *  GNU General Public License for more details.
14
 
 *
15
 
 *  You should have received a copy of the GNU General Public License
16
 
 *  along with this program; if not, write to the Free Software
17
 
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
18
 
 */
19
 
 
20
 
#include "config.h"
21
 
#include CSTDINT_H
22
 
#include "drizzled/function/time/date.h"
23
 
#include "drizzled/temporal.h"
24
 
 
25
 
String *Item_date::val_str(String *str)
26
 
{
27
 
  assert(fixed);
28
 
 
29
 
  /* We have our subclass convert a Date temporal for us */
30
 
  drizzled::Date temporal;
31
 
  if (! get_temporal(temporal))
32
 
    return (String *) NULL; /* get_temporal throws error. */
33
 
 
34
 
  if (str->alloc(MAX_DATE_STRING_REP_LENGTH))
35
 
  {
36
 
    null_value= true;
37
 
    return (String *) NULL;
38
 
  }
39
 
 
40
 
  /* Convert the Date to a string and return it */
41
 
  int new_length;
42
 
  new_length= temporal.to_string(str->c_ptr(), MAX_DATE_STRING_REP_LENGTH);
43
 
  assert(new_length < MAX_DATE_STRING_REP_LENGTH);
44
 
  str->length(new_length);
45
 
  return str;
46
 
}
47
 
 
48
 
int64_t Item_date::val_int()
49
 
{
50
 
  assert(fixed);
51
 
 
52
 
  /* We have our subclass convert a Date temporal for us */
53
 
  drizzled::Date temporal;
54
 
  if (! get_temporal(temporal))
55
 
    return 0; /* get_temporal throws error. */
56
 
 
57
 
  /* Convert the Date to a string and return it */
58
 
  int32_t int_value;
59
 
  temporal.to_int32_t(&int_value);
60
 
  return (int64_t) int_value;
61
 
}