Compile fixes for irix

parent 954542b0
...@@ -488,14 +488,14 @@ template <unsigned size> ...@@ -488,14 +488,14 @@ template <unsigned size>
inline void inline void
BitmaskPOD<size>::assign(const typename BitmaskPOD<size>::Data & src) BitmaskPOD<size>::assign(const typename BitmaskPOD<size>::Data & src)
{ {
assign(rep.data, src.data); BitmaskPOD<size>::assign(rep.data, src.data);
} }
template <unsigned size> template <unsigned size>
inline void inline void
BitmaskPOD<size>::assign(const BitmaskPOD<size> & src) BitmaskPOD<size>::assign(const BitmaskPOD<size> & src)
{ {
assign(rep.data, src.rep.data); BitmaskPOD<size>::assign(rep.data, src.rep.data);
} }
template <unsigned size> template <unsigned size>
...@@ -523,7 +523,7 @@ template <unsigned size> ...@@ -523,7 +523,7 @@ template <unsigned size>
inline bool inline bool
BitmaskPOD<size>::get(unsigned n) const BitmaskPOD<size>::get(unsigned n) const
{ {
return get(rep.data, n); return BitmaskPOD<size>::get(rep.data, n);
} }
template <unsigned size> template <unsigned size>
...@@ -537,7 +537,7 @@ template <unsigned size> ...@@ -537,7 +537,7 @@ template <unsigned size>
inline void inline void
BitmaskPOD<size>::set(unsigned n, bool value) BitmaskPOD<size>::set(unsigned n, bool value)
{ {
set(rep.data, n, value); BitmaskPOD<size>::set(rep.data, n, value);
} }
template <unsigned size> template <unsigned size>
...@@ -551,7 +551,7 @@ template <unsigned size> ...@@ -551,7 +551,7 @@ template <unsigned size>
inline void inline void
BitmaskPOD<size>::set(unsigned n) BitmaskPOD<size>::set(unsigned n)
{ {
set(rep.data, n); BitmaskPOD<size>::set(rep.data, n);
} }
template <unsigned size> template <unsigned size>
...@@ -565,7 +565,7 @@ template <unsigned size> ...@@ -565,7 +565,7 @@ template <unsigned size>
inline void inline void
BitmaskPOD<size>::set() BitmaskPOD<size>::set()
{ {
set(rep.data); BitmaskPOD<size>::set(rep.data);
} }
template <unsigned size> template <unsigned size>
...@@ -579,7 +579,7 @@ template <unsigned size> ...@@ -579,7 +579,7 @@ template <unsigned size>
inline void inline void
BitmaskPOD<size>::clear(unsigned n) BitmaskPOD<size>::clear(unsigned n)
{ {
clear(rep.data, n); BitmaskPOD<size>::clear(rep.data, n);
} }
template <unsigned size> template <unsigned size>
...@@ -593,7 +593,7 @@ template <unsigned size> ...@@ -593,7 +593,7 @@ template <unsigned size>
inline void inline void
BitmaskPOD<size>::clear() BitmaskPOD<size>::clear()
{ {
clear(rep.data); BitmaskPOD<size>::clear(rep.data);
} }
template <unsigned size> template <unsigned size>
...@@ -607,7 +607,7 @@ template <unsigned size> ...@@ -607,7 +607,7 @@ template <unsigned size>
inline bool inline bool
BitmaskPOD<size>::isclear() const BitmaskPOD<size>::isclear() const
{ {
return isclear(rep.data); return BitmaskPOD<size>::isclear(rep.data);
} }
template <unsigned size> template <unsigned size>
...@@ -621,7 +621,7 @@ template <unsigned size> ...@@ -621,7 +621,7 @@ template <unsigned size>
inline unsigned inline unsigned
BitmaskPOD<size>::count() const BitmaskPOD<size>::count() const
{ {
return count(rep.data); return BitmaskPOD<size>::count(rep.data);
} }
template <unsigned size> template <unsigned size>
...@@ -635,7 +635,7 @@ template <unsigned size> ...@@ -635,7 +635,7 @@ template <unsigned size>
inline unsigned inline unsigned
BitmaskPOD<size>::find(unsigned n) const BitmaskPOD<size>::find(unsigned n) const
{ {
return find(rep.data, n); return BitmaskPOD<size>::find(rep.data, n);
} }
template <unsigned size> template <unsigned size>
...@@ -649,7 +649,7 @@ template <unsigned size> ...@@ -649,7 +649,7 @@ template <unsigned size>
inline bool inline bool
BitmaskPOD<size>::equal(const BitmaskPOD<size>& mask2) const BitmaskPOD<size>::equal(const BitmaskPOD<size>& mask2) const
{ {
return equal(rep.data, mask2.rep.data); return BitmaskPOD<size>::equal(rep.data, mask2.rep.data);
} }
template <unsigned size> template <unsigned size>
...@@ -663,7 +663,7 @@ template <unsigned size> ...@@ -663,7 +663,7 @@ template <unsigned size>
inline BitmaskPOD<size>& inline BitmaskPOD<size>&
BitmaskPOD<size>::bitOR(const BitmaskPOD<size>& mask2) BitmaskPOD<size>::bitOR(const BitmaskPOD<size>& mask2)
{ {
bitOR(rep.data, mask2.rep.data); BitmaskPOD<size>::bitOR(rep.data, mask2.rep.data);
return *this; return *this;
} }
...@@ -678,7 +678,7 @@ template <unsigned size> ...@@ -678,7 +678,7 @@ template <unsigned size>
inline BitmaskPOD<size>& inline BitmaskPOD<size>&
BitmaskPOD<size>::bitAND(const BitmaskPOD<size>& mask2) BitmaskPOD<size>::bitAND(const BitmaskPOD<size>& mask2)
{ {
bitAND(rep.data, mask2.rep.data); BitmaskPOD<size>::bitAND(rep.data, mask2.rep.data);
return *this; return *this;
} }
...@@ -693,7 +693,7 @@ template <unsigned size> ...@@ -693,7 +693,7 @@ template <unsigned size>
inline BitmaskPOD<size>& inline BitmaskPOD<size>&
BitmaskPOD<size>::bitANDC(const BitmaskPOD<size>& mask2) BitmaskPOD<size>::bitANDC(const BitmaskPOD<size>& mask2)
{ {
bitANDC(rep.data, mask2.rep.data); BitmaskPOD<size>::bitANDC(rep.data, mask2.rep.data);
return *this; return *this;
} }
...@@ -708,7 +708,7 @@ template <unsigned size> ...@@ -708,7 +708,7 @@ template <unsigned size>
inline BitmaskPOD<size>& inline BitmaskPOD<size>&
BitmaskPOD<size>::bitXOR(const BitmaskPOD<size>& mask2) BitmaskPOD<size>::bitXOR(const BitmaskPOD<size>& mask2)
{ {
bitXOR(rep.data, mask2.rep.data); BitmaskPOD<size>::bitXOR(rep.data, mask2.rep.data);
return *this; return *this;
} }
...@@ -723,7 +723,7 @@ template <unsigned size> ...@@ -723,7 +723,7 @@ template <unsigned size>
inline char * inline char *
BitmaskPOD<size>::getText(char* buf) const BitmaskPOD<size>::getText(char* buf) const
{ {
return getText(rep.data, buf); return BitmaskPOD<size>::getText(rep.data, buf);
} }
template <unsigned size> template <unsigned size>
...@@ -737,7 +737,7 @@ template <unsigned size> ...@@ -737,7 +737,7 @@ template <unsigned size>
inline bool inline bool
BitmaskPOD<size>::contains(BitmaskPOD<size> that) BitmaskPOD<size>::contains(BitmaskPOD<size> that)
{ {
return contains(this->rep.data, that.rep.data); return BitmaskPOD<size>::contains(this->rep.data, that.rep.data);
} }
template <unsigned size> template <unsigned size>
...@@ -751,7 +751,7 @@ template <unsigned size> ...@@ -751,7 +751,7 @@ template <unsigned size>
inline bool inline bool
BitmaskPOD<size>::overlaps(BitmaskPOD<size> that) BitmaskPOD<size>::overlaps(BitmaskPOD<size> that)
{ {
return overlaps(this->rep.data, that.rep.data); return BitmaskPOD<size>::overlaps(this->rep.data, that.rep.data);
} }
template <unsigned size> template <unsigned size>
......
...@@ -261,4 +261,6 @@ const unsigned short NO_OF_PRINT_FUNCTIONS = sizeof(SignalDataPrintFunctions)/si ...@@ -261,4 +261,6 @@ const unsigned short NO_OF_PRINT_FUNCTIONS = sizeof(SignalDataPrintFunctions)/si
template class Bitmask<1>; template class Bitmask<1>;
template class Bitmask<2>; template class Bitmask<2>;
template class Bitmask<4>; template class Bitmask<4>;
template struct BitmaskPOD<1>;
template struct BitmaskPOD<2>;
template struct BitmaskPOD<4>;
...@@ -2822,6 +2822,7 @@ NdbDictInterface::execLIST_TABLES_CONF(NdbApiSignal* signal, ...@@ -2822,6 +2822,7 @@ NdbDictInterface::execLIST_TABLES_CONF(NdbApiSignal* signal,
} }
} }
template class Vector<int>;
template class Vector<Uint32>; template class Vector<Uint32>;
template class Vector<Vector<Uint32> >; template class Vector<Vector<Uint32> >;
template class Vector<NdbTableImpl*>; template class Vector<NdbTableImpl*>;
......
...@@ -146,7 +146,7 @@ tellThreads(StartType what) ...@@ -146,7 +146,7 @@ tellThreads(StartType what)
NDB_COMMAND(flexAsynch, "flexAsynch", "flexAsynch", "flexAsynch", 65535) NDB_COMMAND(flexAsynch, "flexAsynch", "flexAsynch", "flexAsynch", 65535)
{ {
ThreadNdb* pThreadData; ThreadNdb* pThreadData;
int tLoops=0; int tLoops=0, i;
int returnValue = NDBT_OK; int returnValue = NDBT_OK;
flexAsynchErrorData = new ErrorData; flexAsynchErrorData = new ErrorData;
...@@ -256,7 +256,7 @@ NDB_COMMAND(flexAsynch, "flexAsynch", "flexAsynch", "flexAsynch", 65535) ...@@ -256,7 +256,7 @@ NDB_COMMAND(flexAsynch, "flexAsynch", "flexAsynch", "flexAsynch", 65535)
PRINT_TIMER("insert", noOfTransacts, tNoOfOpsPerTrans); PRINT_TIMER("insert", noOfTransacts, tNoOfOpsPerTrans);
if (0 < failed) { if (0 < failed) {
int i = retry_opt ; i = retry_opt ;
int ci = 1 ; int ci = 1 ;
while (0 < failed && 0 < i){ while (0 < failed && 0 < i){
ndbout << failed << " of the transactions returned errors!" ndbout << failed << " of the transactions returned errors!"
...@@ -293,7 +293,7 @@ NDB_COMMAND(flexAsynch, "flexAsynch", "flexAsynch", "flexAsynch", 65535) ...@@ -293,7 +293,7 @@ NDB_COMMAND(flexAsynch, "flexAsynch", "flexAsynch", "flexAsynch", 65535)
PRINT_TIMER("read", noOfTransacts, tNoOfOpsPerTrans); PRINT_TIMER("read", noOfTransacts, tNoOfOpsPerTrans);
if (0 < failed) { if (0 < failed) {
int i = retry_opt ; i = retry_opt ;
int cr = 1; int cr = 1;
while (0 < failed && 0 < i){ while (0 < failed && 0 < i){
ndbout << failed << " of the transactions returned errors!"<<endl ; ndbout << failed << " of the transactions returned errors!"<<endl ;
...@@ -330,7 +330,7 @@ NDB_COMMAND(flexAsynch, "flexAsynch", "flexAsynch", "flexAsynch", 65535) ...@@ -330,7 +330,7 @@ NDB_COMMAND(flexAsynch, "flexAsynch", "flexAsynch", "flexAsynch", 65535)
PRINT_TIMER("update", noOfTransacts, tNoOfOpsPerTrans) ; PRINT_TIMER("update", noOfTransacts, tNoOfOpsPerTrans) ;
if (0 < failed) { if (0 < failed) {
int i = retry_opt ; i = retry_opt ;
int cu = 1 ; int cu = 1 ;
while (0 < failed && 0 < i){ while (0 < failed && 0 < i){
ndbout << failed << " of the transactions returned errors!"<<endl ; ndbout << failed << " of the transactions returned errors!"<<endl ;
...@@ -366,7 +366,7 @@ NDB_COMMAND(flexAsynch, "flexAsynch", "flexAsynch", "flexAsynch", 65535) ...@@ -366,7 +366,7 @@ NDB_COMMAND(flexAsynch, "flexAsynch", "flexAsynch", "flexAsynch", 65535)
PRINT_TIMER("read", noOfTransacts, tNoOfOpsPerTrans); PRINT_TIMER("read", noOfTransacts, tNoOfOpsPerTrans);
if (0 < failed) { if (0 < failed) {
int i = retry_opt ; i = retry_opt ;
int cr2 = 1 ; int cr2 = 1 ;
while (0 < failed && 0 < i){ while (0 < failed && 0 < i){
ndbout << failed << " of the transactions returned errors!"<<endl ; ndbout << failed << " of the transactions returned errors!"<<endl ;
...@@ -403,7 +403,7 @@ NDB_COMMAND(flexAsynch, "flexAsynch", "flexAsynch", "flexAsynch", 65535) ...@@ -403,7 +403,7 @@ NDB_COMMAND(flexAsynch, "flexAsynch", "flexAsynch", "flexAsynch", 65535)
PRINT_TIMER("delete", noOfTransacts, tNoOfOpsPerTrans); PRINT_TIMER("delete", noOfTransacts, tNoOfOpsPerTrans);
if (0 < failed) { if (0 < failed) {
int i = retry_opt ; i = retry_opt ;
int cd = 1 ; int cd = 1 ;
while (0 < failed && 0 < i){ while (0 < failed && 0 < i){
ndbout << failed << " of the transactions returned errors!"<< endl ; ndbout << failed << " of the transactions returned errors!"<< endl ;
...@@ -438,7 +438,7 @@ NDB_COMMAND(flexAsynch, "flexAsynch", "flexAsynch", "flexAsynch", 65535) ...@@ -438,7 +438,7 @@ NDB_COMMAND(flexAsynch, "flexAsynch", "flexAsynch", "flexAsynch", 65535)
execute(stStop); execute(stStop);
void * tmp; void * tmp;
for(int i = 0; i<tNoOfThreads; i++){ for(i = 0; i<tNoOfThreads; i++){
NdbThread_WaitFor(threadLife[i], &tmp); NdbThread_WaitFor(threadLife[i], &tmp);
NdbThread_Destroy(&threadLife[i]); NdbThread_Destroy(&threadLife[i]);
} }
......
...@@ -282,7 +282,7 @@ tellThreads(ThreadData* pt, StartType what) ...@@ -282,7 +282,7 @@ tellThreads(ThreadData* pt, StartType what)
NDB_COMMAND(flexBench, "flexBench", "flexBench", "flexbench", 65535) NDB_COMMAND(flexBench, "flexBench", "flexBench", "flexbench", 65535)
{ {
ThreadData* pThreadsData; ThreadData* pThreadsData;
int tLoops = 0; int tLoops = 0, i;
int returnValue = NDBT_OK; int returnValue = NDBT_OK;
if (readArguments(argc, argv) != 0){ if (readArguments(argc, argv) != 0){
...@@ -355,7 +355,7 @@ NDB_COMMAND(flexBench, "flexBench", "flexBench", "flexbench", 65535) ...@@ -355,7 +355,7 @@ NDB_COMMAND(flexBench, "flexBench", "flexBench", "flexbench", 65535)
****************************************************************/ ****************************************************************/
resetThreads(pThreadsData); resetThreads(pThreadsData);
for (unsigned int i = 0; i < tNoOfThreads; i++){ for (i = 0; i < tNoOfThreads; i++){
pThreadsData[i].threadNo = i; pThreadsData[i].threadNo = i;
pThreadsData[i].threadLife = NdbThread_Create(flexBenchThread, pThreadsData[i].threadLife = NdbThread_Create(flexBenchThread,
(void**)&pThreadsData[i], (void**)&pThreadsData[i],
...@@ -531,7 +531,7 @@ NDB_COMMAND(flexBench, "flexBench", "flexBench", "flexbench", 65535) ...@@ -531,7 +531,7 @@ NDB_COMMAND(flexBench, "flexBench", "flexBench", "flexbench", 65535)
waitForThreads(pThreadsData); waitForThreads(pThreadsData);
void * tmp; void * tmp;
for(Uint32 i = 0; i<tNoOfThreads; i++){ for(i = 0; i<tNoOfThreads; i++){
NdbThread_WaitFor(pThreadsData[i].threadLife, &tmp); NdbThread_WaitFor(pThreadsData[i].threadLife, &tmp);
NdbThread_Destroy(&pThreadsData[i].threadLife); NdbThread_Destroy(&pThreadsData[i].threadLife);
} }
...@@ -540,7 +540,7 @@ NDB_COMMAND(flexBench, "flexBench", "flexBench", "flexbench", 65535) ...@@ -540,7 +540,7 @@ NDB_COMMAND(flexBench, "flexBench", "flexBench", "flexbench", 65535)
if (useLongKeys == true) { if (useLongKeys == true) {
// Only free these areas if they have been allocated // Only free these areas if they have been allocated
// Otherwise cores will happen // Otherwise cores will happen
for (Uint32 i = 0; i < tNoOfLongPK; i++) for (i = 0; i < tNoOfLongPK; i++)
free(longKeyAttrName[i]); free(longKeyAttrName[i]);
free(longKeyAttrName); free(longKeyAttrName);
} // if } // if
...@@ -629,9 +629,10 @@ static void* flexBenchThread(void* pArg) ...@@ -629,9 +629,10 @@ static void* flexBenchThread(void* pArg)
if(useLongKeys){ if(useLongKeys){
// Allocate and populate the longkey array. // Allocate and populate the longkey array.
longKeyAttrValue = (unsigned ***) malloc(sizeof(unsigned**) * tNoOfOperations ); longKeyAttrValue = (unsigned ***) malloc(sizeof(unsigned**) * tNoOfOperations );
for (Uint32 n = 0; n < tNoOfOperations; n++) Uint32 n;
for (n = 0; n < tNoOfOperations; n++)
longKeyAttrValue[n] = (unsigned **) malloc(sizeof(unsigned*) * tNoOfLongPK ); longKeyAttrValue[n] = (unsigned **) malloc(sizeof(unsigned*) * tNoOfLongPK );
for (Uint32 n = 0; n < tNoOfOperations; n++){ for (n = 0; n < tNoOfOperations; n++){
for (Uint32 i = 0; i < tNoOfLongPK ; i++) { for (Uint32 i = 0; i < tNoOfLongPK ; i++) {
longKeyAttrValue[n][i] = (unsigned *) malloc(sizeof(unsigned) * tSizeOfLongPK); longKeyAttrValue[n][i] = (unsigned *) malloc(sizeof(unsigned) * tSizeOfLongPK);
memset(longKeyAttrValue[n][i], 0, sizeof(unsigned) * tSizeOfLongPK); memset(longKeyAttrValue[n][i], 0, sizeof(unsigned) * tSizeOfLongPK);
...@@ -1064,13 +1065,14 @@ static void sleepBeforeStartingTest(int seconds){ ...@@ -1064,13 +1065,14 @@ static void sleepBeforeStartingTest(int seconds){
static int static int
createTables(Ndb* pMyNdb){ createTables(Ndb* pMyNdb){
for (Uint32 i = 0; i < tNoOfAttributes; i++){ int i;
for (i = 0; i < tNoOfAttributes; i++){
snprintf(attrName[i], MAXSTRLEN, "COL%d", i); snprintf(attrName[i], MAXSTRLEN, "COL%d", i);
} }
// Note! Uses only uppercase letters in table name's // Note! Uses only uppercase letters in table name's
// so that we can look at the tables with SQL // so that we can look at the tables with SQL
for (Uint32 i = 0; i < tNoOfTables; i++){ for (i = 0; i < tNoOfTables; i++){
if (theStdTableNameFlag == 0){ if (theStdTableNameFlag == 0){
snprintf(tableName[i], MAXSTRLEN, "TAB%d_%d", i, snprintf(tableName[i], MAXSTRLEN, "TAB%d_%d", i,
(int)(NdbTick_CurrentMillisecond() / 1000)); (int)(NdbTick_CurrentMillisecond() / 1000));
...@@ -1079,7 +1081,7 @@ createTables(Ndb* pMyNdb){ ...@@ -1079,7 +1081,7 @@ createTables(Ndb* pMyNdb){
} }
} }
for(unsigned i = 0; i < tNoOfTables; i++){ for(i = 0; i < tNoOfTables; i++){
ndbout << "Creating " << tableName[i] << "... "; ndbout << "Creating " << tableName[i] << "... ";
NdbDictionary::Table tmpTable(tableName[i]); NdbDictionary::Table tmpTable(tableName[i]);
......
...@@ -173,7 +173,7 @@ NDB_COMMAND(flexTT, "flexTT", "flexTT", "flexTT", 65535) ...@@ -173,7 +173,7 @@ NDB_COMMAND(flexTT, "flexTT", "flexTT", "flexTT", 65535)
{ {
ThreadNdb* pThreadData; ThreadNdb* pThreadData;
int returnValue = NDBT_OK; int returnValue = NDBT_OK;
int i;
flexTTErrorData = new ErrorData; flexTTErrorData = new ErrorData;
flexTTErrorData->resetErrorCounters(); flexTTErrorData->resetErrorCounters();
...@@ -250,7 +250,7 @@ NDB_COMMAND(flexTT, "flexTT", "flexTT", "flexTT", 65535) ...@@ -250,7 +250,7 @@ NDB_COMMAND(flexTT, "flexTT", "flexTT", "flexTT", 65535)
* Create NDB objects. * * Create NDB objects. *
****************************************************************/ ****************************************************************/
resetThreads(); resetThreads();
for (int i = 0; i < tNoOfThreads ; i++) { for (i = 0; i < tNoOfThreads ; i++) {
pThreadData[i].threadNo = i; pThreadData[i].threadNo = i;
threadLife[i] = NdbThread_Create(threadLoop, threadLife[i] = NdbThread_Create(threadLoop,
(void**)&pThreadData[i], (void**)&pThreadData[i],
...@@ -301,7 +301,7 @@ NDB_COMMAND(flexTT, "flexTT", "flexTT", "flexTT", 65535) ...@@ -301,7 +301,7 @@ NDB_COMMAND(flexTT, "flexTT", "flexTT", "flexTT", 65535)
execute(stStop); execute(stStop);
void * tmp; void * tmp;
for(int i = 0; i<tNoOfThreads; i++){ for(i = 0; i<tNoOfThreads; i++){
NdbThread_WaitFor(threadLife[i], &tmp); NdbThread_WaitFor(threadLife[i], &tmp);
NdbThread_Destroy(&threadLife[i]); NdbThread_Destroy(&threadLife[i]);
} }
......
...@@ -264,7 +264,7 @@ static ...@@ -264,7 +264,7 @@ static
int int
readOneNoCommit(Ndb* pNdb, NdbConnection* pTrans, readOneNoCommit(Ndb* pNdb, NdbConnection* pTrans,
const NdbDictionary::Table* tab,NDBT_ResultRow * row){ const NdbDictionary::Table* tab,NDBT_ResultRow * row){
int a;
NdbOperation * pOp = pTrans->getNdbOperation(tab->getName()); NdbOperation * pOp = pTrans->getNdbOperation(tab->getName());
if (pOp == NULL){ if (pOp == NULL){
ERR(pTrans->getNdbError()); ERR(pTrans->getNdbError());
...@@ -280,7 +280,7 @@ readOneNoCommit(Ndb* pNdb, NdbConnection* pTrans, ...@@ -280,7 +280,7 @@ readOneNoCommit(Ndb* pNdb, NdbConnection* pTrans,
} }
// Define primary keys // Define primary keys
for(int a = 0; a<tab->getNoOfColumns(); a++){ for(a = 0; a<tab->getNoOfColumns(); a++){
if (tab->getColumn(a)->getPrimaryKey() == true){ if (tab->getColumn(a)->getPrimaryKey() == true){
if(tmp.equalForAttr(pOp, a, 0) != 0){ if(tmp.equalForAttr(pOp, a, 0) != 0){
ERR(pTrans->getNdbError()); ERR(pTrans->getNdbError());
...@@ -290,7 +290,7 @@ readOneNoCommit(Ndb* pNdb, NdbConnection* pTrans, ...@@ -290,7 +290,7 @@ readOneNoCommit(Ndb* pNdb, NdbConnection* pTrans,
} }
// Define attributes to read // Define attributes to read
for(int a = 0; a<tab->getNoOfColumns(); a++){ for(a = 0; a<tab->getNoOfColumns(); a++){
if((row->attributeStore(a) = if((row->attributeStore(a) =
pOp->getValue(tab->getColumn(a)->getName())) == 0) { pOp->getValue(tab->getColumn(a)->getName())) == 0) {
ERR(pTrans->getNdbError()); ERR(pTrans->getNdbError());
...@@ -639,35 +639,35 @@ int runNoCommitRollback630(NDBT_Context* ctx, NDBT_Step* step){ ...@@ -639,35 +639,35 @@ int runNoCommitRollback630(NDBT_Context* ctx, NDBT_Step* step){
int runNoCommitAndClose(NDBT_Context* ctx, NDBT_Step* step){ int runNoCommitAndClose(NDBT_Context* ctx, NDBT_Step* step){
int result = NDBT_OK; int i, result = NDBT_OK;
HugoOperations hugoOps(*ctx->getTab()); HugoOperations hugoOps(*ctx->getTab());
Ndb* pNdb = GETNDB(step); Ndb* pNdb = GETNDB(step);
do{ do{
// Read // Read
CHECK(hugoOps.startTransaction(pNdb) == 0); CHECK(hugoOps.startTransaction(pNdb) == 0);
for (int i = 0; i < 10; i++) for (i = 0; i < 10; i++)
CHECK(hugoOps.pkReadRecord(pNdb, i, true) == 0); CHECK(hugoOps.pkReadRecord(pNdb, i, true) == 0);
CHECK(hugoOps.execute_NoCommit(pNdb) == 0); CHECK(hugoOps.execute_NoCommit(pNdb) == 0);
CHECK(hugoOps.closeTransaction(pNdb) == 0); CHECK(hugoOps.closeTransaction(pNdb) == 0);
// Update // Update
CHECK(hugoOps.startTransaction(pNdb) == 0); CHECK(hugoOps.startTransaction(pNdb) == 0);
for (int i = 0; i < 10; i++) for (i = 0; i < 10; i++)
CHECK(hugoOps.pkUpdateRecord(pNdb, i) == 0); CHECK(hugoOps.pkUpdateRecord(pNdb, i) == 0);
CHECK(hugoOps.execute_NoCommit(pNdb) == 0); CHECK(hugoOps.execute_NoCommit(pNdb) == 0);
CHECK(hugoOps.closeTransaction(pNdb) == 0); CHECK(hugoOps.closeTransaction(pNdb) == 0);
// Delete // Delete
CHECK(hugoOps.startTransaction(pNdb) == 0); CHECK(hugoOps.startTransaction(pNdb) == 0);
for (int i = 0; i < 10; i++) for (i = 0; i < 10; i++)
CHECK(hugoOps.pkDeleteRecord(pNdb, i) == 0); CHECK(hugoOps.pkDeleteRecord(pNdb, i) == 0);
CHECK(hugoOps.execute_NoCommit(pNdb) == 0); CHECK(hugoOps.execute_NoCommit(pNdb) == 0);
CHECK(hugoOps.closeTransaction(pNdb) == 0); CHECK(hugoOps.closeTransaction(pNdb) == 0);
// Try to insert, record should already exist // Try to insert, record should already exist
CHECK(hugoOps.startTransaction(pNdb) == 0); CHECK(hugoOps.startTransaction(pNdb) == 0);
for (int i = 0; i < 10; i++) for (i = 0; i < 10; i++)
CHECK(hugoOps.pkInsertRecord(pNdb, i) == 0); CHECK(hugoOps.pkInsertRecord(pNdb, i) == 0);
CHECK(hugoOps.execute_Commit(pNdb) == 630); CHECK(hugoOps.execute_Commit(pNdb) == 630);
CHECK(hugoOps.closeTransaction(pNdb) == 0); CHECK(hugoOps.closeTransaction(pNdb) == 0);
...@@ -781,14 +781,14 @@ int runCheckRollbackDeleteMultiple(NDBT_Context* ctx, NDBT_Step* step){ ...@@ -781,14 +781,14 @@ int runCheckRollbackDeleteMultiple(NDBT_Context* ctx, NDBT_Step* step){
CHECK(hugoOps.closeTransaction(pNdb) == 0); CHECK(hugoOps.closeTransaction(pNdb) == 0);
Uint32 updatesValue = 0; Uint32 updatesValue = 0;
Uint32 j;
for(Uint32 i = 0; i<1; i++){ for(Uint32 i = 0; i<1; i++){
// Read record 5 - 10 // Read record 5 - 10
CHECK(hugoOps.startTransaction(pNdb) == 0); CHECK(hugoOps.startTransaction(pNdb) == 0);
CHECK(hugoOps.pkReadRecord(pNdb, 5, true, 10) == 0); CHECK(hugoOps.pkReadRecord(pNdb, 5, true, 10) == 0);
CHECK(hugoOps.execute_NoCommit(pNdb) == 0); CHECK(hugoOps.execute_NoCommit(pNdb) == 0);
for(Uint32 j = 0; j<10; j++){ for(j = 0; j<10; j++){
// Update record 5 - 10 // Update record 5 - 10
updatesValue++; updatesValue++;
CHECK(hugoOps.pkUpdateRecord(pNdb, 5, 10, updatesValue) == 0); CHECK(hugoOps.pkUpdateRecord(pNdb, 5, 10, updatesValue) == 0);
...@@ -799,7 +799,7 @@ int runCheckRollbackDeleteMultiple(NDBT_Context* ctx, NDBT_Step* step){ ...@@ -799,7 +799,7 @@ int runCheckRollbackDeleteMultiple(NDBT_Context* ctx, NDBT_Step* step){
CHECK(hugoOps.verifyUpdatesValue(updatesValue) == 0); CHECK(hugoOps.verifyUpdatesValue(updatesValue) == 0);
} }
for(Uint32 j = 0; j<10; j++){ for(j = 0; j<10; j++){
// Delete record 5 - 10 times // Delete record 5 - 10 times
CHECK(hugoOps.pkDeleteRecord(pNdb, 5, 10) == 0); CHECK(hugoOps.pkDeleteRecord(pNdb, 5, 10) == 0);
CHECK(hugoOps.execute_NoCommit(pNdb) == 0); CHECK(hugoOps.execute_NoCommit(pNdb) == 0);
......
...@@ -1170,6 +1170,7 @@ deleteScan(bool idx) ...@@ -1170,6 +1170,7 @@ deleteScan(bool idx)
static int static int
testmain() testmain()
{ {
int style;
g_ndb = new Ndb("TEST_DB"); g_ndb = new Ndb("TEST_DB");
CHK(g_ndb->init() == 0); CHK(g_ndb->init() == 0);
CHK(g_ndb->waitUntilReady() == 0); CHK(g_ndb->waitUntilReady() == 0);
...@@ -1197,7 +1198,7 @@ testmain() ...@@ -1197,7 +1198,7 @@ testmain()
if (g_opt.m_seed == 0) if (g_opt.m_seed == 0)
srandom(g_loop); srandom(g_loop);
// pk // pk
for (int style = 0; style <= 2; style++) { for (style = 0; style <= 2; style++) {
if (skipcase('k') || skipstyle(style)) if (skipcase('k') || skipstyle(style))
continue; continue;
DBG("--- pk ops " << stylename[style] << " ---"); DBG("--- pk ops " << stylename[style] << " ---");
...@@ -1215,7 +1216,7 @@ testmain() ...@@ -1215,7 +1216,7 @@ testmain()
CHK(verifyBlob() == 0); CHK(verifyBlob() == 0);
} }
// hash index // hash index
for (int style = 0; style <= 2; style++) { for (style = 0; style <= 2; style++) {
if (skipcase('i') || skipstyle(style)) if (skipcase('i') || skipstyle(style))
continue; continue;
DBG("--- idx ops " << stylename[style] << " ---"); DBG("--- idx ops " << stylename[style] << " ---");
...@@ -1233,7 +1234,7 @@ testmain() ...@@ -1233,7 +1234,7 @@ testmain()
CHK(verifyBlob() == 0); CHK(verifyBlob() == 0);
} }
// scan table // scan table
for (int style = 0; style <= 2; style++) { for (style = 0; style <= 2; style++) {
if (skipcase('s') || skipstyle(style)) if (skipcase('s') || skipstyle(style))
continue; continue;
DBG("--- table scan " << stylename[style] << " ---"); DBG("--- table scan " << stylename[style] << " ---");
...@@ -1249,7 +1250,7 @@ testmain() ...@@ -1249,7 +1250,7 @@ testmain()
CHK(verifyBlob() == 0); CHK(verifyBlob() == 0);
} }
// scan index // scan index
for (int style = 0; style <= 2; style++) { for (style = 0; style <= 2; style++) {
if (skipcase('r') || skipstyle(style)) if (skipcase('r') || skipstyle(style))
continue; continue;
DBG("--- index scan " << stylename[style] << " ---"); DBG("--- index scan " << stylename[style] << " ---");
...@@ -1274,6 +1275,7 @@ testmain() ...@@ -1274,6 +1275,7 @@ testmain()
static int static int
bugtest_4088() bugtest_4088()
{ {
unsigned i;
DBG("bug test 4088 - ndb api hang with mixed ops on index table"); DBG("bug test 4088 - ndb api hang with mixed ops on index table");
// insert rows // insert rows
calcTups(false); calcTups(false);
...@@ -1285,7 +1287,7 @@ bugtest_4088() ...@@ -1285,7 +1287,7 @@ bugtest_4088()
// read table pk via index as a table // read table pk via index as a table
const unsigned pkcnt = 2; const unsigned pkcnt = 2;
Tup pktup[pkcnt]; Tup pktup[pkcnt];
for (unsigned i = 0; i < pkcnt; i++) { for (i = 0; i < pkcnt; i++) {
char name[20]; char name[20];
// XXX guess table id // XXX guess table id
sprintf(name, "%d/%s", 4, g_opt.m_x1name); sprintf(name, "%d/%s", 4, g_opt.m_x1name);
...@@ -1304,7 +1306,7 @@ bugtest_4088() ...@@ -1304,7 +1306,7 @@ bugtest_4088()
// BUG 4088: gets 1 tckeyconf, 1 tcindxconf, then hangs // BUG 4088: gets 1 tckeyconf, 1 tcindxconf, then hangs
CHK(g_con->execute(Commit) == 0); CHK(g_con->execute(Commit) == 0);
// verify // verify
for (unsigned i = 0; i < pkcnt; i++) { for (i = 0; i < pkcnt; i++) {
CHK(pktup[i].m_pk1 == tup.m_pk1); CHK(pktup[i].m_pk1 == tup.m_pk1);
CHK(memcmp(pktup[i].m_pk2, tup.m_pk2, g_opt.m_pk2len) == 0); CHK(memcmp(pktup[i].m_pk2, tup.m_pk2, g_opt.m_pk2len) == 0);
} }
......
...@@ -165,12 +165,13 @@ HugoAsynchTransactions::pkUpdateRecordsAsynch(Ndb* pNdb, ...@@ -165,12 +165,13 @@ HugoAsynchTransactions::pkUpdateRecordsAsynch(Ndb* pNdb,
allocRows(trans*operations); allocRows(trans*operations);
allocTransactions(trans); allocTransactions(trans);
int a, t, r;
for (int i = 0; i < batch; i++) { // For each batch for (int i = 0; i < batch; i++) { // For each batch
while (cRecords < records*batch) { while (cRecords < records*batch) {
cTrans = 0; cTrans = 0;
cReadIndex = 0; cReadIndex = 0;
for (int t = 0; t < trans; t++) { // For each transaction for (t = 0; t < trans; t++) { // For each transaction
transactions[t] = pNdb->startTransaction(); transactions[t] = pNdb->startTransaction();
if (transactions[t] == NULL) { if (transactions[t] == NULL) {
ERR(pNdb->getNdbError()); ERR(pNdb->getNdbError());
...@@ -187,7 +188,7 @@ HugoAsynchTransactions::pkUpdateRecordsAsynch(Ndb* pNdb, ...@@ -187,7 +188,7 @@ HugoAsynchTransactions::pkUpdateRecordsAsynch(Ndb* pNdb,
// Read // Read
// Define primary keys // Define primary keys
check = pOp->readTupleExclusive(); check = pOp->readTupleExclusive();
for (int a = 0; a < tab.getNoOfColumns(); a++) { for (a = 0; a < tab.getNoOfColumns(); a++) {
if (tab.getColumn(a)->getPrimaryKey() == true) { if (tab.getColumn(a)->getPrimaryKey() == true) {
if (equalForAttr(pOp, a, cReadRecords) != 0){ if (equalForAttr(pOp, a, cReadRecords) != 0){
ERR(transactions[t]->getNdbError()); ERR(transactions[t]->getNdbError());
...@@ -197,7 +198,7 @@ HugoAsynchTransactions::pkUpdateRecordsAsynch(Ndb* pNdb, ...@@ -197,7 +198,7 @@ HugoAsynchTransactions::pkUpdateRecordsAsynch(Ndb* pNdb,
} }
} }
// Define attributes to read // Define attributes to read
for (int a = 0; a < tab.getNoOfColumns(); a++) { for (a = 0; a < tab.getNoOfColumns(); a++) {
if ((rows[cReadIndex]->attributeStore(a) = if ((rows[cReadIndex]->attributeStore(a) =
pOp->getValue(tab.getColumn(a)->getName())) == 0) { pOp->getValue(tab.getColumn(a)->getName())) == 0) {
ERR(transactions[t]->getNdbError()); ERR(transactions[t]->getNdbError());
...@@ -225,7 +226,7 @@ HugoAsynchTransactions::pkUpdateRecordsAsynch(Ndb* pNdb, ...@@ -225,7 +226,7 @@ HugoAsynchTransactions::pkUpdateRecordsAsynch(Ndb* pNdb,
pNdb->sendPollNdb(3000, 0, 0); pNdb->sendPollNdb(3000, 0, 0);
// Verify the data! // Verify the data!
for (int r = 0; r < trans*operations; r++) { for (r = 0; r < trans*operations; r++) {
if (calc.verifyRowValues(rows[r]) != 0) { if (calc.verifyRowValues(rows[r]) != 0) {
g_info << "|- Verify failed..." << endl; g_info << "|- Verify failed..." << endl;
// Close all transactions // Close all transactions
...@@ -239,7 +240,7 @@ HugoAsynchTransactions::pkUpdateRecordsAsynch(Ndb* pNdb, ...@@ -239,7 +240,7 @@ HugoAsynchTransactions::pkUpdateRecordsAsynch(Ndb* pNdb,
// Update // Update
cTrans = 0; cTrans = 0;
cIndex = 0; cIndex = 0;
for (int t = 0; t < trans; t++) { // For each transaction for (t = 0; t < trans; t++) { // For each transaction
for (int k = 0; k < operations; k++) { // For each operation for (int k = 0; k < operations; k++) { // For each operation
NdbOperation* pOp = transactions[t]->getNdbOperation(tab.getName()); NdbOperation* pOp = transactions[t]->getNdbOperation(tab.getName());
if (pOp == NULL) { if (pOp == NULL) {
...@@ -258,7 +259,7 @@ HugoAsynchTransactions::pkUpdateRecordsAsynch(Ndb* pNdb, ...@@ -258,7 +259,7 @@ HugoAsynchTransactions::pkUpdateRecordsAsynch(Ndb* pNdb,
} }
// Set search condition for the record // Set search condition for the record
for (int a = 0; a < tab.getNoOfColumns(); a++) { for (a = 0; a < tab.getNoOfColumns(); a++) {
if (tab.getColumn(a)->getPrimaryKey() == true) { if (tab.getColumn(a)->getPrimaryKey() == true) {
if (equalForAttr(pOp, a, cRecords) != 0) { if (equalForAttr(pOp, a, cRecords) != 0) {
ERR(transactions[t]->getNdbError()); ERR(transactions[t]->getNdbError());
...@@ -269,7 +270,7 @@ HugoAsynchTransactions::pkUpdateRecordsAsynch(Ndb* pNdb, ...@@ -269,7 +270,7 @@ HugoAsynchTransactions::pkUpdateRecordsAsynch(Ndb* pNdb,
} }
// Update the record // Update the record
for (int a = 0; a < tab.getNoOfColumns(); a++) { for (a = 0; a < tab.getNoOfColumns(); a++) {
if (tab.getColumn(a)->getPrimaryKey() == false) { if (tab.getColumn(a)->getPrimaryKey() == false) {
if (setValueForAttr(pOp, a, cRecords, updates) != 0) { if (setValueForAttr(pOp, a, cRecords, updates) != 0) {
ERR(transactions[t]->getNdbError()); ERR(transactions[t]->getNdbError());
...@@ -298,7 +299,7 @@ HugoAsynchTransactions::pkUpdateRecordsAsynch(Ndb* pNdb, ...@@ -298,7 +299,7 @@ HugoAsynchTransactions::pkUpdateRecordsAsynch(Ndb* pNdb,
pNdb->sendPollNdb(3000, 0, 0); pNdb->sendPollNdb(3000, 0, 0);
// Close all transactions // Close all transactions
for (int t = 0; t < cTrans; t++) { for (t = 0; t < cTrans; t++) {
pNdb->closeTransaction(transactions[t]); pNdb->closeTransaction(transactions[t]);
} }
...@@ -346,6 +347,7 @@ HugoAsynchTransactions::executeAsynchOperation(Ndb* pNdb, ...@@ -346,6 +347,7 @@ HugoAsynchTransactions::executeAsynchOperation(Ndb* pNdb,
int cTrans = 0; int cTrans = 0;
int cRecords = 0; int cRecords = 0;
int cIndex = 0; int cIndex = 0;
int a,t,r;
transactionsCompleted = 0; transactionsCompleted = 0;
allocTransactions(trans); allocTransactions(trans);
...@@ -354,7 +356,7 @@ HugoAsynchTransactions::executeAsynchOperation(Ndb* pNdb, ...@@ -354,7 +356,7 @@ HugoAsynchTransactions::executeAsynchOperation(Ndb* pNdb,
while (cRecords < records*batch) { while (cRecords < records*batch) {
cTrans = 0; cTrans = 0;
cIndex = 0; cIndex = 0;
for (int t = 0; t < trans; t++) { // For each transaction for (t = 0; t < trans; t++) { // For each transaction
transactions[t] = pNdb->startTransaction(); transactions[t] = pNdb->startTransaction();
if (transactions[t] == NULL) { if (transactions[t] == NULL) {
ERR(pNdb->getNdbError()); ERR(pNdb->getNdbError());
...@@ -379,7 +381,7 @@ HugoAsynchTransactions::executeAsynchOperation(Ndb* pNdb, ...@@ -379,7 +381,7 @@ HugoAsynchTransactions::executeAsynchOperation(Ndb* pNdb,
} }
// Set a calculated value for each attribute in this table // Set a calculated value for each attribute in this table
for (int a = 0; a < tab.getNoOfColumns(); a++) { for (a = 0; a < tab.getNoOfColumns(); a++) {
if (setValueForAttr(pOp, a, cRecords, 0 ) != 0) { if (setValueForAttr(pOp, a, cRecords, 0 ) != 0) {
ERR(transactions[t]->getNdbError()); ERR(transactions[t]->getNdbError());
pNdb->closeTransaction(transactions[t]); pNdb->closeTransaction(transactions[t]);
...@@ -394,7 +396,7 @@ HugoAsynchTransactions::executeAsynchOperation(Ndb* pNdb, ...@@ -394,7 +396,7 @@ HugoAsynchTransactions::executeAsynchOperation(Ndb* pNdb,
case NO_READ: case NO_READ:
// Define primary keys // Define primary keys
check = pOp->readTuple(); check = pOp->readTuple();
for (int a = 0; a < tab.getNoOfColumns(); a++) { for (a = 0; a < tab.getNoOfColumns(); a++) {
if (tab.getColumn(a)->getPrimaryKey() == true) { if (tab.getColumn(a)->getPrimaryKey() == true) {
if (equalForAttr(pOp, a, cRecords) != 0){ if (equalForAttr(pOp, a, cRecords) != 0){
ERR(transactions[t]->getNdbError()); ERR(transactions[t]->getNdbError());
...@@ -404,7 +406,7 @@ HugoAsynchTransactions::executeAsynchOperation(Ndb* pNdb, ...@@ -404,7 +406,7 @@ HugoAsynchTransactions::executeAsynchOperation(Ndb* pNdb,
} }
} }
// Define attributes to read // Define attributes to read
for (int a = 0; a < tab.getNoOfColumns(); a++) { for (a = 0; a < tab.getNoOfColumns(); a++) {
if ((rows[cIndex]->attributeStore(a) = if ((rows[cIndex]->attributeStore(a) =
pOp->getValue(tab.getColumn(a)->getName())) == 0) { pOp->getValue(tab.getColumn(a)->getName())) == 0) {
ERR(transactions[t]->getNdbError()); ERR(transactions[t]->getNdbError());
...@@ -423,7 +425,7 @@ HugoAsynchTransactions::executeAsynchOperation(Ndb* pNdb, ...@@ -423,7 +425,7 @@ HugoAsynchTransactions::executeAsynchOperation(Ndb* pNdb,
} }
// Define primary keys // Define primary keys
for (int a = 0; a < tab.getNoOfColumns(); a++) { for (a = 0; a < tab.getNoOfColumns(); a++) {
if (tab.getColumn(a)->getPrimaryKey() == true){ if (tab.getColumn(a)->getPrimaryKey() == true){
if (equalForAttr(pOp, a, cRecords) != 0) { if (equalForAttr(pOp, a, cRecords) != 0) {
ERR(transactions[t]->getNdbError()); ERR(transactions[t]->getNdbError());
...@@ -462,7 +464,7 @@ HugoAsynchTransactions::executeAsynchOperation(Ndb* pNdb, ...@@ -462,7 +464,7 @@ HugoAsynchTransactions::executeAsynchOperation(Ndb* pNdb,
switch (theOperation) { switch (theOperation) {
case NO_READ: case NO_READ:
// Verify the data! // Verify the data!
for (int r = 0; r < trans*operations; r++) { for (r = 0; r < trans*operations; r++) {
if (calc.verifyRowValues(rows[r]) != 0) { if (calc.verifyRowValues(rows[r]) != 0) {
g_info << "|- Verify failed..." << endl; g_info << "|- Verify failed..." << endl;
// Close all transactions // Close all transactions
...@@ -480,7 +482,7 @@ HugoAsynchTransactions::executeAsynchOperation(Ndb* pNdb, ...@@ -480,7 +482,7 @@ HugoAsynchTransactions::executeAsynchOperation(Ndb* pNdb,
} }
// Close all transactions // Close all transactions
for (int t = 0; t < cTrans; t++) { for (t = 0; t < cTrans; t++) {
pNdb->closeTransaction(transactions[t]); pNdb->closeTransaction(transactions[t]);
} }
......
...@@ -51,7 +51,7 @@ int HugoOperations::pkReadRecord(Ndb* pNdb, ...@@ -51,7 +51,7 @@ int HugoOperations::pkReadRecord(Ndb* pNdb,
int recordNo, int recordNo,
bool exclusive, bool exclusive,
int numRecords){ int numRecords){
int a;
allocRows(numRecords); allocRows(numRecords);
int check; int check;
for(int r=0; r < numRecords; r++){ for(int r=0; r < numRecords; r++){
...@@ -71,7 +71,7 @@ int HugoOperations::pkReadRecord(Ndb* pNdb, ...@@ -71,7 +71,7 @@ int HugoOperations::pkReadRecord(Ndb* pNdb,
} }
// Define primary keys // Define primary keys
for(int a = 0; a<tab.getNoOfColumns(); a++){ for(a = 0; a<tab.getNoOfColumns(); a++){
if (tab.getColumn(a)->getPrimaryKey() == true){ if (tab.getColumn(a)->getPrimaryKey() == true){
if(equalForAttr(pOp, a, r+recordNo) != 0){ if(equalForAttr(pOp, a, r+recordNo) != 0){
ERR(pTrans->getNdbError()); ERR(pTrans->getNdbError());
...@@ -81,7 +81,7 @@ int HugoOperations::pkReadRecord(Ndb* pNdb, ...@@ -81,7 +81,7 @@ int HugoOperations::pkReadRecord(Ndb* pNdb,
} }
// Define attributes to read // Define attributes to read
for(int a = 0; a<tab.getNoOfColumns(); a++){ for(a = 0; a<tab.getNoOfColumns(); a++){
if((rows[r]->attributeStore(a) = if((rows[r]->attributeStore(a) =
pOp->getValue(tab.getColumn(a)->getName())) == 0) { pOp->getValue(tab.getColumn(a)->getName())) == 0) {
ERR(pTrans->getNdbError()); ERR(pTrans->getNdbError());
...@@ -95,7 +95,7 @@ int HugoOperations::pkReadRecord(Ndb* pNdb, ...@@ -95,7 +95,7 @@ int HugoOperations::pkReadRecord(Ndb* pNdb,
int HugoOperations::pkDirtyReadRecord(Ndb* pNdb, int HugoOperations::pkDirtyReadRecord(Ndb* pNdb,
int recordNo, int recordNo,
int numRecords){ int numRecords){
int a;
allocRows(numRecords); allocRows(numRecords);
int check; int check;
for(int r=0; r < numRecords; r++){ for(int r=0; r < numRecords; r++){
...@@ -113,7 +113,7 @@ int HugoOperations::pkDirtyReadRecord(Ndb* pNdb, ...@@ -113,7 +113,7 @@ int HugoOperations::pkDirtyReadRecord(Ndb* pNdb,
} }
// Define primary keys // Define primary keys
for(int a = 0; a<tab.getNoOfColumns(); a++){ for(a = 0; a<tab.getNoOfColumns(); a++){
if (tab.getColumn(a)->getPrimaryKey() == true){ if (tab.getColumn(a)->getPrimaryKey() == true){
if(equalForAttr(pOp, a, r+recordNo) != 0){ if(equalForAttr(pOp, a, r+recordNo) != 0){
ERR(pTrans->getNdbError()); ERR(pTrans->getNdbError());
...@@ -123,7 +123,7 @@ int HugoOperations::pkDirtyReadRecord(Ndb* pNdb, ...@@ -123,7 +123,7 @@ int HugoOperations::pkDirtyReadRecord(Ndb* pNdb,
} }
// Define attributes to read // Define attributes to read
for(int a = 0; a<tab.getNoOfColumns(); a++){ for(a = 0; a<tab.getNoOfColumns(); a++){
if((rows[r]->attributeStore(a) = if((rows[r]->attributeStore(a) =
pOp->getValue(tab.getColumn(a)->getName())) == 0) { pOp->getValue(tab.getColumn(a)->getName())) == 0) {
ERR(pTrans->getNdbError()); ERR(pTrans->getNdbError());
...@@ -137,7 +137,7 @@ int HugoOperations::pkDirtyReadRecord(Ndb* pNdb, ...@@ -137,7 +137,7 @@ int HugoOperations::pkDirtyReadRecord(Ndb* pNdb,
int HugoOperations::pkSimpleReadRecord(Ndb* pNdb, int HugoOperations::pkSimpleReadRecord(Ndb* pNdb,
int recordNo, int recordNo,
int numRecords){ int numRecords){
int a;
allocRows(numRecords); allocRows(numRecords);
int check; int check;
for(int r=0; r < numRecords; r++){ for(int r=0; r < numRecords; r++){
...@@ -155,7 +155,7 @@ int HugoOperations::pkSimpleReadRecord(Ndb* pNdb, ...@@ -155,7 +155,7 @@ int HugoOperations::pkSimpleReadRecord(Ndb* pNdb,
} }
// Define primary keys // Define primary keys
for(int a = 0; a<tab.getNoOfColumns(); a++){ for(a = 0; a<tab.getNoOfColumns(); a++){
if (tab.getColumn(a)->getPrimaryKey() == true){ if (tab.getColumn(a)->getPrimaryKey() == true){
if(equalForAttr(pOp, a, r+recordNo) != 0){ if(equalForAttr(pOp, a, r+recordNo) != 0){
ERR(pTrans->getNdbError()); ERR(pTrans->getNdbError());
...@@ -165,7 +165,7 @@ int HugoOperations::pkSimpleReadRecord(Ndb* pNdb, ...@@ -165,7 +165,7 @@ int HugoOperations::pkSimpleReadRecord(Ndb* pNdb,
} }
// Define attributes to read // Define attributes to read
for(int a = 0; a<tab.getNoOfColumns(); a++){ for(a = 0; a<tab.getNoOfColumns(); a++){
if((rows[r]->attributeStore(a) = if((rows[r]->attributeStore(a) =
pOp->getValue(tab.getColumn(a)->getName())) == 0) { pOp->getValue(tab.getColumn(a)->getName())) == 0) {
ERR(pTrans->getNdbError()); ERR(pTrans->getNdbError());
...@@ -180,7 +180,7 @@ int HugoOperations::pkUpdateRecord(Ndb* pNdb, ...@@ -180,7 +180,7 @@ int HugoOperations::pkUpdateRecord(Ndb* pNdb,
int recordNo, int recordNo,
int numRecords, int numRecords,
int updatesValue){ int updatesValue){
int a;
allocRows(numRecords); allocRows(numRecords);
int check; int check;
for(int r=0; r < numRecords; r++){ for(int r=0; r < numRecords; r++){
...@@ -197,7 +197,7 @@ int HugoOperations::pkUpdateRecord(Ndb* pNdb, ...@@ -197,7 +197,7 @@ int HugoOperations::pkUpdateRecord(Ndb* pNdb,
} }
// Define primary keys // Define primary keys
for(int a = 0; a<tab.getNoOfColumns(); a++){ for(a = 0; a<tab.getNoOfColumns(); a++){
if (tab.getColumn(a)->getPrimaryKey() == true){ if (tab.getColumn(a)->getPrimaryKey() == true){
if(equalForAttr(pOp, a, r+recordNo) != 0){ if(equalForAttr(pOp, a, r+recordNo) != 0){
ERR(pTrans->getNdbError()); ERR(pTrans->getNdbError());
...@@ -207,7 +207,7 @@ int HugoOperations::pkUpdateRecord(Ndb* pNdb, ...@@ -207,7 +207,7 @@ int HugoOperations::pkUpdateRecord(Ndb* pNdb,
} }
// Define attributes to update // Define attributes to update
for(int a = 0; a<tab.getNoOfColumns(); a++){ for(a = 0; a<tab.getNoOfColumns(); a++){
if (tab.getColumn(a)->getPrimaryKey() == false){ if (tab.getColumn(a)->getPrimaryKey() == false){
if(setValueForAttr(pOp, a, recordNo+r, updatesValue ) != 0){ if(setValueForAttr(pOp, a, recordNo+r, updatesValue ) != 0){
ERR(pTrans->getNdbError()); ERR(pTrans->getNdbError());
...@@ -224,7 +224,7 @@ int HugoOperations::pkInsertRecord(Ndb* pNdb, ...@@ -224,7 +224,7 @@ int HugoOperations::pkInsertRecord(Ndb* pNdb,
int numRecords, int numRecords,
int updatesValue){ int updatesValue){
int check; int a, check;
for(int r=0; r < numRecords; r++){ for(int r=0; r < numRecords; r++){
NdbOperation* pOp = pTrans->getNdbOperation(tab.getName()); NdbOperation* pOp = pTrans->getNdbOperation(tab.getName());
if (pOp == NULL) { if (pOp == NULL) {
...@@ -239,7 +239,7 @@ int HugoOperations::pkInsertRecord(Ndb* pNdb, ...@@ -239,7 +239,7 @@ int HugoOperations::pkInsertRecord(Ndb* pNdb,
} }
// Define primary keys // Define primary keys
for(int a = 0; a<tab.getNoOfColumns(); a++){ for(a = 0; a<tab.getNoOfColumns(); a++){
if (tab.getColumn(a)->getPrimaryKey() == true){ if (tab.getColumn(a)->getPrimaryKey() == true){
if(equalForAttr(pOp, a, r+recordNo) != 0){ if(equalForAttr(pOp, a, r+recordNo) != 0){
ERR(pTrans->getNdbError()); ERR(pTrans->getNdbError());
...@@ -249,7 +249,7 @@ int HugoOperations::pkInsertRecord(Ndb* pNdb, ...@@ -249,7 +249,7 @@ int HugoOperations::pkInsertRecord(Ndb* pNdb,
} }
// Define attributes to update // Define attributes to update
for(int a = 0; a<tab.getNoOfColumns(); a++){ for(a = 0; a<tab.getNoOfColumns(); a++){
if (tab.getColumn(a)->getPrimaryKey() == false){ if (tab.getColumn(a)->getPrimaryKey() == false){
if(setValueForAttr(pOp, a, recordNo+r, updatesValue ) != 0){ if(setValueForAttr(pOp, a, recordNo+r, updatesValue ) != 0){
ERR(pTrans->getNdbError()); ERR(pTrans->getNdbError());
...@@ -265,7 +265,7 @@ int HugoOperations::pkDeleteRecord(Ndb* pNdb, ...@@ -265,7 +265,7 @@ int HugoOperations::pkDeleteRecord(Ndb* pNdb,
int recordNo, int recordNo,
int numRecords){ int numRecords){
int check; int a, check;
for(int r=0; r < numRecords; r++){ for(int r=0; r < numRecords; r++){
NdbOperation* pOp = pTrans->getNdbOperation(tab.getName()); NdbOperation* pOp = pTrans->getNdbOperation(tab.getName());
if (pOp == NULL) { if (pOp == NULL) {
...@@ -280,7 +280,7 @@ int HugoOperations::pkDeleteRecord(Ndb* pNdb, ...@@ -280,7 +280,7 @@ int HugoOperations::pkDeleteRecord(Ndb* pNdb,
} }
// Define primary keys // Define primary keys
for(int a = 0; a<tab.getNoOfColumns(); a++){ for(a = 0; a<tab.getNoOfColumns(); a++){
if (tab.getColumn(a)->getPrimaryKey() == true){ if (tab.getColumn(a)->getPrimaryKey() == true){
if(equalForAttr(pOp, a, r+recordNo) != 0){ if(equalForAttr(pOp, a, r+recordNo) != 0){
ERR(pTrans->getNdbError()); ERR(pTrans->getNdbError());
...@@ -619,6 +619,7 @@ int HugoOperations::indexReadRecords(Ndb*, const char * idxName, int recordNo, ...@@ -619,6 +619,7 @@ int HugoOperations::indexReadRecords(Ndb*, const char * idxName, int recordNo,
bool exclusive, bool exclusive,
int numRecords){ int numRecords){
int a;
allocRows(numRecords); allocRows(numRecords);
int check; int check;
for(int r=0; r < numRecords; r++){ for(int r=0; r < numRecords; r++){
...@@ -638,7 +639,7 @@ int HugoOperations::indexReadRecords(Ndb*, const char * idxName, int recordNo, ...@@ -638,7 +639,7 @@ int HugoOperations::indexReadRecords(Ndb*, const char * idxName, int recordNo,
} }
// Define primary keys // Define primary keys
for(int a = 0; a<tab.getNoOfColumns(); a++){ for(a = 0; a<tab.getNoOfColumns(); a++){
if (tab.getColumn(a)->getPrimaryKey() == true){ if (tab.getColumn(a)->getPrimaryKey() == true){
if(equalForAttr(pOp, a, r+recordNo) != 0){ if(equalForAttr(pOp, a, r+recordNo) != 0){
ERR(pTrans->getNdbError()); ERR(pTrans->getNdbError());
...@@ -648,7 +649,7 @@ int HugoOperations::indexReadRecords(Ndb*, const char * idxName, int recordNo, ...@@ -648,7 +649,7 @@ int HugoOperations::indexReadRecords(Ndb*, const char * idxName, int recordNo,
} }
// Define attributes to read // Define attributes to read
for(int a = 0; a<tab.getNoOfColumns(); a++){ for(a = 0; a<tab.getNoOfColumns(); a++){
if((rows[r]->attributeStore(a) = if((rows[r]->attributeStore(a) =
pOp->getValue(tab.getColumn(a)->getName())) == 0) { pOp->getValue(tab.getColumn(a)->getName())) == 0) {
ERR(pTrans->getNdbError()); ERR(pTrans->getNdbError());
...@@ -665,7 +666,7 @@ HugoOperations::indexUpdateRecord(Ndb*, ...@@ -665,7 +666,7 @@ HugoOperations::indexUpdateRecord(Ndb*,
int recordNo, int recordNo,
int numRecords, int numRecords,
int updatesValue){ int updatesValue){
int a;
allocRows(numRecords); allocRows(numRecords);
int check; int check;
for(int r=0; r < numRecords; r++){ for(int r=0; r < numRecords; r++){
...@@ -682,7 +683,7 @@ HugoOperations::indexUpdateRecord(Ndb*, ...@@ -682,7 +683,7 @@ HugoOperations::indexUpdateRecord(Ndb*,
} }
// Define primary keys // Define primary keys
for(int a = 0; a<tab.getNoOfColumns(); a++){ for(a = 0; a<tab.getNoOfColumns(); a++){
if (tab.getColumn(a)->getPrimaryKey() == true){ if (tab.getColumn(a)->getPrimaryKey() == true){
if(equalForAttr(pOp, a, r+recordNo) != 0){ if(equalForAttr(pOp, a, r+recordNo) != 0){
ERR(pTrans->getNdbError()); ERR(pTrans->getNdbError());
...@@ -692,7 +693,7 @@ HugoOperations::indexUpdateRecord(Ndb*, ...@@ -692,7 +693,7 @@ HugoOperations::indexUpdateRecord(Ndb*,
} }
// Define attributes to update // Define attributes to update
for(int a = 0; a<tab.getNoOfColumns(); a++){ for(a = 0; a<tab.getNoOfColumns(); a++){
if (tab.getColumn(a)->getPrimaryKey() == false){ if (tab.getColumn(a)->getPrimaryKey() == false){
if(setValueForAttr(pOp, a, recordNo+r, updatesValue ) != 0){ if(setValueForAttr(pOp, a, recordNo+r, updatesValue ) != 0){
ERR(pTrans->getNdbError()); ERR(pTrans->getNdbError());
......
This diff is collapsed.
...@@ -625,9 +625,9 @@ int restartNFDuringNR(NdbRestarter& _restarter, ...@@ -625,9 +625,9 @@ int restartNFDuringNR(NdbRestarter& _restarter,
const NdbRestarts::NdbRestart* _restart){ const NdbRestarts::NdbRestart* _restart){
myRandom48Init(NdbTick_CurrentMillisecond()); myRandom48Init(NdbTick_CurrentMillisecond());
int i;
const int sz = sizeof(NFDuringNR_codes)/sizeof(NFDuringNR_codes[0]); const int sz = sizeof(NFDuringNR_codes)/sizeof(NFDuringNR_codes[0]);
for(int i = 0; i<sz; i++){ for(i = 0; i<sz; i++){
int randomId = myRandom48(_restarter.getNumDbNodes()); int randomId = myRandom48(_restarter.getNumDbNodes());
int nodeId = _restarter.getDbNodeId(randomId); int nodeId = _restarter.getDbNodeId(randomId);
int error = NFDuringNR_codes[i]; int error = NFDuringNR_codes[i];
...@@ -673,7 +673,7 @@ int restartNFDuringNR(NdbRestarter& _restarter, ...@@ -673,7 +673,7 @@ int restartNFDuringNR(NdbRestarter& _restarter,
if(NdbEnv_GetEnv("USER", buf, 256) == 0 || strcmp(buf, "ejonore") != 0) if(NdbEnv_GetEnv("USER", buf, 256) == 0 || strcmp(buf, "ejonore") != 0)
return NDBT_OK; return NDBT_OK;
for(int i = 0; i<sz; i++){ for(i = 0; i<sz; i++){
const int randomId = myRandom48(_restarter.getNumDbNodes()); const int randomId = myRandom48(_restarter.getNumDbNodes());
int nodeId = _restarter.getDbNodeId(randomId); int nodeId = _restarter.getDbNodeId(randomId);
const int error = NFDuringNR_codes[i]; const int error = NFDuringNR_codes[i];
...@@ -753,14 +753,14 @@ NRDuringLCP_NonMaster_codes[] = { ...@@ -753,14 +753,14 @@ NRDuringLCP_NonMaster_codes[] = {
int restartNodeDuringLCP(NdbRestarter& _restarter, int restartNodeDuringLCP(NdbRestarter& _restarter,
const NdbRestarts::NdbRestart* _restart) { const NdbRestarts::NdbRestart* _restart) {
int i;
// Master // Master
int val = DumpStateOrd::DihMinTimeBetweenLCP; int val = DumpStateOrd::DihMinTimeBetweenLCP;
CHECK(_restarter.dumpStateAllNodes(&val, 1) == 0, CHECK(_restarter.dumpStateAllNodes(&val, 1) == 0,
"Failed to set LCP to min value"); // Set LCP to min val "Failed to set LCP to min value"); // Set LCP to min val
int sz = sizeof(NRDuringLCP_Master_codes)/ int sz = sizeof(NRDuringLCP_Master_codes)/
sizeof(NRDuringLCP_Master_codes[0]); sizeof(NRDuringLCP_Master_codes[0]);
for(int i = 0; i<sz; i++) { for(i = 0; i<sz; i++) {
int error = NRDuringLCP_Master_codes[i]; int error = NRDuringLCP_Master_codes[i];
int masterNodeId = _restarter.getMasterNodeId(); int masterNodeId = _restarter.getMasterNodeId();
...@@ -798,7 +798,7 @@ int restartNodeDuringLCP(NdbRestarter& _restarter, ...@@ -798,7 +798,7 @@ int restartNodeDuringLCP(NdbRestarter& _restarter,
// NON-Master // NON-Master
sz = sizeof(NRDuringLCP_NonMaster_codes)/ sz = sizeof(NRDuringLCP_NonMaster_codes)/
sizeof(NRDuringLCP_NonMaster_codes[0]); sizeof(NRDuringLCP_NonMaster_codes[0]);
for(int i = 0; i<sz; i++) { for(i = 0; i<sz; i++) {
int error = NRDuringLCP_NonMaster_codes[i]; int error = NRDuringLCP_NonMaster_codes[i];
int nodeId = getRandomNodeId(_restarter); int nodeId = getRandomNodeId(_restarter);
......
...@@ -1040,7 +1040,7 @@ UtilTransactions::readRowFromTableAndIndex(Ndb* pNdb, ...@@ -1040,7 +1040,7 @@ UtilTransactions::readRowFromTableAndIndex(Ndb* pNdb,
NdbDictionary::Index::Type indexType= pIndex->getType(); NdbDictionary::Index::Type indexType= pIndex->getType();
int retryAttempt = 0; int retryAttempt = 0;
const int retryMax = 100; const int retryMax = 100;
int check; int check, a;
NdbConnection *pTrans1=NULL; NdbConnection *pTrans1=NULL;
NdbResultSet *cursor= NULL; NdbResultSet *cursor= NULL;
NdbOperation *pOp; NdbOperation *pOp;
...@@ -1100,7 +1100,7 @@ UtilTransactions::readRowFromTableAndIndex(Ndb* pNdb, ...@@ -1100,7 +1100,7 @@ UtilTransactions::readRowFromTableAndIndex(Ndb* pNdb,
#if VERBOSE #if VERBOSE
printf("PK: "); printf("PK: ");
#endif #endif
for(int a = 0; a<tab.getNoOfColumns(); a++){ for(a = 0; a<tab.getNoOfColumns(); a++){
const NdbDictionary::Column* attr = tab.getColumn(a); const NdbDictionary::Column* attr = tab.getColumn(a);
if (attr->getPrimaryKey() == true){ if (attr->getPrimaryKey() == true){
if (pOp->equal(attr->getName(), row.attributeStore(a)->aRef()) != 0){ if (pOp->equal(attr->getName(), row.attributeStore(a)->aRef()) != 0){
...@@ -1119,7 +1119,7 @@ UtilTransactions::readRowFromTableAndIndex(Ndb* pNdb, ...@@ -1119,7 +1119,7 @@ UtilTransactions::readRowFromTableAndIndex(Ndb* pNdb,
#if VERBOSE #if VERBOSE
printf("Reading %u attributes: ", tab.getNoOfColumns()); printf("Reading %u attributes: ", tab.getNoOfColumns());
#endif #endif
for(int a = 0; a<tab.getNoOfColumns(); a++){ for(a = 0; a<tab.getNoOfColumns(); a++){
if((tabRow.attributeStore(a) = if((tabRow.attributeStore(a) =
pOp->getValue(tab.getColumn(a)->getName())) == 0) { pOp->getValue(tab.getColumn(a)->getName())) == 0) {
ERR(pTrans1->getNdbError()); ERR(pTrans1->getNdbError());
...@@ -1170,7 +1170,7 @@ UtilTransactions::readRowFromTableAndIndex(Ndb* pNdb, ...@@ -1170,7 +1170,7 @@ UtilTransactions::readRowFromTableAndIndex(Ndb* pNdb,
#if VERBOSE #if VERBOSE
printf("SI: "); printf("SI: ");
#endif #endif
for(int a = 0; a<(int)pIndex->getNoOfColumns(); a++){ for(a = 0; a<(int)pIndex->getNoOfColumns(); a++){
const NdbDictionary::Column * col = pIndex->getColumn(a); const NdbDictionary::Column * col = pIndex->getColumn(a);
int r; int r;
...@@ -1200,7 +1200,7 @@ UtilTransactions::readRowFromTableAndIndex(Ndb* pNdb, ...@@ -1200,7 +1200,7 @@ UtilTransactions::readRowFromTableAndIndex(Ndb* pNdb,
#if VERBOSE #if VERBOSE
printf("Reading %u attributes: ", tab.getNoOfColumns()); printf("Reading %u attributes: ", tab.getNoOfColumns());
#endif #endif
for(int a = 0; a<tab.getNoOfColumns(); a++){ for(a = 0; a<tab.getNoOfColumns(); a++){
void* pCheck; void* pCheck;
if (pIndexOp) if (pIndexOp)
......
...@@ -192,7 +192,7 @@ main(int argc, const char** argv){ ...@@ -192,7 +192,7 @@ main(int argc, const char** argv){
,{ "rm", 0, arg_flag, &rm, "-c rm", "undefine process(es)" } ,{ "rm", 0, arg_flag, &rm, "-c rm", "undefine process(es)" }
}; };
const int num_args = 10; const int num_args = 10;
int i;
int optind = 0; int optind = 0;
char desc[] = "[host:[port]]\n"; char desc[] = "[host:[port]]\n";
...@@ -215,13 +215,13 @@ main(int argc, const char** argv){ ...@@ -215,13 +215,13 @@ main(int argc, const char** argv){
Expression * m_expr = 0; Expression * m_expr = 0;
for(int i = optind; i<argc; i++){ for(i = optind; i<argc; i++){
add_host(g_hosts, argv[i]); add_host(g_hosts, argv[i]);
} }
OrExpr * orE = new OrExpr(new Operate(cmd, g_settings), true); OrExpr * orE = new OrExpr(new Operate(cmd, g_settings), true);
m_expr = orE; m_expr = orE;
for(int i = optind; i<argc; i++){ for(i = optind; i<argc; i++){
BaseString tmp(argv[i]); BaseString tmp(argv[i]);
Vector<BaseString> split; Vector<BaseString> split;
tmp.split(split, ":"); tmp.split(split, ":");
......
...@@ -43,7 +43,7 @@ int main(int argc, const char** argv) ...@@ -43,7 +43,7 @@ int main(int argc, const char** argv)
}; };
int num_args = sizeof(args) / sizeof(args[0]); int num_args = sizeof(args) / sizeof(args[0]);
int optind = 0; int optind = 0, i;
if(getarg(args, num_args, argc, argv, &optind) || argv[optind] == NULL) { if(getarg(args, num_args, argc, argv, &optind) || argv[optind] == NULL) {
arg_printusage(args, num_args, argv[0], "table name\n"); arg_printusage(args, num_args, argv[0], "table name\n");
...@@ -80,7 +80,7 @@ int main(int argc, const char** argv) ...@@ -80,7 +80,7 @@ int main(int argc, const char** argv)
} }
op->readTuple(); op->readTuple();
NdbRecAttr** data = new NdbRecAttr*[table->getNoOfColumns()]; NdbRecAttr** data = new NdbRecAttr*[table->getNoOfColumns()];
for (int i = 0; i < table->getNoOfColumns(); i++) for (i = 0; i < table->getNoOfColumns(); i++)
{ {
const NdbDictionary::Column* c = table->getColumn(i); const NdbDictionary::Column* c = table->getColumn(i);
if (c->getPrimaryKey()) if (c->getPrimaryKey())
...@@ -93,11 +93,10 @@ int main(int argc, const char** argv) ...@@ -93,11 +93,10 @@ int main(int argc, const char** argv)
data[i] = op->getValue(c->getName(), NULL); data[i] = op->getValue(c->getName(), NULL);
} }
} }
if (conn->execute(Commit) == 0) if (conn->execute(Commit) == 0)
{ {
// Print column names // Print column names
for (int i = 0; i < table->getNoOfColumns(); i++) for (i = 0; i < table->getNoOfColumns(); i++)
{ {
const NdbDictionary::Column* c = table->getColumn(i); const NdbDictionary::Column* c = table->getColumn(i);
...@@ -111,7 +110,7 @@ int main(int argc, const char** argv) ...@@ -111,7 +110,7 @@ int main(int argc, const char** argv)
{ {
g_info << hex; g_info << hex;
} }
for (int i = 0; i < table->getNoOfColumns(); i++) for (i = 0; i < table->getNoOfColumns(); i++)
{ {
NdbRecAttr* a = data[i]; NdbRecAttr* a = data[i];
switch(a->getType()) switch(a->getType())
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment