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
|
//////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////////
//
// copyright : (C) 2014 Eran Ifrah
// file name : svncommand.cpp
//
// -------------------------------------------------------------------------
// A
// _____ _ _ _ _
// / __ \ | | | | (_) |
// | / \/ ___ __| | ___| | _| |_ ___
// | | / _ \ / _ |/ _ \ | | | __/ _ )
// | \__/\ (_) | (_| | __/ |___| | || __/
// \____/\___/ \__,_|\___\_____/_|\__\___|
//
// F i l e
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2 of the License, or
// (at your option) any later version.
//
//////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////////
#include "environmentconfig.h"
#include "file_logger.h"
#include "globals.h"
#include "imanager.h"
#include "subversion2.h"
#include "subversion_strings.h"
#include "svn_console.h"
#include "svncommand.h"
#include <wx/aui/framemanager.h>
SvnCommand::SvnCommand(Subversion2* plugin)
: m_process(NULL)
, m_handler(NULL)
, m_plugin(plugin)
{
Bind(wxEVT_ASYNC_PROCESS_OUTPUT, &SvnCommand::OnProcessOutput, this);
Bind(wxEVT_ASYNC_PROCESS_TERMINATED, &SvnCommand::OnProcessTerminated, this);
}
SvnCommand::~SvnCommand() { ClearAll(); }
bool SvnCommand::Execute(const wxString& command, const wxString& workingDirectory, SvnCommandHandler* handler,
Subversion2* plugin)
{
// Dont run 2 commands at the same time
if(m_process) {
wxDELETE(handler);
return false;
}
ClearAll();
// Apply the environment variables before executing the command
wxStringMap_t om;
om.insert(std::make_pair("LC_ALL", "C"));
bool useOverrideMap = m_plugin->GetSettings().GetFlags() & SvnUsePosixLocale;
EnvSetter env(m_plugin->GetManager()->GetEnv(), useOverrideMap ? &om : NULL);
m_process = CreateAsyncProcess(this, command, IProcessCreateDefault | IProcessWrapInShell, workingDirectory);
if(!m_process) {
return false;
}
m_workingDirectory = workingDirectory.c_str();
m_command = command.c_str();
m_handler = handler;
return true;
}
void SvnCommand::OnProcessOutput(clProcessEvent& event)
{
m_output.Append(event.GetOutput());
LOG_IF_TRACE { clDEBUG1() << "Subversion:" << m_output << clEndl; }
}
void SvnCommand::OnProcessTerminated(clProcessEvent& event)
{
if(m_handler) {
LOG_IF_TRACE { clDEBUG1() << "Subversion:" << m_output << clEndl; }
if(m_handler->TestLoginRequired(m_output)) {
// re-issue the last command but this time with login dialog
m_handler->GetPlugin()->GetConsole()->AppendText(_("Authentication failed. Retrying...\n"));
m_handler->ProcessLoginRequired(m_workingDirectory);
} else if(m_handler->TestVerificationFailed(m_output)) {
m_handler->GetPlugin()->GetConsole()->AppendText(
_("Server certificate verification failed. Retrying...\n"));
m_handler->ProcessVerificationRequired();
} else {
// command ended successfully, invoke the "success" callback
m_handler->Process(m_output);
}
wxDELETE(m_handler);
}
wxDELETE(m_process);
}
void SvnCommand::ClearAll()
{
m_workingDirectory.Clear();
m_command.Clear();
m_output.Clear();
}
|