summaryrefslogtreecommitdiff
path: root/Program.cs
blob: ea1eab31f6e5ec123b4e6b68b9af83321d25def2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
using System;
using System.Collections.Generic;
using System.Text;
using System.Windows.Forms;
using System.IO;

namespace BCDD
{
    class Program
    {
        static List<String> getFiles(string[] args)
        {
            List<String> filenames = new List<String>();
            foreach (String arg in args)
            {
                if (File.Exists(arg))
                {
                    filenames.Add(arg);
                }
            }
            if (filenames.Count == 0)
            {
                OpenFileDialog fd = new OpenFileDialog();
                fd.Multiselect = true;
                fd.Filter = "PBN files (*.pbn)|*.pbn|All files (*.*)|*.*";
                if (fd.ShowDialog() == DialogResult.OK)
                {
                    filenames = new List<String>(fd.FileNames);
                }
            }
            return filenames;
        }

        [STAThread]
        static void Main(string[] args)
        {
            List<String> files = Program.getFiles(args);
            List<String> errors = new List<String>();
            if (files.Count > 0)
            {
                foreach (String filename in files)
                {
                    try
                    {
                        Console.WriteLine("Analyzing " + filename);
                        PBNFile file = new PBNFile(filename);
                        foreach (PBNBoard board in file.Boards)
                        {
                            DDTable table = new DDTable(board);
                            String boardNo;
                            try
                            {
                                boardNo = board.GetNumber();
                            }
                            catch (FieldNotFoundException)
                            {
                                boardNo = "?";
                            }
                            try
                            {
                                int[,] ddTable = table.GetDDTable();
                                if (ddTable != null)
                                {
                                    Console.WriteLine("Board " + boardNo);
                                    DDTable.PrintTable(ddTable);
                                    ParScore par = new ParScore(board);
                                    ParContract contract = par.GetParContract(ddTable);
                                    Console.WriteLine(contract);
                                    Console.WriteLine();
                                    board.SaveDDTable(ddTable);
                                    board.SaveParContract(contract);
                                    file.WriteBoard(board);
                                }
                                else
                                {
                                    String error = "unable to determine DD table for board " + boardNo;
                                    errors.Add(String.Format("[{0}] {1}", filename, error));
                                    Console.WriteLine("ERROR: " + error);
                                }
                            }
                            catch (DllNotFoundException)
                            {
                                throw;
                            }
                            catch (Exception e)
                            {
                                errors.Add(String.Format("[{0}:{1}] {2}", filename, boardNo, e.Message));
                                Console.WriteLine("ERROR: " + e.Message);
                            }
                        }
                        file.Save();
                    }
                    catch (DllNotFoundException e)
                    {
                        errors.Add("libbcalcdds.dll could not be loaded - make sure it's present in application directory!");
                        Console.WriteLine("ERROR: " + e.Message);
                        break;
                    }
                    catch (Exception e)
                    {
                        errors.Add(e.Message);
                        Console.WriteLine("ERROR: " + e.Message);
                    }
                }
                if (errors.Count > 0) {
                    Console.WriteLine("Following ERRORs occured:");
                    foreach (String error in errors) {
                        Console.WriteLine(error);
                    }
                    Console.WriteLine("Press any key to continue...");
                    Console.ReadKey();
                }
            }
        }
    }
}