当前位置: 首页>>代码示例>>C#>>正文


C# System.Diagnostics.Process.Kill方法代码示例

本文整理汇总了C#中System.Diagnostics.Process.Kill方法的典型用法代码示例。如果您正苦于以下问题:C# System.Diagnostics.Process.Kill方法的具体用法?C# System.Diagnostics.Process.Kill怎么用?C# System.Diagnostics.Process.Kill使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在System.Diagnostics.Process的用法示例。


在下文中一共展示了System.Diagnostics.Process.Kill方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: Exec

        public static string Exec(String command)
        {
            Console.WriteLine("command : " + command);
            System.Diagnostics.Process p = new System.Diagnostics.Process();
            p.StartInfo.UseShellExecute = false;
            p.StartInfo.CreateNoWindow = true;
            p.StartInfo.FileName = "cmd.exe";
            p.StartInfo.Arguments = "/c " + command;
            p.StartInfo.RedirectStandardError = true;
            p.StartInfo.RedirectStandardInput = true;
            p.StartInfo.RedirectStandardOutput = true;

            p.Start();

            var stdout = new StringBuilder();
            var stderr = new StringBuilder();
            p.OutputDataReceived += (sender, e) => {
                if (e.Data != null) {
                    stdout.AppendLine(e.Data);
                }
            };
            p.ErrorDataReceived += (sendar, e) => {
                if (e.Data != null) {
                    stderr.AppendLine(e.Data);
                }
            };
            p.BeginOutputReadLine();
            p.BeginErrorReadLine();

            var output = new StringBuilder();
            var isTimeOut = false;
            if (!p.WaitForExit(3000)) {
                isTimeOut = true;
                p.Kill();
            }
            p.CancelOutputRead();
            p.CancelErrorRead();
            output.Append(stdout.ToString());
            output.Append(stderr.ToString());
            if (isTimeOut) {
                output.Append("TIMEOUT.");
            }
            return output.ToString();
        }
开发者ID:Kuchinashi,项目名称:AndroidExplorer,代码行数:44,代码来源:DoCommand.cs

示例2: CreateRepl

		public void CreateRepl(Process replProcess)
		{
			var tabItem = new ReplTab();
			var replEntity = new Entity<ReplState> { CurrentState = new ReplState() };

			WireUpTheTextBoxInputToTheReplProcess(tabItem.InteractiveText, replProcess, replEntity);
			WireUpTheOutputOfTheReplProcessToTheTextBox(tabItem.InteractiveText, replProcess, replEntity);
			WireUpTheReplEditorCommandsToTheEditor(tabItem.InteractiveText, replProcess, replEntity, tabItem);

			tabItem.CloseButton.Click +=
			(o, e) =>
			{
				replProcess.Kill();
				ReplManager.Items.Remove(tabItem);
			};

			ReplManager.Items.Add(tabItem);
			ReplManager.SelectedItem = tabItem;
		  ReplToolWindow.Show();
		}
开发者ID:rpete4130,项目名称:vsClojure,代码行数:20,代码来源:ReplFactory.cs

示例3: runShellCommand

 internal static bool runShellCommand(string command) {
     System.Diagnostics.Process p = new System.Diagnostics.Process {
         StartInfo = new System.Diagnostics.ProcessStartInfo {
             WindowStyle = System.Diagnostics.ProcessWindowStyle.Hidden,
             FileName = "cmd.exe",
             Arguments = (@"CMD /C " + command)
         }
     };
     p.Start();
     p.WaitForExit(5000);
     if (p.HasExited == false) { //Check to see if the process is still running.
         if (p.Responding) {//Test to see if the process is hung up.
             p.CloseMainWindow();//Process was responding; close the main window.
             return false;
         } else {
             p.Kill(); //Process was not responding; force the process to close.
             return false;
         }
     }
     return true;
 }
开发者ID:ubuetake,项目名称:selenium-vba,代码行数:21,代码来源:Utils.cs

