C # SVN Pre Commit Hook, ошибка SharpSvn - PullRequest
1 голос
/ 22 февраля 2011

У меня есть консольное приложение C #, которое я использую как SVN Pre Commit Hook.Консольное приложение запускается отлично.Однако, как только я пытаюсь выполнить запись с использованием SharpSvn, я получаю эту ошибку:

Commit failed (details follow):
Commit blocked by pre-commit hook (exit code -1066598274) with output:

Unhandled Exception: System.Runtime.InteropServices.SEHException: External 
component has thrown an exception.
at svn_client_cat2(svn_stream_t* , SByte* , svn_opt_revision_t* , 
svn_opt_revision_t* , svn_client_ctx_t* , apr_pool_t* )
at SharpSvn.SvnClient.Write(SvnTarget target, Stream output, SvnWriteArgs args)
   at SharpSvn.SvnClient.Write(SvnTarget target, Stream output)
   at SvnPreCommitHook.Program.Main(String[] args)

Я попытался выполнить команду svn.Write со своего компьютера, указывая на svn: // svn-сервер вместо localhost - и это прекрасно работает.Я думаю, это что-то на сервере.TortoiseSVN установлен, хотя я не вижу никаких контекстных меню ...

Мой код выглядит так:

private static EventLog _serviceEventLog;

static void Main(string[] args)
{
    _serviceEventLog = new EventLog();

    if (!System.Diagnostics.EventLog.SourceExists("Svn Hooks"))
    {
        System.Diagnostics.EventLog.CreateEventSource("Svn Hooks", "Svn Hooks");
    }

    _serviceEventLog.Source = "Svn Hooks";
    _serviceEventLog.Log = "Svn Hooks";

    SvnHookArguments ha;
    if (!SvnHookArguments.ParseHookArguments(args, SvnHookType.PreCommit, false, out ha))
    {
        /*Console.Error.WriteLine("Invalid arguments");
        Environment.Exit(1);*/
    }

    using (SvnLookClient cl = new SvnLookClient())
    {
        SvnChangeInfoEventArgs ci;
        cl.GetChangeInfo(ha.LookOrigin, out ci);

        if (!ci.LogMessage.Equals("Svn Hook Test"))
        {
            AllowCommit();

            return;
        }

        var checkoutDir = @"C:\SvnTemp\" + DateTime.Now.Ticks.ToString();

        foreach (SvnChangeItem i in ci.ChangedPaths)
        {
            var checkoutFilepath = checkoutDir + "\\" + Path.GetFileName(i.Path);

            if (!Directory.Exists(checkoutDir))
            {
                Directory.CreateDirectory(checkoutDir);
            }

            using (SvnClient svn = new SvnClient())
            {
                using (StreamWriter sw = new StreamWriter(checkoutFilepath))
                {
                    svn.Write(SvnTarget.FromString("svn://localhost/" + i.RepositoryPath), sw.BaseStream);
                }
            }

            var fileContents = File.ReadAllText(checkoutFilepath);

            if (fileContents.Contains("Martin Normark"))
            {
                RemoveTempDirectory(checkoutDir);

                PreventCommit("Name is not allowed!");
            }
        }

        RemoveTempDirectory(checkoutDir);
    }

    AllowCommit();
}

1 Ответ

0 голосов
/ 22 февраля 2011

Возможно одно из следующего:

  • 64 бит против 32 бит
  • vcredist отсутствует на сервере
...