예제 #1
0
        public static void Main(string[] args)
        {
            ExceptionLogging.Initialize("17a42e4a67dd2e42d4aa40d8bf2d23ee", Assembly.GetExecutingAssembly().GetName().Name);
            var options = AuxToolOptions.ParseCommandLineArgs(args);

            if (options == null)
            {
                return;
            }

            if (!File.Exists(options.Project))
            {
                Console.WriteLine("Can't find project file '{0}'", options.Project);
                return;
            }

            Icu.Wrapper.Init();

            // initialize the SLDR
            Sldr.Initialize();

            try
            {
                var projectFileInfo = new FileInfo(options.Project);
                options.Project = projectFileInfo.FullName;

                if (options.InfoOnly)
                {
                    DisplayInfo(options);
                }

                ExceptionLogging.Client.AddInfo(options.Project,
                                                FwProject.GetModelVersion(options.Project));

                if (options.Migrate)
                {
                    MigrateData(options);
                }

                if (options.Commit)
                {
                    CommitData(options);
                }
            }
            finally
            {
                if (Sldr.IsInitialized)
                {
                    Sldr.Cleanup();
                }

                Icu.Wrapper.Cleanup();
            }
        }
예제 #2
0
        public static void Main(string[] args)
        {
            ExceptionLogging.Initialize("17a42e4a67dd2e42d4aa40d8bf2d23ee", Assembly.GetExecutingAssembly().GetName().Name);
            var options = AuxToolOptions.ParseCommandLineArgs(args);

            if (options == null)
            {
                return;
            }

            if (!File.Exists(options.Project))
            {
                Console.WriteLine("Can't find project file '{0}'", options.Project);
                return;
            }

            if (options.InfoOnly)
            {
                Console.WriteLine("{0} has model version {1}", Path.GetFileName(options.Project),
                                  FwProject.GetModelVersion(options.Project));
            }

            ExceptionLogging.Client.AddInfo(options.Project, FwProject.GetModelVersion(options.Project));

            if (options.Migrate)
            {
                var oldVersion = FwProject.GetModelVersion(options.Project);
                try
                {
                    var project = Path.Combine(Path.GetDirectoryName(options.Project),
                                               Path.GetFileNameWithoutExtension(options.Project));
                    FwProject.AllowDataMigration = true;
                    using (new FwProject(new LfMergeSettings(), project))
                    {
                        Console.WriteLine("Migrated {0} from {1} to {2}",
                                          Path.GetFileName(options.Project), oldVersion,
                                          FwProject.GetModelVersion(options.Project));
                    }
                }
                catch (FdoDataMigrationForbiddenException)
                {
                    Console.WriteLine("FDO: Incompatible version (can't migrate data)");
                }
                catch (FdoNewerVersionException)
                {
                    Console.WriteLine("FDO: Incompatible version (version number newer than expected)");
                }
                catch (FdoFileLockedException)
                {
                    Console.WriteLine("FDO: Access denied");
                }
                catch
                {
                    Console.WriteLine("FDO: Unknown error");
                }
            }

            if (options.Commit)
            {
                var hgDir = Path.Combine(Path.GetDirectoryName(options.Project), ".hg");
                if (!Directory.Exists(hgDir))
                {
                    Console.WriteLine("It looks the project isn't setup for S/R - can't find '{0}'",
                                      hgDir);
                    return;
                }

                // Call into LF Bridge to do the work.
                string syncResult;
                var    mergeBridgeOptions = new Dictionary <string, string> {
                    { "fullPathToProject", Path.GetDirectoryName(options.Project) },
                    { "fwdataFilename", options.Project },
                    { "fdoDataModelVersion", FdoCache.ModelVersion },
                };
                var result = LfMergeBridge.LfMergeBridge.Execute("Language_Forge_Auxiliary_Commit",
                                                                 new NullProgress(), mergeBridgeOptions, out syncResult);

                Console.WriteLine(syncResult);
                if (result)
                {
                    Console.WriteLine("Successfully updated .hg files");
                }
            }
        }