示例4: PrintPDF

        public static void PrintPDF(string path)
        {
            string printerPath = "";
            PrintDialog pd = new PrintDialog();
            var result = pd.ShowDialog();
            if (result == DialogResult.OK)
            {
                printerPath = pd.PrinterSettings.PrinterName;
            }

            //string printer = GetDefaultPrinter();
            System.Diagnostics.Process process = new System.Diagnostics.Process();
            process.StartInfo.FileName = path;
            process.StartInfo.Verb = "printto";
            process.StartInfo.Arguments = "\"" + printerPath + "\"";

            process.Start();

            // I have to use this in case of Adobe Reader to close the window
            process.WaitForInputIdle();
            process.Kill();
        }
开发者ID:jmd7p7,项目名称:Futures-In-Faith,代码行数:22,代码来源:PDFPrinter.cs

示例5: Main

 static void Main(string[] args)
 {
     System.Diagnostics.Process process = new System.Diagnostics.Process();
     
     process.Kill();
     //InternetExplorer ie = new InternetExplorer();
     //object Empty = 0;
     
     //ie.BeforeNavigate2 += new DWebBrowserEvents2_BeforeNavigate2EventHandler(ie_BeforeNavigate2);
     //ie.Visible = true;
     //ie.Navigate("http://www.google.com", ref Empty, ref Empty, ref Empty, ref Empty);
     //for (int i = 0; i < 10; i++)
     //{
     //    Thread.Sleep(500);
     //    SendKeys.Send("{Tab}");
     //}
     //Thread.Sleep(10000);
     //ie.Quit();
    
     //CallBack call = new CallBack(EnumeratorWindow);
     //EnumWindows(call, 0);
 }
开发者ID:EdiCarlos,项目名称:MyPractices,代码行数:22,代码来源:Program.cs

