Skip to main content

Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

The routine I use in the calling pgm does not compile in the called class. (Typo above)


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

Sure you can use the MessageBox class in a console application if you like but you will have to add the proper assembly to the project.

In the Visual COBOL Help search for MessageBox.

The help will list a number of items because there are a couple different MessageBox classes depending on the technology you are using such as Windows Forms or WPF.

Since you are using Windows Forms. click on the entry for MessageBox Class in System.Windows.Forms.

The docs will tell you that the assembly name where this class resides is called System.Windows.Forms.

In Solution Explorer, right click on References under the project name in which you wish to display the message and then select Add Reference.

From the .NET tab scroll to find System.Windows.Forms for the .NET Framework version that you are using. This will be .NET Framework 4 by default.

Click on OK to add the assembly to the project.

In order to be able to reference this class without fully qualifying the name like System.Windows.Forms.MessageBox you will need to add the namespace to the project or to the program.

To add it to the project, open up project properties by double clicking on Properties under the project name and then navigate to the Namespace tab.

Scroll down the list and check System.Windows.Forms and save.

If you wish to add the namespace to just that program then add the directive:

$set ilusing"System.Windows.Forms" to the top of the program.

Example: this is a console program that displays a messagebox.

     $set ilusing"System.Windows.Forms"

      program-id. Program1 as "testpopup.Program1".

      procedure division.

          invoke type MessageBox::Show("This is a message")

          goback.


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

Chris,

Excellent answer thank you.

As most of our messages are 'update messages' in that they keep the user informed as to whats happening as a process runs how do I REMOVE the box from the screen at the end of the program ?

e.g

A-PROCESS

   invoke type MessageBox::Show("This is a message")

B-PROCESS

  Perform process until eof.

C-END.

< get rid of message box >

What goes in the < get rid of message box > bit to remove the box from screen at end of process?


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

Chris,

Excellent answer thank you.

As most of our messages are 'update messages' in that they keep the user informed as to whats happening as a process runs how do I REMOVE the box from the screen at the end of the program ?

e.g

A-PROCESS

   invoke type MessageBox::Show("This is a message")

B-PROCESS

  Perform process until eof.

C-END.

< get rid of message box >

What goes in the < get rid of message box > bit to remove the box from screen at end of process?


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

Also I've noticed that there is a DEFAULT <Ok> button on the message box.

How can I have a message box WITHOUT a button that just repopulates itself when I pass it the appropriate message?


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

Also I've noticed that there is a DEFAULT <Ok> button on the message box.

How can I have a message box WITHOUT a button that just repopulates itself when I pass it the appropriate message?


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

You should check the .NET Framework documentation for the MessageBox class to get a full description of the options that are available. You can do this opening up the Visual COBOL Help in the IDE and then doing a search on "system.windows.forms.messagebox".

For Example you can get an OK button by modifying the statement to read:

invoke type MessageBox::Show("This is a message", "Message Box Name", type MessageBoxButtons::OK)

But I don't think that the MessageBox class is going to work for you because the MessageBox requires that one of its buttons is pressed prior to it disappearing.

You might want to look at using a custom popup form like a tooltip so that you can control the display of the message. Either that or perhaps you should place a Label or Textbox control on the main form that can be updated with a string value at required intervals.

I will work on putting together a sample for using the popup window approach.


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

Cheers Chris.

I went away and tried calling a new dialog form (rather than a message box) from the legacy code program but run into the same problem in that without any user action on the newly called dialog I can't get the thing to come back to the program calling the new dialog.

Tried using a 'timer' when I'd count to 10k as a LOAD action but to no avail.

As these legacy programs perform ALL processing at one go they aren't built to keep returning to the main program with an update as to whether each individual record got processed or not.

I'm looking for a solution that simply pops up a box at the start of the program, repopulates the box with an ever changing message while processing the data then closes the box at the end of the program.

Simples????


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

I think the problem is that using a form to do this will change the focus from the main form to the new form so you would have to change the focus back to the main form thru code.

I created an example that kind of does what you want only it uses a statusStrip control on the bottom of the main form instead of popping up a new form.

Let me know if this will work for you...

I changed the attached file because it had a bug in the code where it needed a call to refresh method in order to cause a redraw to occur on the status bar.

