Simple alias for a more complex command...
create procedure nameofmyprocedure () select * from mytable;
To use within mySQL
call nameofmyprocedure();
This assumes that no arguments are required (empty argument list () ).
Tuesday, 23 September 2008
Fixing undefined reference to vtable errors in QT3
Assuming that you have added the Q_OBJECT macro to your class definition then the problem is that you are not generating and referencing the moc file for that class.
Easiest way to fix is to run qmake on your src.pro file (if you are using kdevelop, making sure that qmake is the correct one for your version, QT3 and QT4 qmake are not the same.)
Alternatively, run
moc -o myheader.moc myheader.h
and include the myheader.moc file in your project. It will need to be updated every time you change your SIGNALS or SLOTS in that class, so you may want to automate its creation.
Easiest way to fix is to run qmake on your src.pro file (if you are using kdevelop, making sure that qmake is the correct one for your version, QT3 and QT4 qmake are not the same.)
Alternatively, run
moc -o myheader.moc myheader.h
and include the myheader.moc file in your project. It will need to be updated every time you change your SIGNALS or SLOTS in that class, so you may want to automate its creation.
Friday, 12 September 2008
Linux library types
Copied from yolinux.
.a Static library, the contents become part of the compiled executable.
.so Dynamically linked shared object library. Do not become part of the executable but must be present at run-time.
How to generate a static library (.a)
Compile: cc -Wall -c ctest1.c ctest2.c
Compiler options:
-Wall: include warnings. See man page for warnings specified.
Create library "libctest.a": ar -cvq libctest.a ctest1.o ctest2.o
List files in library: ar -t libctest.a
Linking with the library:
cc -o executable-name prog.c libctest.a
cc -o executable-name prog.c -L/path/to/library-directory -lctest
How to generate a dynamically linked shared object library: .so
Create object code
gcc -Wall -fPIC -c *.c
Create library
gcc -shared -Wl,-soname,libctest.so.1 -o libctest.so.1.0 *.o
Optional: create default version using symbolic link
mv libctest.so.1.0 /usr/lib
ln -sf /usr/lib/libctest.so.1.0 /usr/lib/libctest.so
ln -sf /usr/lib/libctest.so.1.0 /usr/lib/libctest.so.1
Compiler options:
-Wall: include warnings. See man page for warnings specified.
-fPIC: Compiler directive to output position independent code, a characteristic required by shared libraries. Also see "-fpic".
-shared: Produce a shared object which can then be linked with other objects to form an executable.
-W1: Pass options to linker.
In this example the options to be passed on to the linker are: "-soname libctest.so.1". The name passed with the "-o" option is passed to gcc.
Option -o: Output of operation. In this case the name of the shared object to be output will be "libctest.so.1.0"
Library Links:
The link to /usr/lib/libctest.so allows the naming convention for the compile flag -lctest to work.
The link to /usr/lib/libctest.so.1 allows the run time binding to work. See dependency below.
Compiling for runtime linking with a dynamically linked libctest.so.1.0:
gcc -Wall -I/path/to/include-files -L/path/to/libraries prog.c -lctest -o prog
Use:
gcc -Wall -L/opt/lib prog.c -lctest -o prog
Where the name of the library is libctest.so. (This is why you must create the symbolic links or you will get the error "/usr/bin/ld: cannot find -lctest".)
The libraries will NOT be included in the executable but will be dynamically linked during runtime execution.
The shared library dependencies of the executable can be listed with the command: ldd name-of-executable
.a Static library, the contents become part of the compiled executable.
.so Dynamically linked shared object library. Do not become part of the executable but must be present at run-time.
How to generate a static library (.a)
Compile: cc -Wall -c ctest1.c ctest2.c
Compiler options:
-Wall: include warnings. See man page for warnings specified.
Create library "libctest.a": ar -cvq libctest.a ctest1.o ctest2.o
List files in library: ar -t libctest.a
Linking with the library:
cc -o executable-name prog.c libctest.a
cc -o executable-name prog.c -L/path/to/library-directory -lctest
How to generate a dynamically linked shared object library: .so
Create object code
gcc -Wall -fPIC -c *.c
Create library
gcc -shared -Wl,-soname,libctest.so.1 -o libctest.so.1.0 *.o
Optional: create default version using symbolic link
mv libctest.so.1.0 /usr/lib
ln -sf /usr/lib/libctest.so.1.0 /usr/lib/libctest.so
ln -sf /usr/lib/libctest.so.1.0 /usr/lib/libctest.so.1
Compiler options:
-Wall: include warnings. See man page for warnings specified.
-fPIC: Compiler directive to output position independent code, a characteristic required by shared libraries. Also see "-fpic".
-shared: Produce a shared object which can then be linked with other objects to form an executable.
-W1: Pass options to linker.
In this example the options to be passed on to the linker are: "-soname libctest.so.1". The name passed with the "-o" option is passed to gcc.
Option -o: Output of operation. In this case the name of the shared object to be output will be "libctest.so.1.0"
Library Links:
The link to /usr/lib/libctest.so allows the naming convention for the compile flag -lctest to work.
The link to /usr/lib/libctest.so.1 allows the run time binding to work. See dependency below.
Compiling for runtime linking with a dynamically linked libctest.so.1.0:
gcc -Wall -I/path/to/include-files -L/path/to/libraries prog.c -lctest -o prog
Use:
gcc -Wall -L/opt/lib prog.c -lctest -o prog
Where the name of the library is libctest.so. (This is why you must create the symbolic links or you will get the error "/usr/bin/ld: cannot find -lctest".)
The libraries will NOT be included in the executable but will be dynamically linked during runtime execution.
The shared library dependencies of the executable can be listed with the command: ldd name-of-executable
Monday, 8 September 2008
Automating FTP transfer with linux
edit file ~/.netrc to contain
machine sample.ftpsite.com
login anonymous (or user name)
password mymail@mydomain.com (or user's password)
Make sure you:
chmod 600 ~/.netrc
To keep your passwords secure.
The ftp client will check the contents of this file when performing an ftp connection and will use the login and password when the machine matches one of the entries in the file. This is useful when writing a script to automate file transfer (as part of a cronjob for example) as no user intervention is necessary.
machine sample.ftpsite.com
login anonymous (or user name)
password mymail@mydomain.com (or user's password)
Make sure you:
chmod 600 ~/.netrc
To keep your passwords secure.
The ftp client will check the contents of this file when performing an ftp connection and will use the login and password when the machine matches one of the entries in the file. This is useful when writing a script to automate file transfer (as part of a cronjob for example) as no user intervention is necessary.
The FTP script itself might look like:
open sample.ftpsite.com
cd backupdir
lcd mylocalbackups
put backupfile.log
That script (remember to chmod +x scriptname) can be added to the cron daemon.
Subscribe to:
Posts (Atom)