コード例 #1
0
        public void LoadMap(string map, IReadOnlyPackage package, MapClassification classification, MapGrid mapGrid, string oldMap)
        {
            IReadOnlyPackage mapPackage = null;

            try
            {
                using (new Support.PerfTimer(map))
                {
                    mapPackage = package.OpenPackage(map, modData.ModFiles);
                    if (mapPackage != null)
                    {
                        var uid = Map.ComputeUID(mapPackage);
                        previews[uid].UpdateFromMap(mapPackage, package, classification, modData.Manifest.MapCompatibility, mapGrid.Type);

                        if (oldMap != uid)
                        {
                            MapUpdated(oldMap, uid);
                        }
                    }
                }
            }
            catch (Exception e)
            {
                mapPackage?.Dispose();
                Console.WriteLine("Failed to load map: {0}", map);
                Console.WriteLine("Details: {0}", e);
                Log.Write("debug", "Failed to load map: {0}", map);
                Log.Write("debug", "Details: {0}", e);
            }
        }
コード例 #2
0
 public IReadOnlyPackage OpenPackage(string filename, IReadOnlyPackage parent)
 {
     // TODO: Make legacy callers access the parent package directly
     return(parent.OpenPackage(filename, this));
 }