Ejemplo n.º 1
0
        public override bool Execute(string[] arguments)
        {
            var args = new StatParameters();

            if (!ArgumentParser.ParseArguments(arguments, args))
            {
                return(false);
            }

            var stat = new StatisticsData();

            if (!string.IsNullOrEmpty(args.Input))
            {
                if (TryComputeStat(args.Input, ref stat))
                {
                    stat.Pages = (double)stat.Chars / StatisticsData.CharsPerA4Page;
                    CurrentState.Log.PrintLine(stat);
                    return(true);
                }
                return(false);
            }
            else
            {
                FolderLock.ExitIfFolderIsLocked(args.Directory, CurrentState.Log);

                using (var l = new FolderLock(args.Directory))
                {
                    ProjectLoader loader = new ProjectLoader(CurrentState.Log, args.Directory);
                    bool          result = loader.TryLoadProjectAndExecuteOperation((config, toc) =>
                    {
                        var settings = loader.CreateRuntimeSettings(config, toc, new BuildConfig());

                        foreach (var link in settings.TocContents.Files)
                        {
                            if (!TryComputeStat(link, ref stat))
                            {
                                return(false);
                            }
                        }
                        return(true);
                    });

                    if (result)
                    {
                        stat.Pages = (double)stat.Chars / StatisticsData.CharsPerA4Page;
                        CurrentState.Log.PrintLine(stat);
                    }

                    return(result);
                }
            }
        }
Ejemplo n.º 2
0
        public override bool Execute(string[] arguments)
        {
            PageGenParameters args = new PageGenParameters();

            if (!ArgumentParser.ParseArguments(arguments, args))
            {
                return(false);
            }

            CurrentState.Log.LogLevel = args.Verbose ? Api.LogLevel.Detail : Api.LogLevel.Info;

            FolderLock.ExitIfFolderIsLocked(args.Directory, CurrentState.Log);

            using (var l = new FolderLock(args.Directory))
            {
                ProjectLoader loader = new ProjectLoader(CurrentState.Log, args.Directory);

                loader.TryLoadProjectAndExecuteOperation((config, toc) =>
                {
                    Stopwatch stopwatch = new Stopwatch();
                    stopwatch.Start();

                    var settings = loader.CreateRuntimeSettings(config, toc, new BuildConfig());

                    switch (args.PageType)
                    {
                    case PageType.ExternalLinks:
                        RunGetLinks(settings, CurrentState.Log);
                        break;

                    case PageType.Chaptersummary:
                        RunChapterSummary(settings, CurrentState.Log);
                        break;
                    }

                    stopwatch.Stop();
                    CurrentState.Log.Info("Total runtime: {0}ms", stopwatch.ElapsedMilliseconds);

                    return(true);
                });
            }

            return(false);
        }