示例6: Reopen

		/// <summary>
		/// Restart the file reading at the beginning.
		/// </summary>
		/// <exception cref="IOException">The command cannot be executed.</exception>
		/// <exception cref="InvalidOperationException">The stream is not reopenable</exception>
		protected virtual void Reopen()
		{
			if (!reopenable) throw new InvalidOperationException("The stream is not reopenable.");
			Finish();
			if (proc != null)
			{
				try
				{
					proc.Kill();
					proc.WaitForExit();
				}
				catch
				{
				}
				//proc.WaitForExit();
				proc.Close();
				proc = null;
			}

			exitCode = -10;
			try
			{
				// **** threads must be restarted!!

				if (commandName.IndexOf('\\') < 0 && commandName.IndexOf('/') < 0) // && !File.Exists(commandName))
				{
					// should this be done? ***
					string foundName = FindInPath(commandName);
					if (foundName == null) foundName = FindInPath(commandName + ".exe");
					if (foundName == null) foundName = FindInPath(commandName + ".cmd");
					if (foundName == null) foundName = FindInPath(commandName + ".bat");
					if (foundName == null)
					{
						throw new InvalidOperationException("Stream cannot be created to wrap '" + commandName +
							"' because it cannot be found.");
					}
					commandName = foundName;
				}
				System.Diagnostics.ProcessStartInfo psi = new System.Diagnostics.ProcessStartInfo(commandName, commandArgs);
				//psi.WorkingDirectory = workingDir;
				psi.WindowStyle = System.Diagnostics.ProcessWindowStyle.Hidden;
				psi.CreateNoWindow = true;
				psi.RedirectStandardInput = !skipStdin;  // is this always OK?
				psi.RedirectStandardOutput = true;
				psi.RedirectStandardError = true;
#if DOTNET2
				psi.StandardOutputEncoding = Encoding.UTF8;
#endif
				psi.UseShellExecute = false;

				if (psiCustomizer != null)
				{
					psiCustomizer(psi);
				}

				proc = System.Diagnostics.Process.Start(psi);

				StreamReader outReader = proc.StandardOutput;
				if (outReader == null)
				{
					throw new IOException("Cannot obtain output reader for command");
				}
				outStream = outReader.BaseStream;
				if (outStream == null)
				{
					throw new IOException("Cannot obtain output stream for command");
				}
#if !NO_BUFFER
				// this is a small buffer to make byte operations not be horribly expensive:
				//outStream = new BufferedStream(outStream, 4096 << 1);
				outStream = new BufferedStream(outStream, BUFFER_SIZE);
#endif
				errorThread = IOUtil.ConsumeBackground(proc.StandardError);

				// is this always OK?
				if (skipStdin)
				{
					inStream = null;
				}
				else
				{
					StreamWriter inWriter = proc.StandardInput;
					if (inWriter == null)
					{
						throw new IOException("Cannot obtain input writer for command");
					}
					inStream = inWriter.BaseStream;
					if (inStream == null)
					{
						throw new IOException("Cannot obtain input stream for command");
					}
#if !NO_BUFFER
					// this is a small buffer to make byte operations not be horribly expensive:
					//inStream = new BufferedStream(inStream, 4096 << 1);
					inStream = new BufferedStream(inStream, BUFFER_SIZE);
//.........这里部分代码省略.........
开发者ID:zbxzc35,项目名称:BoostTree,代码行数:101,代码来源:MiscStreams.cs

示例7: RunFfmpegCmd

        /// <summary>
        /// Runs the ffmpeg command
        /// </summary>
        public void RunFfmpegCmd()
        {
            // can we run it?
            if (worker != null) {
                Debug.LogError ("Please command is still running. Wait it to complete or kill it first");
                return;
            }

            if(File.Exists(FinalOutfile)) {
                if (!EditorUtility.DisplayDialog ("Overwrite?", FinalOutfile + " exists. Overwrite?", "Yes", "No")) {
                    Debug.Log ("Output file '" + FinalOutfile + "' exists, didn't overwrite");
                    return;
                }
            }

            string ffmpegArgs = BuildFfmpegArgs ();
            Debug.Log ("Running: " + ffmpegPath + " " + ffmpegArgs);

            // start ffmpeg process inside a background worker so that it won't block the UI
            worker = new BackgroundWorker ();
            worker.WorkerReportsProgress = true;
            worker.WorkerSupportsCancellation = true;
            worker.DoWork += delegate(object sender, DoWorkEventArgs e) {
                // start the process.
                // currently we're doing it the easy way and not capturing standard input and output
                // for creating better UX.
                var process = new System.Diagnostics.Process ();
                process.StartInfo = new System.Diagnostics.ProcessStartInfo (ffmpegPath, ffmpegArgs);
                process.StartInfo.CreateNoWindow = false;
                process.StartInfo.UseShellExecute = true;
                process.Start ();
                do {
                    process.WaitForExit (200);
                    if (worker.CancellationPending) {
                        process.Kill ();
                    }
                } while(!process.HasExited);
                ffmpegExitCode = process.ExitCode;
            };
            worker.RunWorkerAsync ();
        }
开发者ID:sawakun,项目名称:Sphere_screen,代码行数:44,代码来源:FfmpegWindow.cs

示例8: Execute

        static string Execute(string cmd, string arguments)
        {
            string result = "";
            using (System.Diagnostics.Process shell = new System.Diagnostics.Process())
            {
                shell.StartInfo.UseShellExecute = false;

                shell.StartInfo.FileName = cmd;
                shell.StartInfo.Arguments = arguments;
                shell.StartInfo.WindowStyle = System.Diagnostics.ProcessWindowStyle.Hidden;

                shell.StartInfo.RedirectStandardOutput = true;
                shell.Start();
                if (shell.WaitForExit(3 * 60 * 1000))
                {
                    result = shell.StandardOutput.ReadToEnd();
                    shell.Close();
                }
                else
                {
                    shell.Kill();
                    Kill(System.IO.Path.GetFileName(cmd), System.IO.Path.GetDirectoryName(cmd));
                    Kill("DW20.exe", System.IO.Path.GetDirectoryName(cmd));
                }
                return result;
            }
        }
开发者ID:Redi0,项目名称:meijing-ui,代码行数:27,代码来源:Program.cs

示例9: RunPyScript

        public bool RunPyScript(string sArguments, int iTimeOutMinutes)
        {

            System.Diagnostics.ProcessStartInfo procStartInfo = null;
            System.Diagnostics.Process proc = null;
            RegistryKey rk = null;
            string sCommand = string.Empty;
            try
            {
                // Get sPythonDir from registry
                string sPythonDir = @"C:\Python27\ArcGIS10.1\";

                string subkey = @"SOFTWARE\Python\PythonCore\2.7\InstallPath";
                string value64 = string.Empty; 
                string value32 = string.Empty; 
                RegistryKey localKey = RegistryKey.OpenBaseKey(Microsoft.Win32.RegistryHive.LocalMachine, RegistryView.Registry64);
                localKey = localKey.OpenSubKey(subkey);
                if (localKey != null)
                {
                    sPythonDir = localKey.GetValue("").ToString();
                }
                else
                {
                    RegistryKey localKey32 = RegistryKey.OpenBaseKey(Microsoft.Win32.RegistryHive.LocalMachine, RegistryView.Registry32);
                    localKey32 = localKey32.OpenSubKey(subkey);
                    if (localKey32 != null)
                    {
                        sPythonDir = localKey32.GetValue("").ToString();
                    }

                }

                sCommand = Path.Combine(sPythonDir, "python.exe") + " " + sArguments;                
                // Create the ProcessStartInfo using "cmd" as the program to be run,
                // and "/c " as the parameters.
                // "/c" tells cmd that you want it to execute the command that follows,
                // then exit.
                procStartInfo = new System.Diagnostics.ProcessStartInfo("cmd", "/c " + sCommand);

                // The following commands are needed to redirect the standard output.
                // This means that it will be redirected to the Process.StandardOutput StreamReader.
                procStartInfo.RedirectStandardOutput = true;
                procStartInfo.RedirectStandardError = true;
                procStartInfo.UseShellExecute = false;

                // Do not create the black window.
                procStartInfo.CreateNoWindow = true;

                // Now you create a process, assign its ProcessStartInfo, and start it.
                proc = new System.Diagnostics.Process();
                proc.StartInfo = procStartInfo;
                proc.Start();
                proc.WaitForExit(iTimeOutMinutes * 60 * 1000);


                // Get the output into a string.
                _errOutput = proc.StandardError.ReadToEnd();
                _stdOutput = proc.StandardOutput.ReadToEnd().TrimEnd('\r', '\n');               

                int exitCode = proc.ExitCode;
                Console.WriteLine("Exit Code: {0}", proc.ExitCode);

                if (exitCode != 0 && (!(string.IsNullOrEmpty(_errOutput))))
                {
                    _errOutput = "Error in RunPyScript! Command: " + sCommand + Environment.NewLine + _errOutput;
                    return false;
                }

                return true;
            }
            catch (Exception objException)
            {
                Console.WriteLine(objException.Message);
                // Log the exception and errors.
                _errOutput = "Error in RunPyScript! Command: " + sCommand + Environment.NewLine + objException.Message;
                return false;
            }
            finally
            {
                if (!(proc == null))
                {
                    if (!(proc.HasExited))
                    {
                        proc.Kill();
                    }
                    proc = null;
                }
                rk = null;
            }
        }
开发者ID:joshuacroff,项目名称:arcgis-osm-editor,代码行数:90,代码来源:RunPython.cs

示例10: OnStart

        //////////////////////////////////////////////////////////////////////////
        /// <summary>
        /// </summary>
        //////////////////////////////////////////////////////////////////////////
        private void OnStart(object sender, DoWorkEventArgs e)
        {
            var nantCommand   = Properties.Settings.Default.NANT_COMMAND;
            var nantArguments = string.Format(Properties.Settings.Default.NANT_PARAMS,  m_Filename, m_TargetNode["name"]);

            var workingDir = Path.GetDirectoryName( m_Filename );

            if ( !Path.IsPathRooted( nantCommand ) && !string.IsNullOrEmpty(workingDir) )
            {//if the path is not rooted, then make it relative to the mFileName path.
                nantCommand = Path.Combine( workingDir, nantCommand );
            }

            try
            {
                string nantOutput = null;

                // Create and initialize the process
                m_NAntProcess = new System.Diagnostics.Process();

                m_NAntProcess.StartInfo.UseShellExecute = false;
                m_NAntProcess.StartInfo.RedirectStandardError = true;
                m_NAntProcess.StartInfo.RedirectStandardOutput = true;
                m_NAntProcess.StartInfo.CreateNoWindow = true;
                m_NAntProcess.StartInfo.FileName = nantCommand;
                m_NAntProcess.StartInfo.WorkingDirectory = workingDir;
                m_NAntProcess.StartInfo.Arguments = nantArguments;

                // Start process
                m_NAntProcess.Start();

                // Read standard output and write string in console
                while ((nantOutput = m_NAntProcess.StandardOutput.ReadLine()) != null)
                {
                    if (m_BackgroundWorker.CancellationPending)
                    {
                        if (!m_NAntProcess.HasExited)
                        {
                            m_NAntProcess.Kill();
                            m_NAntProcess.WaitForExit();
                            e.Cancel = true;
                        }
                    }
                    else
                    {
                        nantOutput += System.Environment.NewLine;
                        m_BackgroundWorker.ReportProgress(0, nantOutput);
                    }
                }
            }
            catch (Exception e1)
            {
                // Trace exception on console
                WriteConsole("[NAntAddin]: Unexpected error occured while executing command: "
                    + Environment.NewLine
                    + "\t" + nantCommand + nantArguments
                    + Environment.NewLine
                    + Environment.NewLine
                    + "An exception has been raised with the following stacktrace:"
                    + Environment.NewLine
                    + "   " + e1.Message
                    + Environment.NewLine
                    + e1.StackTrace
                    + Environment.NewLine
                    + Environment.NewLine
                    + "Please check that NAnt command path is properly configured within NAntAddin options."
                    + Environment.NewLine
                );
            }
        }
开发者ID:bchavez,项目名称:NAntAddin2,代码行数:73,代码来源:NAntProcess.cs

示例11: Run_Import_ContextWithArchiveImage_Case1572

        // Case1572: 1.1.06.11_Import Context_Normal_contains an archived image
        public void Run_Import_ContextWithArchiveImage_Case1572()
        {
            int runCount = 0;
            foreach (InputDataSet ids in this.Input.DataSets)
            {
                string patientdir = string.Empty;
                runCount++;
                Round r = this.NewRound(runCount.ToString(), "Acquisition");
                CheckPoint pImportAnalysis = new CheckPoint("Import Context", "Import Context using conversiontool");
                r.CheckPoints.Add(pImportAnalysis);

                PatientService pa = new PatientService();
                XMLParameter query = new XMLParameter("filter");
                //XMLParameter psa = new XMLParameter("presentationstate");

                //XMLParameterCollection psaCollection = new XMLParameterCollection();

                for (int i = 0; i < ids.InputParameters.Count; i++)
                {
                    if (ids.InputParameters.GetParameter(i).Step == "patient")
                    {
                        if (ids.InputParameters.GetParameter(i).Key == "patientdir")
                            patientdir = ids.InputParameters.GetParameter(i).Value;
                        else
                            query.AddParameter(ids.InputParameters.GetParameter(i).Key, ids.InputParameters.GetParameter(i).Value);
                    }
                }
                System.Diagnostics.Process p = new System.Diagnostics.Process();
                p.StartInfo.FileName = System.IO.Directory.GetCurrentDirectory() + "\\ConversionTool version 1.0.4.0\\conversiontool.exe";
                p.StartInfo.Arguments = "-P\"" + patientdir + "\"";
                p.Start();
                System.Threading.Thread.Sleep(20000);
                p.Kill();

                XMLResult rslQuery = pa.queryPatients(query);
                string puid = null;

                if (rslQuery.IsErrorOccured)
                {
                    pImportAnalysis.Result = TestResult.Fail;
                    pImportAnalysis.Outputs.AddParameter("archiveFMS Import", "Query Fail:", rslQuery.Message);
                    goto CLEANUP;
                }
                else
                {
                    puid = rslQuery.SingleResult;
                }

                NewPatientService nps = new NewPatientService();
                PatientListObjectsRequestType request = new PatientListObjectsRequestType();
                request.type = PatientListObjectsType.all;
                request.currentSpecified = true;
                request.current = true;
                request.patientInternalId = puid;

                nps.listObjects(request);

                System.Threading.Thread.Sleep(10000);
                PatientListObjectsResponseType response = nps.listObjects(request);

                if (!nps.LastReturnXMLValidateResult.isValid)
                {
                    pImportAnalysis.Result = TestResult.Fail;
                    pImportAnalysis.Outputs.AddParameter("archiveContext Import", "List Fail:", "Response is not complied with XML Schema");
                    goto CLEANUP;
                }

                if (response.status.code != 0)
                {
                    pImportAnalysis.Result = TestResult.Fail;
                    pImportAnalysis.Outputs.AddParameter("archiveContext Import", "List Fail:", response.status.message);
                    goto CLEANUP;
                }

                if (ids.ExpectedValues.GetParameter("currentps").Value != null)
                {
                    if (response.presentationStates.Length.ToString() != ids.ExpectedValues.GetParameter("currentps").Value)
                    {
                        pImportAnalysis.Result = TestResult.Fail;
                        pImportAnalysis.Outputs.AddParameter("archiveContext Import", "Import Fail:", "Expected" + ids.ExpectedValues.GetParameter("currentps").Value + "PS, actual:" + response.presentationStates.Length.ToString());
                        goto CLEANUP;
                    }
                }

                request.current = false; // below to check non-current PS and analysis
                response = nps.listObjects(request);
                if (!nps.LastReturnXMLValidateResult.isValid)
                {
                    pImportAnalysis.Result = TestResult.Fail;
                    pImportAnalysis.Outputs.AddParameter("archiveContext Import", "List Fail:", "Response is not complied with XML Schema");
                    goto CLEANUP;
                }

                if (response.status.code != 0)
                {
                    pImportAnalysis.Result = TestResult.Fail;
                    pImportAnalysis.Outputs.AddParameter("archiveContext Import", "List Fail:", response.status.message);
                    goto CLEANUP;
                }
//.........这里部分代码省略.........
开发者ID:Manivannan-ezhumalai,项目名称:AutomationTestFramework,代码行数:101,代码来源:Import.cs

示例12: InstallAppx

        public InstallResult InstallAppx(string filepath)
        {
            var result = new InstallResult();

              try
              {
            var sb = new StringBuilder();
            sb.Append(@"add-appxpackage ");
            sb.Append(filepath);

            var process = new System.Diagnostics.Process();
            process.StartInfo.UseShellExecute = false;
            process.StartInfo.RedirectStandardError = true;
            process.StartInfo.RedirectStandardOutput = true;

            process.StartInfo.FileName = "powershell.exe";
            process.StartInfo.Arguments = sb.ToString();

            process.StartInfo.CreateNoWindow = false;
            process.StartInfo.WindowStyle = System.Diagnostics.ProcessWindowStyle.Hidden;

            process.Start();

            var stdout = process.StandardOutput;
            var stderr = process.StandardError;

            result.Output = stdout.ReadToEnd();
            result.Error = stderr.ReadToEnd();

            if (!process.HasExited)
              process.Kill();

            stdout.Close();
            stderr.Close();
              }
              catch (Exception ex)
              {
            if (string.IsNullOrWhiteSpace(result.Error))
              result.Error = ex.Message;
            else
              result.Error += Environment.NewLine + ex.Message;
              }
              finally
              {
            File.Delete(filepath);
              }

              return result;
        }
开发者ID:Bowman74,项目名称:OrgPortal,代码行数:49,代码来源:Installer.cs

示例13: MainForm_FormClosing

        private void MainForm_FormClosing(object sender, FormClosingEventArgs e)
        {
            //Try to kill winvnc on exit in case it is still running.
            //Since this is a single instance app there should only be one instance running
            System.Diagnostics.Process p = new System.Diagnostics.Process();
            if (Globals.WinVncProcessID != -1)
            {
                p = System.Diagnostics.Process.GetProcessById(Globals.WinVncProcessID);
                p.Kill();
                p.WaitForExit();  // give time to exit before proceeding to try the delete
            }

            //System.Diagnostics.Process.Start(System.IO.Path.Combine(Globals.ProcomSupportLocalAppDataDirectory, "winvnc.exe") & " -kill")
            //System.Threading.Thread.Sleep(5000)

            try
            {
                // Since this is a single instance app there should only be able to be one copy of this directory
                // So we get rid of our temp files when finished.
                //System.IO.Directory.Delete(Globals.MajorSilenceSupportLocalAppDataDirectory, true);
                if (System.IO.Directory.Exists(Globals.MajorSilenceSupportLocalAppDataDirectory))
                {
                    DeleteFilesRecursively(new DirectoryInfo(Globals.MajorSilenceSupportLocalAppDataDirectory));
                }

            }
            catch (UnauthorizedAccessException uex)
            {
                MessageBox.Show("Error cleaning up temp support files." + uex.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
            catch (IOException iex)
            {
                MessageBox.Show("Error cleaning up temp support files." + iex.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }

            MessageBox.Show("MajorSilenceConnect Software Support is now closed.", "MajorSilenceConnect Support Closed", MessageBoxButtons.OK, MessageBoxIcon.Information);
        }
开发者ID:majorsilence,项目名称:MajorSilenceConnect,代码行数:37,代码来源:MainForm.cs

示例14: Main


//.........这里部分代码省略.........
                        if (lSide == "buttons" || lSide == "b")
                            buttonsString = rSide;
                        else if (lSide == "exec" || lSide == "e")
                            execString = rSide;
                        else if (lSide == "params" || lSide == "p")
                            paramsString = rSide;
                        else if (lSide == "time" || lSide == "t")
                            timeString = rSide;
                        else if (lSide == "contoller" || lSide == "c")
                            controllerString = rSide;
                    }
                }

                {
                    bool error = false;
                    int oVal = 0;

                    Console.ForegroundColor = ConsoleColor.Yellow;
                    foreach (var b in buttonsString.Split('+')) //Find Button Combo that is required
                    {
                        if (int.TryParse(b, out oVal))
                            buttonCombo += (int)Math.Pow(2, oVal);
                        else
                        {
                            if (buttonsString == string.Empty)
                                Console.WriteLine("A button combination is not specififed.");
                            else
                                Console.WriteLine("The button argument is not used properly.");
                            error = true;
                            break;
                        }
                    }
                    if (!System.IO.File.Exists(execString))
                    {
                        if (execString == string.Empty)
                            Console.WriteLine("An executable is not specififed.");
                        else
                            Console.WriteLine("The executable does not exist, it's possibly an invalid path.");
                        error = true;
                    }
                    if (!int.TryParse(timeString, out time))
                    {
                        Console.WriteLine("The time argument not used properly.");
                        error = true;
                    }
                    if (!int.TryParse(controllerString, out controllerNum))
                    {
                        Console.WriteLine("The controller argument not used properly.");
                        error = true;
                    }
                    if(error)
                    {
                        Console.ForegroundColor = ConsoleColor.Green;
                        Console.WriteLine("Command      Alt   Purpose");
                        Console.ForegroundColor = ConsoleColor.White;
                        Console.WriteLine("--buttons    --b   Button combination to close the program" + Environment.NewLine +
                                          "                       --b=0+8+6" + Environment.NewLine +
                                          "--exec       --e   Full path to the executable" + Environment.NewLine +
                                          "                       --e=C:\\Emulators\\nestopia.exe" + Environment.NewLine +
                                          "--controller --c   ID of specific controller to use           [Optional]" + Environment.NewLine +
                                          "                       --c=0" + Environment.NewLine +
                                          "--time       --t   Milliseconds to hold down the combination  [Optional]" + Environment.NewLine +
                                          "                       --t=2500" + Environment.NewLine +
                                          "--params     --p   Parameters when launching the program      [Optional]" + Environment.NewLine +
                                          "                       --p=C:\\roms\\NES\\Super Mario Bros..nes");
                        Console.ForegroundColor = ConsoleColor.Gray;
                        return;
                    }
                    else
                        Console.ForegroundColor = ConsoleColor.Gray;
                }

                controller = new Controller(controllerNum, buttonCombo); //Controller class that handles button presses when checked

                runProgram = new System.Diagnostics.Process(); //Start up the program
                runProgram.StartInfo.FileName = execString;
                runProgram.StartInfo.Arguments = paramsString;
                runProgram.StartInfo.WorkingDirectory = System.IO.Path.GetDirectoryName(execString);
                runProgram.Start();
            }

            while(true)
            {
                if (!controller.comboPressed())
                {
                    timer.Restart();
                }
                else if(timer.ElapsedMilliseconds >= time)
                {
                    try
                    {
                        runProgram.Kill();
                    }
                    catch { }
                    return;
                }

                System.Threading.Thread.Sleep(35);
            }
        }
开发者ID:BitLooter,项目名称:quitbit,代码行数:101,代码来源:QuitBit.cs

示例15: Run_Import_ArchivedFMS_Case1570

        //Case 1570: 1.1.06.02_Import an archived FMS_Normal_contains shortcut of archived image(French FE Tool)
        public void Run_Import_ArchivedFMS_Case1570()
        {
            int runCount = 0;

            foreach (InputDataSet ids in this.Input.DataSets)
            {
                runCount++;
                Round r = this.NewRound(runCount.ToString(), "Import FMS1");
                CheckPoint pImportFMS = new CheckPoint("Import FMS1", "Import FMS using conversiontool");
                r.CheckPoints.Add(pImportFMS);
                string patientdir = ids.InputParameters.GetParameter("patientdir").Value;
                string patient_id = ids.InputParameters.GetParameter("patient_id").Value;
                string dpms_id = ids.InputParameters.GetParameter("dpms_id").Value;

                //call conversiontool to import archivedFMS
                System.Diagnostics.Process p = new System.Diagnostics.Process();
                p.StartInfo.FileName = System.IO.Directory.GetCurrentDirectory() + "\\ConversionTool version 1.0.4.0\\conversiontool.exe";
                p.StartInfo.Arguments = "-P\"" + patientdir + "\"";
                p.Start();
                System.Threading.Thread.Sleep(20000);
                p.Kill();

                string puid = null;
                PatientService ps = new PatientService();
                XMLParameter cInputQuery = new XMLParameter("filter");
                cInputQuery.AddParameter("dpms_id", dpms_id);
                cInputQuery.AddParameter("patient_id", patient_id);
                XMLResult rslQuery = ps.queryPatients(cInputQuery);
                if (rslQuery.IsErrorOccured)
                {
                    pImportFMS.Result = TestResult.Fail;
                    pImportFMS.Outputs.AddParameter("archiveFMS Import", "Query Fail:", rslQuery.Message);
                    SaveRound(r);
                    goto CLEANUP;
                }

                puid = rslQuery.SingleResult;
                //trigger the post import of FMS
                NewPatientService nps = new NewPatientService();
                PatientListObjectsRequestType request = new PatientListObjectsRequestType();
                request.type = PatientListObjectsType.all;
                request.currentSpecified = true;
                request.current = true;
                request.patientInternalId = puid;

                nps.listObjects(request);

                //wait the post import completed
                System.Threading.Thread.Sleep(10000);
                PatientListObjectsResponseType response = nps.listObjects(request);

                if (!nps.LastReturnXMLValidateResult.isValid)
                {
                    pImportFMS.Result = TestResult.Fail;
                    pImportFMS.Outputs.AddParameter("archiveFMS Import", "List Fail:", "Response is not complied with XML Schema");
                    SaveRound(r);
                    goto CLEANUP;
                }

                if (response.status.code != 0)
                {

                    pImportFMS.Result = TestResult.Fail;
                    pImportFMS.Outputs.AddParameter("archiveFMS Import", "List Fail:", response.status.message);
                    SaveRound(r);
                    goto CLEANUP;
                }
                if (response.fmss == null)
                {
                    pImportFMS.Result = TestResult.Fail;
                    pImportFMS.Outputs.AddParameter("archiveFMS Import", "Import Fail:", "Expected 3 fms, actual none.");
                    SaveRound(r);
                    goto CLEANUP;
                }
                else if (response.fmss.Length != 3)
                {
                    pImportFMS.Result = TestResult.Fail;
                    pImportFMS.Outputs.AddParameter("archiveFMS Import", "Import Fail:", "Expected 3 fms, actual:" + response.fmss.Length.ToString());
                    SaveRound(r);
                    goto CLEANUP;
                }

                if (response.presentationStates == null)
                {
                    pImportFMS.Result = TestResult.Fail;
                    pImportFMS.Outputs.AddParameter("archiveFMS Import", "Import Fail:", "Expected 21 PS, actual none.");
                    SaveRound(r);
                    goto CLEANUP;
                }
                else if (response.presentationStates.Length != 21)
                {
                    pImportFMS.Result = TestResult.Fail;
                    pImportFMS.Outputs.AddParameter("archiveFMS Import", "Import Fail:", "Expected 21 PS, actual:" + response.presentationStates.Length.ToString());
                    SaveRound(r);
                    goto CLEANUP;
                }

                foreach (PresentationStateType pstate in response.presentationStates)
                {
//.........这里部分代码省略.........
开发者ID:Manivannan-ezhumalai,项目名称:AutomationTestFramework,代码行数:101,代码来源:Import.cs


注:本文中的System.Diagnostics.Process.Kill方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。