Wiki
Version 2 (modified by Gameday, 14 years ago)

added an example on how to use Mdbg

Cobra runs on top of .NET and Mono. Also it generates the same kinds of classes, methods and statements that C# and VB use, so you can leverage tools like debuggers and profilers.

Debugging programs include:

  • DbgCLR.exe
  • Mdbg.exe
  • Cordbg.exe

This blog post gives some useful information on debugging .NET programs sans Visual Studio:

You might also use an IDE on your executable such as VisualStudio, MonoDevelop or SharpDevelop.

Sample debugging session using Mdbg

For this example, we're gonna' use Mdbg.exe. To start debugging, make sure your Cobra sources are compiled with the -d switch:

cobra.exe -d -compile d.cobra

For this example, let's assume d.cobra contains this:

sig SampleMethod(b as int) as int

class A
    def main is shared
        a as SampleMethod = do(b as int)
            if b > 20
                return b+5
            return b+6
        print a(21)
        print a(10)

After the command finished, you have an exe created. Fire up Mdbg like this:

Mdbg.exe d.exe

You'll see output like this:

run d.exe
STOP: Breakpoint Hit
4:      def main is shared

To start stepping through code, write next ( n has the same effect ). You'll see the debugger advance:

[p#:0, t#:0] mdbg> next
5:              a as SampleMethod = do(b as int)

Let's keep stepping until we reach the print a(21) line:

[p#:0, t#:0] mdbg> n
5:              a as SampleMethod = do(b as int)
[p#:0, t#:0] mdbg> n
9:              print a(21)

If you want to step in that method and see what happens, press s. At any time, you can see the value of the variables by writing:

print variable_name

and that will write the value of variable_name. Similar, you can just type print and that will write the value of all the variables in that context.

If at any time you want to quit debugging, just write exit.

Even though this example only covers the basics, I hope it's enough to get you started.

See also: DebuggingTopics