Refactoring of obsolete functions checks. Ticket: #1940

This commit is contained in:
Sbastien Debrard 2010-08-15 21:26:13 +02:00 committed by Daniel Marjamäki
parent 72916caee6
commit 296289d190
2 changed files with 51 additions and 311 deletions

View File

@ -38,216 +38,15 @@ void CheckObsoleteFunctions::obsoleteFunctions()
for (const Token *tok = _tokenizer->tokens(); tok; tok = tok->next()) for (const Token *tok = _tokenizer->tokens(); tok; tok = tok->next())
{ {
if (tok->strAt(1) == "bsd_signal" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::") std::list< std::pair<const std::string, const std::string> >::const_iterator it (_obsoleteFunctions.begin()), itend(_obsoleteFunctions.end());
{ for(;it!=itend;++it) {
obsoleteFunctionbsd_signal(tok->tokAt(1)); if (tok->strAt(1) == it->first && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
} {
else if (tok->strAt(1) == "gethostbyaddr" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::") reportError(tok->tokAt(1), Severity::style, "obsoleteFunctions"+it->first, it->second);
{ break;
obsoleteFunctiongethostbyaddr(tok->tokAt(1)); }
}
else if (tok->strAt(1) == "gethostbyname" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctiongethostbyname(tok->tokAt(1));
}
else if (tok->strAt(1) == "usleep" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctionusleep(tok->tokAt(1));
}
else if (tok->strAt(1) == "bcmp" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctionbcmp(tok->tokAt(1));
}
else if (tok->strAt(1) == "bcopy" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctionbcopy(tok->tokAt(1));
}
else if (tok->strAt(1) == "bzero" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctionbzero(tok->tokAt(1));
}
else if (tok->strAt(1) == "ecvt" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctionecvt(tok->tokAt(1));
}
else if (tok->strAt(1) == "fcvt" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctionfcvt(tok->tokAt(1));
}
else if (tok->strAt(1) == "gcvt" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctiongcvt(tok->tokAt(1));
}
else if (tok->strAt(1) == "ftime" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctionftime(tok->tokAt(1));
}
else if (tok->strAt(1) == "getcontext" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctiongetcontext(tok->tokAt(1));
}
else if (tok->strAt(1) == "makecontext" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctionmakecontext(tok->tokAt(1));
}
else if (tok->strAt(1) == "swapcontext" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctionswapcontext(tok->tokAt(1));
}
else if (tok->strAt(1) == "getwd" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctiongetwd(tok->tokAt(1));
}
else if (tok->strAt(1) == "index" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctionindex(tok->tokAt(1));
}
else if (tok->strAt(1) == "pthread_attr_getstackaddr" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctionpthread_attr_getstackaddr(tok->tokAt(1));
}
else if (tok->strAt(1) == "pthread_attr_setstackaddr" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctionpthread_attr_setstackaddr(tok->tokAt(1));
}
else if (tok->strAt(1) == "rindex" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctionrindex(tok->tokAt(1));
}
else if (tok->strAt(1) == "scalb" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctionscalb(tok->tokAt(1));
}
else if (tok->strAt(1) == "ualarm" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctionualarm(tok->tokAt(1));
}
else if (tok->strAt(1) == "vfork" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctionvfork(tok->tokAt(1));
}
else if (tok->strAt(1) == "wcswcs" && tok->strAt(2) == "(" && tok->tokAt(1)->varId() == 0 && !tok->tokAt(0)->isName() && tok->strAt(0) != "." && tok->strAt(0) != "::")
{
obsoleteFunctionwcswcs(tok->tokAt(1));
} }
} }
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void CheckObsoleteFunctions::obsoleteFunctionbsd_signal(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctionbsd_signal", "Found obsolete function 'bsd_signal'. It is recommended that new applications use the 'sigaction' function");
}
void CheckObsoleteFunctions::obsoleteFunctiongethostbyaddr(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctiongethostbyaddr", "Found obsolete function 'gethostbyaddr'. It is recommended that new applications use the 'getaddrinfo' function");
}
void CheckObsoleteFunctions::obsoleteFunctiongethostbyname(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctiongethostbyname", "Found obsolete function 'gethostbyname'. It is recommended that new applications use the 'getnameinfo' function");
}
void CheckObsoleteFunctions::obsoleteFunctionusleep(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctionusleep", "Found obsolete function 'usleep'. It is recommended that new applications use the 'nanosleep' or 'setitimer' function");
}
void CheckObsoleteFunctions::obsoleteFunctionbcmp(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctionbcmp", "Found obsolete function 'bcmp'. It is recommended that new applications use the 'memcmp' function");
}
void CheckObsoleteFunctions::obsoleteFunctionbcopy(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctionbcopy", "Found obsolete function 'bcopy'. It is recommended that new applications use the 'memmove' function");
}
void CheckObsoleteFunctions::obsoleteFunctionbzero(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctionbzero", "Found obsolete function 'bzero'. It is recommended that new applications use the 'memset' function");
}
void CheckObsoleteFunctions::obsoleteFunctionecvt(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctionecvt", "Found obsolete function 'ecvt'. It is recommended that new applications use the 'sprintf' function");
}
void CheckObsoleteFunctions::obsoleteFunctionfcvt(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctionfcvt", "Found obsolete function 'fcvt'. It is recommended that new applications use the 'sprintf' function");
}
void CheckObsoleteFunctions::obsoleteFunctiongcvt(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctiongcvt", "Found obsolete function 'gcvt'. It is recommended that new applications use the 'sprintf' function");
}
void CheckObsoleteFunctions::obsoleteFunctionftime(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctionftime", "Found obsolete function 'ftime'. It is recommended that new applications use the 'ftime' function. Realtime applications should use ''clock_gettime'' to determine the current time");
}
void CheckObsoleteFunctions::obsoleteFunctiongetcontext(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctiongetcontext", "Found obsolete function 'getcontext'. Due to portability issues with this function, applications are recommended to be rewritten to use POSIX threads");
}
void CheckObsoleteFunctions::obsoleteFunctionmakecontext(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctionmakecontext", "Found obsolete function 'makecontext'. Due to portability issues with this function, applications are recommended to be rewritten to use POSIX threads");
}
void CheckObsoleteFunctions::obsoleteFunctionswapcontext(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctionswapcontext", "Found obsolete function 'swapcontext'. Due to portability issues with this function, applications are recommended to be rewritten to use POSIX threads");
}
void CheckObsoleteFunctions::obsoleteFunctiongetwd(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctiongetwd", "Found obsolete function 'getwd'. It is recommended that new applications use the 'getcwd' function");
}
void CheckObsoleteFunctions::obsoleteFunctionindex(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctionindex", "Found obsolete function 'index'. It is recommended to use the function 'strchr' instead");
}
void CheckObsoleteFunctions::obsoleteFunctionpthread_attr_getstackaddr(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctionpthread_attr_getstackaddr", "Found obsolete function 'pthread_attr_getstackaddr'.It is recommended that new applications use the 'pthread_attr_getstack' function");
}
void CheckObsoleteFunctions::obsoleteFunctionpthread_attr_setstackaddr(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctionpthread_attr_setstackaddr", "Found obsolete function 'pthread_attr_setstackaddr'.It is recommended that new applications use the 'pthread_attr_setstack' function");
}
void CheckObsoleteFunctions::obsoleteFunctionrindex(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctionrindex", "Found obsolete function 'rindex'. It is recommended to use the function 'strrchr' instead");
}
void CheckObsoleteFunctions::obsoleteFunctionscalb(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctionscalb", "Found obsolete function 'scalb'.It is recommended to use either 'scalbln', 'scalblnf()' or 'scalblnl' instead of this function");
}
void CheckObsoleteFunctions::obsoleteFunctionualarm(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctionualarm", "Found obsolete function 'ualarm'.It is recommended to use either 'timer_create', 'timer_delete', 'timer_getoverrun', 'timer_gettime', or 'timer_settime' instead of this function");
}
void CheckObsoleteFunctions::obsoleteFunctionvfork(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctionvfork", "Found obsolete function 'vfork'. It is recommended to use the function 'fork' instead");
}
void CheckObsoleteFunctions::obsoleteFunctionwcswcs(const Token *tok)
{
reportError(tok, Severity::style, "obsoleteFunctionwcswcs", "Found obsolete function 'wcswcs'. It is recommended to use the function 'wcsstr' instead");
}

View File

@ -23,6 +23,9 @@
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
#include "check.h" #include "check.h"
#include <string>
#include <list>
/// @addtogroup Checks /// @addtogroup Checks
/// @{ /// @{
@ -36,12 +39,12 @@ class CheckObsoleteFunctions : public Check
public: public:
/** This constructor is used when registering the CheckObsoleteFunctions */ /** This constructor is used when registering the CheckObsoleteFunctions */
CheckObsoleteFunctions() : Check() CheckObsoleteFunctions() : Check()
{ } { initObsoleteFunctions(); }
/** This constructor is used when running checks. */ /** This constructor is used when running checks. */
CheckObsoleteFunctions(const Tokenizer *tokenizer, const Settings *settings, ErrorLogger *errorLogger) CheckObsoleteFunctions(const Tokenizer *tokenizer, const Settings *settings, ErrorLogger *errorLogger)
: Check(tokenizer, settings, errorLogger) : Check(tokenizer, settings, errorLogger)
{ } { initObsoleteFunctions(); }
void runSimplifiedChecks(const Tokenizer *tokenizer, const Settings *settings, ErrorLogger *errorLogger) void runSimplifiedChecks(const Tokenizer *tokenizer, const Settings *settings, ErrorLogger *errorLogger)
{ {
@ -53,100 +56,56 @@ public:
void obsoleteFunctions(); void obsoleteFunctions();
private: private:
/** Report Error : Using obsolete function 'bsd_signal' */ /* function name / error message */
void obsoleteFunctionbsd_signal(const Token *tok); std::list< std::pair< const std::string, const std::string> > _obsoleteFunctions;
/** Report Error : Using obsolete function 'gethostbyaddr' */ /** init obsolete functions list ' */
void obsoleteFunctiongethostbyaddr(const Token*); void initObsoleteFunctions() {
_obsoleteFunctions.push_back(std::make_pair("bsd_signal","Found obsolete function 'bsd_signal'. It is recommended that new applications use the 'sigaction' function"));
/** Report Error : Using obsolete function 'gethostbyname' */ _obsoleteFunctions.push_back(std::make_pair("gethostbyaddr","Found obsolete function 'gethostbyaddr'. It is recommended that new applications use the 'getaddrinfo' function"));
void obsoleteFunctiongethostbyname(const Token*); _obsoleteFunctions.push_back(std::make_pair("gethostbyname","Found obsolete function 'gethostbyname'. It is recommended that new applications use the 'getnameinfo' function"));
/** Report Error : Using obsolete function 'usleep' */ _obsoleteFunctions.push_back(std::make_pair("usleep","Found obsolete function 'usleep'. It is recommended that new applications use the 'nanosleep' or 'setitimer' function"));
void obsoleteFunctionusleep(const Token*);
/** Report Error : Using obsolete function 'bcmp' */ _obsoleteFunctions.push_back(std::make_pair("bcmp","Found obsolete function 'bcmp'. It is recommended that new applications use the 'memcmp' function"));
void obsoleteFunctionbcmp(const Token *tok); _obsoleteFunctions.push_back(std::make_pair("bcopy","Found obsolete function 'bcopy'. It is recommended that new applications use the 'memmove' function"));
_obsoleteFunctions.push_back(std::make_pair("bzero","Found obsolete function 'bzero'. It is recommended that new applications use the 'memset' function"));
/** Report Error : Using obsolete function 'bcopy' */ _obsoleteFunctions.push_back(std::make_pair("ecvt","Found obsolete function 'ecvt'. It is recommended that new applications use the 'sprintf' function"));
void obsoleteFunctionbcopy(const Token *tok); _obsoleteFunctions.push_back(std::make_pair("fcvt","Found obsolete function 'fcvt'. It is recommended that new applications use the 'sprintf' function"));
_obsoleteFunctions.push_back(std::make_pair("gcvt","Found obsolete function 'gcvt'. It is recommended that new applications use the 'sprintf' function"));
/** Report Error : Using obsolete function 'bzero' */ _obsoleteFunctions.push_back(std::make_pair("ftime","Found obsolete function 'ftime'. It is recommended that new applications use the 'ftime' function. Realtime applications should use ''clock_gettime'' to determine the current time"));
void obsoleteFunctionbzero(const Token *tok);
/** Report Error : Using obsolete function 'ecvt' */ _obsoleteFunctions.push_back(std::make_pair("getcontext","Found obsolete function 'getcontext'. Due to portability issues with this function, applications are recommended to be rewritten to use POSIX threads"));
void obsoleteFunctionecvt(const Token *tok); _obsoleteFunctions.push_back(std::make_pair("makecontext","Found obsolete function 'makecontext'. Due to portability issues with this function, applications are recommended to be rewritten to use POSIX threads"));
_obsoleteFunctions.push_back(std::make_pair("swapcontext","Found obsolete function 'swapcontext'. Due to portability issues with this function, applications are recommended to be rewritten to use POSIX threads"));
/** Report Error : Using obsolete function 'fcvt' */ _obsoleteFunctions.push_back(std::make_pair("getwd","Found obsolete function 'getwd'. It is recommended that new applications use the 'getcwd' function"));
void obsoleteFunctionfcvt(const Token *tok);
/** Report Error : Using obsolete function 'gcvt' */ _obsoleteFunctions.push_back(std::make_pair("index","Found obsolete function 'index'. It is recommended to use the function 'strchr' instead"));
void obsoleteFunctiongcvt(const Token *tok); _obsoleteFunctions.push_back(std::make_pair("rindex","Found obsolete function 'rindex'. It is recommended to use the function 'strrchr' instead"));
/** Report Error : Using obsolete function 'ftime' */ _obsoleteFunctions.push_back(std::make_pair("pthread_attr_getstackaddr","Found obsolete function 'pthread_attr_getstackaddr'.It is recommended that new applications use the 'pthread_attr_getstack' function"));
void obsoleteFunctionftime(const Token *tok); _obsoleteFunctions.push_back(std::make_pair("pthread_attr_setstackaddr","Found obsolete function 'pthread_attr_setstackaddr'.It is recommended that new applications use the 'pthread_attr_setstack' function"));
/** Report Error : Using obsolete function 'getcontext' */ _obsoleteFunctions.push_back(std::make_pair("scalbln","Found obsolete function 'scalb'.It is recommended to use either 'scalbln', 'scalblnf' or 'scalblnl' instead of this function"));
void obsoleteFunctiongetcontext(const Token *tok);
/** Report Error : Using obsolete function 'makecontext' */ _obsoleteFunctions.push_back(std::make_pair("ualarm","Found obsolete function 'ualarm'.It is recommended to use either 'timer_create', 'timer_delete', 'timer_getoverrun', 'timer_gettime', or 'timer_settime' instead of this function"));
void obsoleteFunctionmakecontext(const Token *tok);
/** Report Error : Using obsolete function 'swapcontext' */ _obsoleteFunctions.push_back(std::make_pair("vfork","Found obsolete function 'vfork'. It is recommended to use the function 'fork' instead"));
void obsoleteFunctionswapcontext(const Token *tok);
/** Report Error : Using obsolete function 'getwd' */ _obsoleteFunctions.push_back(std::make_pair("wcswcs","Found obsolete function 'wcswcs'. It is recommended to use the function 'wcsstr' instead"));
void obsoleteFunctiongetwd(const Token *tok);
/** Report Error : Using obsolete function 'index' */ }
void obsoleteFunctionindex(const Token *tok);
/** Report Error : Using obsolete function 'pthread_attr_getstackaddr' */
void obsoleteFunctionpthread_attr_getstackaddr(const Token *tok);
/** Report Error : Using obsolete function 'pthread_attr_setstackaddr' */
void obsoleteFunctionpthread_attr_setstackaddr(const Token *tok);
/** Report Error : Using obsolete function 'rindex' */
void obsoleteFunctionrindex(const Token *tok);
/** Report Error : Using obsolete function 'scalb' */
void obsoleteFunctionscalb(const Token *tok);
/** Report Error : Using obsolete function 'ualarm' */
void obsoleteFunctionualarm(const Token *tok);
/** Report Error : Using obsolete function 'vfork' */
void obsoleteFunctionvfork(const Token *tok);
/** Report Error : Using obsolete function 'wcswcs' */
void obsoleteFunctionwcswcs(const Token *tok);
void getErrorMessages() void getErrorMessages()
{ {
obsoleteFunctionbsd_signal(0); std::list< std::pair<const std::string, const std::string> >::const_iterator it (_obsoleteFunctions.begin()), itend(_obsoleteFunctions.end());
obsoleteFunctiongethostbyaddr(0); for(;it!=itend;++it) {
obsoleteFunctiongethostbyname(0); reportError(0, Severity::style, "obsoleteFunctions"+it->first, it->second);
obsoleteFunctionusleep(0); }
obsoleteFunctionbcmp(0);
obsoleteFunctionbcopy(0);
obsoleteFunctionbzero(0);
obsoleteFunctionecvt(0);
obsoleteFunctionfcvt(0);
obsoleteFunctiongcvt(0);
obsoleteFunctionftime(0);
obsoleteFunctiongetcontext(0);
obsoleteFunctionmakecontext(0);
obsoleteFunctionswapcontext(0);
obsoleteFunctiongetwd(0);
obsoleteFunctionindex(0);
obsoleteFunctionpthread_attr_getstackaddr(0);
obsoleteFunctionpthread_attr_setstackaddr(0);
obsoleteFunctionrindex(0);
obsoleteFunctionscalb(0);
obsoleteFunctionualarm(0);
obsoleteFunctionvfork(0);
obsoleteFunctionwcswcs(0);
} }
std::string name() const std::string name() const
@ -156,30 +115,12 @@ private:
std::string classInfo() const std::string classInfo() const
{ {
return "Warn if any of these obsolete functions are used:\n" std::string info = "Warn if any of these obsolete functions are used:\n";
"* bsd_signal\n" std::list< std::pair<const std::string, const std::string> >::const_iterator it (_obsoleteFunctions.begin()), itend(_obsoleteFunctions.end());
"* gethostbyaddr\n" for(;it!=itend;++it) {
"* gethostbyname\n" info += "* " + it->first + "\n";
"* usleep\n" }
"* bcmp\n" return info;
"* bcopy\n"
"* bzero\n"
"* ecvt\n"
"* fcvt\n"
"* gcvt\n"
"* ftime\n"
"* getcontext\n"
"* makecontext\n"
"* swapcontext\n"
"* getwd\n"
"* index\n"
"* pthread_attr_getstackaddr\n"
"* pthread_attr_setstackaddr\n"
"* rindex\n"
"* scalb\n"
"* ualarm\n"
"* vfork\n"
"* wcswcs\n";
} }
}; };
/// @} /// @}