#region Disclaimer / License // Copyright (C) 2009, Kenneth Skovhede // http://www.hexad.dk, opensource@hexad.dk // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 2.1 of the License, or (at your option) any later version. // // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public // License along with this library; if not, write to the Free Software // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // #endregion using System; using System.Collections.Generic; using System.Text; using Duplicati.CommandLine; using Maestro.Login; using OSGeo.MapGuide.ObjectModels.Common; using OSGeo.MapGuide.MaestroAPI; using System.Collections.Specialized; using OSGeo.MapGuide.ObjectModels; using OSGeo.MapGuide.ExtendedObjectModels; namespace MgCooker { public class Program { private static DateTime beginMap; private static DateTime beginGroup; private static DateTime beginScale; private static DateTime beginTile; private static DateTime lastUpdate; private static List exceptionList = new List(); private static List tileRuns; private static long tileCount; private static long totalTiles; private static TimeSpan prevDuration; private static long mapCount; private static long groupCount; private static bool m_logableProgress = false; private static bool hasConsole = true; [STAThread()] public static void Main(string[] args) { System.Windows.Forms.Application.EnableVisualStyles(); System.Windows.Forms.Application.DoEvents(); PreferredSiteList.InitCulture(); ModelSetup.Initialize(); //Parameters: //mapagent= //username= //password= //mapdefinition= //scaleindex=0,1,2,3,4,5 //basegroups="x","y" //extentoverride=minx,miny,maxx,maxy Boolean batchMode = false; string mapagent = "http://localhost/mapguide"; string username = "Anonymous"; string password = ""; string mapdefinitions = ""; string scaleindex = ""; string basegroups = ""; string limitRows = ""; string limitCols = ""; string tileWidth = ""; string tileHeight = ""; string DPI = ""; string metersPerUnit = ""; IEnvelope overrideExtents = null; List largs = new List(args); Dictionary opts = CommandLineParser.ExtractOptions(largs); if (opts.ContainsKey("mapagent")) mapagent = opts["mapagent"]; if (opts.ContainsKey("username")) username = opts["username"]; if (opts.ContainsKey("password")) password = opts["password"]; if (opts.ContainsKey("mapdefinitions")) mapdefinitions = opts["mapdefinitions"]; if (opts.ContainsKey("scaleindex")) scaleindex = opts["scaleindex"]; if (opts.ContainsKey("basegroups")) basegroups = opts["basegroups"]; if (opts.ContainsKey("limitrows")) limitRows = opts["limitrows"]; if (opts.ContainsKey("limitcols")) limitCols = opts["limitcols"]; if (opts.ContainsKey("tilewidth")) tileWidth = opts["tilewidth"]; if (opts.ContainsKey("tileheight")) tileHeight = opts["tileheight"]; if (opts.ContainsKey("DPI")) DPI = opts["DPI"]; if (opts.ContainsKey("metersperunit")) metersPerUnit = opts["metersperunit"]; if (opts.ContainsKey("extentoverride")) { string[] parts = opts["extentoverride"].Split(','); if (parts.Length == 4) { double minx; double miny; double maxx; double maxy; if ( double.TryParse(parts[0], System.Globalization.NumberStyles.Float, System.Globalization.CultureInfo.InvariantCulture, out minx) && double.TryParse(parts[1], System.Globalization.NumberStyles.Float, System.Globalization.CultureInfo.InvariantCulture, out miny) && double.TryParse(parts[2], System.Globalization.NumberStyles.Float, System.Globalization.CultureInfo.InvariantCulture, out maxx) && double.TryParse(parts[3], System.Globalization.NumberStyles.Float, System.Globalization.CultureInfo.InvariantCulture, out maxy) ) { overrideExtents = ObjectFactory.CreateEnvelope(minx, miny, maxx, maxy); } } } if (largs.IndexOf("batch") >= 0 || largs.IndexOf("/batch") >= 0 || largs.IndexOf("commandline") >= 0 || largs.IndexOf("/commandline") >= 0) { batchMode = true; } try { Console.Clear(); m_logableProgress = true; } catch { hasConsole = false; m_logableProgress = false; } IServerConnection connection = null; string[] maps = mapdefinitions.Split(','); SetupRun sr = null; if (!opts.ContainsKey("username") || (!opts.ContainsKey("mapagent"))) { if (!batchMode) { var frm = new LoginDialog(); if (frm.ShowDialog() != System.Windows.Forms.DialogResult.OK) return; connection = frm.Connection; try { mapagent = connection.GetCustomProperty("BaseUrl").ToString(); } catch { } sr = new SetupRun(frm.Username, frm.Password, connection, maps, opts); } } if (connection == null) { var initP = new NameValueCollection(); if (!opts.ContainsKey("native-connection")) { initP["Url"] = mapagent; initP["Username"] = username; initP["Password"] = password; initP["Locale"] = System.Globalization.CultureInfo.CurrentUICulture.TwoLetterISOLanguageName; initP["AllowUntestedVersion"] = "true"; connection = ConnectionProviderRegistry.CreateConnection("Maestro.Http", initP); } else { string serverconfig = System.IO.Path.Combine(System.IO.Path.GetDirectoryName(System.Reflection.Assembly.GetExecutingAssembly().Location), "webconfig.ini"); initP["ConfigFile"] = serverconfig; initP["Username"] = username; initP["Password"] = password; initP["Locale"] = System.Globalization.CultureInfo.CurrentUICulture.TwoLetterISOLanguageName; connection = ConnectionProviderRegistry.CreateConnection("Maestro.LocalNative", initP); } } if (!batchMode) { if (sr == null) sr = new SetupRun(connection, maps, opts); sr.ShowDialog(); return; } BatchSettings bx = new BatchSettings(connection); int x; if (!string.IsNullOrEmpty(limitCols) && int.TryParse(limitCols, out x)) bx.LimitCols(x); if (!string.IsNullOrEmpty(limitRows) && int.TryParse(limitRows, out x)) bx.LimitRows(x); if (!string.IsNullOrEmpty(tileWidth) && int.TryParse(tileWidth, out x)) bx.Config.TileWidth = x; if (!string.IsNullOrEmpty(tileHeight) && int.TryParse(tileHeight, out x)) bx.Config.TileHeight = x; if (!string.IsNullOrEmpty(DPI) && int.TryParse(DPI, out x)) bx.Config.DPI = x; double d; if (!string.IsNullOrEmpty(metersPerUnit) && double.TryParse(metersPerUnit, System.Globalization.NumberStyles.Float, System.Globalization.CultureInfo.CurrentCulture, out d)) { bx.Config.MetersPerUnit = d; bx.Config.UseOfficialMethod = true; } if (opts.ContainsKey("random-tile-order")) bx.Config.RandomizeTileSequence = true; if (opts.ContainsKey("threadcount") && int.TryParse(opts["threadcount"], out x) && x > 0) bx.Config.ThreadCount = x; bx.AddMapDefinitions(maps); //basegroups must be set in each mapdefinition if (!string.IsNullOrEmpty(basegroups)) { List groups = new List(); foreach (string s in basegroups.Split(',')) { string f = s; if (f.StartsWith("\"")) f = f.Substring(1); if (f.EndsWith("\"")) f = f.Substring(0, f.Length - 1); groups.Add(f); } bx.SetGroups(groups.ToArray()); } if (overrideExtents != null) { List scales = new List(); int tmp; foreach (string s in scaleindex.Split(',')) if (int.TryParse(s, out tmp)) scales.Add(tmp); foreach (BatchMap bm in bx.Maps) bm.SetScalesAndExtend(scales.ToArray(), overrideExtents); } else if (!string.IsNullOrEmpty(scaleindex)) { List scales = new List(); int tmp; foreach (string s in scaleindex.Split(',')) if (int.TryParse(s, out tmp)) scales.Add(tmp); bx.SetScales(scales.ToArray()); } if (!batchMode) { Progress pg = new Progress(bx); pg.ShowDialog(); } else { bx.BeginRenderingMap += new ProgressCallback(bx_BeginRenderingMap); bx.FinishRenderingMap += new ProgressCallback(bx_FinishRenderingMap); bx.BeginRenderingGroup += new ProgressCallback(bx_BeginRenderingGroup); bx.FinishRenderingGroup += new ProgressCallback(bx_FinishRenderingGroup); bx.BeginRenderingScale += new ProgressCallback(bx_BeginRenderingScale); bx.FinishRenderingScale += new ProgressCallback(bx_FinishRenderingScale); bx.BeginRenderingTile += new ProgressCallback(bx_BeginRenderingTile); bx.FinishRenderingTile += new ProgressCallback(bx_FinishRenderingTile); bx.FailedRenderingTile += new ErrorCallback(bx_FailedRenderingTile); mapCount = 0; lastUpdate = DateTime.Now; bx.RenderAll(); } } static void bx_FailedRenderingTile(CallbackStates state, BatchMap map, string group, int scaleindex, int row, int column, ref Exception exception) { exceptionList.Add(exception); exception = null; } static void DisplayProgress(BatchMap map, string group, int scaleindex, int row, int column, ref bool cancel) { if (hasConsole) Console.Clear(); Console.WriteLine(string.Format(Properties.Resources.ConsoleUpdateTime.Replace("\\t", "\t"), DateTime.Now)); Console.WriteLine(string.Format(Properties.Resources.ConsoleCurrentMap.Replace("\\t", "\t"), map.ResourceId, mapCount, map.Parent.Maps.Count)); Console.WriteLine(string.Format(Properties.Resources.ConsoleCurrentGroup.Replace("\\t", "\t"), group, groupCount, map.Map.BaseMap.GroupCount)); Console.WriteLine(string.Format(Properties.Resources.ConsoleCurrentScale.Replace("\\t", "\t"), map.Map.BaseMap.GetScaleAt(Array.IndexOf(map.ScaleIndexMap, scaleindex)), Array.IndexOf(map.ScaleIndexMap, scaleindex) + 1, map.Map.BaseMap.ScaleCount)); Console.WriteLine(string.Format(Properties.Resources.ConsoleCurrentTile.Replace("\\t", "\t"), tileCount, totalTiles)); Console.WriteLine(); Console.WriteLine(string.Format(Properties.Resources.ConsoleGroupDuration.Replace("\\t", "\t"), DateTime.Now - beginGroup)); Console.WriteLine(string.Format(Properties.Resources.ConsoleGroupEstimate.Replace("\\t", "\t"), new TimeSpan(prevDuration.Ticks * totalTiles))); if (exceptionList.Count != 0) { Console.WriteLine(); Console.WriteLine(string.Format(Properties.Resources.ConsoleErrorSummary, exceptionList.Count, exceptionList[exceptionList.Count - 1].ToString())); } } static void bx_FinishRenderingGroup(CallbackStates state, BatchMap map, string group, int scaleindex, int row, int column, ref bool cancel) { TimeSpan duration = DateTime.Now - beginGroup; if (m_logableProgress) Console.WriteLine(string.Format(Properties.Resources.ConsoleOperationFinishGroup, DateTime.Now, group, duration)); } static void bx_BeginRenderingGroup(CallbackStates state, BatchMap map, string group, int scaleindex, int row, int column, ref bool cancel) { groupCount++; beginGroup = DateTime.Now; if (m_logableProgress) Console.WriteLine(string.Format(Properties.Resources.ConsoleOperationBeginGroup, beginGroup, group, 1, 1)); tileRuns = new List(); tileCount = 0; totalTiles = map.TotalTiles; } static void bx_FinishRenderingTile(CallbackStates state, BatchMap map, string group, int scaleindex, int row, int column, ref bool cancel) { tileRuns.Add(DateTime.Now - beginTile); tileCount++; //Update display, after 1000 tiles if (tileRuns.Count > 500 || (DateTime.Now - lastUpdate).TotalSeconds > 5) { long d = 0; foreach (TimeSpan ts in tileRuns) d += ts.Ticks; d /= tileRuns.Count; //For all other than the first calculation, we use the previous counts too if (tileCount != tileRuns.Count) d = (d + prevDuration.Ticks) / 2; prevDuration = new TimeSpan(d); TimeSpan duration = new TimeSpan(d * totalTiles); tileRuns.Clear(); lastUpdate = DateTime.Now; if (m_logableProgress) Console.WriteLine(string.Format(Properties.Resources.ConsoleOperationFinishTile, tileCount, totalTiles, group, duration)); else DisplayProgress(map, group, scaleindex, row, column, ref cancel); } } static void bx_BeginRenderingTile(CallbackStates state, BatchMap map, string group, int scaleindex, int row, int column, ref bool cancel) { beginTile = DateTime.Now; } static void bx_FinishRenderingScale(CallbackStates state, BatchMap map, string group, int scaleindex, int row, int column, ref bool cancel) { TimeSpan duration = DateTime.Now - beginScale; if (m_logableProgress) Console.WriteLine(string.Format(Properties.Resources.ConsoleOperationFinishScale, DateTime.Now, map.Map.BaseMap.GetScaleAt(scaleindex), duration)); } static void bx_BeginRenderingScale(CallbackStates state, BatchMap map, string group, int scaleindex, int row, int column, ref bool cancel) { beginScale = DateTime.Now; if (m_logableProgress) Console.WriteLine(string.Format(Properties.Resources.ConsoleOperationBeginScale, beginMap, map.Map.BaseMap.GetScaleAt(scaleindex), scaleindex, map.Resolutions)); } static void bx_FinishRenderingMap(CallbackStates state, BatchMap map, string group, int scaleindex, int row, int column, ref bool cancel) { groupCount = 0; TimeSpan duration = DateTime.Now - beginMap; if (m_logableProgress) Console.WriteLine(string.Format(Properties.Resources.ConsoleOperationFinishMap, DateTime.Now, map.ResourceId, duration)); } static void bx_BeginRenderingMap(CallbackStates state, BatchMap map, string group, int scaleindex, int row, int column, ref bool cancel) { mapCount++; beginMap = DateTime.Now; if (m_logableProgress) Console.WriteLine(string.Format(Properties.Resources.ConsoleOperationBeginMap, beginMap, map.ResourceId)); } } }