* Makefile.am:
[monodevelop.git] / extras / MonoDevelop.Debugger.Mdb / Mono.Debugging.Backend.Mdb / IDebuggerServer.cs
blob2404cbf867d0d4acfd2e7eb87056f0e7130237a1
1 // IDebuggerServer.cs
2 //
3 // Author:
4 // Lluis Sanchez Gual <lluis@novell.com>
5 //
6 // Copyright (c) 2008 Novell, Inc (http://www.novell.com)
7 //
8 // Permission is hereby granted, free of charge, to any person obtaining a copy
9 // of this software and associated documentation files (the "Software"), to deal
10 // in the Software without restriction, including without limitation the rights
11 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12 // copies of the Software, and to permit persons to whom the Software is
13 // furnished to do so, subject to the following conditions:
15 // The above copyright notice and this permission notice shall be included in
16 // all copies or substantial portions of the Software.
18 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23 // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24 // THE SOFTWARE.
28 using System;
29 using Mono.Debugging.Client;
31 namespace Mono.Debugging.Backend.Mdb
33 public interface IDebuggerServer
35 void Run (DebuggerStartInfo startInfo);
37 void Stop ();
39 void AttachToProcess (int id);
41 void Detach ();
43 void Exit ();
45 // Step one source line
46 void StepLine ();
48 // Step one source line, but step over method calls
49 void NextLine ();
51 // Step one instruction
52 void StepInstruction ();
54 // Step one instruction, but step over method calls
55 void NextInstruction ();
57 // Continue until leaving the current method
58 void Finish ();
60 //breakpoints etc
62 // returns a handle
63 int InsertBreakEvent (BreakEvent be, bool activate);
65 void RemoveBreakEvent (int handle);
67 void EnableBreakEvent (int handle, bool enable);
69 object UpdateBreakEvent (object handle, BreakEvent be);
71 void Continue ();
73 ThreadInfo[] GetThreads (int processId);
75 ProcessInfo[] GetPocesses ();
77 Backtrace GetThreadBacktrace (int processId, int threadId);
79 AssemblyLine[] DisassembleFile (string file);
81 void SetActiveThread (int processId, int threadId);