com.penalara.ghc.jsonghcfile.engineghcfile.SessionSettings Maven / Gradle / Ivy
Show all versions of engineGHCFile Show documentation
package com.penalara.ghc.jsonghcfile.engineghcfile;
import java.util.HashMap;
import java.util.Map;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonPropertyDescription;
import com.fasterxml.jackson.annotation.JsonPropertyOrder;
import com.fasterxml.jackson.annotation.JsonValue;
/**
* SessionSettings
*
* Conditions on the position of the class unit.
*
*/
@JsonInclude(JsonInclude.Include.NON_NULL)
@JsonPropertyOrder({
"avoidFirstHourSessions",
"avoidLastHourSessions",
"avoidAssingLastHourAndFirstNextDay",
"sameHourPreference",
"avoidAfternoonSessions",
"avoidAfterBreakSessions",
"nonBreakInTheMiddleOfConsecutiveSession",
"nonBreakInTheMiddleOfSession",
"followedDaysPreference",
"consecutiveWeeksBorders",
"samePositionEveryPeriod"
})
public class SessionSettings {
/**
* It penalises the position of the class units if more than 50% of the class units are at first hour.
*
*/
@JsonProperty("avoidFirstHourSessions")
@JsonPropertyDescription("It penalises the position of the class units if more than 50% of the class units are at first hour.")
private Boolean avoidFirstHourSessions = true;
/**
* It penalises the position of the class units if more than 50% of the class units are at last hour.
*
*/
@JsonProperty("avoidLastHourSessions")
@JsonPropertyDescription("It penalises the position of the class units if more than 50% of the class units are at last hour.")
private Boolean avoidLastHourSessions = true;
/**
* It penalises if the last hour and the first hour of the following day match.
*
*/
@JsonProperty("avoidAssingLastHourAndFirstNextDay")
@JsonPropertyDescription("It penalises if the last hour and the first hour of the following day match.")
private Boolean avoidAssingLastHourAndFirstNextDay = true;
/**
* Preference over class units that coincide in the same time slot.
*
*/
@JsonProperty("sameHourPreference")
@JsonPropertyDescription("Preference over class units that coincide in the same time slot.")
private SessionSettings.SameHourPreference sameHourPreference = SessionSettings.SameHourPreference.fromValue("ignore");
/**
* It penalises if there is more than one class unit after noon stop..
*
*/
@JsonProperty("avoidAfternoonSessions")
@JsonPropertyDescription("It penalises if there is more than one class unit after noon stop..")
private Boolean avoidAfternoonSessions = true;
/**
* It penalises if more than 50% of the class unit are after the last break of the day.
*
*/
@JsonProperty("avoidAfterBreakSessions")
@JsonPropertyDescription("It penalises if more than 50% of the class unit are after the last break of the day.")
private Boolean avoidAfterBreakSessions = true;
/**
* Do not allow breaks between consecutive class units (class duration of more than one section).
*
*/
@JsonProperty("nonBreakInTheMiddleOfConsecutiveSession")
@JsonPropertyDescription("Do not allow breaks between consecutive class units (class duration of more than one section).")
private Boolean nonBreakInTheMiddleOfConsecutiveSession = true;
/**
* Do not allow breaks between class units of multiple duration (class duration of more than one section).
*
*/
@JsonProperty("nonBreakInTheMiddleOfSession")
@JsonPropertyDescription("Do not allow breaks between class units of multiple duration (class duration of more than one section).")
private Boolean nonBreakInTheMiddleOfSession = false;
/**
* If the class unit has more than one lesson, indicates the preference on assigning them on consecutive days.
*
*/
@JsonProperty("followedDaysPreference")
@JsonPropertyDescription("If the class unit has more than one lesson, indicates the preference on assigning them on consecutive days.")
private SessionSettings.FollowedDaysPreference followedDaysPreference = SessionSettings.FollowedDaysPreference.fromValue("ignore");
/**
* It considers the end-of-week day, and the start-of-week day, as consecutive days for 'followedDaysPreference'.
*
*/
@JsonProperty("consecutiveWeeksBorders")
@JsonPropertyDescription("It considers the end-of-week day, and the start-of-week day, as consecutive days for 'followedDaysPreference'.")
private Boolean consecutiveWeeksBorders = false;
/**
* SamePositionEveryPeriod
*
* Keep the same position every week or period for the class units.
*
*/
@JsonProperty("samePositionEveryPeriod")
@JsonPropertyDescription("Keep the same position every week or period for the class units.")
private SamePositionEveryPeriod samePositionEveryPeriod = SamePositionEveryPeriod.fromValue("ignore");
/**
* It penalises the position of the class units if more than 50% of the class units are at first hour.
*
*/
@JsonProperty("avoidFirstHourSessions")
public Boolean getAvoidFirstHourSessions() {
return avoidFirstHourSessions;
}
/**
* It penalises the position of the class units if more than 50% of the class units are at first hour.
*
*/
@JsonProperty("avoidFirstHourSessions")
public void setAvoidFirstHourSessions(Boolean avoidFirstHourSessions) {
this.avoidFirstHourSessions = avoidFirstHourSessions;
}
/**
* It penalises the position of the class units if more than 50% of the class units are at last hour.
*
*/
@JsonProperty("avoidLastHourSessions")
public Boolean getAvoidLastHourSessions() {
return avoidLastHourSessions;
}
/**
* It penalises the position of the class units if more than 50% of the class units are at last hour.
*
*/
@JsonProperty("avoidLastHourSessions")
public void setAvoidLastHourSessions(Boolean avoidLastHourSessions) {
this.avoidLastHourSessions = avoidLastHourSessions;
}
/**
* It penalises if the last hour and the first hour of the following day match.
*
*/
@JsonProperty("avoidAssingLastHourAndFirstNextDay")
public Boolean getAvoidAssingLastHourAndFirstNextDay() {
return avoidAssingLastHourAndFirstNextDay;
}
/**
* It penalises if the last hour and the first hour of the following day match.
*
*/
@JsonProperty("avoidAssingLastHourAndFirstNextDay")
public void setAvoidAssingLastHourAndFirstNextDay(Boolean avoidAssingLastHourAndFirstNextDay) {
this.avoidAssingLastHourAndFirstNextDay = avoidAssingLastHourAndFirstNextDay;
}
/**
* Preference over class units that coincide in the same time slot.
*
*/
@JsonProperty("sameHourPreference")
public SessionSettings.SameHourPreference getSameHourPreference() {
return sameHourPreference;
}
/**
* Preference over class units that coincide in the same time slot.
*
*/
@JsonProperty("sameHourPreference")
public void setSameHourPreference(SessionSettings.SameHourPreference sameHourPreference) {
this.sameHourPreference = sameHourPreference;
}
/**
* It penalises if there is more than one class unit after noon stop..
*
*/
@JsonProperty("avoidAfternoonSessions")
public Boolean getAvoidAfternoonSessions() {
return avoidAfternoonSessions;
}
/**
* It penalises if there is more than one class unit after noon stop..
*
*/
@JsonProperty("avoidAfternoonSessions")
public void setAvoidAfternoonSessions(Boolean avoidAfternoonSessions) {
this.avoidAfternoonSessions = avoidAfternoonSessions;
}
/**
* It penalises if more than 50% of the class unit are after the last break of the day.
*
*/
@JsonProperty("avoidAfterBreakSessions")
public Boolean getAvoidAfterBreakSessions() {
return avoidAfterBreakSessions;
}
/**
* It penalises if more than 50% of the class unit are after the last break of the day.
*
*/
@JsonProperty("avoidAfterBreakSessions")
public void setAvoidAfterBreakSessions(Boolean avoidAfterBreakSessions) {
this.avoidAfterBreakSessions = avoidAfterBreakSessions;
}
/**
* Do not allow breaks between consecutive class units (class duration of more than one section).
*
*/
@JsonProperty("nonBreakInTheMiddleOfConsecutiveSession")
public Boolean getNonBreakInTheMiddleOfConsecutiveSession() {
return nonBreakInTheMiddleOfConsecutiveSession;
}
/**
* Do not allow breaks between consecutive class units (class duration of more than one section).
*
*/
@JsonProperty("nonBreakInTheMiddleOfConsecutiveSession")
public void setNonBreakInTheMiddleOfConsecutiveSession(Boolean nonBreakInTheMiddleOfConsecutiveSession) {
this.nonBreakInTheMiddleOfConsecutiveSession = nonBreakInTheMiddleOfConsecutiveSession;
}
/**
* Do not allow breaks between class units of multiple duration (class duration of more than one section).
*
*/
@JsonProperty("nonBreakInTheMiddleOfSession")
public Boolean getNonBreakInTheMiddleOfSession() {
return nonBreakInTheMiddleOfSession;
}
/**
* Do not allow breaks between class units of multiple duration (class duration of more than one section).
*
*/
@JsonProperty("nonBreakInTheMiddleOfSession")
public void setNonBreakInTheMiddleOfSession(Boolean nonBreakInTheMiddleOfSession) {
this.nonBreakInTheMiddleOfSession = nonBreakInTheMiddleOfSession;
}
/**
* If the class unit has more than one lesson, indicates the preference on assigning them on consecutive days.
*
*/
@JsonProperty("followedDaysPreference")
public SessionSettings.FollowedDaysPreference getFollowedDaysPreference() {
return followedDaysPreference;
}
/**
* If the class unit has more than one lesson, indicates the preference on assigning them on consecutive days.
*
*/
@JsonProperty("followedDaysPreference")
public void setFollowedDaysPreference(SessionSettings.FollowedDaysPreference followedDaysPreference) {
this.followedDaysPreference = followedDaysPreference;
}
/**
* It considers the end-of-week day, and the start-of-week day, as consecutive days for 'followedDaysPreference'.
*
*/
@JsonProperty("consecutiveWeeksBorders")
public Boolean getConsecutiveWeeksBorders() {
return consecutiveWeeksBorders;
}
/**
* It considers the end-of-week day, and the start-of-week day, as consecutive days for 'followedDaysPreference'.
*
*/
@JsonProperty("consecutiveWeeksBorders")
public void setConsecutiveWeeksBorders(Boolean consecutiveWeeksBorders) {
this.consecutiveWeeksBorders = consecutiveWeeksBorders;
}
/**
* SamePositionEveryPeriod
*
* Keep the same position every week or period for the class units.
*
*/
@JsonProperty("samePositionEveryPeriod")
public SamePositionEveryPeriod getSamePositionEveryPeriod() {
return samePositionEveryPeriod;
}
/**
* SamePositionEveryPeriod
*
* Keep the same position every week or period for the class units.
*
*/
@JsonProperty("samePositionEveryPeriod")
public void setSamePositionEveryPeriod(SamePositionEveryPeriod samePositionEveryPeriod) {
this.samePositionEveryPeriod = samePositionEveryPeriod;
}
/**
* If the class unit has more than one lesson, indicates the preference on assigning them on consecutive days.
*
*/
public enum FollowedDaysPreference {
IGNORE("ignore"),
ATTEMPT("attempt"),
AVOID("avoid"),
STRICT("strict"),
FORBIDDEN("forbidden");
private final String value;
private final static Map CONSTANTS = new HashMap();
static {
for (SessionSettings.FollowedDaysPreference c: values()) {
CONSTANTS.put(c.value, c);
}
}
FollowedDaysPreference(String value) {
this.value = value;
}
@Override
public String toString() {
return this.value;
}
@JsonValue
public String value() {
return this.value;
}
@JsonCreator
public static SessionSettings.FollowedDaysPreference fromValue(String value) {
SessionSettings.FollowedDaysPreference constant = CONSTANTS.get(value);
if (constant == null) {
throw new IllegalArgumentException(value);
} else {
return constant;
}
}
}
/**
* Preference over class units that coincide in the same time slot.
*
*/
public enum SameHourPreference {
IGNORE("ignore"),
AVOID("avoid"),
SAME("same");
private final String value;
private final static Map CONSTANTS = new HashMap();
static {
for (SessionSettings.SameHourPreference c: values()) {
CONSTANTS.put(c.value, c);
}
}
SameHourPreference(String value) {
this.value = value;
}
@Override
public String toString() {
return this.value;
}
@JsonValue
public String value() {
return this.value;
}
@JsonCreator
public static SessionSettings.SameHourPreference fromValue(String value) {
SessionSettings.SameHourPreference constant = CONSTANTS.get(value);
if (constant == null) {
throw new IllegalArgumentException(value);
} else {
return constant;
}
}
}
}