Bestimmung der Zeitpunkte von Ereignissen
ulrich
2023-03-19 8cf8493e4b918cece529fef978d50c8b9835d230
commit | author | age
66d68b 1 /*
U 2   Zeitrechnung - a class library to determine calendar events
3   Copyright (c) 1984-2023 Ulrich Hilger, http://uhilger.de
4
5   This program is free software: you can redistribute it and/or modify
6   it under the terms of the GNU Affero General Public License as published by
7   the Free Software Foundation, either version 3 of the License, or
8   (at your option) any later version.
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 Affero General Public License for more details.
14
15   You should have received a copy of the GNU Affero General Public License
16   along with this program.  If not, see <http://www.gnu.org/licenses/>.
17  */
18 package de.uhilger.zeitrechnung.ereignis;
19
20 import de.uhilger.zeitrechnung.Datum;
21 import de.uhilger.zeitrechnung.Definition;
22 import de.uhilger.zeitrechnung.kalender.ISOKalender;
23 import java.util.ArrayList;
24 import java.util.List;
25
26 /**
27  * <p>Ein Ereignis, das an einem bestimmten Wochentag und einer bestimmten Woche
28  * eines Monats stattfindet, z.B. am zweiten Sonntag im Mai.</p>
29  *
30  * Ereignisdefinition<br>
31  * p1 Wochentag (0=Sonntag .. 6=Samstag)<br>
32  * p2 Monat (1=Januar .. 12=Dezember)<br>
33  * p3 Woche, z.B. 2 fuer 'den zweiten' wie in zweiter Sonntag im Mai,
34  * -1=letzter<br>
35  *
36  * @author Ulrich Hilger
37  */
38 public class TagWocheMonatEreignis extends EreignisBasis {
39
40   /**
41    * Ein Objekt der Klasse TagWocheMonatEreignis erzeugen
42    */
43   public TagWocheMonatEreignis() {
44     super();
45   }
46
47   /**
48    * Den Typ des Ereignisses ermitteln
49    * 
50    * @return Ereignis.TYP_TAG_WOCHE_MONAT
51    */
52   @Override
53   public int getTyp() {
54     return Ereignis.TYP_TAG_WOCHE_MONAT;
55   }
56
57   /**
58    * Die Tage eines Jahres im gregorianischen Kalendersystem 
59    * ermitteln, an denen das Ereignis stattfindet.
60    * 
61    * @param isoJahr das Jahr im gregorianischen Kalender, 
62    * fuer das ermittelt werden soll, an welchen Tagen das Ereignis stattfindet
63    * @return die Liste aus Datum-Objekten, die die Tage im gregorianischen 
64    * Kalender bezeichnet, an denen das Ereignis stattfindet
65    */
66   @Override
67   public List<Datum> getZeitpunkte(long isoJahr) {
68     Definition def = getDefinition();
69     long generischesDatum;
70     ISOKalender w = new ISOKalender();
71     if (def.getp3() < 0) {
72       int letzterTag = w.letzterDesMonats(isoJahr, (int) def.getp2());
73       long tage = w.zuTagen(isoJahr, (int) def.getp2(), letzterTag);
74       generischesDatum = w.letzterTag((int) def.getp1(), tage);
75     } else {
76       long tage = w.zuTagen(isoJahr, (int) def.getp2(), 1);
77       generischesDatum = w.nterTag((int) def.getp3(), (int) def.getp1(), tage);
78     }
79     ArrayList list = new ArrayList();
80     list.add(w.vonTagen(generischesDatum));
81     return list;
82   }
83
84 }