Jump to content

.a3x error undefined function


Skysnake
 Share

Recommended Posts

Hi

I need help.

I have re-installed AutoIt, but the problem persists.

My script uses an #include <tourney_mymain.a3x> which Scite fails to read.  To be clear, as long as it is in .au3 format, it works.  The moment I build it as .a3x, it fails.

;#include <tourney_mymain.a3x>
#include <tourney_mymain.au3>

_MyMainFunc()

The file tourney_mymain.au3 exists in the same folder, and the header looks like this

#Region ;**** Directives created by AutoIt3Wrapper_GUI ****
#AutoIt3Wrapper_Outfile_type=a3x
#AutoIt3Wrapper_Outfile=C:\AutoIt\tourney\tourney_mymain.a3x
#AutoIt3Wrapper_Run_AU3Check=n
#AutoIt3Wrapper_Run_Tidy=y
#EndRegion ;**** Directives created by AutoIt3Wrapper_GUI ****

The error looks like this:

>"C:\Program Files (x86)\AutoIt3\SciTE\..\AutoIt3.exe" "C:\Program Files (x86)\AutoIt3\SciTE\AutoIt3Wrapper\AutoIt3Wrapper.au3" /run /prod /ErrorStdOut /in "C:\AutoIt\tourney\tourney.au3" /UserParams    
+>16:13:57 Starting AutoIt3Wrapper v.16.306.1237.0 SciTE v.3.6.2.0   Keyboard:00000409  OS:WIN_10/  CPU:X64 OS:X64  Environment(Language:0409)  CodePage:0  utf8.auto.check:4    # detect ascii high characters and if none found set default encoding to UTF8 and do not add BOM
+>         SciTEDir => C:\Program Files (x86)\AutoIt3\SciTE   UserDir => C:\Users\user\AppData\Local\AutoIt v3\SciTE\AutoIt3Wrapper   SCITE_USERHOME => C:\Users\user\AppData\Local\AutoIt v3\SciTE 
>Running Tidy (16.306.1237.0)  from:C:\Program Files (x86)\AutoIt3\SciTE\tidy
+>16:13:57 Tidy ended.rc:0
>Running AU3Check (3.3.14.2)  from:C:\Program Files (x86)\AutoIt3  input:C:\AutoIt\tourney\tourney.au3
"C:\AutoIt\tourney\tourney.au3"(55,13) : error: _MyMainFunc(): undefined function.
_MyMainFunc()
~~~~~~~~~~~~^
C:\AutoIt\tourney\tourney.au3 - 1 error(s), 0 warning(s)
!>16:13:57 AU3Check ended. Press F4 to jump to next error.rc:2
+>16:13:57 AutoIt3Wrapper Finished.
>Exit code: 2    Time: 1.028

When I toggle back to the .au3 file and compile/run, it works.

>"C:\Program Files (x86)\AutoIt3\SciTE\..\AutoIt3.exe" "C:\Program Files (x86)\AutoIt3\SciTE\AutoIt3Wrapper\AutoIt3Wrapper.au3" /run /prod /ErrorStdOut /in "C:\AutoIt\tourney\tourney.au3" /UserParams    
+>16:28:05 Starting AutoIt3Wrapper v.16.306.1237.0 SciTE v.3.6.2.0   Keyboard:00000409  OS:WIN_10/  CPU:X64 OS:X64  Environment(Language:0409)  CodePage:0  utf8.auto.check:4    # detect ascii high characters and if none found set default encoding to UTF8 and do not add BOM
+>         SciTEDir => C:\Program Files (x86)\AutoIt3\SciTE   UserDir => C:\Users\user\AppData\Local\AutoIt v3\SciTE\AutoIt3Wrapper   SCITE_USERHOME => C:\Users\user\AppData\Local\AutoIt v3\SciTE 
>Running Tidy (16.306.1237.0)  from:C:\Program Files (x86)\AutoIt3\SciTE\tidy
+>16:28:06 Tidy ended.rc:0
>Running AU3Check (3.3.14.2)  from:C:\Program Files (x86)\AutoIt3  input:C:\AutoIt\tourney\tourney.au3
+>16:28:06 AU3Check ended.rc:0
>Running:(3.3.14.2):C:\Program Files (x86)\AutoIt3\autoit3.exe "C:\AutoIt\tourney\tourney.au3"    
--> Press Ctrl+Alt+Break to Restart or Ctrl+Break to Stop
I was here!
+>16:28:06 AutoIt3.exe ended.rc:0
+>16:28:06 AutoIt3Wrapper Finished.
>Exit code: 0    Time: 1.066

Building the .a3x file, returns this:

>"C:\Program Files (x86)\AutoIt3\SciTE\..\AutoIt3.exe" "C:\Program Files (x86)\AutoIt3\SciTE\AutoIt3Wrapper\AutoIt3Wrapper.au3" /NoStatus /prod /in "C:\AutoIt\tourney\tourney_mymain.au3"
+>16:29:01 Starting AutoIt3Wrapper v.16.306.1237.0 SciTE v.3.6.2.0   Keyboard:00000409  OS:WIN_10/  CPU:X64 OS:X64  Environment(Language:0409)  CodePage:0  utf8.auto.check:4    # detect ascii high characters and if none found set default encoding to UTF8 and do not add BOM
+>         SciTEDir => C:\Program Files (x86)\AutoIt3\SciTE   UserDir => C:\Users\user\AppData\Local\AutoIt v3\SciTE\AutoIt3Wrapper   SCITE_USERHOME => C:\Users\user\AppData\Local\AutoIt v3\SciTE 
>Running Tidy (16.306.1237.0)  from:C:\Program Files (x86)\AutoIt3\SciTE\tidy
+>16:29:01 Tidy ended.rc:0
>Running:(3.3.14.2):C:\Program Files (x86)\AutoIt3\aut2exe\aut2exe.exe  /in "C:\AutoIt\tourney\tourney_mymain.au3" /out "C:\Users\user\AppData\Local\AutoIt v3\Aut2exe\~AUDA33.tmp.a3x" /nopack /comp 2
+>16:29:02 Aut2exe.exe ended.C:\Users\user\AppData\Local\AutoIt v3\Aut2exe\~AUDA33.tmp.a3x. rc:0
+>16:29:02 Created program:C:\AutoIt\tourney\tourney_mymain.a3x
+>16:29:02 AutoIt3Wrapper Finished.
>Exit code: 0    Time: 1.718

