/// <summary> /// Changes initial Root Wt to an array. /// </summary> /// <param name="root">The root JSON token.</param> /// <param name="fileName">The name of the apsimx file.</param> private static void UpgradeToVersion99(JObject root, string fileName) { // Delete all alias children. foreach (var soilNitrogen in JsonUtilities.ChildrenOfType(root, "SoilNitrogen")) { var parent = JsonUtilities.Parent(soilNitrogen); var nutrient = JsonUtilities.CreateNewChildModel(parent, "Nutrient", "Models.Soils.Nutrients.Nutrient"); nutrient["ResourceName"] = "Nutrient"; soilNitrogen.Remove(); } foreach (var manager in JsonUtilities.ChildManagers(root)) { manager.Replace("using Models.Soils;", "using Models.Soils;\r\nusing Models.Soils.Nutrients;"); manager.Replace("SoilNitrogen.FOMN", ".Nutrient.FOMN"); manager.Replace("SoilNitrogen.FOMC", ".Nutrient.FOMC"); if (manager.Replace("Soil.SoilNitrogen.HumicN", "Humic.N")) { manager.AddDeclaration("NutrientPool", "Humic", new string[] { "[ScopedLinkByName]" }); } if (manager.Replace("Soil.SoilNitrogen.HumicC", "Humic.C")) { manager.AddDeclaration("NutrientPool", "Humic", new string[] { "[ScopedLinkByName]" }); } if (manager.Replace("Soil.SoilNitrogen.MicrobialN", "Microbial.N")) { manager.AddDeclaration("NutrientPool", "Microbial", new string[] { "[ScopedLinkByName]" }); } if (manager.Replace("Soil.SoilNitrogen.MicrobialC", "Microbial.C")) { manager.AddDeclaration("NutrientPool", "Microbial", new string[] { "[ScopedLinkByName]" }); } if (manager.Replace("Soil.SoilNitrogen.dlt_n_min_res", "SurfaceResidueDecomposition.MineralisedN")) { manager.AddDeclaration("CarbonFlow", "SurfaceResidueDecomposition", new string[] { "[LinkByPath(Path=\"[Nutrient].SurfaceResidue.Decomposition\")]" }); } manager.Replace("SoilNitrogen.MineralisedN", "Nutrient.MineralisedN"); manager.Replace("SoilNitrogen.TotalN", "Nutrient.TotalN"); if (manager.Replace("SoilNitrogen.TotalN", "Nutrient.TotalN")) { manager.RemoveDeclaration("SoilNitrogen"); manager.AddDeclaration("INutrient", "Nutrient", new string[] { "[ScopedLinkByName]" }); } manager.Replace("SoilNitrogen.TotalC", "Nutrient.TotalC"); if (manager.Replace("SoilNitrogen.TotalC", "Nutrient.TotalC")) { manager.RemoveDeclaration("SoilNitrogen"); manager.AddDeclaration("INutrient", "Nutrient", new string[] { "[ScopedLinkByName]" }); } manager.Replace("SoilNitrogen.mineral_n", "Nutrient.MineralN"); manager.Replace("SoilNitrogen.Denitrification", "Nutrient.Natm"); manager.Replace("SoilNitrogen.n2o_atm", "Nutrient.N2Oatm"); manager.Save(); } foreach (var report in JsonUtilities.ChildrenOfType(root, "Report")) { JsonUtilities.SearchReplaceReportVariableNames(report, "SoilNitrogen.NO3.kgha", "Nutrient.NO3.kgha"); JsonUtilities.SearchReplaceReportVariableNames(report, "SoilNitrogen.NH4.kgha", "Nutrient.NH4.kgha"); JsonUtilities.SearchReplaceReportVariableNames(report, "SoilNitrogen.Urea.kgha", "Nutrient.Urea.kgha"); JsonUtilities.SearchReplaceReportVariableNames(report, "SoilNitrogen.PlantAvailableNO3.kgha", "Nutrient.PlantAvailableNO3.kgha"); JsonUtilities.SearchReplaceReportVariableNames(report, "SoilNitrogen.PlantAvailableNH4.kgha", "Nutrient.PlantAvailableNH4.kgha"); JsonUtilities.SearchReplaceReportVariableNames(report, "[SoilNitrogen].NO3.kgha", "[Nutrient].NO3.kgha"); JsonUtilities.SearchReplaceReportVariableNames(report, "[SoilNitrogen].NH4.kgha", "[Nutrient].NH4.kgha"); JsonUtilities.SearchReplaceReportVariableNames(report, "[SoilNitrogen].Urea.kgha", "[Nutrient].Urea.kgha"); JsonUtilities.SearchReplaceReportVariableNames(report, ".SoilNitrogen.FOMN", ".Nutrient.FOMN"); JsonUtilities.SearchReplaceReportVariableNames(report, ".SoilNitrogen.FOMC", ".Nutrient.FOMC"); JsonUtilities.SearchReplaceReportVariableNames(report, ".SoilNitrogen.HumicN", ".Nutrient.Humic.N"); JsonUtilities.SearchReplaceReportVariableNames(report, ".SoilNitrogen.HumicC", ".Nutrient.Humic.C"); JsonUtilities.SearchReplaceReportVariableNames(report, ".SoilNitrogen.MicrobialN", ".Nutrient.Microbial.N"); JsonUtilities.SearchReplaceReportVariableNames(report, ".SoilNitrogen.MicrobialC", ".Nutrient.Microbial.C"); JsonUtilities.SearchReplaceReportVariableNames(report, ".SoilNitrogen.urea", ".Nutrient.Urea.kgha"); JsonUtilities.SearchReplaceReportVariableNames(report, ".SoilNitrogen.dlt_n_min_res", ".Nutrient.SurfaceResidue.Decomposition.MineralisedN"); JsonUtilities.SearchReplaceReportVariableNames(report, ".SoilNitrogen.MineralisedN", ".Nutrient.MineralisedN"); JsonUtilities.SearchReplaceReportVariableNames(report, ".SoilNitrogen.Denitrification", ".Nutrient.Natm"); JsonUtilities.SearchReplaceReportVariableNames(report, ".SoilNitrogen.n2o_atm", ".Nutrient.N2Oatm"); JsonUtilities.SearchReplaceReportVariableNames(report, ".SoilNitrogen.TotalC", ".Nutrient.TotalC"); JsonUtilities.SearchReplaceReportVariableNames(report, ".SoilNitrogen.TotalN", ".Nutrient.TotalN"); JsonUtilities.SearchReplaceReportVariableNames(report, ".SoilNitrogen.mineral_n", ".Nutrient.MineralN"); JsonUtilities.SearchReplaceReportVariableNames(report, ".SoilNitrogen.Nitrification", ".Nutrient.NH4.Nitrification"); } foreach (var series in JsonUtilities.ChildrenOfType(root, "Series")) { if (series["XFieldName"] != null) { series["XFieldName"] = series["XFieldName"].ToString().Replace("SoilNitrogen.NO3.kgha", "Nutrient.NO3.kgha"); series["XFieldName"] = series["XFieldName"].ToString().Replace("SoilNitrogen.NH4.kgha", "Nutrient.NH4.kgha"); series["XFieldName"] = series["XFieldName"].ToString().Replace("SoilNitrogen.Urea.kgha", "Nutrient.Urea.kgha"); series["XFieldName"] = series["XFieldName"].ToString().Replace("SoilNitrogen.PlantAvailableNO3.kgha", "Nutrient.PlantAvailableNO3.kgha"); series["XFieldName"] = series["XFieldName"].ToString().Replace("SoilNitrogen.PlantAvailableNH4.kgha", "Nutrient.PlantAvailableNH4.kgha"); } if (series["YFieldName"] != null) { series["YFieldName"] = series["YFieldName"].ToString().Replace("SoilNitrogen.NO3.kgha", "Nutrient.NO3.kgha"); series["YFieldName"] = series["YFieldName"].ToString().Replace("SoilNitrogen.NH4.kgha", "Nutrient.NH4.kgha"); series["YFieldName"] = series["YFieldName"].ToString().Replace("SoilNitrogen.Urea.kgha", "Nutrient.Urea.kgha"); series["YFieldName"] = series["YFieldName"].ToString().Replace("SoilNitrogen.PlantAvailableNO3.kgha", "Nutrient.PlantAvailableNO3.kgha"); series["YFieldName"] = series["YFieldName"].ToString().Replace("SoilNitrogen.PlantAvailableNH4.kgha", "Nutrient.PlantAvailableNH4.kgha"); } } }
/// <summary> /// Adds solutes under SoilNitrogen. /// </summary> /// <param name="root">The root JSON token.</param> /// <param name="fileName">The name of the apsimx file.</param> private static void UpgradeToVersion53(JObject root, string fileName) { foreach (var soilNitrogen in JsonUtilities.ChildrenOfType(root, "SoilNitrogen")) { JsonUtilities.CreateNewChildModel(soilNitrogen, "NO3", "Models.Soils.SoilNitrogenNO3"); JsonUtilities.CreateNewChildModel(soilNitrogen, "NH4", "Models.Soils.SoilNitrogenNH4"); JsonUtilities.CreateNewChildModel(soilNitrogen, "Urea", "Models.Soils.SoilNitrogenUrea"); JsonUtilities.CreateNewChildModel(soilNitrogen, "PlantAvailableNO3", "Models.Soils.SoilNitrogenPlantAvailableNO3"); JsonUtilities.CreateNewChildModel(soilNitrogen, "PlantAvailableNH4", "Models.Soils.SoilNitrogenPlantAvailableNH4"); } foreach (var report in JsonUtilities.ChildrenOfType(root, "Report")) { JsonUtilities.SearchReplaceReportVariableNames(report, "SoilNitrogen.NO3", "SoilNitrogen.NO3.kgha"); JsonUtilities.SearchReplaceReportVariableNames(report, "SoilNitrogen.NH4", "SoilNitrogen.NH4.kgha"); JsonUtilities.SearchReplaceReportVariableNames(report, "SoilNitrogen.urea", "SoilNitrogen.Urea.kgha"); JsonUtilities.SearchReplaceReportVariableNames(report, "SoilNitrogen.PlantAvailableNO3", "SoilNitrogen.PlantAvailableNO3.kgha"); JsonUtilities.SearchReplaceReportVariableNames(report, "SoilNitrogen.PlantAvailableNH4", "SoilNitrogen.PlantAvailableNH4.kgha"); JsonUtilities.SearchReplaceReportVariableNames(report, "[SoilNitrogen].no3", "[SoilNitrogen].NO3.kgha"); JsonUtilities.SearchReplaceReportVariableNames(report, "[SoilNitrogen].nh4", "[SoilNitrogen].NH4.kgha"); JsonUtilities.SearchReplaceReportVariableNames(report, "[SoilNitrogen].urea", "[SoilNitrogen].Urea.kgha"); } foreach (var manager in JsonUtilities.ChildManagers(root)) { var originalCode = manager.ToString(); if (originalCode != null) { if (originalCode.Contains("SoilNitrogen.NO3")) { manager.Replace("Soil.SoilNitrogen.NO3", "NO3.kgha"); manager.Replace("SoilNitrogen.NO3", "NO3.kgha"); manager.AddDeclaration("ISolute", "NO3", new string[] { "[ScopedLinkByName]" }); } if (originalCode.Contains("SoilNitrogen.NH4")) { manager.Replace("Soil.SoilNitrogen.NH4", "NH4.kgha"); manager.Replace("SoilNitrogen.NH4", "NH4.kgha"); manager.AddDeclaration("ISolute", "NH4", new string[] { "[ScopedLinkByName]" }); } if (originalCode.Contains("SoilNitrogen.urea")) { manager.Replace("Soil.SoilNitrogen.urea", "Urea.kgha"); manager.Replace("SoilNitrogen.urea", "Urea.kgha"); manager.AddDeclaration("ISolute", "Urea", new string[] { "[ScopedLinkByName]" }); } if (originalCode.Contains("SoilNitrogen.PlantAvailableNO3")) { manager.Replace("Soil.SoilNitrogen.PlantAvailableNO3", "PlantAvailableNO3.kgha"); manager.Replace("SoilNitrogen.PlantAvailableNO3", "PlantAvailableNO3.kgha"); manager.AddDeclaration("ISolute", "PlantAvailableNO3", new string[] { "[ScopedLinkByName]" }); } if (originalCode.Contains("SoilNitrogen.PlantAvailableNH4")) { manager.Replace("Soil.SoilNitrogen.PlantAvailableNH4", "PlantAvailableNH4.kgha"); manager.Replace("SoilNitrogen.PlantAvailableNH4", "PlantAvailableNH4.kgha"); manager.AddDeclaration("ISolute", "PlantAvailableNH4", new string[] { "[ScopedLinkByName]" }); } if (originalCode != manager.ToString()) { var usingLines = manager.GetUsingStatements().ToList(); usingLines.Add("Models.Interfaces"); manager.SetUsingStatements(usingLines); manager.Save(); } } } foreach (var series in JsonUtilities.ChildrenOfType(root, "Series")) { if (series["XFieldName"] != null) { series["XFieldName"] = series["XFieldName"].ToString().Replace("SoilNitrogen.NO3", "SoilNitrogen.NO3.kgha"); series["XFieldName"] = series["XFieldName"].ToString().Replace("SoilNitrogen.NH4", "SoilNitrogen.NH4.kgha"); series["XFieldName"] = series["XFieldName"].ToString().Replace("SoilNitrogen.urea", "SoilNitrogen.Urea.kgha"); series["XFieldName"] = series["XFieldName"].ToString().Replace("SoilNitrogen.PlantAvailableNO3", "SoilNitrogen.PlantAvailableNO3.kgha"); series["XFieldName"] = series["XFieldName"].ToString().Replace("SoilNitrogen.PlantAvailableNH4", "SoilNitrogen.PlantAvailableNH4.kgha"); } if (series["YFieldName"] != null) { series["YFieldName"] = series["YFieldName"].ToString().Replace("SoilNitrogen.NO3", "SoilNitrogen.NO3.kgha"); series["YFieldName"] = series["YFieldName"].ToString().Replace("SoilNitrogen.NH4", "SoilNitrogen.NH4.kgha"); series["YFieldName"] = series["YFieldName"].ToString().Replace("SoilNitrogen.urea", "SoilNitrogen.Urea.kgha"); series["YFieldName"] = series["YFieldName"].ToString().Replace("SoilNitrogen.PlantAvailableNO3", "SoilNitrogen.PlantAvailableNO3.kgha"); series["YFieldName"] = series["YFieldName"].ToString().Replace("SoilNitrogen.PlantAvailableNH4", "SoilNitrogen.PlantAvailableNH4.kgha"); } } }