Utils.php
2.59 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
<?php
/**
* i-Educar - Sistema de gestão escolar
*
* Copyright (C) 2006 Prefeitura Municipal de Itajaí
* <ctima@itajai.sc.gov.br>
*
* Este programa é software livre; você pode redistribuí-lo e/ou modificá-lo
* sob os termos da Licença Pública Geral GNU conforme publicada pela Free
* Software Foundation; tanto a versão 2 da Licença, como (a seu critério)
* qualquer versão posterior.
*
* Este programa é distribuído na expectativa de que seja útil, porém, SEM
* NENHUMA GARANTIA; nem mesmo a garantia implícita de COMERCIABILIDADE OU
* ADEQUAÇÃO A UMA FINALIDADE ESPECÍFICA. Consulte a Licença Pública Geral
* do GNU para mais detalhes.
*
* Você deve ter recebido uma cópia da Licença Pública Geral do GNU junto
* com este programa; se não, escreva para a Free Software Foundation, Inc., no
* endereço 59 Temple Street, Suite 330, Boston, MA 02111-1307 USA.
*
* @author Eriksen Costa Paixão <eriksen.paixao_bs@cobra.com.br>
* @category i-Educar
* @license @@license@@
* @package App_Date
* @since Arquivo disponível desde a versão 1.1.0
* @version $Id$
*/
require_once 'App/Date/Exception.php';
/**
* App_Date_Utils class.
*
* Possui métodos
*
* @author Eriksen Costa Paixão <eriksen.paixao_bs@cobra.com.br>
* @category i-Educar
* @license @@license@@
* @package App_Date
* @since Classe disponível desde a versão 1.2.0
* @version @@package_version@@
*/
class App_Date_Utils
{
/**
* Retorna o ano de uma string nos formatos dd/mm/yyyy e dd/mm/yyyy hh:ii:ss.
* @param string $date
* @param int
*/
public static function getYear($date)
{
$parts = explode('/', $date);
$year = explode(' ', $parts[2]);
if (is_array($year)) {
$year = $year[0];
}
return (int) $year;
}
/**
* Verifica se ao menos uma das datas de um array é do ano especificado.
* @param array $dates Datas nos formatos dd/mm/yyyy [hh:ii:ss].
* @param int $year Ano esperado.
* @param int $at Quantidade mínima de datas esperadas no ano $year.
* @return bool TRUE se ao menos uma das datas estiver no ano esperado.
* @throws App_Date_Exception
*/
public static function datesYearAtLeast(array $dates, $year, $at = 1)
{
$matches = 0;
foreach ($dates as $date) {
$dateYear = self::getYear($date);
if ($year == $dateYear) {
$matches++;
}
}
if ($matches >= $at) {
return TRUE;
}
throw new App_Date_Exception(sprintf(
'Ao menos "%d" das datas informadas deve ser do ano "%d". Datas: "%s".',
$at, $year, implode('", "', $dates)
));
}
}