- NSIS Discussion
- System::Call is not working with Win98
Archive: System::Call is not working with Win98
Gurleen
31st August 2004 00:04 UTC
System::Call is not working with Win98
I have a custom Dll, that I use with System::Call . It works fine with 2000 , 2003 and XP , but it does not work with win98. Is it a problem with my Dll or with System:Call compatability with win98.
Eg:
System::Call 'InstLibrary::isValidProductKey(t r1)i .r2'
IntCmp $2 1 validKey
MessageBox MB_OK|MB_ICONSTOP "Key Not valid!!!"
KrYpT
31st August 2004 05:41 UTC
System::Call should work on Win98, AFAIK. What exactly is going wrong? (I think you can pop an error message from the stack if System::Call fails.) Also maybe check your search path; I know the different operating systems use different search paths, and that may stop it from finding your DLL.
Joel
31st August 2004 14:50 UTC
What's r1? Maybe some attachment I can try it in my old Win98?
Gurleen
31st August 2004 15:15 UTC
I copy the dll to a temp directory. The I set the SetOutPath to that location so that system::call can see my dll
Gurleen
31st August 2004 15:21 UTC
r1 is a string . It's a product key . I use a function in the dll to check if it's a valid key . The problem is not with the function as I tried caling several other function in the dll and none gets called.
Gurleen
31st August 2004 15:35 UTC
The odd thing is that there is no error also . It skips the iferrors statement and dies on IntCmp statement. The output from the MessageBox MB_OK|MB_ICONSTOP " Output: $2"
is " Output: error" . Hope this may shed some light on the problem.
clearerrors
; check if the product key is valid
System::Call 'InstLibrary::isValidProductKey(t r1) i .r2'
MessageBox MB_OK|MB_ICONSTOP " Output: $2"
iferrors 0 moveNextInst
MessageBox MB_OK|MB_ICONSTOP " Error in System Call:"
quit
moveNextInst:
IntCmp $2 1 validKey
MessageBox MB_OK|MB_ICONSTOP "Key Not valid!!!"
Quit
Joel
31st August 2004 15:52 UTC
Sorry... same :/
From this view, I don't see problems with your last post code.... I'm still confised about r1, can you post how r1 become string?
zimsms
31st August 2004 15:53 UTC
Sounds like a "no unicode support" error. Try installing unicows.dll (The win9x unicode support library) onto your 95/98/ME, NT4 box, then try again.
Those platforms listed above don't support unicode fully, and if your dll calls any unicode function, or was compiled with unicode support on a box that supports unicode, your dll may not function on these OSes.
Gurleen
31st August 2004 16:19 UTC
For Lobo Lunar -
Now you cans ee where the value is coming from. It's a custom Page that asks for a username and a password. But that should have no effect on the outcome of the system:call
*******************************************************
Push ${TEMP1}
InstallOptions::dialog $PLUGINSDIR\CustomDialog.ini
Pop ${TEMP1}
StrCmp ${TEMP1} "success" 0 continue
; get the values of the Name and Product key
ReadINIStr $0 "$PLUGINSDIR\CustomDialog.ini" "Field 1" "State"
ReadINIStr $1 "$PLUGINSDIR\CustomDialog.ini" "Field 3" "State"
strcmp $debugMode "Yes" 0 +2
MessageBox MB_OK|MB_ICONSTOP " $\nName: $0 $\nKEY: $1"
clearerrors
; check if the product key is valid
System::Call 'InstLibrary::isValidProductKey(t r1) i .r2'
MessageBox MB_OK|MB_ICONSTOP " Output: $2"
iferrors 0 moveNextInst
MessageBox MB_OK|MB_ICONSTOP " Error in System Call:"
quit
moveNextInst:
IntCmp $2 1 validKey
MessageBox MB_OK|MB_ICONSTOP "Key Not valid!!!"
Quit
validKey:
Strcpy $UserName $0
StrCpy $Key $1
*******************************************************
KrYpT
31st August 2004 16:56 UTC
I have no idea why this would work on any OS, but is your dll function _stdcall or _cdecl?
Gurleen
31st August 2004 17:10 UTC
I use stdcall for my functions . This is what I use.
extern "C" int __stdcall isValidProductKeyNSIS( const char *productKey )
KrYpT
31st August 2004 17:20 UTC
Is there any difference between isValidProductKey and isValidProductKeyNSIS? (and shouldn't that declaration have included a __declspec(dllexport)?)
Joel
31st August 2004 18:51 UTC
Try from this:
System::Call 'InstLibrary::isValidProductKey(t r1) i .r2'
To this:
System::Call 'InstLibrary::isValidProductKey(t "$1") i .r2'
/edit: Forgot the "'s
Gurleen
31st August 2004 19:24 UTC
-Is there any difference between isValidProductKey and isValidProductKeyNSIS? (and shouldn't that declaration have included a __declspec(dllexport)?)
Well I use a .def file for exporting the functions, the function name was just a misspell in the previous post , sorry about that
*****************************************************
"Lobo Lunar"
System::Call 'InstLibrary::isValidProductKey(t "$1") i .r2'
Well what did you wanted me to do with the "'s .Also the coe that I am using works fine with ME,2000, XP So i think there is nothing wrong with the syntax. It's just that maybe my installer cannot locate the dll.
Joel
31st August 2004 19:36 UTC
Well what did you wanted me to do with the "'s
Nowhere :/
Is just my personal not that I forgot to include the ".
If the path is the problem, then you should try use the
InitpluginsDir
Gurleen
31st August 2004 19:46 UTC
I do use the InitpluginsDir
Joel
31st August 2004 19:58 UTC
Then... I rest my case.... :/
kichik
31st August 2004 20:06 UTC
If $2 is "error" after the call, System.dll couldn't find or load the DLL or the address of the requested function.
I suggest you try loading the DLL using a call to kernel32::LoadLibrary with the ?e flag and see what you get.
It's probably a missing import.
Gurleen
31st August 2004 20:34 UTC
Can you tell me the full command name. Also where is the manual for system dll ( like the info on return values etc)
This looks like a good lead.
kichik
31st August 2004 20:38 UTC
Which command name? LoadLibrary? That's already the full name.
The documentation is, as always, in Contrib\<Plug-in name>. In this case, Contrib\System\System.txt or System.html if you're using the latest CVS version.
You should also take a look at:
http://forums.winamp.com/showthread....+documentation
Gurleen
31st August 2004 20:43 UTC
So I need to load the dll first with kernel32::LoadLibrary
and then call system::call
kichik
31st August 2004 20:47 UTC
No. You should use LoadLibrary and the ?e flag to see if you get any error. If you get an error, you know something went wrong with loading the DLL and you also have the error code.
It's a test, not a solution.
Gurleen
31st August 2004 21:03 UTC
You mean something like this
System::Call 'kernel32::LoadLibrary(t "${INSTALLERDLL}\ApplianzInstallerLibrary.dll" ) v ?e'
and then pop the stack
kichik
31st August 2004 21:07 UTC
Yes. But I'd get the return value too, just to make sure you get all the details.
Gurleen
31st August 2004 21:18 UTC
What is the function prototype for Kernel::LoadDll
Does it return a int or a pointer to an Int.
System::Call 'kernel32::LoadLibrary(t "${INSTALLERDLL}\ApplianzInstallerLibrary.dll" ) i .r4 ? e'
OR
System::Call 'kernel32::LoadLibrary(t "${INSTALLERDLL}\ApplianzInstallerLibrary.dll" ) !i .r4 ?e'
kichik
31st August 2004 21:23 UTC
It returns HMODULE which you should treat as an integer.
Gurleen
31st August 2004 21:33 UTC
When I pop the variable I get the result 1157 . The return value is 0.
System::Call 'kernel32::LoadLibrary(t "${INSTALLERDLL}\ApplianzInstallerLibrary.dll" ) i .r4 ? e'
POP $5
MessageBox MB_OK|MB_ICONSTOP "Library Loadinjg Message: $5 , return value : $4"
kichik
31st August 2004 21:43 UTC
From WinError.h:
#define ERROR_DLL_NOT_FOUND 1157L
Gurleen
31st August 2004 22:14 UTC
So how do I get system:: to see my dll . I have tried putting it in system folder , system32 , windows . What can it be ?
I am dining the temp dir as :
!define INSTALLERDLL "$TEMP\eInspect"
The I copy the dll with these commands
SetOutPath ${INSTALLERDLL}
File C:\ApplianzDevWorkingFolder\Client\ApplianzInstallerLibrary\Debug\ApplianzInstallerLibrary.dll
SetOutPath ${INSTALLERDLL}
System::Call 'ApplianzInstallerLibrary::isValidProductKeyNSIS(t r1) i .r2'
kichik
31st August 2004 22:22 UTC
Hmm... Lets skip this method, seems not so reliable. Go to Start->Run and type:
regsvr32 "C:\ApplianzDevWorkingFolder\Client\ApplianzInstallerLibrary\Debug\ApplianzInstal
lerLibrary.dll"
What does the error message say?
Gurleen
31st August 2004 22:29 UTC
Well I am attching the screenshot of what I got after running the command.
kichik
31st August 2004 22:33 UTC
That looks like XP. Didn't you say your problem is on Windows 98?
Gurleen
31st August 2004 22:38 UTC
Sorry for that. I did not realise I was running the command on Xp . Well when I ran that on win98 it said "Bdd Command" . Does that mean that I am missing some basic libraries on 98 .
kichik
31st August 2004 22:41 UTC
No, it probably means the path is not set right. Anyway, lets just skip the testing part and assume it is a missing import. Use Dependency Walker on the DLL (from Windows 98) and see what it's missing.
Gurleen
31st August 2004 22:44 UTC
Well I did run it. It gave the following error
kichik
31st August 2004 22:47 UTC
Taken from:
http://support.microsoft.com/default...b;en-us;249873
LoadLibrary("Dllname") failed. GetlastError returns 0x00000485
From Winerror.h, 0x00000485 = 1157 (ERROR_DLL_NOT_FOUND), which means "One of the library files needed to run this application cannot be found." For example, typing regsvr32 missing.dll returns this error message if the Missing.dll file is not found.
So it really is a missing import. Use Dependecy Walker to find out which one it is.
[edit] hmm... misread that... seems like it can't find the DLL. Assuming the DLL is really located in C:\, I'd still say it's a missing import.
KrYpT
31st August 2004 22:48 UTC
My two bits: Why are you tring to use the debug version of the DLL? Maybe switching to a release version would help.
Gurleen
31st August 2004 22:53 UTC
I ran the Depends and it says I am missing msi.dll
kichik
31st August 2004 22:56 UTC
Then you must require the user to install MSI, or, the more reasonable solution, remove that dependency as it makes no sense. You're already using NSIS, why would you need MSI?
Gurleen
31st August 2004 23:03 UTC
Thanks Man .. It Worked
Well in the end it required MSI.dll . But why would it require MSI.dll . I just created a dll using VS6.0 .
But in the end it worked.. Thats what matters. Thanks a lot for helping me out. Now I can sleep tonight. Thanks to all of you who gave their input and special thanks to "kichik" for meking it work.