And the header of the  contents of the .a3x file looks like this:

£HK¾˜lJ©™LS
†ÖH}AU3!EA06M¨ÿs$§<öz�ñg¬Á“çkCÊR¦­  á»:)ãìç�˜.@½ášÞ€F±�k;!Ô±Öu:È=ÆÐ3÷�¯Ë�¢”���ˆþd•aç¶M�ø  ,p~©=�ã™Õˆ   ¬C�9˜�8öþ8_Yr©0h�d

It looks like this in pure AutoIt:

Func _MainFunc()

    ConsoleWrite("I was here!" & @CRLF)

    Local $sMainstatus = 'The database is empty'

    $Main = GUICreate("Roster", 640, 480)

    ; --- Top level menu
    Global $idHelpmenu = GUICtrlCreateMenu(" Help ")

I have a similar AutoIT installation running on Windows 7, no problem.  The machine giving problems is Win 10.

Any ideas would be appreciated.  This is a new pet project of mine and this is just the start, so I am willing to zip ALL of it and send it along if anyone wants to see inside.

Thanks.

Skysnake

Edited by Skysnake
typo

Skysnake

Why is the snake in the sky?

Link to comment
Share on other sites

Your function is named _MainFunc, you're calling _MyMainFunc in the script.

If I posted any code, assume that code was written using the latest release version unless stated otherwise. Also, if it doesn't work on XP I can't help with that because I don't have access to XP, and I'm not going to.
Give a programmer the correct code and he can do his work for a day. Teach a programmer to debug and he can do his work for a lifetime - by Chirag Gude
How to ask questions the smart way!

I hereby grant any person the right to use any code I post, that I am the original author of, on the autoitscript.com forums, unless I've specifically stated otherwise in the code or the thread post. If you do use my code all I ask, as a courtesy, is to make note of where you got it from.

Back up and restore Windows user files _Array.au3 - Modified array functions that include support for 2D arrays.  -  ColorChooser - An add-on for SciTE that pops up a color dialog so you can select and paste a color code into a script.  -  Customizable Splashscreen GUI w/Progress Bar - Create a custom "splash screen" GUI with a progress bar and custom label.  -  _FileGetProperty - Retrieve the properties of a file  -  SciTE Toolbar - A toolbar demo for use with the SciTE editor  -  GUIRegisterMsg demo - Demo script to show how to use the Windows messages to interact with controls and your GUI.  -   Latin Square password generator

Link to comment
Share on other sites

Nope that is not it.

 

The difference is simply coz of my testing.

I have just renamed it to _TheFunctionWhicha3xDoesnotFind() in the main, then pasted into my include .au3, where it works.

Build ,a3x and I get the error

>"C:\Program Files (x86)\AutoIt3\SciTE\..\AutoIt3.exe" "C:\Program Files (x86)\AutoIt3\SciTE\AutoIt3Wrapper\AutoIt3Wrapper.au3" /run /prod /ErrorStdOut /in "C:\AutoIt\tourney\tourney.au3" /UserParams    
+>17:10:47 Starting AutoIt3Wrapper v.16.306.1237.0 SciTE v.3.6.2.0   Keyboard:00000409  OS:WIN_10/  CPU:X64 OS:X64  Environment(Language:0409)  CodePage:0  utf8.auto.check:4    # detect ascii high characters and if none found set default encoding to UTF8 and do not add BOM
+>         SciTEDir => C:\Program Files (x86)\AutoIt3\SciTE   UserDir => C:\Users\user\AppData\Local\AutoIt v3\SciTE\AutoIt3Wrapper   SCITE_USERHOME => C:\Users\user\AppData\Local\AutoIt v3\SciTE 
>Running Tidy (16.306.1237.0)  from:C:\Program Files (x86)\AutoIt3\SciTE\tidy
+>17:10:48 Tidy ended.rc:0
>Running AU3Check (3.3.14.2)  from:C:\Program Files (x86)\AutoIt3  input:C:\AutoIt\tourney\tourney.au3
"C:\AutoIt\tourney\tourney.au3"(67,33) : error: _TheFunctionWhicha3xDoesnotFind(): undefined function.
_TheFunctionWhicha3xDoesnotFind()
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^
C:\AutoIt\tourney\tourney.au3 - 1 error(s), 0 warning(s)
!>17:10:48 AU3Check ended. Press F4 to jump to next error.rc:2
+>17:10:48 AutoIt3Wrapper Finished.
>Exit code: 2    Time: 1.043

 

Edited by Skysnake

Skysnake

Why is the snake in the sky?

Link to comment
Share on other sites

I changed the .a3x file's name to 

#AutoIt3Wrapper_Outfile=C:\AutoIt\tourney\tourney_mymain.lib

and now it works.

is it possible that access to the .a3x is restricted by my Anti virus?

Built as .a3x.  Trying to include it results in this error.  Changing the build name makes it work.  I changed the .lib back to .a3x and the error came back...

thnx for the interest. :)

 

Edited by Skysnake

Skysnake

Why is the snake in the sky?

Link to comment
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
 Share

×
×
  • Create New...