473,405 Members | 2,287 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,405 software developers and data experts.

C# subwindow in a Win32 application?

Hi

Our product consists of a complex application that is written in C/C++
and uses the old event-based Win32 API (some code has already been in
there in times of Windows 3.11!) We cannot afford a complete
reimplementation of the whole application, so we would like to
gradually port portions of the application to more contemporary
platforms like C#.

Is it possible for a Win32-based application to encapsulate C# code? I
think of a subwindow or sort of control, which I can place in any
window and which is a view of C# code.
Jun 27 '08 #1
5 2332
digory wrote:
Hi

Our product consists of a complex application that is written in C/C++
and uses the old event-based Win32 API (some code has already been in
there in times of Windows 3.11!) We cannot afford a complete
reimplementation of the whole application, so we would like to
gradually port portions of the application to more contemporary
platforms like C#.

Is it possible for a Win32-based application to encapsulate C# code? I
think of a subwindow or sort of control, which I can place in any
window and which is a view of C# code.
Yes, it is, you need to host the .NET runtime and call into .NET to
obtain IDispatch-compatible objects of your .NET classes.

We've done this from Delphi, and I can probably dig up some example
interfaces, api-functions, etc. that you need to work with.
Unfortunately (for you) since we've done this in Delphi, direct code
examples will likely be unusable to you.

We've had the following experiences with this approach:

1. using a C# control inside a Delphi control is doable, but needs way
more plumbing code in Delphi than we're prepared to do. Specifically, if
you focus a textbox on a .NET control that is placed on a Delphi form,
and hit Tab, focus doesn't move inside the .NET control but just jumps
back to the Delphi code. The Delphi code thus considers the whole .NET
control as something that cannot take focus.

2. Exceptions are tricky, mostly due to the way Delphi hides IErrorInfo
interfaces from us when interfacing with IDispatch-objects the way we
do, so we're a bit thin on cross-world exception handling.

3. Two-way calling is also possible, provided you can give an object to
..NET through an interface implementing callback functions.

In short, it's doable, it works, but could be more polished and isn't
without its problems.

If you google for "hosting .NET runtime c/c++" you'll find a few links,
and if you need more, just send me an email.

--
Lasse Vågsæther Karlsen
mailto:la***@vkarlsen.no
http://presentationmode.blogspot.com/
PGP KeyID: 0xBCDEA2E3
Jun 27 '08 #2
Thanks a lot for your reply! How do I host the .NET runtime? Is there
a special DLL? Do you have a link to a site with further information
about how to do this?
Jun 27 '08 #3
digory wrote:
Thanks a lot for your reply! How do I host the .NET runtime? Is there
a special DLL? Do you have a link to a site with further information
about how to do this?
I found what we needed on google:

here's one of the top links:
http://msdn.microsoft.com/en-us/libr...z3(VS.71).aspx

--
Lasse Vågsæther Karlsen
mailto:la***@vkarlsen.no
http://presentationmode.blogspot.com/
PGP KeyID: 0xBCDEA2E3
Jun 27 '08 #4
Thanks! That helps a lot!
Jun 27 '08 #5
What about C++/CLI? Assuming the C++ part can be done in Visual Studio 2008?
"Lasse Vågsæther Karlsen" <la***@vkarlsen.noskrev i en meddelelse
news:up**************@TK2MSFTNGP03.phx.gbl...
digory wrote:
>Hi

Our product consists of a complex application that is written in C/C++
and uses the old event-based Win32 API (some code has already been in
there in times of Windows 3.11!) We cannot afford a complete
reimplementation of the whole application, so we would like to
gradually port portions of the application to more contemporary
platforms like C#.

Is it possible for a Win32-based application to encapsulate C# code? I
think of a subwindow or sort of control, which I can place in any
window and which is a view of C# code.

Yes, it is, you need to host the .NET runtime and call into .NET to obtain
IDispatch-compatible objects of your .NET classes.

We've done this from Delphi, and I can probably dig up some example
interfaces, api-functions, etc. that you need to work with. Unfortunately
(for you) since we've done this in Delphi, direct code examples will
likely be unusable to you.

We've had the following experiences with this approach:

