public void AddPartCourses(AvailablePart ap, bool isKCTExperimentalNode = false) { if (ap.partPrefab.isVesselEVA || ap.name.StartsWith("kerbalEVA", StringComparison.OrdinalIgnoreCase) || ap.partPrefab.Modules.Contains <KerbalSeat>() || ap.partPrefab.Modules.Contains <LaunchClamp>() || ap.partPrefab.HasTag("PadInfrastructure")) { return; } TrainingDatabase.SynonymReplace(ap.name, out string name); if (!_partSynsHandled.TryGetValue(name, out var coursePair)) { bool isPartUnlocked = !isKCTExperimentalNode && ResearchAndDevelopment.GetTechnologyState(ap.TechRequired) == RDTech.State.Available; CourseTemplate profCourse = GenerateCourseProf(ap, !isPartUnlocked); AppendToPartTooltip(ap, profCourse); CourseTemplate missionCourse = null; if (isPartUnlocked && IsMissionTrainingEnabled) { missionCourse = GenerateCourseMission(ap); AppendToPartTooltip(ap, missionCourse); } _partSynsHandled.Add(name, new Tuple <CourseTemplate, CourseTemplate>(profCourse, missionCourse)); } else { CourseTemplate pc = coursePair.Item1; CourseTemplate mc = coursePair.Item2; AppendToPartTooltip(ap, pc); if (mc != null) { AppendToPartTooltip(ap, mc); } } }
private CourseTemplate GenerateCourseProf(AvailablePart ap, bool isTemporary) { var n = new ConfigNode("FS_COURSE"); bool found = TrainingDatabase.SynonymReplace(ap.name, out string name); n.AddValue("id", "prof_" + name); n.AddValue("name", "Proficiency: " + (found ? name : ap.title)); n.AddValue("time", 1d + (TrainingDatabase.GetTime(name) * 86400)); n.AddValue("isTemporary", isTemporary); n.AddValue("conflicts", $"{TrainingType_Proficiency}:{name}"); ConfigNode r = n.AddNode("REWARD"); r.AddValue("XPAmt", Settings.trainingProficiencyXP); ConfigNode l = r.AddNode("FLIGHTLOG"); l.AddValue("0", $"{TrainingType_Proficiency},{name}"); var c = new CourseTemplate(n); c.PopulateFromSourceNode(); OfferedCourses.Add(c); return(c); }
private CourseTemplate GenerateCourseMission(AvailablePart ap) { var n = new ConfigNode("FS_COURSE"); bool found = TrainingDatabase.SynonymReplace(ap.name, out string name); n.AddValue("id", "msn_" + name); n.AddValue("name", "Mission: " + (found ? name : ap.title)); n.AddValue("time", 1 + TrainingDatabase.GetTime(name + "-Mission") * 86400); n.AddValue("isTemporary", false); n.AddValue("timeUseStupid", true); n.AddValue("seatMax", ap.partPrefab.CrewCapacity * 2); n.AddValue("expiration", Settings.trainingMissionExpirationDays * 86400); n.AddValue("preReqs", $"{TrainingType_Proficiency}:{name}"); ConfigNode r = n.AddNode("REWARD"); ConfigNode l = r.AddNode("FLIGHTLOG"); l.AddValue("0", $"{TrainingType_Mission},{name}"); var c = new CourseTemplate(n); c.PopulateFromSourceNode(); OfferedCourses.Add(c); return(c); }
protected void GenerateOfferedCourses() //somehow provide some variable options here? { //convert the saved configs to course offerings foreach (CourseTemplate template in CourseTemplates) { CourseTemplate duplicate = new CourseTemplate(template.sourceNode, true); //creates a duplicate so the initial template is preserved duplicate.PopulateFromSourceNode(); if (duplicate.Available) { OfferedCourses.Add(duplicate); } } foreach (AvailablePart ap in PartLoader.LoadedPartsList) { if (ap.partPrefab.CrewCapacity > 0 /*&& ap.TechRequired != "start"*/) { if (ResearchAndDevelopment.PartModelPurchased(ap)) { string name = TrainingDatabase.SynonymReplace(ap.name); if (!partSynsHandled.Contains(name)) { partSynsHandled.Add(name); AddPartCourses(ap); } } } } Debug.Log("[FS] Offering " + OfferedCourses.Count + " courses."); //fire an event to let other mods add available courses (where they can pass variables through then) }
protected void GenerateCourseMission(AvailablePart ap) { ConfigNode n = new ConfigNode("FS_COURSE"); string name = TrainingDatabase.SynonymReplace(ap.name); n.AddValue("id", "msn_" + name); n.AddValue("name", "Mission: " + name); n.AddValue("time", 1d + TrainingDatabase.GetTime(name + "-Mission") * 86400d); n.AddValue("isTemporary", false); n.AddValue("timeUseStupid", true); n.AddValue("seatMax", ap.partPrefab.CrewCapacity * 2); n.AddValue("expiration", settings.trainingMissionExpirationDays * 86400d); n.AddValue("preReqs", "TRAINING_proficiency:" + name); n.AddValue("conflicts", "TRAINING_mission:" + name); ConfigNode r = n.AddNode("REWARD"); ConfigNode l = r.AddNode("FLIGHTLOG"); l.AddValue("0", "TRAINING_mission," + name); CourseTemplate c = new CourseTemplate(n); c.PopulateFromSourceNode(); OfferedCourses.Add(c); }
public double GetTime() { double c = days; foreach (string s in children) { c += TrainingDatabase._GetTime(s); } return(c); }
public void AddPartCourses(AvailablePart ap) { string name = TrainingDatabase.SynonymReplace(ap.name); if (!partSynsHandled.Contains(name)) { partSynsHandled.Add(name); bool isPartUnlocked = ResearchAndDevelopment.PartModelPurchased(ap); GenerateCourseProf(ap, !isPartUnlocked); if (isPartUnlocked) { GenerateCourseMission(ap); } } }
public bool NautHasTrainingForPart(ProtoCrewMember pcm, string partName) { TrainingDatabase.SynonymReplace(partName, out partName); FlightLog.Entry ent = pcm.careerLog.Last(); if (ent == null) { return(false); } bool lacksMission = IsMissionTrainingEnabled; for (int i = pcm.careerLog.Entries.Count; i-- > 0;) { FlightLog.Entry e = pcm.careerLog.Entries[i]; if (lacksMission) { if (string.IsNullOrEmpty(e.type) || string.IsNullOrEmpty(e.target)) { continue; } if (e.type == TrainingType_Mission && e.target == partName) { double exp = GetExpiration(pcm.name, e); lacksMission = exp == 0d || exp < KSPUtils.GetUT(); } } else { if (string.IsNullOrEmpty(e.type) || string.IsNullOrEmpty(e.target)) { continue; } if (e.type == TrainingType_Proficiency && e.target == partName) { return(true); } } } return(false); }
protected void GenerateCourseProf(AvailablePart ap) { ConfigNode n = new ConfigNode("FS_COURSE"); string name = TrainingDatabase.SynonymReplace(ap.name); n.AddValue("id", "prof_" + name); n.AddValue("name", "Proficiency: " + name); n.AddValue("time", 1d + (TrainingDatabase.GetTime(name) * 86400d)); n.AddValue("expiration", settings.trainingProficiencyExpirationYears * 86400d * 365d); n.AddValue("expirationUseStupid", true); n.AddValue("conflicts", "TRAINING_proficiency:" + name); ConfigNode r = n.AddNode("REWARD"); r.AddValue("XPAmt", settings.trainingProficiencyXP); ConfigNode l = r.AddNode("FLIGHTLOG"); l.AddValue("0", "TRAINING_proficiency," + name); CourseTemplate c = new CourseTemplate(n); c.PopulateFromSourceNode(); OfferedCourses.Add(c); ConfigNode n2 = n.CreateCopy(); n2.SetValue("id", "profR_" + name); n2.SetValue("name", "Refresher: " + name); n2.SetValue("time", 1d + TrainingDatabase.GetTime(name) * 86400d * settings.trainingProficiencyRefresherTimeMult); n2.AddValue("preReqsAny", "expired_TRAINING_proficiency:" + name + ",TRAINING_proficiency:" + name); n2.RemoveValue("conflicts"); r = n2.GetNode("REWARD"); r.SetValue("XPAmt", "0"); ConfigNode exp = r.AddNode("EXPIRELOG"); exp.AddValue("0", "TRAINING_proficiency," + name); c = new CourseTemplate(n2); c.PopulateFromSourceNode(); OfferedCourses.Add(c); }
public bool NautHasTrainingForPart(ProtoCrewMember pcm, string partName) { partName = TrainingDatabase.SynonymReplace(partName); FlightLog.Entry ent = pcm.careerLog.Last(); if (ent == null) { return(false); } bool lacksMission = true; for (int i = pcm.careerLog.Entries.Count; i-- > 0;) { FlightLog.Entry e = pcm.careerLog.Entries[i]; if (lacksMission) { if (string.IsNullOrEmpty(e.type) || string.IsNullOrEmpty(e.target)) { continue; } if (e.type == "TRAINING_mission" && e.target == partName) { double exp = GetExpiration(pcm.name, e); lacksMission = exp == 0d || exp < Planetarium.GetUniversalTime(); } } else { if (string.IsNullOrEmpty(e.type) || string.IsNullOrEmpty(e.target)) { continue; } if (e.type == "TRAINING_proficiency" && e.target == partName) { return(true); } } } return(false); }
public void AddPartCourses(AvailablePart ap) { if (ap.partPrefab.isVesselEVA || ap.partPrefab.Modules.Contains <KerbalSeat>() || ap.partPrefab.Modules.Contains <LaunchClamp>() || ap.partPrefab.HasTag("PadInfrastructure")) { return; } TrainingDatabase.SynonymReplace(ap.name, out string name); if (!_partSynsHandled.Contains(name)) { _partSynsHandled.Add(name); bool isPartUnlocked = ResearchAndDevelopment.PartModelPurchased(ap) && !ResearchAndDevelopment.IsExperimentalPart(ap); GenerateCourseProf(ap, !isPartUnlocked); if (isPartUnlocked && IsMissionTrainingEnabled) { GenerateCourseMission(ap); } } }
protected void GenerateCourseProf(AvailablePart ap) { ConfigNode n = new ConfigNode("FS_COURSE"); string name = TrainingDatabase.SynonymReplace(ap.name); n.AddValue("id", "prof_" + name); n.AddValue("name", "Proficiency: " + name); n.AddValue("time", 1d + (TrainingDatabase.GetTime(name) * 86400d)); n.AddValue("conflicts", "TRAINING_proficiency:" + name); ConfigNode r = n.AddNode("REWARD"); r.AddValue("XPAmt", settings.trainingProficiencyXP); ConfigNode l = r.AddNode("FLIGHTLOG"); l.AddValue("0", "TRAINING_proficiency," + name); CourseTemplate c = new CourseTemplate(n); c.PopulateFromSourceNode(); OfferedCourses.Add(c); }
public override void OnLoad(ConfigNode node) { base.OnLoad(node); if (Settings == null) { Settings = new CrewHandlerSettings(); foreach (ConfigNode stg in GameDatabase.Instance.GetConfigNodes("CREWHANDLERSETTINGS")) { Settings.Load(stg); } } KerbalRetireTimes.Clear(); ConfigNode n = node.GetNode("RETIRETIMES"); if (n != null) { _isFirstLoad = false; foreach (ConfigNode.Value v in n.values) { KerbalRetireTimes[v.name] = double.Parse(v.value); } } KerbalRetireIncreases.Clear(); n = node.GetNode("RETIREINCREASES"); if (n != null) { foreach (ConfigNode.Value v in n.values) { KerbalRetireIncreases[v.name] = double.Parse(v.value); } } _retirees.Clear(); n = node.GetNode("RETIREES"); if (n != null) { foreach (ConfigNode.Value v in n.values) { _retirees.Add(v.value); } } _expireTimes.Clear(); n = node.GetNode("EXPIRATIONS"); if (n != null) { foreach (ConfigNode eN in n.nodes) { _expireTimes.Add(new TrainingExpiration(eN)); } } ConfigNode FSData = node.GetNode("FlightSchoolData"); if (FSData != null) { //load all the active courses ActiveCourses.Clear(); foreach (ConfigNode courseNode in FSData.GetNodes("ACTIVE_COURSE")) { try { ActiveCourses.Add(new ActiveCourse(courseNode)); } catch (Exception ex) { Debug.LogException(ex); } } } TrainingDatabase.EnsureInitialized(); KACWrapper.InitKACWrapper(); }
public override void OnLoad(ConfigNode node) { base.OnLoad(node); foreach (ConfigNode stg in GameDatabase.Instance.GetConfigNodes("CREWHANDLERSETTINGS")) { settings.Load(stg); } kerbalRetireTimes.Clear(); ConfigNode n = node.GetNode("RETIRETIMES"); if (n != null) { foreach (ConfigNode.Value v in n.values) { kerbalRetireTimes[v.name] = double.Parse(v.value); } } retirees.Clear(); n = node.GetNode("RETIREES"); if (n != null) { foreach (ConfigNode.Value v in n.values) { retirees.Add(v.value); } } expireTimes.Clear(); n = node.GetNode("EXPIRATIONS"); if (n != null) { foreach (ConfigNode eN in n.nodes) { expireTimes.Add(new TrainingExpiration(eN)); } } ConfigNode FSData = node.GetNode("FlightSchoolData"); if (FSData == null) { return; } //load all the active courses ActiveCourses.Clear(); foreach (ConfigNode courseNode in FSData.GetNodes("ACTIVE_COURSE")) { try { ActiveCourses.Add(new ActiveCourse(courseNode)); } catch (Exception ex) { Debug.LogException(ex); } } TrainingDatabase.Initialize(); KACWrapper.InitKACWrapper(); }