关于一些编译错误的处理
编译过程中如果产生错误信息,需要解决掉才能继续编译下去,错误信息的产生主要是因为编译器版本造成的,共有以下几类错误信息:
1 缺少工具错误
这是编译时遇到的第一个问题,编译 qt2 时需要使用 uic 工具,uic 是 PC 上运行的工具,
用来把 Qt 的界面文件,也就是.ui 文件转换成.h 文件和.cpp 文件,转换完成后才能交
给交叉编译器编译。
解 决 办 法 :把 qtopia-free-2.2.0/dqt/bin 里 面 的 uic 文 件 拷 贝 到
qtopia-free-2.2.0/qt2/bin 下面即可。
注意:uic 拷贝到 qtopia-free-2.2.0/qt2/bin 后,需要修改一下 build 脚本文件,因为
如果您重新执行 build 命令,该脚本会把刚才编译中的 qtopia-free-2.2.0 文件夹删除,重新
解压,形成新的 qtopia-free-2.2.0,开始编译,这样刚才拷贝的 uic 就没意义了。
修改方法如下图所示:
就是在 rm –fr qtopia-free-2.2.0 和 tar xfvz qtopia-free-src-2.2.0.tar.gz 语句前加上
#注释掉,修改后保存退出。
然后执行#./build,重新编译。
2 缺少类声明
error: ‘QWSInputMethod’ has not been declared
修改方法如下:
#cd /root/yizhi/qtopia-free-2.2.0/qt2/src/kernel
# gedit qwindowsystem_qws.h
在前面增加以下两行:
class QWSInputMethod;
class QWSGestureMethod;
保存退出,继续编译。
3 缺少文件错误
源代码需要 custom-linux-arm-g++.h/cpp 文件,但是没找到。
解决办法:
#cd ./qtopia-free-2.2.0/qtopia/src/libraries/qtopia
#cp custom-linux-ipaq-g++.h custom-linux-arm-g++.h
#cp custom-linux-ipaq-g++.cpp custom-linux-arm-g++.cpp
继续编译
#cd /root/yizhi
#./build
4 无法匹配到 QSizePolicy 类的构造函数
即 QSizePolicy 类没有提供特定参数的构造函数
解决办法:
查看出错信息的文件,这里是 passwordbase_p.cpp,且出错的地方是第 35 行,使用
find 命令找到该文件在 Ubuntu 中的具体位置:
#find ./ -name passwordbase_p.cpp
找 到 后 在./qtopia-free-2.2.0/qtopia/src/libraries/qtopia/.ui/release-shared 目
录下面,执行以下命令,修改该文件:
# gedit ./qtopia-free-2.2.0/qtopia/src/libraries/qtopia/.ui/release-shared/pas
swordbase_p.cpp
移动光标到第 35 行,如下图所示:
把
prompt->setSizePolicy(QsizePolicy((QsizePolicy::SizeType)7,
(QsizePolicy::SizeType) 7,0,0,prompt->sizePolicy().hasHeightForWidth()))
函数中的 0,0 去掉,即:
prompt->setSizePolicy(QsizePolicy((QsizePolicy::SizeType)7,
(QsizePolicy::SizeType) 7,prompt->sizePolicy().hasHeightForWidth()))
去掉后如下图:
保存退出,执行如下命令重新编译:
#./build
重新编译后,会出现若干次这个类型的错误,解决办法非常相似,这里就不一一介绍了。
5 类的成员函数前有额外的类名字
如下图:
解决办法:
根据错误提示信息找到 qdawg.cpp 文件,gedit 打开该文件,移动光标到 294 行。
修改后如下图:
保存退出,继续编译
#./build
6. open 函数调用缺少必要的参数
如下图提示的错误:
解决办法参考下图:
打开 qmemoryfile_unix.cpp 文件,修改第 51 行
f=::open(tempFile,latin1(),0_CREAT | 0_WRONLY); 修改为
f=::open(tempFile,latin1(),0_CREAT | 0_WRONLY,0666);即增加 0666 参数,
保存,退出。
对于 open 函数来说,仅当创建新文件时,第三个参数使用,用于指定文件的访问权限
位
注 意:共 有 两 处 这 样 的 修 改, 另 外 一 处:
qtopia-free-2.2.0\qt2\src\tools\qmemoryfile_unix.cpp 文件的第 143 行位置,修改
方 法与 qmemoryfile_unix.cpp 文件相似。
#./build 重新编译
7 缺少 this 指针
如下图:
解决办法:执行下面的命令
# gedit ./qtopia-free-2.2.0/qt2/include/qvaluestack.h
移动光标到 57 行
将 remove( this->fromLast());改为 this->remove( this->fromLast());
保存退出。
8 缺少系统头文件
如下图所示:
解决办法如下:
# gedit .\ qtopia-free-2.2.0\qt2\src\kernel\qpixmapcache.cpp
修改第 125 行为
即:
#define PAGE_SHIFT 12
#define PAGE_SIZE (1UL << PAGE_SHIFT)
#define PAGE_MASK (~(PAGE_SIZE-1))
//# include<asm/page.h> //PAGE_SIZE,PAGE_MASK,PAGE_ALIGN
这样修改是因为新的 Linux 内核源码中已经不包含这个头文件了。
另外其他的地方也用到了该头文件,同样需要去掉,执行以下命令:
# gedit ./qtopia-free-2.2.0/qt2/tools/qvfb/qvfbview.cpp
移动到第 39 行,修改为下图所示:
修改原因是因为 asm/page.h 文件里面定义了一些宏,咱们在这里重新定义了必须使用
的宏,所以这里就不需要 asm/page.h 文件了。
说明:继续编译后会出现几次以上类型的错误,出现的错误类型就是以上总结的几种
(出错的信息通过 google 能找到解决方法),修改方法按以上步骤即可,主要就是发现哪个
文件出错,找到该文件,用 gedit 打开该文件,移动到出错的行上,修改,保存退出。出错
的文件和行号是根据编译时的错误提示信息来找到的,一定要查找第一个 Erro 的地方,这里
是需要重点关注的。通过这几种错误类型的修改,您会对 Qt 移植有了新的认识,也提高了您
的软件移植能力。
编译成功完成后,Qtopia2.2.0 会自动的安装到 qtopia-free-2.2.0/qtopia/zImage/opt
下面,如下图
进入到 Qtopia 录下面,如图:
注 意 : 编 译 好 的 Qtopia 下 面 没 有 字 体 , 自 己 需 要 把 字 体 放
到 Qtopia/lib/fonts 下面,qtopia-free-2.2.0/qt2/lib/fonts 文件夹下有各种可以用的字
体,但是我们只需要 helvetica 类型,该类型支持中文。执行以下命令:
#cp/root/yizhi/qtopia-free-2.2.0/qt2/lib/fonts/Helvetica* /root/yizhi/qtopia-fr
ee-2.2.0/qtopia/image/opt/Qtopia/lib/fonts/
另 外 需 要 把/root/yizhi/armlib 下 面 的 文 件 全 部 拷 贝 到
/root/yizhi/qtopia-free-2.2.0/qtopia/image/opt/Qtopia/lib/下面
字体文件和库文件拷贝完成后,把 Qtopia 整个录拷贝到文件系统的 /opt 录下面,如
果该目录下面已经有迅为电子提供的 Qtopia 文件夹,您可以把迅为电子提供的 Qtopia 文件
夹删除掉,来运行您自己编译的版本,运行方法参考下一章节的 Qtopia2.2.0 的使用。
更多内容:关注迅为电子