|
Oke lets passing another parameter
<br />
Public Function ExecuteAndWait(cmdline$)<br />
<br />
Dim NameOfProc As PROCESS_INFORMATION<br />
Dim NameStart As STARTUPINFO<br />
Dim x As Long<br />
Dim A<br />
Dim WorkingDirectory As String<br />
<br />
WorkingDirectory = cmdline$<br />
'MsgBox WorkingDirectory<br />
<br />
<br />
NameStart.cb = Len(NameStart)<br />
x = CreateProcessA(0&, cmdline$, 0&, 0&, 1&, HIGH_PRIORITY_CLASS, 0&, WorkingDirectory, NameStart, NameOfProc)<br />
x = WaitForSingleObject(NameOfProc.hProcess, INFINITE)<br />
x = CloseHandle(NameOfProc.hProcess)<br />
End Function<br />
it gives this error code:
run-time error 13
Type mismatch
Why ? im missing somthing ?
Thanks for your time
Greets jeroen
|
|
|
|
|
This is the Declare you used for CreateProcess:
Declare Function CreateProcessA Lib "kernel32" _
(ByVal lpApplicationName As Long, _
ByVal lpCommandLine As String, _
ByVal lpProcessAttributes As Long, _
ByVal lpThreadAttributes As Long, _
ByVal bInheritHandles As Long, _
ByVal dwCreationFlags As Long, _
ByVal lpEnvironment As Long, _
ByVal lpCurrentDirectory As Long, _
ByRef lpStartupInfo As STARTUPINFO, _
ByRef lpProcessInformation As PROCESS_INFORMATION) _
As Long
Now your trying to pass a String where your Declare said your going to pass a ByVal Long. Change it so that it reads:
ByVal lpCurrentDriectory As String
BTW, the correct Declare out of the VS6 APIViewer is this one: Your version will work so long as you pass the parameters the function expects in the format that it expects.
Public Declare Function CreateProcess Lib "kernel32" Alias "CreateProcessA" _
(ByVal lpApplicationName As String, _
ByVal lpCommandLine As String, _
ByRef lpProcessAttributes As SECURITY_ATTRIBUTES, _
ByRef lpThreadAttributes As SECURITY_ATTRIBUTES, _
ByVal bInheritHandles As Long, _
ByVal dwCreationFlags As Long, _
ByRef lpEnvironment As Any, _
ByVal lpCurrentDriectory As String, _
ByRef lpStartupInfo As STARTUPINFO, _
ByRef lpProcessInformation As PROCESS_INFORMATION) _
As Long
RageInTheMachine9532
"...a pungent, ghastly, stinky piece of cheese!" -- The Roaming Gnome
|
|
|
|
|
Thanks its working better now,
Its not opening the working Directory
It’s using the executing directory as working directory
<br />
Public Function ExecuteAndWait(cmdline$)<br />
<br />
Dim NameOfProc As PROCESS_INFORMATION<br />
Dim NameStart As STARTUPINFO<br />
Dim x As Long<br />
Dim WorkingDirectory As String<br />
WorkingDirectory = "c:\"<br />
'MsgBox WorkingDirectory<br />
NameStart.cb = Len(NameStart)<br />
<br />
x = CreateProcessA(0&, cmdline$, 0&, 0&, 1&, HIGH_PRIORITY_CLASS, 0&, WorkingDirectory, NameStart, NameOfProc)<br />
x = WaitForSingleObject(NameOfProc.hProcess, INFINITE)<br />
x = CloseHandle(NameOfProc.hProcess)<br />
<br />
End Function<br />
thats strange, any idee ?
thanks for your time
Greets jeroen
|
|
|
|
|
The open dialog is using the executing directory, not the directory from which the application was "launched", which would be the "working directory". This app is apparantly setting this internally. If that's the case, your not going to be able to change that.
RageInTheMachine9532
"...a pungent, ghastly, stinky piece of cheese!" -- The Roaming Gnome
|
|
|
|
|
Correct, im testing the function with notepad
(using windows XP)
its working now
i need this function for another
program (slow loading game)
Thanks for your help
Greets jeroen
|
|
|
|
|
I have the hWnd for another window, not part of my application, and I need to get the icon that explorer.exe is using for the window's icon in the task bar. It needs to be in a form that I can use it to create a system tray icon.
VB6 or .Net is fine.
|
|
|
|
|
To get the ICON of a EXE file use API Function: SHGetFileInfo()
|
|
|
|
|
You'll have to extract the icons out of the resources of the target app's .EXE. You can't get an application to given up it's running icon so easily. You'll end up trying to read the memory of another process and that's not easily allowed in Windows.
RageInTheMachine9532
"...a pungent, ghastly, stinky piece of cheese!" -- The Roaming Gnome
|
|
|
|
|
Thanks for the help, but I think both of you are looking at this the wrong way.
Extractoing icons from the exe would work, but if there was more than one icon I wouldn'y know which to use. The application's icon is not alwayse the window icon.
Shell replacements seem to have no problems getting the icon for a running window... The following code is from Soft Shell Logi - a VB6 shell replacement: (Declarations neglected)
<br />
Private Sub DrawIcon(HDC As Long, hwnd As Long, X As Integer, Y As Integer)<br />
ico = GetIcon(hwnd)<br />
DrawIconEx HDC, X, Y, ico, 16, 16, 0, 0, DI_NORMAL<br />
End Sub<br />
<br />
Public Function GetIcon(hwnd As Long) As Long<br />
Call SendMessageTimeout(hwnd, WM_GETICON, 0, 0, 0, 1000, GetIcon)<br />
If Not CBool(GetIcon) Then GetIcon = GetClassLong(hwnd, GCL_HICONSM)<br />
If Not CBool(GetIcon) Then Call SendMessageTimeout(hwnd, WM_GETICON, 1, 0, 0, 1000, GetIcon)<br />
If Not CBool(GetIcon) Then GetIcon = GetClassLong(hwnd, GCL_HICON)<br />
If Not CBool(GetIcon) Then Call SendMessageTimeout(hwnd, WM_QUERYDRAGICON, 0, 0, 0, 1000, GetIcon)<br />
End Function<br />
Is there a way I can use DrawIcon to draw to a bitmap and create the icon for use in the system tray?
|
|
|
|
|
Since you got the handle to the icon, just can try (.NET):
Dim bmpIcon As Bitmap = Bitmap.FromHicon(handle returned by your GetIcon)
RageInTheMachine9532
"...a pungent, ghastly, stinky piece of cheese!" -- The Roaming Gnome
|
|
|
|
|
I figured out fully the functions of this call through the use of for loops. This is great but there is a speed issue when handling the functions of this dll through for loops. I am just wandering if annoy one knows how to make this call work in .NET. The declare in vb 6.0 is
Private Declare Sub CopyMemory Lib "kernel32.dll" Alias "RtlMoveMemory" (ByRef Destination As Any, ByRef Source As Any, ByVal Length As Long)<br />
This is what i am having to work with. As anyone should know that the datatype
is not supported in .net. So i replaced it with the Object datatype.
a call to this dll function looks like this
<br />
Dim bytearray(3) as Byte<br />
dim bytearray2(3) as Byte<br />
<br />
Copymemory(bytearray(0), bytearray2(0), 4)<br />
This function copys all data starting with bytearray2(0) to bytearray(0) then
bytearray2(1) to bytearray(1) and so on until it copys 4 times. As you can see this can be done with a for loop. But say you have to run thought that for loop 1000 times. The Dll call is much more efficient. When i do it in the manner that i am now my processor sits at 100 percent for almost 3 seconds while it goes through these loops. In 6.0 using the dll call there is no wait and no processor jump. I need this call to work for program efficiency. Any help would be great. Thank you
|
|
|
|
|
The problem is you CAN'T use this function on managed objects and variables in .NET. The address you provide is not guaranteed to be the address of your object when the call to CopyMemory if made. The speed issue your having is because your marshaling objects back and forth between managed and unmanaged code.
Youe best bet is to trace through the code in VB6, and step by step, follow what happens to the array, then duplicate the steps necessary to perform the same thng in managed code. You'll be writing extra lines of code to do this, but you'll also gain a nice performance benefit by doing it either of there two ways.
So instead of CopyMemory from bytearray2 to bytearray0, you would just do:
bytearray(0) = bytearray(2)
bytearray(1) = bytearray(3)
bytearray(2) = bytearray(4)
bytearray(3) = bytearray(5)
You could also do this:
Array.Copy( bytearray, 2, bytearray, 0, 4)
You'll have to test each method to find out which is going to give you the greatest performance benefit, but both will be MUCH better than calling an unmanaged function on a managed object...
RageInTheMachine9532
"...a pungent, ghastly, stinky piece of cheese!" -- The Roaming Gnome
|
|
|
|
|
I would like to limit user using the System Menu CANCEL box in order to force them using CANCEL button instead! I can disable MINIMIZE & MAXIMIZE boxes but I can not disable CANCEL box in Property of System.Window.form... anyone knows how to do it?
Thanks,
|
|
|
|
|
Make the ControlBox property of the Form False.
|
|
|
|
|
Hi,
Thank you very much, I got it!
Regards
|
|
|
|
|
hello
well... i posted twice the same problem but it looks like
i wont get any answer
so i just want to know the answer
can i create a connection that enable me to chat with other computer user
(1 on 1) only
i just want to know can or cannot
please answer me cause if cannot i have to change or alter my whole program
but if can then can you please give me a link or help to where i can find such sample or codings
thank you
Gary
|
|
|
|
|
it's possible..
A friend of mine made a nice program to chat and share files on LAN.
do you use VB6 or VB.net ?
in both cases you'll need to know about Windows sockets.
using Winsock control in VB6 or .NET classes for VB.NET.
|
|
|
|
|
|
thank you very much for your help
currently in using VB.Net
so i'll study the winsock
so that i can try to connect or detect other computer
again here i thank you for your help
Gary
|
|
|
|
|
Hi, I want to import data from hundreds if not thousands of password protected excel spreadsheets.
Instead of manually opening them and unprotecting them by hand, how can I modify my program, which already imports the un-protected ones, so that it can read them even tough they are password protected.
|
|
|
|
|
The Open method of the Workbooks collection supports opening the file with a password. All you have to do is supply it. This is the description for the 2003 version of Office. Previous versions support most of the same options, but they all support opening a password protected file:
expression.Open(FileName, UpdateLinks, ReadOnly, Format, Password, WriteResPassword, IgnoreReadOnlyRecommended, Origin,
Delimiter, Editable, Notify, Converter, AddToMru, Local, CorruptLoad)
expression must return the Workbooks object.
RageInTheMachine9532
"...a pungent, ghastly, stinky piece of cheese!" -- The Roaming Gnome
|
|
|
|
|
hello
please help me
i have the code below that i got from a few books
Private Sub Connect_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Connect.Click
If ipB.Text <> "" And portB.Text <> "" Then
chatB.AppendText("Requesting Connection" & vbCrLf)
On Error GoTo ErrorM
myclient = New TcpClient(ipB.Text, portB.Text)
myclient.GetStream.BeginRead(mydata, 0, 1024, AddressOf DoRead, Nothing)
Status.Panels.Text = "Requesting Connection..."
chatB.AppendText("Connected..." & vbCrLf)
chatB.AppendText("----------------" & vbCrLf)
Status1.Panels(0).Text = "Connected to " & ipB.Text & ":" & portB.Text
Timer1.Enabled = True
a = InputB("Enter Nickname:", "Chat 2003")
Send("nick:" & a)
portB.Enabled = False
SendB.Enabled = True
Connect.Visible = False
DC.Visible = True
ipB.Enabled = False
End If
ErrorM: If SendB.Enabled = False Then
chatB.AppendText("Please try again")
End If
End Sub
somehow the code wont work. i keep getting "Please try again"
im trying detect my college server with the coding
is it possible??
or do i need something else??
can u tell me what else i need
thank you in advance
Gary
|
|
|
|
|
Let's say that I have created 2 interface types that is implemented in 2 classes in a dll, 1 interface implemented by 1 class. Now I need to load those classes and then instantiate an object to invoke the interfaces. Question: How do I determine at runtime the interface implemented by a class so that I can cast to the object's type and then invoke it's interface? Is there a better way than trying to cast it to a specific object hoping it will not raise an exception in which case I'd have to cast it to another type?
I am building an application that is extensible by plugins and I need this functionality.
It hurts to ask, but it hurts more to be ignorant.
|
|
|
|
|
|
I got it!!! I forgot about the Typeof keyword. Thanks.
It really does not hurt to ask, especially when you knew the answer all along.
|
|
|
|
|