-
Jul 27th, 2021, 05:34 AM
#41
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Looks promisingly. Looking forward to test your software =)
BTW, I'd suggest to overlook a helper code for missing Wow64RevertWow64FsRedirection, because there are some scenarios, e.g. in ShellW, where it is not paired due to using "goto" statements. It's also good practice to store "OldValue" parameter globally to prevent "out of sync" even if above case happened.
The same actual for all other functions like "File Exist" where I don't see redirector functions at all, which surely have to be implemented in tools like "file manager".
Originally Posted by MountainMan
I didn't know you could run VB6.EXE, even the commandline version, without elevating.
This is a default behaviour after installation. Perhaps, you patched exe file via manifest, or set Admin mark in exe's or shortcut's properties, that's why it is always ask you for elevation.
I don't insist that it should be "must have" feature, since I can always create a special shortcut to bypass UAC, but ability to compile as non-elevated where possible would be good manner. Also, the user should understand he can manually start your tool elevated if he knows his project require higher privileges in order to compile.
Last edited by Dragokas; Jul 27th, 2021 at 05:40 AM.
-
Jul 27th, 2021, 08:32 AM
#42
Thread Starter
Hyperactive Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
When I installed VB6 I set my system to elevate VB6 each time it was run. I did that because everybody I had read (some here) say that because VB6 writes into a section of the registry that isn't accessible any more without elevation. What cases have you found it acceptable to run VB6.EXE without elevation?
Tell me more about helper code. When I use Goto I try to ensure that I don't have any orphaned or "out of sync" variables.If you see any in my code please let me know.
-
Jul 27th, 2021, 09:43 AM
#43
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Originally Posted by MountainMan
When I installed VB6 I set my system to elevate VB6 each time it was run. I did that because everybody I had read (some here) say that because VB6 writes into a section of the registry that isn't accessible any more without elevation. What cases have you found it acceptable to run VB6.EXE without elevation?
I'll split answer in 2 use cases:
1) Run IDE.
Personally, I see the only reason when one needs to run IDE non-elevated - to be able debug code in the same (or very close) environment as it will be run further by user to have the opportunity to catch all those possible "access denied" errors and so. Or when you, e.g., develop an application which by design should always be run with restricted permissions to prevent cases, e.g., when you think some function should work normally both as admin / and non-admin, but it is not true (like the above case with SHFileOperation).
In all other "design" cases, VB6 IDE is really suffered from those access denied errors when one try to add new, not yet registered components / references and so on, which write themselves to HKLM and thus required admin access. Such a way, yes, it's much convenient to work always as evelated.
2) Compile.
It's also convenient to compile project as elevated every time.
But it's not always convenient for end user. Like, if one wants to integrate OCX2StdExe into another builder script which by design is not intended to run as admin.
Surely, it's up to you, do a little change to support non-elevated compilation, or stay as is. But if second, than a logical question: why not force "requireAdministrator" instantly in the manifest of your tool...
Originally Posted by MountainMan
Tell me more about helper code. When I use Goto I try to ensure that I don't have any orphaned or "out of sync" variables.If you see any in my code please let me know.
Well, look ShellW function.
Code:
j = Wow64DisableWow64FsRedirection(DisableWOW)
Firstly, I suggest to declare DisableWOW globally. So, the system can re-use those value when needed (when you'll have more such use cases in your code, of course).
Even, if Wow64RevertWow64FsRedirection pair will be lost, you will not lose tracking of DisableWOW value, used by system for special purposes to sync the redirector state.
Second, you have a lot of labels for "goto", such as Leaving/DoSee0/DoSEE1. E.g., see this part:
Code:
ShellProcInfo.hProcess = 0
GoTo Leaving
End If
AsAdmin = AdminYes
GoTo RunElevated ' failed to run un-elevated & AsAdmin is AdminOnlyIfNeeded
Else
i = Err.LastDllError
End If
End If
End If
'#If (Win64 = 0) Then
' If hModule <> 0 Then FreeLibrary hModule
'#End If
If IsWOW64 Then
're-enable redirection
j = Wow64RevertWow64FsRedirection(DisableWOW)
If j = 0 Then
If those goto executed, it jump over Wow64RevertWow64FsRedirection, so the redirector remains disabled.
I didn't learn all the code, just a quick look.
Another potential lose of pair could happen if code trapped runtime error for some reason.
And the last, to make code (faster?/more stable): file system redirector affects only C:\Windows\System32 (with 2 exclusions), so no need to manipulate it for other paths. Simple way is to check just for "C:\Windows"). I'm using such helper routine.
Second reason is such Microsoft does not suggest to disable it for a long time. So, it's very important to track this moment carefully. Some functions from my practice are working incorrectly with redirector turned off (example: WinVerifyTrust).
-
Oct 20th, 2021, 05:31 AM
#44
Addicted Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Originally Posted by MountainMan
Nineteen years ago I had a cardiac arrest and I was dead for 10 minutes. That really makes you look at life differently. I realize that a)I am not in control like i thought I was and b)I don't know if i will be on this planet for another nano-second so I'd better make the most out of what I have.
I have benefited a lot from this forum and this is one way I can give back. My contribution to this is tiny compared to what Krool has done. I hope you find it worthwhile...
First of all, thanks a lot, MountainMan, for being always extremely kind, thankful and humble in your words. And, coming to your greatly useful work which I find many are getting benefited from, I also join them in thanking you sincerely, though I have not started using your work though.
Actually, with our dear Krool's update on 13th Oct, I thought I will start using the OCX version hereafter. So, I needed to do the reverse (StdExe2Ocx) for my situation. So, I searched in the net and found this link - https://dev.xenforo.relay.cool/index...-vbccr.882529/. I saw that you have also replied therein. So, based on the same, few days back, I attempted to do the reverse (StdExe2Ocx) on taking ComCtlsDemo itself as an example.
I just replaced## all the references in the forms (.frm files) from ComCtlsDemo to VBCCR17. Then, edited the .vbp file suitably (added object reference to VBCCR17, removed references to all user control files) and started it. It all worked correctly^^, but still you can add your own invaluable tips in confirming whether this is all that is required (or further more things need to be done). Next, I attempted a similar procedure for converting my own important project which has 50+ forms, many of Krool's controls (incl. vbFlexGrid) and SSTabEx control. It all seems to work perfectly only though I have not individually opened and checked each screen after starting the executable.
(##) Instead of sed, I searched (and searched and searched) and found out an old yet superb freeware ('Replace Text' by Ecobyte [formerly 'BK ReplaceEM' by Bill Klein]). This gem of a freeware has very powerful features. More specifically, it did what I wanted - replace multiple search strings in multiple files - with an ever so easy configuration. The 3-point 'License Agreement' for this software brought heartwarming tears in my eyes. As far as I can remember, I have never seen a 'License Agreement' of such a nature in any freeware. Sure the writer of that license agreement must be a kind soul like you. God Bless him! God Bless you! God Bless all!
(^^) except one line of code - Animation1.LoadRes 100 (which is in the Form_Load event of MainForm), when the executable (ComCtlsDemo.exe) is run. Curious to know why. I tried certain things like deleting and adding the resource file again, etc., but this line of code never worked. I felt like adding the .avi animation demo file to a different .res file, remove the existing .res file, add the new .res file and then see whether the aforesaid line of code works with the ocx version but then I am not familiar with .res files. So, could not afford to spend time on that.
As of now, I did not want to write to Krool on all of the above, since I thought you yourself can definitely help me on this, so that Krool can continue to concentrate on enhancing his controls.
I take this opportunity to once again thank, in tons, our dear Krool, for his stupendous free controls, which are a great boon to the whole world society.
More than anything, I am extremely happy today to have written to a compassionate person like you. God is Great. All Thanks to the Lord Almighty.
Kind Regards.
"Gratitude is a currency that we can mint for ourselves, and spend without fear of bankruptcy." - Fred De Witt Van Amburgh
-
Oct 20th, 2021, 06:58 AM
#45
Addicted Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Originally Posted by MountainMan
I apologize for taking so long to reply. I have had some serious medical issues I had to fight through. I have just released an update to this utility which addresses your problem as well as many others. Please see post #1. ... .. .
I just now read, this message of yours. I, for one, very well know about fighting through serious medical issues, because of my own personal experiences in that front. So, my sincerest prayers, from the very bottom of my heart, for the welfare of a great heart like yours, ever.
By the by, I have had a very quick look into your project and I have to say the ToolTips is awesome. Thanks to you and The Trick. And, the resizing of controls' and texts' sizes, as form is resized, is fabulous. I shall explore more as and when time permits and share with you.
My utmost prayers for the very best of healths to you at all times..... I have just now prayed so to the Lord Almighty.
Kind regards.
-
Oct 20th, 2021, 10:10 PM
#46
Thread Starter
Hyperactive Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
As you know, I only wrote the utility to go from the OCX version to the StdEXE version. Te reason I did not go the other way was that I figured the number of developers using the StdEXE version is extremely small, especially since for the last couple of years Krool has said in his first post on the StdEXE version that this version is unstable in the IDE and that he recommended using the OCX version for development. So if you use my utility, you can develop with the OCX version and then do a commandline compile with the StdEXE version to produce an EXE file with no dependencies and without the instability of using the StdEXE version in the IDE.
I think your approach to going the other way is fine but I suggest 2 more things need to be done. First, when you use the OCX version you do not need OLEGuids.tlb since it is effectively already compiled into VBCCRxx.OCX so you can remove it from your project references. It doesn't end up nn the compiled EXE anyway but it helps to remove some confusion to remove it.
Second, if you want to remove the OCX dependency in the final EXE file you will need to get and use the side-by-side manifest from Krool's first post for the OCX version.
-
Oct 22nd, 2021, 09:29 AM
#47
Addicted Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Originally Posted by MountainMan
... .. . since for the last couple of years Krool has said in his first post on the StdEXE version that this version is unstable in the IDE and that he recommended using the OCX version for development. So if you use my utility, you can develop with the OCX version and then do a commandline compile with the StdEXE version to produce an EXE file with no dependencies and without the instability of using the StdEXE version in the IDE.
I think your approach to going the other way is fine but I suggest 2 more things need to be done. First, when you use the OCX version you do not need OLEGuids.tlb since it is effectively already compiled into VBCCRxx.OCX so you can remove it from your project references. It doesn't end up in the compiled EXE anyway but it helps to remove some confusion to remove it.
Second, if you want to remove the OCX dependency in the final EXE file you will need to get and use the side-by-side manifest from Krool's first post for the OCX version.
Thanks for that tip on 'OLEGuids.tlb', MountainMain.
By the by, my app has been getting deployed as Std-Exe version only in users' systems so far.
But, for development also, I was forced to use the Std-Exe version itself (though quite unstable) so far because of the long-pending (years long) fix in the RichTextBox control. That's why I wrote that with Krool's recent update (on 13th Oct), I have switched over to using his OCX version for development. Before this fix, I needed to effect my own modifications in the RichTextBox.ctl code, every time krool released an update to VBCCR Std-Exe version.
Well, coming to OCX version, suppose I decide to deploy the OCX version's compiled executable itself hereafter in my users' systems, using the side by side approach (i.e. without registering the ocx in the user's system). Then, kindly let me know the following:
1. My project has to include the “VBCCR16SideBySideAndVisualStyles.res” file (since obviously I want the visual styles too along with side by side) and not the “VBCCR16SideBySide.res” file. Right? I have read the relevant portions of your ReadMe.docx file regarding this and it suggests that only. Anyway, just confirming from you again.
2. For large projects where most or almost all of my forms contain many of krool's controls, since I deploy my ocx version's compiled executable in my user's system,
a. Will there be any reduction in load time of my app?
b. Will there be any reduction in memory usage of my app?
c. Will there be increase in speed of execution of my app's various modules?
3. If your answer to questions "a,b,c" above are 'No", then is there any other advantage at all in deploying the ocx version's executable in my user's systems? If there is absolutely no advantage at all (for sure), then finally, I will convert my project from 'ocx version' to 'std-exe' version (I may use your utility of course) so that I shall continue to deploy the std-exe version itself in my users' systems.
Kind regards.
N.B. Thanks for such a detailed documentation (your 'ReadMe.docx')
Last edited by softv; Oct 22nd, 2021 at 09:32 AM.
-
Oct 22nd, 2021, 11:10 AM
#48
Thread Starter
Hyperactive Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
softv,
I am not sure why you want to use the OCX version for distribution. The main reason I wrote my utility was so that you could develop with the OCX version and then use my utiliity to make an EXE based on the StdEXE version. That way you have only the VBCCR controls you actually use included in the EXE and there is no requirement to use the OCX at all with the EXE file that is made (also means you don't need to do the side-by-side stuff with the EXE.
If you have the side-by-side stuff included in a manifest, it is temporarily removed when the EXE is made so that the SXS is not in the final EXE.
Unless I am missing something, this seems like a much better solution for you. You will always develop with he much more stable OCX version and be able to make the StdEXE version whenever you want and as often as you want (my utility leaves your OCX version alone).
-
Oct 22nd, 2021, 12:07 PM
#49
Addicted Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Originally Posted by MountainMan
softv,
I am not sure why you want to use the OCX version for distribution. The main reason I wrote my utility was so that you could develop with the OCX version and then use my utiliity to make an EXE based on the StdEXE version. That way you have only the VBCCR controls you actually use included in the EXE and there is no requirement to use the OCX at all with the EXE file that is made (also means you don't need to do the side-by-side stuff with the EXE.
If you have the side-by-side stuff included in a manifest, it is temporarily removed when the EXE is made so that the SXS is not in the final EXE.
Unless I am missing something, this seems like a much better solution for you. You will always develop with he much more stable OCX version and be able to make the StdEXE version whenever you want and as often as you want (my utility leaves your OCX version alone).
// I am not sure why you want to use the OCX version for distribution. //
Sorry. I did not mean to say that I am going to use the OCX version for distribution. As written already, I just wanted to know that if at all myself/anybody decides to use the ocx version, are there any advantages at all in doing so? I just wished to know the answers to my 3 questions (a, b, c) as below. That's all. Nothing else.
For large projects where most or almost all of my forms contain many of krool's controls, if at all I/anyone decides to deploy the ocx version's compiled executable in user's system,
a. Will there be any reduction in load time of such an app?
b. Will there be any reduction in memory usage of such an app?
c. Will there be increase in speed of execution of such an app's various modules?
Hope I have made myself clear now. Thanks.
Kind regards.
-
Oct 22nd, 2021, 12:42 PM
#50
Thread Starter
Hyperactive Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
I do not believe that an EXE made with the OCX version will load faster, reduce memory consumption or increase execution speed versus running an EXE that has been made with the StdEXE version. The advantage I see for the OCX version is stability in the IDE.
Load time with the StdEXE version should be a bit less since not all controls will necessarily be in the EXE and on today's PC's the StdEXE version is only loading one file instead of 2. On today's PC's though, I don't think the load times will be very noticeable.
OCX will have a bit higher memory consumption since it has all the code and variables for all of the controls instead of just ones you are using in your EXE. This is likely a few MB which also is not a big deal on modern PC's.
Since the OCX and EXE have the same code for the controls and they are both compiled I would anticipate execution speed to be the same except possibly for a slight difference in initialization.
So I only use the OCX version for development due to its stability and then I use the StdEXE for production code.
-
Oct 22nd, 2021, 12:49 PM
#51
Addicted Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Originally Posted by MountainMan
I do not believe that an EXE made with the OCX version will load faster, reduce memory consumption or increase execution speed versus running an EXE that has been made with the StdEXE version. The advantage I see for the OCX version is stability in the IDE.
Load time with the StdEXE version should be a bit less since not all controls will necessarily be in the EXE and on today's PC's the StdEXE version is only loading one file instead of 2. On today's PC's though, I don't think the load times will be very noticeable.
OCX will have a bit higher memory consumption since it has all the code and variables for all of the controls instead of just ones you are using in your EXE. This is likely a few MB which also is not a big deal on modern PC's.
Since the OCX and EXE have the same code for the controls and they are both compiled I would anticipate execution speed to be the same except possibly for a slight difference in initialization.
So I only use the OCX version for development due to its stability and then I use the StdEXE for production code.
Thanks a TON, MountainMain, for your immediate reply with clear-cut answers. Thank you so much.
Kind regards.
-
Nov 12th, 2021, 08:52 PM
#52
New Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
hi MountainMan, after researching I found your idea of using the tool is the best, but I have the following problem, please help:
- I copied VBCCR17.OCX to syswow64 (my computer win 10 64bit), I have registered regsvr32 successfully.
- But when I run the project OCX2StdExe the error message "there are no VBCCRxx.OCX or VBFLXGDxx.OCX files on this PC!"
-
Nov 13th, 2021, 12:24 AM
#53
Thread Starter
Hyperactive Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
minhtungph,
I think I have found the problem. Until 25 Oct, there had been only one version of each of Krool's OCX controls (one for 1.7, 1 for 1.6 etc.) and my utility only looked for the one version (1.0) of VBCCR17.OCX. As of Krool's version 1.7.32 the .OCX file is now 1.1 and is registered as such. I will have to modify my code to allow for versions 1.0 and 1.1 of VBCCR17.OCX. I might be able to get to it this weekend.
-
Nov 13th, 2021, 12:27 AM
#54
New Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
@MountainMan!
thank you for all you do for the vb6 community, i will wait for your new tool, good luck
-
Nov 19th, 2021, 03:21 AM
#55
Thread Starter
Hyperactive Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Version 3.1 has been released (see post #1). It now handles the changes to the VBCCROCX17 package released on 25 Oct 2021 (and all later versions).
-
Dec 20th, 2021, 10:00 PM
#56
Thread Starter
Hyperactive Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Version 3.2 is available for download at the bottom of post #1 in this thread. It now is able to handle the newest version of VBFLXGRDxx.OCX (v1.5). As before, it handles all of the VBCCRxx.OCX versions up through the present v1.7.
-
Dec 21st, 2021, 03:01 AM
#57
Lively Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Hello!
ToolBarResFileTest.zip
Compiler Results:
file not found: '..\ToolRes.RES'
'C:\ActiveXs\Krool\Krool\Zip\ToolBarTest\StdEXE\ToolBarTest.vbp' One or more of the attributes are incorrect. Some or all properties are set incorrectly。
-
Dec 22nd, 2021, 07:41 AM
#58
Thread Starter
Hyperactive Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
sileyoufu,
I had an error of deleting the .RES file if it didn't contain a manifest. Since one of the main reasons for using Krool's controls is to get theming, it is not normal for the resource file to not contain a manifest. At any rate I really meant to just skip over the manifest-less .RES file but I had a line in there to delete it. That's fixed and I added some additional error handling stuff. See the attachments at the bottom of post #1.
Also, this is similar to a test program from last year where you were referencing one of Krool's controls with a variable in your code (the Load procedure of form frmToolBarTemp.frm). If you remember, the last time you did this I advised that it would be very difficult for me to track variables in your code to figure out which control you were using so I put the Special form that you get to from the Options form for the compiler. In your case, check the Toolbar control so it will be forced to be added.
Let me know how the new version works.
-
Dec 22nd, 2021, 09:15 AM
#59
Lively Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
MountainMan:
Thank you very much for your reply and help:
1. In the development of the project, in addition to the two types of controls (source code), VBCCR and VBFLXGRD, other files without source code may be used, such as: RC6.dll, RC6Widgets.dll, gregn6.dll (Grid ++Report 6http://www.rubylong.cn/), Png file, Svg file, manifest file...
2. I want to put all of the above in the Res file. After compilation, it is an independent exe file. When the project is released, only an exe file needs to be released to the user. When the EXE file is running, C6.dll and RC6Widgets.dll are automatically released. gregn6.dll to the local current folder (Using OCX Files with SxS Technologyhttps://www.vbforums.com/showthread....=1#post5212143)
3.At any rate I really meant to just skip over the manifest-less .RES file-------whether it can be used as an option, it is up to the user to decide whether to delete or keep the RES file as it is
4. The Google translation used in the above content, if there is any unclear expression, please forgive me!
thank you for your help!
Last edited by smileyoufu; Dec 22nd, 2021 at 09:23 AM.
-
Dec 22nd, 2021, 06:25 PM
#60
Thread Starter
Hyperactive Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
OK, so now you've got me puzzled. In order to take advantage pf themes and modern-looking forms and controls, you have to specify using Comctl32.dll v6 and as far as I know, with VB6 you either have to have an appropriate external manifest (discouraged in recent years) or essentially have that manifest information included in a resource file. You don't have a manifest file nor does your resource file have the right XML to specify Comctl32.dll v6. Yet you are wanting to use at least some of Krool's controls and although they can sort of be used without activating visual styles (through Comctl32.dll v6) the controls look and behave better if they do. Since you already have a resource file why not use LaVolpe's Manifest Cr5eatr II on this site to embed a simple manifest into your resource file so you can get the benefits of the newer controls?
I would use Google translate to put this into your language but I don't know what that is...
-
Sep 11th, 2022, 04:16 AM
#61
Lively Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Thank you very much for your reply and help
1. This tool is very practical, very easy to use, I have been using it;
2. According to your suggestion, I added a list to the project, and now the project can be compiled normally
3. Now I encounter a small problem: VBCCR17.OCX version number: 1.7.45 , This file uses VBCCR1.ocx New Version: null (the project can be compiled normally)
4.cbutUpdate button (Update .OCX References) Enabled=False, cannot be used
5. Above, please help to solve it when it is convenient.
In addition: My language is simplified Chinese, you can continue to use English, I will use Google Translate to view the page
thank you very much!
-
Feb 2nd, 2023, 12:32 AM
#62
Fanatic Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Looks like a cool project. I downloaded it but it won't run. First, a missing form as it loads "c:\Files & File Systems\FileOps\mFileStufflite.bas"
Then a variable that's not defined: NameIncrNoCase
Is there another demo somewhere or any tips on how to get this thing working? It looks very interesting.
-
May 15th, 2023, 08:07 AM
#63
Lively Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Hello MountainMan! Thank you for providing the very practical "OCX2StdExe" tool, which I have been using and has been of great help to me.
Krool's VBCCR17.OCX version has been updated to 1.7.53
The version of VBFLXGRD15 has been updated to VBFLXGRD16 with version number 1.6.0.
OCX2StdExe v3.2.1 is no longer compatible with the new version of controls mentioned above. Do you have any plans to upgrade "OCX2StdExe" to adapt to VBCCR17.OCX1.7.53 and VBFLXGRD16 1.6.0 in the near future.
Thank you very much!
-
May 29th, 2023, 11:38 PM
#64
Thread Starter
Hyperactive Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Originally Posted by smileyoufu
Hello MountainMan! Thank you for providing the very practical "OCX2StdExe" tool, which I have been using and has been of great help to me.
Krool's VBCCR17.OCX version has been updated to 1.7.53
The version of VBFLXGRD15 has been updated to VBFLXGRD16 with version number 1.6.0.
OCX2StdExe v3.2.1 is no longer compatible with the new version of controls mentioned above. Do you have any plans to upgrade "OCX2StdExe" to adapt to VBCCR17.OCX1.7.53 and VBFLXGRD16 1.6.0 in the near future.
Thank you very much!
An update is coming within the week to address your concerns.
-
May 31st, 2023, 02:37 AM
#65
Lively Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Hello MountainMan!
Thank you for your prompt response and look forward to your update.
During long-term use of the OCX2StdExe tool, the following issues were encountered:
1.Sometimes when compiling a program, OCX2StdExe3.2.1 will prompt "XX module already exists", causing compilation failure. Even if the corresponding "XX module" is deleted, other modules will prompt "XX module already exists", causing compilation failure Reason: Under unknown circumstances, duplicate lines appeared in the '. vbp' file, resulting in compilation failure. Unable to find the reason for duplicate lines in '. vbp'. The method I am currently using is to delete duplicate lines in '. vbp' and then compile it to work properly. It is recommended to confirm if there are any duplicate lines when adding code to ". vbp" in the new version of "OCX2StdExe". If there are duplicates, do not add them (or delete the duplicate lines in ". vbp"), which can relatively solve this problem (if you want to find the reason for the duplicate lines in ". vbp", it may be more complex).
2. I often use the "OCX2StdExe" tool to compile DLLs, but when compiling Dll files, I cannot set "component version compatibility". Even if it is the same code, without any modifications or recompilations, it cannot be set to "component version compatibility", and the "component version compatibility" prompt cannot be set. I don't know if there is any way to solve this problem.
3. It is recommended to add the "Copy to StdEXE" function without compiling. For the convenience of running and copying code to "StdEXE" when compilation fails, for troubleshooting and debugging purposes (or manually compiling files if necessary).
Thank you very much!
-
Jun 24th, 2023, 10:19 PM
#66
Thread Starter
Hyperactive Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Version 3.3 is now uploaded in message #1. The biggest changes are 1) it now supports VBFLexGrid v1.6 and 2) it works better with VBCCR17.
-
Jun 24th, 2023, 10:54 PM
#67
Thread Starter
Hyperactive Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
smileyoufu,
Can you please send me a copy of a program you have that shows the problems you describe in post #65 above? Thanks.
-
Jun 25th, 2023, 12:19 AM
#68
Re: Krools Common Controls - Documentation and an Update/Compile Utility
i need a tool,your project have 10 usercontrol,i want to remove 9 usercontrol,only live listview control,how to do?
or ,how to remove all functions for not need?remove other modules file? remove other forms?
-
Jun 25th, 2023, 05:49 AM
#69
Fanatic Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Originally Posted by xiaoyao
i need a tool,your project have 10 usercontrol,i want to remove 9 usercontrol,only live listview control,how to do?
or ,how to remove all functions for not need?remove other modules file? remove other forms?
https://www.vbforums.com/showthread....use&highlight=
-
Sep 13th, 2023, 11:09 PM
#70
Lively Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Originally Posted by MountainMan
smileyoufu,
Can you please send me a copy of a program you have that shows the problems you describe in post #65 above? Thanks.
Hello MountainMan!
Thank you for your reply.
I have been quite busy lately and rarely appear on forums. I apologize for the late response. Please forgive me!
There are many program files and the volume after packaging is also large, making it impossible to upload the entire project. Please excuse me!
I have provided the "VBP" file separately, please refer to the attachment for details.
The text for duplicate lines in VBP is "frmCreateFrom2. frm", I hope it can be helpful!
VBP files.zip
Last edited by smileyoufu; Sep 14th, 2023 at 05:08 AM.
-
Sep 15th, 2023, 08:05 AM
#71
Lively Member
-
Oct 3rd, 2023, 06:20 PM
#72
Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
I'm sorry, but your tool never worked for me. I get errors that search for files with a .bax extension. Does it really work for anyone?
-
Oct 3rd, 2023, 06:57 PM
#73
Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
This script that I programmed in BASH for Linux, you have to copy it to the directory of your visual basic project, execute it in Linux bash and it generates a .bat with which you can later execute as many times as you want to compile the project with visual studio 6 in windows.
Code:
#!/bin/bash
# Script to convert VBCCR17 OCX to StdExe
# Run in WLinux/Kali/PengWin. Download Ubuntu or Kali from Microsoft Store and run this script.
# Modify variable "PROJECT_VB" and "ComCtlsDemoDIR"
# Enable the dependencies you need
# This script create a Batch File to run in Windows and not modify XXX_*.vbp
#
#v1.7.0
#
# Create by Ulises Cuñe @ulises2k
#
###MODIFY THIS###
PROJECT_VB="StrategyTester.vbp"
ComCtlsDemoDIR="ComCtlsDemo"
#Enable Module Dependencias TRUE=Enable / FALSE=Disable
EnableComCtlsBase=TRUE
EnableCommon=TRUE
EnableVisualStyle=TRUE
EnableVTableHandle=TRUE
EnableISubClass=TRUE
EnableCommonDialog=TRUE
VBCCRXX=VBCCR17
VB6EXE="c:\Archivos de programa\Microsoft Visual Studio\VB98\VB6.EXE"
CreateBatchWindows=TRUE
###MODIFY THIS###
###DON'T TOUCH###
function Check() {
if [ ! -d "$ComCtlsDemoDIR/Builds" ]; then
ComCtlsDemoDIR=$(echo $ComCtlsDemoDIR | tr '/' '\\')
echo "Directory $ComCtlsDemoDIR\Builds not exist. Edit this script and modify variable ComCtlsDemoDIR and run again"
exit 1
fi
if [ ! -f "$PROJECT_VB" ]; then
echo "File $PROJECT_VB not exist. Edit this script and modify variable PROJECT_VB and run again"
exit 2
fi
}
###DON'T TOUCH###
function Main() {
cp "$PROJECT_VB" "XXX_$PROJECT_VB"
#Add reference to OLEGuids
>convert_OCX2StdExe_vbp.txt
echo 'Reference=*\G{5A2B9220-BF07-11E6-9598-0800200C9A66}#1.0#0#C:\WINDOWS\system32\OLEGuids.tlb#OLE Guid and interface definitions' >> convert_OCX2StdExe_vbp.txt
#Delete reference to OCX
#sed -i -e 's/Object={AEACE989-6973-4D87-9F9D-04A487D3679D}#1.0#0;\ VBCCR11.OCX//g' "XXX_$PROJECT_VB"
#sed -i -e 's/Object={A1B7D620-9184-40D2-B545-9307A6E0C109}#1.0#0;\ VBCCR12.OCX//g' "XXX_$PROJECT_VB"
#sed -i -e 's/Object={07C05129-C2E5-483C-8237-8636C3F11E4E}#1.0#0;\ VBCCR13.OCX//g' "XXX_$PROJECT_VB"
#sed -i -e 's/Object={A99BDCD4-AB6D-490E-A03D-BF90764CBC6B}#1.0#0;\ VBCCR14.OCX//g' "XXX_$PROJECT_VB"
#sed -i -e 's/Object={43C88BE4-8BE0-4661-B06E-9A2F6AD0D267}#1.0#0;\ VBCCR15.OCX//g' "XXX_$PROJECT_VB"
#sed -i -e 's/Object={0DF5D14C-08DD-4806-8BE2-B59CB924CFC9}#1.0#0;\ VBCCR16.OCX//g' "XXX_$PROJECT_VB"
#sed -i -e 's/Object={7020C36F-09FC-41FE-B822-CDE6FBB321EB}#1.0#0;\ VBCCR17.OCX//g' "XXX_$PROJECT_VB"
sed -i -e 's/Object={7020C36F-09FC-41FE-B822-CDE6FBB321EB}#1.3#0;\ VBCCR17.OCX//g' "XXX_$PROJECT_VB"
NAME=$(grep "^Name=\"" $PROJECT_VB | cut -d "=" -f 2 | cut -d '"' -f 2)
FORM=$(grep "^Form=" $PROJECT_VB | grep -v "^IconForm=" | cut -d "=" -f 2 | tr -d "\r")
RESOURCEFILE=$(grep "^ResFile32=\"" $PROJECT_VB | cut -d "=" -f 2 | cut -d '"' -f 2)
>convert_OCX2StdExe_controls_tmp.txt
>convert_OCX2StdExe_batch.bat
#Replace RESOURCEFILE with XXX_$fileoriginal
if ! [ -z "$RESOURCEFILE" ] ; then
sed -i -e "s/$RESOURCEFILE/XXX_$RESOURCEFILE/g" "XXX_$PROJECT_VB"
if [ $CreateBatchWindows == TRUE ] ; then
echo "del /F /Q XXX_$RESOURCEFILE && copy $RESOURCEFILE XXX_$RESOURCEFILE" >> convert_OCX2StdExe_batch.bat
fi
fi
for f in $FORM ; do
#Convert Slash Windows to Linux
f=$(echo $f | tr '\\' '/')
ffilename=${f##*/}
fpath=${f%/*}
if [ $fpath == $ffilename ] ; then
cp $ffilename XXX_$ffilename
###MODIFY THIS###
#sed -i -e 's/Object\ =\ "{AEACE989-6973-4D87-9F9D-04A487D3679D}#1.0#0";\ "VBCCR11.OCX"//g' XXX_$f
#sed -i -e 's/Object\ =\ "{A1B7D620-9184-40D2-B545-9307A6E0C109}#1.0#0";\ "VBCCR12.OCX"//g' XXX_$f
#sed -i -e 's/Object\ =\ "{07C05129-C2E5-483C-8237-8636C3F11E4E}#1.0#0";\ "VBCCR13.OCX"//g' XXX_$f
#sed -i -e 's/Object\ =\ "{A99BDCD4-AB6D-490E-A03D-BF90764CBC6B}#1.0#0";\ "VBCCR14.OCX"//g' XXX_$f
#sed -i -e 's/Object\ =\ "{43C88BE4-8BE0-4661-B06E-9A2F6AD0D267}#1.0#0";\ "VBCCR15.OCX"//g' XXX_$f
#sed -i -e 's/Object\ =\ "{0DF5D14C-08DD-4806-8BE2-B59CB924CFC9}#1.0#0";\ "VBCCR16.OCX"//g' XXX_$f
#sed -i -e 's/Object\ =\ "{7020C36F-09FC-41FE-B822-CDE6FBB321EB}#1.0#0";\ "VBCCR17.OCX"//g' XXX_$f
sed -i -e 's/Object\ =\ "{7020C36F-09FC-41FE-B822-CDE6FBB321EB}#1.0#0";\ "VBCCR17.OCX"//g' XXX_$ffilename
sed -i -e "s/Begin\ $VBCCRXX\./Begin\ $NAME./g" XXX_$ffilename
sed -i -e "s/As\ $VBCCRXX\./As\ /g" XXX_$ffilename
sed -i -e "s/$ffilename/XXX_$f/g" "XXX_$PROJECT_VB"
if [ $CreateBatchWindows == TRUE ] ; then
echo "del /F /Q XXX_$ffilename && copy $ffilename XXX_$ffilename" >> convert_OCX2StdExe_batch.bat
fi
else
cp $f $fpath/XXX_$ffilename
###MODIFY THIS###
#sed -i -e 's/Object\ =\ "{AEACE989-6973-4D87-9F9D-04A487D3679D}#1.0#0";\ "VBCCR11.OCX"//g' XXX_$f
#sed -i -e 's/Object\ =\ "{A1B7D620-9184-40D2-B545-9307A6E0C109}#1.0#0";\ "VBCCR12.OCX"//g' XXX_$f
#sed -i -e 's/Object\ =\ "{07C05129-C2E5-483C-8237-8636C3F11E4E}#1.0#0";\ "VBCCR13.OCX"//g' XXX_$f
#sed -i -e 's/Object\ =\ "{A99BDCD4-AB6D-490E-A03D-BF90764CBC6B}#1.0#0";\ "VBCCR14.OCX"//g' XXX_$f
#sed -i -e 's/Object\ =\ "{43C88BE4-8BE0-4661-B06E-9A2F6AD0D267}#1.0#0";\ "VBCCR15.OCX"//g' XXX_$f
#sed -i -e 's/Object\ =\ "{0DF5D14C-08DD-4806-8BE2-B59CB924CFC9}#1.0#0";\ "VBCCR16.OCX"//g' XXX_$f
#sed -i -e 's/Object\ =\ "{7020C36F-09FC-41FE-B822-CDE6FBB321EB}#1.0#0";\ "VBCCR17.OCX"//g' XXX_$f
sed -i -e 's/Object\ =\ "{7020C36F-09FC-41FE-B822-CDE6FBB321EB}#1.0#0";\ "VBCCR17.OCX"//g' $fpath/XXX_$ffilename
sed -i -e "s/Begin\ $VBCCRXX\./Begin\ $NAME./g" $fpath/XXX_$ffilename
sed -i -e "s/As\ $VBCCRXX\./As\ /g" $fpath/XXX_$ffilename
sed -i -e "s/$$ffilename/XXX_$$ffilename/g" $fpath/XXX_$ffilename
if [ $CreateBatchWindows == TRUE ] ; then
echo "del /F /Q XXX_$ffilename && copy $f $fpath/XXX_$ffilename" >> convert_OCX2StdExe_batch.bat
fi
fi
cat $f | grep "Begin $VBCCRXX." | cut -d "." -f 2 | cut -d " " -f 1 >> convert_OCX2StdExe_controls_tmp.txt
done
cat convert_OCX2StdExe_controls_tmp.txt | sort | uniq > convert_OCX2StdExe_controls.txt
#Call to function of controls used in form
echo "Controls used:"
for c in $(cat convert_OCX2StdExe_controls.txt) ; do
$c
echo $c
done
rm -f convert_OCX2StdExe_controls_tmp.txt
rm -f convert_OCX2StdExe_controls.txt
MODULE=$(grep "^Module=" $PROJECT_VB | cut -d "=" -f 2 | cut -d ";" -f 2 | tr -d "\r")
for m in $MODULE ; do
#Convert Slash Windows to Linux
m=$(echo $m | tr '\\' '/')
mfilename=${m##*/}
mpath=${m%/*}
if [ "$mfilename" != "Common.bas" ] && [ "$mfilename" != "VisualStyles.bas" ] && [ "$mfilename" != "ComCtlsBase.bas" ] && [ "$mfilename" != "VTableHandle.bas" ]; then
if [ $mpath == $mfilename ] ; then
cp $mfilename XXX_$mfilename
sed -i -e "s/As\ $VBCCRXX\./As\ /g" XXX_$mfilename
sed -i -e "s/$mfilename/XXX_$mfilename/g" "XXX_$PROJECT_VB"
if [ $CreateBatchWindows == TRUE ] ; then
echo "del /F /Q XXX_$mfilename && copy $mfilename XXX_$mfilename" >> convert_OCX2StdExe_batch.bat
fi
else
cp $m $mpath/XXX_$mfilename
sed -i -e "s/As\ $VBCCRXX\./As\ /g" $mpath/XXX_$mfilename
sed -i -e "s/$mfilename/XXX_$mfilename/g" "XXX_$PROJECT_VB"
if [ $CreateBatchWindows == TRUE ] ; then
echo "del /F /Q XXX_$mfilename && copy $m $mpath/XXX_$mfilename" >> convert_OCX2StdExe_batch.bat
fi
fi
fi
done
CLASS=$(grep "^Class=" $PROJECT_VB | cut -d "=" -f 2 | cut -d ";" -f 2 | tr -d "\r")
for c in $CLASS ; do
#Convert Slash Windows to Linux
c=$(echo $c | tr '\\' '/')
cfilename=${c##*/}
cpath=${c%/*}
if [ "$cfilename" != "ISubclass.cls" ] && [ "$cfilename" != "CommonDialog.cls" ]; then
if [ $cpath == $cfilename ] ; then
cp $cfilename XXX_$cfilename
sed -i -e "s/As\ $VBCCRXX\./As\ /g" XXX_$cfilename
sed -i -e "s/$cfilename/XXX_$cfilename/g" "XXX_$PROJECT_VB"
if [ $CreateBatchWindows == TRUE ] ; then
echo "del /F /Q XXX_$cfilename && copy $cfilename XXX_$cfilename" >> convert_OCX2StdExe_batch.bat
fi
else
cp $c $cpath/XXX_$cfilename
sed -i -e "s/As\ $VBCCRXX\./As\ /g" $cpath/XXX_$cfilename
sed -i -e "s/$cfilename/XXX_$cfilename/g" "XXX_$PROJECT_VB"
if [ $CreateBatchWindows == TRUE ] ; then
echo "del /F /Q XXX_$cfilename && copy $c $cpath/XXX_$cfilename" >> convert_OCX2StdExe_batch.bat
fi
fi
fi
done
if [ $EnableComCtlsBase == TRUE ] ; then
ComCtlsBase
fi
if [ $EnableCommon == TRUE ] ; then
Common
fi
if [ $EnableVisualStyle == TRUE ] ; then
VisualStyle
fi
if [ $EnableVTableHandle == TRUE ] ; then
VTableHandle
fi
if [ $EnableISubClass == TRUE ] ; then
ISubClass
fi
if [ $EnableCommonDialog == TRUE ] ; then
CommonDialog
fi
#Create a Bat for exec in Windows
#FART Download from https://sourceforge.net/projects/fart-it/
if [ $CreateBatchWindows == TRUE ] ; then
echo "if not exist \"fart.exe\" ( echo \"Donwload fart.exe from https://sourceforge.net/projects/fart-it/\" && pause && exit ) " >> convert_OCX2StdExe_batch.bat
echo "fart.exe XXX_*.frm \"Begin $VBCCRXX.\" \"Begin $NAME.\" " >> convert_OCX2StdExe_batch.bat
echo "fart.exe XXX_*.frm --remove \"$VBCCRXX.\" " >> convert_OCX2StdExe_batch.bat
echo "fart.exe XXX_*.bas --remove \"$VBCCRXX.\" " >> convert_OCX2StdExe_batch.bat
OUTDIR=$(grep "^Path32=" "XXX_$PROJECT_VB" | cut -d "=" -f 2)
if [ -z $OUTDIR ] ; then
OUTDIR='%CD%'
fi
echo "\"$VB6EXE\" /make \"XXX_$PROJECT_VB\" /outdir $OUTDIR " >> convert_OCX2StdExe_batch.bat
echo "if %ERRORLEVEL% NEQ 0 ( echo Compile failed. ) else ( del XXX_*.frm XXX_*.frx XXX_*.bas XXX_*.cls ) " >> convert_OCX2StdExe_batch.bat
echo "echo \"Finish\" " >> convert_OCX2StdExe_batch.bat
fi
}
###### MODULE AND CLASS ######
function ComCtlsBase() {
echo "Module=ComCtlsBase; $ComCtlsDemoDIR\\Builds\\ComCtlsBase.bas" >> convert_OCX2StdExe_vbp.txt
}
function Common() {
echo "Module=Common; $ComCtlsDemoDIR\\Common\\Common.bas" >> convert_OCX2StdExe_vbp.txt
}
function VisualStyle() {
echo "Module=VisualStyles; $ComCtlsDemoDIR\\Common\\VisualStyles.bas" >> convert_OCX2StdExe_vbp.txt
}
function VTableHandle() {
echo "Module=VTableHandle; $ComCtlsDemoDIR\\Builds\\VTableHandle.bas" >> convert_OCX2StdExe_vbp.txt
}
function ISubClass() {
echo "Class=ISubclass; $ComCtlsDemoDIR\\Builds\\ISubclass.cls" >> convert_OCX2StdExe_vbp.txt
}
function CommonDialog() {
echo "Class=CommonDialog; $ComCtlsDemoDIR\\Builds\\CommonDialog.cls" >> convert_OCX2StdExe_vbp.txt
}
#######CONTROLS#######
function ImageList() {
echo "UserControl=$ComCtlsDemoDIR\Builds\ImageList\ImageList.ctl" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\ImageList\PPImageListGeneral.pag" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\ImageList\PPImageListImages.pag" >> convert_OCX2StdExe_vbp.txt
echo "Class=ImlListImages; $ComCtlsDemoDIR\Builds\ImageList\ImlListImages.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=ImlListImage; $ComCtlsDemoDIR\Builds\ImageList\ImlListImage.cls" >> convert_OCX2StdExe_vbp.txt
}
function ListView() {
echo "UserControl=$ComCtlsDemoDIR\Builds\ListView\ListView.ctl" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\ListView\PPListViewImageLists.pag" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\ListView\PPListViewSorting.pag" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\ListView\PPListViewGeneral.pag" >> convert_OCX2StdExe_vbp.txt
echo "Class=LvwColumnHeader; $ComCtlsDemoDIR\Builds\ListView\LvwColumnHeader.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=LvwColumnHeaders; $ComCtlsDemoDIR\Builds\ListView\LvwColumnHeaders.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=LvwListItem; $ComCtlsDemoDIR\Builds\ListView\LvwListItem.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=LvwListItems; $ComCtlsDemoDIR\Builds\ListView\LvwListItems.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=LvwListSubItem; $ComCtlsDemoDIR\Builds\ListView\LvwListSubItem.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=LvwListSubItems; $ComCtlsDemoDIR\Builds\ListView\LvwListSubItems.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=LvwGroup; $ComCtlsDemoDIR\Builds\ListView\LvwGroup.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=LvwGroups; $ComCtlsDemoDIR\Builds\ListView\LvwGroups.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=LvwVirtualListItem; $ComCtlsDemoDIR\Builds\ListView\LvwVirtualListItem.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=LvwVirtualListItems; $ComCtlsDemoDIR\Builds\ListView\LvwVirtualListItems.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=LvwWorkArea; $ComCtlsDemoDIR\Builds\ListView\LvwWorkArea.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=LvwWorkAreas; $ComCtlsDemoDIR\Builds\ListView\LvwWorkAreas.cls" >> convert_OCX2StdExe_vbp.txt
}
function ProgressBar() {
echo "UserControl=$ComCtlsDemoDIR\Builds\ProgressBar\ProgressBar.ctl" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\ProgressBar\PPProgressBarGeneral.pag" >> convert_OCX2StdExe_vbp.txt
}
function RichTextBox() {
echo "UserControl=$ComCtlsDemoDIR\Builds\RichTextBox\RichTextBox.ctl" >> convert_OCX2StdExe_vbp.txt
echo "Module=RichTextBoxBase; $ComCtlsDemoDIR\Builds\RichTextBox\RichTextBoxBase.bas" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\RichTextBox\PPRichTextBoxGeneral.pag" >> convert_OCX2StdExe_vbp.txt
}
function TabStrip() {
echo "UserControl=$ComCtlsDemoDIR\Builds\TabStrip\TabStrip.ctl" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\TabStrip\PPTabStripTabs.pag" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\TabStrip\PPTabStripGeneral.pag" >> convert_OCX2StdExe_vbp.txt
echo "Class=TbsTabs; $ComCtlsDemoDIR\Builds\TabStrip\TbsTabs.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=TbsTab; $ComCtlsDemoDIR\Builds\TabStrip\TbsTab.cls" >> convert_OCX2StdExe_vbp.txt
}
function ToolBar() {
echo "UserControl=$ComCtlsDemoDIR\Builds\ToolBar\ToolBar.ctl" >> convert_OCX2StdExe_vbp.txt
echo "Class=TbrButtons; $ComCtlsDemoDIR\Builds\ToolBar\TbrButtons.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=TbrButton; $ComCtlsDemoDIR\Builds\ToolBar\TbrButton.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=TbrButtonMenus; $ComCtlsDemoDIR\Builds\ToolBar\TbrButtonMenus.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=TbrButtonMenu; $ComCtlsDemoDIR\Builds\ToolBar\TbrButtonMenu.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=TbrButtonProperties; $ComCtlsDemoDIR\Builds\ToolBar\TbrButtonProperties.cls" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\ToolBar\PPToolBarButtons.pag" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\ToolBar\PPToolBarGeneral.pag" >> convert_OCX2StdExe_vbp.txt
}
function TreeView() {
echo "UserControl=$ComCtlsDemoDIR\Builds\TreeView\TreeView.ctl" >> convert_OCX2StdExe_vbp.txt
echo "Class=TvwNodes; $ComCtlsDemoDIR\Builds\TreeView\TvwNodes.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=TvwNode; $ComCtlsDemoDIR\Builds\TreeView\TvwNode.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=TvwSelectedNodes; $ComCtlsDemoDIR\Builds\TreeView\TvwSelectedNodes.cls" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\TreeView\PPTreeViewGeneral.pag" >> convert_OCX2StdExe_vbp.txt
}
function Animation() {
echo "UserControl=$ComCtlsDemoDIR\Builds\Animation\Animation.ctl" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\Animation\PPAnimationGeneral.pag" >> convert_OCX2StdExe_vbp.txt
}
function CheckBoxW() {
echo "UserControl=$ComCtlsDemoDIR\Builds\CheckBoxW\CheckBoxW.ctl" >> convert_OCX2StdExe_vbp.txt
}
function ComboBoxW() {
echo "UserControl=$ComCtlsDemoDIR\Builds\ComboBoxW\ComboBoxW.ctl" >> convert_OCX2StdExe_vbp.txt
}
function CommandButtonW() {
echo "UserControl=$ComCtlsDemoDIR\Builds\CommandButtonW\CommandButtonW.ctl" >> convert_OCX2StdExe_vbp.txt
}
function CommandLink() {
echo "UserControl=$ComCtlsDemoDIR\Builds\CommandLink\CommandLink.ctl" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\CommandLink\PPCommandLinkGeneral.pag" >> convert_OCX2StdExe_vbp.txt
}
function CoolBar() {
echo "UserControl=$ComCtlsDemoDIR\Builds\CoolBar\CoolBar.ctl" >> convert_OCX2StdExe_vbp.txt
echo "Class=CbrBands; $ComCtlsDemoDIR\Builds\CoolBar\CbrBands.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=CbrBand; $ComCtlsDemoDIR\Builds\CoolBar\CbrBand.cls" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\CoolBar\PPCoolBarGeneral.pag" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\CoolBar\PPCoolBarBands.pag" >> convert_OCX2StdExe_vbp.txt
echo "Class=CbrBandProperties; $ComCtlsDemoDIR\Builds\CoolBar\CbrBandProperties.cls" >> convert_OCX2StdExe_vbp.txt
}
function DTPicker() {
echo "UserControl=$ComCtlsDemoDIR\Builds\DTPicker\DTPicker.ctl" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\DTPicker\PPDTPickerGeneral.pag" >> convert_OCX2StdExe_vbp.txt
}
function FontCombo() {
echo "UserControl=$ComCtlsDemoDIR\Builds\FontCombo\FontCombo.ctl" >> convert_OCX2StdExe_vbp.txt
}
function FrameW() {
echo "UserControl=$ComCtlsDemoDIR\Builds\FrameW\FrameW.ctl" >> convert_OCX2StdExe_vbp.txt
}
function HotKey() {
echo "UserControl=$ComCtlsDemoDIR\Builds\HotKey\HotKey.ctl" >> convert_OCX2StdExe_vbp.txt
}
function ImageCombo() {
echo "UserControl=$ComCtlsDemoDIR\Builds\ImageCombo\ImageCombo.ctl" >> convert_OCX2StdExe_vbp.txt
echo "Class=ImcComboItems; $ComCtlsDemoDIR\Builds\ImageCombo\ImcComboItems.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=ImcComboItem; $ComCtlsDemoDIR\Builds\ImageCombo\ImcComboItem.cls" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\ImageCombo\PPImageComboGeneral.pag" >> convert_OCX2StdExe_vbp.txt
}
function IPAddress() {
echo "UserControl=$ComCtlsDemoDIR\Builds\IPAddress\IPAddress.ctl" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\IPAddress\PPIPAddressGeneral.pag" >> convert_OCX2StdExe_vbp.txt
}
function LabelW() {
echo "UserControl=$ComCtlsDemoDIR\Builds\LabelW\LabelW.ctl" >> convert_OCX2StdExe_vbp.txt
}
function LinkLabel() {
echo "UserControl=$ComCtlsDemoDIR\Builds\LinkLabel\LinkLabel.ctl" >> convert_OCX2StdExe_vbp.txt
echo "Class=LlbLinks; $ComCtlsDemoDIR\Builds\LinkLabel\LlbLinks.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=LlbLink; $ComCtlsDemoDIR\Builds\LinkLabel\LlbLink.cls" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\LinkLabel\PPLinkLabelGeneral.pag" >> convert_OCX2StdExe_vbp.txt
}
function ListBoxW() {
echo "UserControl=$ComCtlsDemoDIR\Builds\ListBoxW\ListBoxW.ctl" >> convert_OCX2StdExe_vbp.txt
}
function MCIWnd() {
echo "UserControl=$ComCtlsDemoDIR\Builds\MCIWnd\MCIWnd.ctl" >> convert_OCX2StdExe_vbp.txt
}
function MonthView() {
echo "UserControl=$ComCtlsDemoDIR\Builds\MonthView\MonthView.ctl" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\MonthView\PPMonthViewGeneral.pag" >> convert_OCX2StdExe_vbp.txt
}
function OptionButtonW() {
echo "UserControl=$ComCtlsDemoDIR\Builds\OptionButtonW\OptionButtonW.ctl" >> convert_OCX2StdExe_vbp.txt
}
function Pager() {
echo "UserControl=$ComCtlsDemoDIR\Builds\Pager\Pager.ctl" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\Pager\PPPagerGeneral.pag" >> convert_OCX2StdExe_vbp.txt
}
function Slider() {
echo "UserControl=$ComCtlsDemoDIR\Builds\Slider\Slider.ctl" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\Slider\PPSliderGeneral.pag" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\Slider\PPSliderAppearance.pag" >> convert_OCX2StdExe_vbp.txt
}
function SpinBox() {
echo "UserControl=$ComCtlsDemoDIR\Builds\SpinBox\SpinBox.ctl" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\SpinBox\PPSpinBoxGeneral.pag" >> convert_OCX2StdExe_vbp.txt
}
function StatusBar() {
echo "UserControl=$ComCtlsDemoDIR\Builds\StatusBar\StatusBar.ctl" >> convert_OCX2StdExe_vbp.txt
echo "Class=SbrPanelProperties; $ComCtlsDemoDIR\Builds\StatusBar\SbrPanelProperties.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=SbrPanels; $ComCtlsDemoDIR\Builds\StatusBar\SbrPanels.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=SbrPanel; $ComCtlsDemoDIR\Builds\StatusBar\SbrPanel.cls" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\StatusBar\PPStatusBarGeneral.pag" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\StatusBar\PPStatusBarPanels.pag" >> convert_OCX2StdExe_vbp.txt
}
function SysInfo() {
echo "UserControl=$ComCtlsDemoDIR\Builds\SysInfo\SysInfo.ctl" >> convert_OCX2StdExe_vbp.txt
}
function TabStrip() {
echo "UserControl=$ComCtlsDemoDIR\Builds\TabStrip\TabStrip.ctl" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\TabStrip\PPTabStripTabs.pag" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\TabStrip\PPTabStripGeneral.pag" >> convert_OCX2StdExe_vbp.txt
echo "Class=TbsTabs; $ComCtlsDemoDIR\Builds\TabStrip\TbsTabs.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=TbsTab; $ComCtlsDemoDIR\Builds\TabStrip\TbsTab.cls" >> convert_OCX2StdExe_vbp.txt
}
function TextBoxW() {
echo "UserControl=$ComCtlsDemoDIR\Builds\TextBoxW\TextBoxW.ctl" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\TextBoxW\PPTextBoxWText.pag" >> convert_OCX2StdExe_vbp.txt
}
function ToolBar() {
echo "UserControl=$ComCtlsDemoDIR\Builds\ToolBar\ToolBar.ctl" >> convert_OCX2StdExe_vbp.txt
echo "Class=TbrButtonProperties; $ComCtlsDemoDIR\Builds\ToolBar\TbrButtonProperties.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=TbrButtons; $ComCtlsDemoDIR\Builds\ToolBar\TbrButtons.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=TbrButton; $ComCtlsDemoDIR\Builds\ToolBar\TbrButton.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=TbrButtonMenus; $ComCtlsDemoDIR\Builds\ToolBar\TbrButtonMenus.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=TbrButtonMenu; $ComCtlsDemoDIR\Builds\ToolBar\TbrButtonMenu.cls" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\ToolBar\PPToolBarButtons.pag" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\ToolBar\PPToolBarGeneral.pag" >> convert_OCX2StdExe_vbp.txt
}
function TreeView() {
echo "UserControl=$ComCtlsDemoDIR\Builds\TreeView\TreeView.ctl" >> convert_OCX2StdExe_vbp.txt
echo "Class=TvwNodes; $ComCtlsDemoDIR\Builds\TreeView\TvwNodes.cls" >> convert_OCX2StdExe_vbp.txt
echo "Class=TvwNode; $ComCtlsDemoDIR\Builds\TreeView\TvwNode.cls" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\TreeView\PPTreeViewGeneral.pag" >> convert_OCX2StdExe_vbp.txt
}
function UpDown() {
echo "UserControl=$ComCtlsDemoDIR\Builds\UpDown\UpDown.ctl" >> convert_OCX2StdExe_vbp.txt
echo "PropertyPage=$ComCtlsDemoDIR\Builds\UpDown\PPUpDownGeneral.pag" >> convert_OCX2StdExe_vbp.txt
}
function VirtualCombo() {
echo "UserControl=$ComCtlsDemoDIR\Builds\VirtualCombo\VirtualCombo.ctl" >> convert_OCX2StdExe_vbp.txt
echo "Module=VirtualComboBase; $ComCtlsDemoDIR\Builds\VirtualCombo\VirtualComboBase.bas" >> convert_OCX2StdExe_vbp.txt
}
function VListBox() {
echo "UserControl=$ComCtlsDemoDIR\Builds\VListBox\VListBox.ctl" >> convert_OCX2StdExe_vbp.txt
}
function AddToVBProject() {
#Get Number Firts Form=
TOTALLINES=$(wc -l "XXX_$PROJECT_VB" | cut -d " " -f 1)
NUMLINE=$(grep "Form=" "XXX_$PROJECT_VB" -n -m 1 -o | cut -d : -f 1)
NUMLINE=$(($NUMLINE-1))
head -$(($NUMLINE)) "XXX_$PROJECT_VB" > convert_OCX2StdExe_vbp.tmp
#Convert Linux File to Windows # CRLF endline
awk 'sub("$", "\r")' convert_OCX2StdExe_vbp.txt >> convert_OCX2StdExe_vbp.tmp
tail -$(($TOTALLINES-$NUMLINE)) "XXX_$PROJECT_VB" >> convert_OCX2StdExe_vbp.tmp
cp convert_OCX2StdExe_vbp.tmp "XXX_$PROJECT_VB"
rm -f convert_OCX2StdExe_vbp.tmp
rm -f convert_OCX2StdExe_vbp.txt
awk 'sub("$", "\r")' convert_OCX2StdExe_batch.bat > convert_OCX2StdExe_Windows.bat
rm -f convert_OCX2StdExe_batch.bat
}
###DON'T TOUCH###
#Check Directory ComCtlsDemo and File Visual Baic Project
Check
#Convert Slash Linux to Windows
ComCtlsDemoDIR=$(echo $ComCtlsDemoDIR | tr '/' '\\')
#Start Function
Main
AddToVBProject
echo "Finish"
Last edited by pepegriyo2016; Oct 3rd, 2023 at 11:14 PM.
-
Nov 28th, 2023, 09:29 AM
#74
Lively Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
-
Nov 28th, 2023, 01:22 PM
#75
Thread Starter
Hyperactive Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Smileyoufu,
The OCX2StdExe does not have any of Krool's controls in it so you can't specify it as the VB6 project.
You should compile OCX2StdExe normally within the VB6 IDE. Then use the .EXE file that VB6 generates to work on other programs you have that do use Krool's controls.
MountainMan
-
Dec 3rd, 2023, 07:05 AM
#76
Lively Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
-
Dec 28th, 2023, 04:08 PM
#77
Thread Starter
Hyperactive Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Version 3.4 of this utility is available in post #1. The only change is that it now handles VBFlexGrid through v1.7.
-
May 10th, 2024, 08:13 AM
#78
Lively Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Hello MountainMan!
Do you have support VBCCR18. Plans for OCX 1.8.2 release, as well as fixes in #76 above.
-
May 30th, 2024, 06:16 AM
#79
Hyperactive Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Hi, MountainMan!
The VBCCR18 is released. Help us to update your code, please. A new control (WindowedLabel) was added. This code is not enougth:
Code:
Sub Set_xx_CCR()
Dim i As Long, oReg As Object, myStr As String
'Dim GUIDxx() As String
Dim Verxx() As String
' if you are using this in anything other than Excel, enter the latest OCX data here & recompile
MaxOCXVerCCR = 18 ' Most recent version number released of Krool's controls (VBCCRxx.OCX)
ReDim GUIDxxCCR(11 To MaxOCXVerCCR)
ReDim Verxx(11 To MaxOCXVerCCR)
ReDim NamexxCCR(11 To MaxOCXVerCCR)
ReDim Control_GUIDCCR(1 To 65, 1 To MaxOCXVerCCR)
GUIDxxCCR(18) = "{379157C5-E9BD-43F1-9F83-B037496BED42}"
Verxx(18) = "1.0"
NamexxCCR(18) = "VBCCR18.OCX"
Control_GUIDCCR(1, 18) = "C8359683-55BA-4AAC-9927-88C9C7A8DD3C" 'progid="VBCCR18.CommonDialog"
Control_GUIDCCR(2, 18) = "EC8A7603-EB8C-4173-9C42-4972A793A86C" 'progid="VBCCR18.Animation"
Control_GUIDCCR(3, 18) = "E4E59B8B-D20D-4656-9228-226EF3CA0CB0"
Control_GUIDCCR(4, 18) = "B2CC04FF-5090-4C02-B510-9716E88BDCD9" 'progid="VBCCR18.CheckBoxW"
Control_GUIDCCR(5, 18) = "19147FFA-158B-4DA9-B031-FA75DD0AF890" 'progid="VBCCR18.ComboBoxW"
Control_GUIDCCR(6, 18) = "9667B0DB-2C76-4F27-97BF-11156BBA4E11" 'progid="VBCCR18.CommandButtonW"
Control_GUIDCCR(7, 18) = "5EAF07AB-7A56-4149-A497-82E035D7090B" 'progid="VBCCR18.CommandLink"
Control_GUIDCCR(8, 18) = "834C6E68-AF2C-4053-89D2-E3FCCED69287"
Control_GUIDCCR(9, 18) = "DF4944EF-764A-4D93-B4DA-0D6749338EF6" 'progid="VBCCR18.CoolBar"
Control_GUIDCCR(10, 18) = "5FC44145-D7D8-4EAB-8CA7-60B87F381065"
Control_GUIDCCR(11, 18) = "4B3C58FC-7112-4B08-B3B1-470B2DCFFA2F"
Control_GUIDCCR(12, 18) = "FEB00E45-C4A0-4DFB-8454-C4987A2DBE06" 'progid="VBCCR18.DTPicker"
Control_GUIDCCR(13, 18) = "B8D33C5F-A8D8-469A-B00C-D27F7B2EE487"
Control_GUIDCCR(14, 18) = "B83DDC0B-CAC7-47B2-9627-4EC164A31700" 'progid="VBCCR18.FontCombo"
Control_GUIDCCR(15, 18) = "095CCEEA-03B6-44E9-8E7B-AFFEB72F6A60" 'progid="VBCCR18.FrameW"
Control_GUIDCCR(16, 18) = "DEC225A1-68EB-4CBB-91C0-4FD4D0913949" 'progid="VBCCR18.HotKey"
Control_GUIDCCR(17, 18) = "589AF2C5-643E-40C4-85F3-2C67D24A9571" 'progid="VBCCR18.ImageCombo"
Control_GUIDCCR(18, 18) = "2CC64D4B-DC8F-4495-AD42-580AC5690376"
Control_GUIDCCR(19, 18) = "3B393273-5E3E-4506-A3F0-3173B140F466" 'progid="VBCCR18.ImageList"
Control_GUIDCCR(20, 18) = "A40E9C6B-E357-4781-A59C-2CA5D7930B70"
Control_GUIDCCR(21, 18) = "63788658-57FC-457C-ABB0-87EC36842315"
Control_GUIDCCR(22, 18) = "0CDC9FE2-8D27-4D68-80E7-0FF7CDC0F6F6" 'progid="VBCCR18.IPAddress"
Control_GUIDCCR(23, 18) = "D984BD17-30BA-4E0B-AB85-7491DF73CB4F"
Control_GUIDCCR(24, 18) = "5D105D48-B608-4B50-AE86-CF1947379F57" 'progid="VBCCR18.LabelW"
Control_GUIDCCR(25, 18) = "D6D1A4D2-61DD-433D-BCD8-650A5537F95D" 'progid="VBCCR18.LinkLabel"
Control_GUIDCCR(26, 18) = "A70DB71A-AC70-4F8F-A1D6-68E3F1F24CF5"
Control_GUIDCCR(27, 18) = "9874AC62-910D-4566-BC10-5DF3F02CE204" 'progid="VBCCR18.ListBoxW"
Control_GUIDCCR(28, 18) = "B1E75914-8CB4-4800-A71B-A43310D6B4E2" 'progid="VBCCR18.ListView"
Control_GUIDCCR(29, 18) = "AB0C5F37-A56C-4C79-9962-321B616D943A"
Control_GUIDCCR(30, 18) = "9D107ACC-E9C7-4D8D-BED5-AAB9F6ED1590"
Control_GUIDCCR(31, 18) = "AA7E6F94-FE56-4F61-9609-E48E186FB28E"
Control_GUIDCCR(32, 18) = "9C8AFD17-3999-4C84-B4F7-8D90FB4033A5" 'progid="VBCCR18.MCIWnd"
Control_GUIDCCR(33, 18) = "E284466E-6750-4DF7-AEFE-16183FDC6C6F" 'progid="VBCCR18.MonthView"
Control_GUIDCCR(34, 18) = "30342EC9-6AA6-4A44-B90D-3CE73A5CEAEC"
Control_GUIDCCR(35, 18) = "0E682A9B-93A5-4F4C-A2C6-169D2AD10641" 'progid="VBCCR18.OptionButtonW"
Control_GUIDCCR(36, 18) = "6662F4B4-E0F0-4D60-9A6A-5E9B208B3392" 'progid="VBCCR18.Pager"
Control_GUIDCCR(37, 18) = "5DB956BE-A012-4C4F-AF80-5F9F778CE3A8"
Control_GUIDCCR(38, 18) = "A886CB1C-F3C9-4915-BF0E-E19A2291796E" 'progid="VBCCR18.ProgressBar"
Control_GUIDCCR(39, 18) = "8BBE0224-1DE7-45D4-BA29-B86C71D33264"
Control_GUIDCCR(40, 18) = "EEF33BF2-B9B9-4385-A703-D511BEFAEC81" 'progid="VBCCR18.RichTextBox"
Control_GUIDCCR(41, 18) = "3FA4D46D-883B-4F6A-B569-65DBE6535FF0"
Control_GUIDCCR(42, 18) = "73BBF696-6D19-46BA-9EC7-BE2B5921D43F" 'progid="VBCCR18.Slider"
Control_GUIDCCR(43, 18) = "E5A1AEC3-5509-42EC-8C1F-40BCBB5D5C3C"
Control_GUIDCCR(44, 18) = "476BDCA6-91E1-44A8-8393-A95C2052532D"
Control_GUIDCCR(45, 18) = "FE369216-6FB1-456A-A049-4A8D8E076DDC" 'progid="VBCCR18.SpinBox"
Control_GUIDCCR(46, 18) = "60DC56A6-2949-4D6D-966D-842F9B396947"
Control_GUIDCCR(47, 18) = "ED0D12DC-8D47-4B13-8B54-C4E26E771E30" 'progid="VBCCR18.StatusBar"
Control_GUIDCCR(48, 18) = "DC2A4C26-4A02-4BE7-911E-0EF40147E18E"
Control_GUIDCCR(49, 18) = "8DDC9945-3E89-4000-B35F-A87B36F21BF0"
Control_GUIDCCR(50, 18) = "1217ADD4-05E7-4949-AA9B-3961442A1330" 'progid="VBCCR18.SysInfo"
Control_GUIDCCR(51, 18) = "7FF38013-0606-4268-AD3B-970D2CEE4431" 'progid="VBCCR18.TabStrip"
Control_GUIDCCR(52, 18) = "41D7D7A5-882F-4CE8-865E-1071BB63FEF1"
Control_GUIDCCR(53, 18) = "51192D9B-177C-4737-AC63-0E2DADAA1B0B"
Control_GUIDCCR(54, 18) = "5783BC5F-C3FE-4982-B10E-D68C9DBC2B93" 'progid="VBCCR18.TextBoxW"
Control_GUIDCCR(55, 18) = "CCFE7049-5B76-4C89-B2F5-B841E63D7B81"
Control_GUIDCCR(56, 18) = "FCCADBB2-F12F-442D-9E48-00A55D2E39B2" 'progid="VBCCR18.ToolBar"
Control_GUIDCCR(57, 18) = "F6511082-8B4F-4246-BEC2-5E492989E7B2"
Control_GUIDCCR(58, 18) = "4849FCF6-C182-45DD-8986-5D8A4593C8DB"
Control_GUIDCCR(59, 18) = "35EF5609-4AE7-40C1-8196-F1ACE9213E2E" 'progid="VBCCR18.TreeView"
Control_GUIDCCR(60, 18) = "FBF38358-FBEC-4D38-AFBA-2D5A4CDD3B3C"
Control_GUIDCCR(61, 18) = "7B4B942C-C0A8-4F16-9AE2-365EFE4D8526" 'progid="VBCCR18.UpDown"
Control_GUIDCCR(62, 18) = "24EED684-815B-4A9F-AAC9-E0D8F1C75BBB"
Control_GUIDCCR(63, 18) = "EEE1C302-99F4-4ABC-B180-1C41533722B0" 'progid="VBCCR18.VirtualCombo"
Control_GUIDCCR(64, 18) = "D88CC683-6B92-4FEE-8DD0-A9212D5B7D37" 'progid="VBCCR18.VListBox"
Control_GUIDCCR(65, 18) = "49D77466-C1F3-436A-A0CA-7B5B6C462FC5" 'progid="VBCCR18.WindowedLabel"
-
May 30th, 2024, 12:43 PM
#80
Hyperactive Member
Re: Krools Common Controls - Documentation and an Update/Compile Utility
Originally Posted by Nouyana
Hi, MountainMan!
The VBCCR18 is released. Help us to update your code, please. A new control (WindowedLabel) was added. This code is not enougth:
I'm sorry. All works fine with the piece of code above. And you don't need anything else.
Tags for this Thread
Posting Permissions
- You may not post new threads
- You may not post replies
- You may not post attachments
- You may not edit your posts
-
Forum Rules
|
Click Here to Expand Forum to Full Width
|