The new example also utilizes a prograss bar if you are interested in perhaps using one of these to report current status.


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

Chris,

This is proving to be trickier than we thought....

Your example files work perfectly well IF the subform (Form1) is part of the SAME solution as the main program (Program1) as it references.

In your example program1.cbl references the form to call as 'mainform as type displaystatus.Form1' where, being part of the same solution this is recognisable.

In my situation I have a top level .EXE (PROGA) which holds the main form stuff.

PROGA calls out to SUBPRG1.DLL to do some processing. SUBPRG1 is legacy COBOL code in which I've added the appropriate namespaces to allow for direct form use. This DLL knows nothing about the mainform only stuff that resides within it.

SO...in my SUBPRG1 code I have written the following code...

set MessageDialog to new Infomessage() (where InfoMessage is my dialog box)

invoke MessageDialog::populateLinkage(Progress-Message) (where Progress-Message is my message I'm trying to show)

invoke MessageDialog::ShowDialog()

 OK. So far so good...my initial message pops up.

Problem is now is that I need to return to SUBPRG1 (without user action) in order to continue processing (and to continually update my message) and, at the end of the program, close the MessageDialog (which I can do with invoke MessageDialog::Close()

Is there a way I can attach a process within the InfoMessage.cbl code to perform ONCE the dialog loads and displays and then to return to the calling program (Tried using Sleep(1000) upon the 'Load' event.

 


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

Chris,

This is proving to be trickier than we thought....

Your example files work perfectly well IF the subform (Form1) is part of the SAME solution as the main program (Program1) as it references.

In your example program1.cbl references the form to call as 'mainform as type displaystatus.Form1' where, being part of the same solution this is recognisable.

In my situation I have a top level .EXE (PROGA) which holds the main form stuff.

PROGA calls out to SUBPRG1.DLL to do some processing. SUBPRG1 is legacy COBOL code in which I've added the appropriate namespaces to allow for direct form use. This DLL knows nothing about the mainform only stuff that resides within it.

SO...in my SUBPRG1 code I have written the following code...

set MessageDialog to new Infomessage() (where InfoMessage is my dialog box)

invoke MessageDialog::populateLinkage(Progress-Message) (where Progress-Message is my message I'm trying to show)

invoke MessageDialog::ShowDialog()

 OK. So far so good...my initial message pops up.

Problem is now is that I need to return to SUBPRG1 (without user action) in order to continue processing (and to continually update my message) and, at the end of the program, close the MessageDialog (which I can do with invoke MessageDialog::Close()

Is there a way I can attach a process within the InfoMessage.cbl code to perform ONCE the dialog loads and displays and then to return to the calling program (Tried using Sleep(1000) upon the 'Load' event.

 


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

What happens if you do a Show on MessageDialog instead of ShowDialog?

I still think that the statusstrip on the main form is the best way to do this.
I am attaching a reworked version of my sample that now works with the mainform in a different project than the legacy code.

To do this I created a new mainprog windows application project which will be the applications .EXE which only contains the main.cbl.
I removed the main.cbl from the original displaystatus project and made displaystatus into a Class Library (.dll) so that I could add a reference to it.

I changed the reference to Form1 in main.cbl to point to displaystatus.Form1.

So now I have a solution with 3 projects.

1. mainprog (main .EXE)
2. displaystatus (.DLL containing Forms)
3. ClassLibrary1 (.DLL containing legacy programs)


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

Chris,

On attempting to BUILD your solution I get the following errors...

img705.imageshack.us/.../builderrors.jpg>


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

Chris,

On attempting to BUILD your solution I get the following errors...

img705.imageshack.us/.../builderrors.jpg>


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

OK, I have a new simplified example that should work for you. (I hope!)

Because this forum only allows for 64K byte attachments I am forced to delete the bin folders prior to zipping them so they are small enough to attach.

The previous example was using a reference back to the calling assembly in order to saitisfy the reference to the form class and this reference caused a build error if the projects were not built in the correct sequence.

This new example uses an interface definition instead which allows it to reference the form without requiring a reference to the calling assembly.

This is the way I should have done it to begin with as it allows me to heep the forms in the original .EXE instead of moving it to a new class library.


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

Thanks for that.

I'll have a play around and see what I can do with the example code as it relates to my own application and get back to you.


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

Implemented the code and works well however I've now come across a 'knock-on' error which hopefully you can help me resolve.

Have a main menu program (.EXE) which calls out to all programs as .DLLs.

Code in main menu program reads as...

      *///////////////////////////////////////////////////////////////////////////////

     * Code to process the 'UPDATE' function.

     *//////////////////////////////////////////////////////////////////////////////

      method-id doUpdate public.

      local-storage section.

      01 my-update           type IPUPDATE.Form1.

      procedure division.

     *>>> Create the object 'my-update' as the form which belongs to the IPUPDATE program

          set my-update to new IPUPDATE.Form1

    *>>> Fire off the main FORM inside IPUPDATE. Will terminate once the 'Exit Button' is pressed!

          invoke my-update::ShowDialog(self)

      end method.

Have implemented the 'interface code' in IPUPDATE so that the first line of IPUPDATE.cbl now reads as...

class-id IPUPDATE.Form1 is partial inherits type System.Windows.Forms.Form implements type Idisplaystatus.

My call-out to the program i'm doing all the 'employee processing' in is called as...

CALL "IPVAL" USING VAL-LINK by value self.

...and this program (IPUPDATE) compiles and runs as a .EXE (calling out to IPVAL which is compiled as a .DLL)

In order to incorporate IPUPDATE into our 'overall' system then IPUPDATE must become a .DLL also and then be called from our main menu program.

The problem that has now arisen is that when I comple MAINMENU,cbl (as a .EXE) I get the following error message...

COBCH0845 Unknown Class...'IPUPDATE.Form1'

even though this would compile ok BEFORE I added in the 'implements type idisplaystatus' to the top line.

What additional code must I incorporate in order for my mainmenu program to compile without error when refering to the IPUPDATE program?


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

Implemented the code and works well however I've now come across a 'knock-on' error which hopefully you can help me resolve.

Have a main menu program (.EXE) which calls out to all programs as .DLLs.

Code in main menu program reads as...

      *///////////////////////////////////////////////////////////////////////////////

     * Code to process the 'UPDATE' function.

     *//////////////////////////////////////////////////////////////////////////////

      method-id doUpdate public.

      local-storage section.

      01 my-update           type IPUPDATE.Form1.

      procedure division.

     *>>> Create the object 'my-update' as the form which belongs to the IPUPDATE program

          set my-update to new IPUPDATE.Form1

    *>>> Fire off the main FORM inside IPUPDATE. Will terminate once the 'Exit Button' is pressed!

          invoke my-update::ShowDialog(self)

      end method.

Have implemented the 'interface code' in IPUPDATE so that the first line of IPUPDATE.cbl now reads as...

class-id IPUPDATE.Form1 is partial inherits type System.Windows.Forms.Form implements type Idisplaystatus.

My call-out to the program i'm doing all the 'employee processing' in is called as...

CALL "IPVAL" USING VAL-LINK by value self.

...and this program (IPUPDATE) compiles and runs as a .EXE (calling out to IPVAL which is compiled as a .DLL)

In order to incorporate IPUPDATE into our 'overall' system then IPUPDATE must become a .DLL also and then be called from our main menu program.

The problem that has now arisen is that when I comple MAINMENU,cbl (as a .EXE) I get the following error message...

COBCH0845 Unknown Class...'IPUPDATE.Form1'

even though this would compile ok BEFORE I added in the 'implements type idisplaystatus' to the top line.

What additional code must I incorporate in order for my mainmenu program to compile without error when refering to the IPUPDATE program?


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

You should just be able to add a reference in your .EXE project to your .DLL project that contains IPUPDATE.FORM1.

Right clck on References under MAINMENU project and select Add Reference and then under the Projects tab select the IPUPDATE project.


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

Hi Chris.

Of course....my mistake....too many things to do! :)

Thanks.


Is it possible to show a message box from a class that has no form?  Two separate projects, one has a form but calls the class without a form to read, write data etc.  If there is an error, can I show the message box from the called class or do I need to pass the error back to the calling class and display it there?  The routing I use in the calling pgm does not compile in the called class.  Thanks.


#VisualCOBOL
#VisualStudio

Hi Chris.

Of course....my mistake....too many things to do! :)

Thanks.