summaryrefslogtreecommitdiff
path: root/src/main/java/design/model/StrokeLeague.java
diff options
context:
space:
mode:
authorTyler Ferrari <69283684+Sowgro@users.noreply.github.com>2025-11-16 02:16:38 -0500
committerGitHub <noreply@github.com>2025-11-16 02:16:38 -0500
commit73dfd2dd419483c7d1060ef2fb40e328a0209e02 (patch)
tree456ed56e629a6324e5993b7ce094705c72e0b922 /src/main/java/design/model/StrokeLeague.java
parentb5d46c7701716bcb2dd6127aeb97f8fcdb7774fc (diff)
parent6ffc6b4cbd9e0c5ce2dc82a7c77f39b3adf849b6 (diff)
downloaddesignproject-design-6-73dfd2dd419483c7d1060ef2fb40e328a0209e02.tar.gz
designproject-design-6-73dfd2dd419483c7d1060ef2fb40e328a0209e02.tar.bz2
designproject-design-6-73dfd2dd419483c7d1060ef2fb40e328a0209e02.zip
Merge pull request #21 from RIT-SWEN-262/league-model
League model
Diffstat (limited to 'src/main/java/design/model/StrokeLeague.java')
-rw-r--r--src/main/java/design/model/StrokeLeague.java42
1 files changed, 37 insertions, 5 deletions
diff --git a/src/main/java/design/model/StrokeLeague.java b/src/main/java/design/model/StrokeLeague.java
index 2b787b5..d051fd0 100644
--- a/src/main/java/design/model/StrokeLeague.java
+++ b/src/main/java/design/model/StrokeLeague.java
@@ -4,33 +4,65 @@ import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonTypeName;
import java.util.ArrayList;
+import java.util.Collections;
+import java.util.Comparator;
import java.util.Date;
+import java.util.HashMap;
import java.util.List;
+import java.util.Map;
@JsonTypeName("stroke")
public class StrokeLeague extends League {
- private final List<Golfer> participants;
+ private List<Golfer> participants;
+ private Map<Golfer, Integer> totalStrokes;
@JsonCreator
private StrokeLeague(int id, String name, Date registrationDate, Date startDate, Date endDate, Golfer owner, List<Golfer> participants, List<Match> schedule) {
super(id, name, registrationDate, startDate, endDate, owner, schedule);
this.participants = participants;
+ this.totalStrokes = new HashMap<>();
+ participants.forEach(p -> totalStrokes.putIfAbsent(p, 0));
}
public StrokeLeague(String name, Date registrationDate, Date startDate, Date endDate, Golfer owner) {
super(name, registrationDate, startDate, endDate, owner);
this.participants = new ArrayList<>();
+ this.totalStrokes = new HashMap<>();
}
- public boolean addParticipants(Golfer e) {
- return participants.add(e);
+ public boolean addParticipants(Golfer g) {
+ boolean added = participants.add(g);
+ if(added) totalStrokes.putIfAbsent(g, 0);
+ return added;
}
- public boolean removeParticipants(Golfer o) {
- return participants.remove(o);
+ public boolean removeParticipants(Golfer g) {
+ totalStrokes.remove(g);
+ return participants.remove(g);
}
public Golfer[] getParticipants() {
return participants.toArray(Golfer[]::new);
}
+
+ @Override
+ public String getType() {
+ return "stroke";
+ }
+ public void recordPlay(Golfer player, Match match, Round round){
+ if(!isPlayable() || !participants.contains(player)) return;
+ int strokes = round.getTotalSwings();
+ totalStrokes.merge(player, strokes, Integer::sum);
+ match.addRound(round);
+ }
+
+ @Override
+ public void finalizeLeague(){
+ markCompleted();
+ participants.sort(Comparator.comparingInt(totalStrokes::get));
+ }
+
+ public Map<Golfer, Integer> getTotalStrokes(){
+ return Collections.unmodifiableMap(totalStrokes);
+ }
}