1. using a C# control inside a Delphi control is doable, but needs way
more plumbing code in Delphi than we're prepared to do. Specifically, if
you focus a textbox on a .NET control that is placed on a Delphi form, and
hit Tab, focus doesn't move inside the .NET control but just jumps back to
the Delphi code. The Delphi code thus considers the whole .NET control as
something that cannot take focus.

2. Exceptions are tricky, mostly due to the way Delphi hides IErrorInfo
interfaces from us when interfacing with IDispatch-objects the way we do,
so we're a bit thin on cross-world exception handling.

3. Two-way calling is also possible, provided you can give an object to
.NET through an interface implementing callback functions.

In short, it's doable, it works, but could be more polished and isn't
without its problems.

If you google for "hosting .NET runtime c/c++" you'll find a few links,
and if you need more, just send me an email.

--
Lasse Vågsæther Karlsen
mailto:la***@vkarlsen.no
http://presentationmode.blogspot.com/
PGP KeyID: 0xBCDEA2E3

Jun 27 '08 #6

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

1
by: Venkat | last post by:
Hi All, I have got two windows namely parent and a child . My parent window has got a link, on clicking which opens a child window(i am using window.open function). I do the following set...
2
by: Paul Moffitt | last post by:
We have a Javascript function that opens an electronic document in a subwindow. The Title bar of the subwindow shows the filepath of the document. Looking at the script below is there any way to...
8
by: Tony Johansson | last post by:
Hello! I just wonder what the difference is between a native win32-app and MFC. What I know is that you can use Win32 API in both cases. I think an MFC application is connected with a GUI...
1
by: Marcel | last post by:
I have a subwindow hich displays a grid. When the user selects a row from the grid, I wish to store the selected row ID in session state and close the subwindow, returning focus to the parent...
3
by: Gil | last post by:
I need to create a web page in which its content should be controlled by some win32 application. this application may add or remove some gif images from the page and it should be smooth as possible...
0
by: =?Utf-8?B?Q29saXZpZXI=?= | last post by:
If anyone can help me with this I would really appreciate it: I have an assembly into which I have linked a manifest file as a Win32 resource. This is necessary since I want to use a class in this...
6
by: Wolf Grossi | last post by:
Greetings, how to refresh a parent window after processing forms from the subwindow? Currently I have a solution (see below) which works with IE and Konqueror, but not with Firefox, so I...
1
by: Wolf Grossi | last post by:
Greetings, how to refresh or reload a parent window after processing forms from the subwindow? Currently I have a solution (see below) which works with IE and Konqueror, but not with Firefox,...
2
by: nicofari | last post by:
Hi all, I would need to open a "subwindow of a subwindow". From first page (say "main.html") I open a window using javascript window.open('form1.html',...) After that I have two browser...
0
by: emmanuelkatto | last post by:
Hi All, I am Emmanuel katto from Uganda. I want to ask what challenges you've faced while migrating a website to cloud. Please let me know. Thanks! Emmanuel
1
by: nemocccc | last post by:
hello, everyone, I want to develop a software for my android phone for daily needs, any suggestions?
1
by: Sonnysonu | last post by:
This is the data of csv file 1 2 3 1 2 3 1 2 3 1 2 3 2 3 2 3 3 the lengths should be different i have to store the data by column-wise with in the specific length. suppose the i have to...
0
by: Hystou | last post by:
Most computers default to English, but sometimes we require a different language, especially when relocating. Forgot to request a specific language before your computer shipped? No problem! You can...
0
Oralloy
by: Oralloy | last post by:
Hello folks, I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>". The problem is that using the GNU compilers,...
0
by: Hystou | last post by:
Overview: Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows...
0
tracyyun
by: tracyyun | last post by:
Dear forum friends, With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each...
0
agi2029
by: agi2029 | last post by:
Let's talk about the concept of autonomous AI software engineers and no-code agents. These AIs are designed to manage the entire lifecycle of a software development project—planning, coding, testing,...
0
isladogs
by: isladogs | last post by:
The next Access Europe User Group meeting will be on Wednesday 1 May 2024 starting at 18:00 UK time (6PM UTC+1) and finishing by 19:30 (7.30PM). In this session, we are pleased to welcome a new...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.