Statistics
| Branch: | Tag: | Revision:

root / src / main / scala / gr / grnet / aquarium / util / date / TimeHelpers.scala @ 060b04bd

History | View | Annotate | Download (2.6 kB)

1
/*
2
 * Copyright 2011-2012 GRNET S.A. All rights reserved.
3
 *
4
 * Redistribution and use in source and binary forms, with or
5
 * without modification, are permitted provided that the following
6
 * conditions are met:
7
 *
8
 *   1. Redistributions of source code must retain the above
9
 *      copyright notice, this list of conditions and the following
10
 *      disclaimer.
11
 *
12
 *   2. Redistributions in binary form must reproduce the above
13
 *      copyright notice, this list of conditions and the following
14
 *      disclaimer in the documentation and/or other materials
15
 *      provided with the distribution.
16
 *
17
 * THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
18
 * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
19
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
20
 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
21
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
24
 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
25
 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
26
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
27
 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28
 * POSSIBILITY OF SUCH DAMAGE.
29
 *
30
 * The views and conclusions contained in the software and
31
 * documentation are those of the authors and should not be
32
 * interpreted as representing official policies, either expressed
33
 * or implied, of GRNET S.A.
34
 */
35

    
36
package gr.grnet.aquarium.util.date
37

    
38
import java.util.Date
39
import org.joda.time.MutableDateTime
40

    
41

    
42
/**
43
 *
44
 * @author Christos KK Loverdos <loverdos@gmail.com>
45
 */
46

    
47
final object TimeHelpers {
48
  @inline
49
  final def nowMillis() = System.currentTimeMillis()
50

    
51
  @inline
52
  final def nowDate = new Date(nowMillis())
53

    
54
  def secDiffOfMillis(ms0: Long, ms1: Long) = (ms1 - ms0).toDouble / 1000.0
55

    
56
  def timed[U](f: ⇒ U): (Long, Long, U) = {
57
    val ms0 = nowMillis()
58
    val u = f
59
    val ms1 = nowMillis()
60
    (ms0, ms1, u)
61
  }
62

    
63
  def toYYYYMMDDHHMMSSSSS(millis: Long): String = {
64
    new MutableDateCalc(millis).toYYYYMMDDHHMMSSSSS
65
  }
66

    
67
  def calcCalendarMonthDiff(fromMillis: Long, toMillis: Long): Int = {
68
    val fromDate = new MutableDateTime(fromMillis)
69
    val toDate = new MutableDateTime(toMillis)
70

    
71
    val fromYear  = fromDate.getYear
72
    val fromMonth = fromDate.getMonthOfYear
73

    
74
    val toYear = toDate.getYear
75
    val toMonth = toDate.getMonthOfYear
76

    
77
    val _from = fromYear * 12 + fromMonth
78
    val _to = toYear * 12 + toMonth
79

    
80
    _to - _from
81
  }
82
}