Oracle Pro*C 预编译器错误 PCC-S-02201



正在转换为使用 Oracle Pro*C 的现有程序在预编译时导致问题。 它从文件系统中读取文件,解析该文件,然后写入几个数据库表。

有一个具有以下定义的方法:

void parse_line(inline)
char *inline;
{
// do stuff
}

当我尝试制作它时,我看到:

Syntax error at line 162, column 13, file myfile.cp:
Error at line 162, column 13 in file myfile.cp
char *inline;
............1
PCC-S-02201, Encountered the symbol ";" when expecting one of the following:
   ( * const, volatile, an identifier,

据我所知,这个函数声明在语法上是正确的,所以我不得不假设这个预编译器错误是由于其他地方的问题而出现的。

除了将整个程序粘贴在这里之外,有人对我可以开始寻找的几个好地方有任何建议吗?

我的pcscfg.cfg看起来像这样:

sys_include=($ORACLE_HOME/precomp/public,/usr/include,/usr/lib/gcc-lib/x86_64-redhat-linux/3.2.3/include,/usr/lib/gcc/x86_64-redhat-linux/4.1.1/include,/usr/lib64/gcc/x86_64-suse-linux/4.1.2/include,/usr/lib64/gcc/x86_64-suse-linux/4.3/include)
ltype=short
define=__x86_64__

该声明无效,因为inline是C和C++中的关键字(并且只能在C中用作函数说明符)。

将该变量名称更改为其他名称,如果您编译为 C 而不是 C++,则应通过该名称。我不认为函数定义语法的风格在C++是可以接受的。

相关内容

  • 没有找到相关文章

最新更新