mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-28 06:32:09 +00:00
Strings now handled correctly.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@3920 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
9474dd68e8
commit
e548f009f7
@ -985,18 +985,23 @@ void CWriter::printIndexingExpression(Value *Ptr, User::op_iterator I,
|
||||
|
||||
writeOperandInternal(Ptr);
|
||||
|
||||
if (HasImplicitAddress && (!CI || !CI->isNullValue()))
|
||||
if (HasImplicitAddress && (!CI || !CI->isNullValue())) {
|
||||
Out << ")";
|
||||
HasImplicitAddress = false; // HIA is only true if we haven't addressed yet
|
||||
}
|
||||
|
||||
// Print out the -> operator if possible...
|
||||
if (CI && CI->isNullValue() && I+1 != E) {
|
||||
assert(!HasImplicitAddress || (CI && CI->isNullValue()) &&
|
||||
"Can only have implicit address with direct accessing");
|
||||
|
||||
if (HasImplicitAddress) {
|
||||
++I;
|
||||
} else if (CI && CI->isNullValue() && I+1 != E) {
|
||||
// Print out the -> operator if possible...
|
||||
if ((*(I+1))->getType() == Type::UByteTy) {
|
||||
Out << (HasImplicitAddress ? "." : "->");
|
||||
Out << "field" << cast<ConstantUInt>(*(I+1))->getValue();
|
||||
I += 2;
|
||||
} else { // First array index of 0: Just skip it
|
||||
++I;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
for (; I != E; ++I)
|
||||
@ -1015,14 +1020,14 @@ void CWriter::visitLoadInst(LoadInst &I) {
|
||||
}
|
||||
|
||||
void CWriter::visitStoreInst(StoreInst &I) {
|
||||
Out << "*";
|
||||
//Out << "*";
|
||||
writeOperand(I.getPointerOperand());
|
||||
Out << " = ";
|
||||
writeOperand(I.getOperand(0));
|
||||
}
|
||||
|
||||
void CWriter::visitGetElementPtrInst(GetElementPtrInst &I) {
|
||||
Out << "&";
|
||||
//Out << "&";
|
||||
printIndexingExpression(I.getPointerOperand(), I.idx_begin(), I.idx_end());
|
||||
}
|
||||
|
||||
|
@ -985,18 +985,23 @@ void CWriter::printIndexingExpression(Value *Ptr, User::op_iterator I,
|
||||
|
||||
writeOperandInternal(Ptr);
|
||||
|
||||
if (HasImplicitAddress && (!CI || !CI->isNullValue()))
|
||||
if (HasImplicitAddress && (!CI || !CI->isNullValue())) {
|
||||
Out << ")";
|
||||
HasImplicitAddress = false; // HIA is only true if we haven't addressed yet
|
||||
}
|
||||
|
||||
// Print out the -> operator if possible...
|
||||
if (CI && CI->isNullValue() && I+1 != E) {
|
||||
assert(!HasImplicitAddress || (CI && CI->isNullValue()) &&
|
||||
"Can only have implicit address with direct accessing");
|
||||
|
||||
if (HasImplicitAddress) {
|
||||
++I;
|
||||
} else if (CI && CI->isNullValue() && I+1 != E) {
|
||||
// Print out the -> operator if possible...
|
||||
if ((*(I+1))->getType() == Type::UByteTy) {
|
||||
Out << (HasImplicitAddress ? "." : "->");
|
||||
Out << "field" << cast<ConstantUInt>(*(I+1))->getValue();
|
||||
I += 2;
|
||||
} else { // First array index of 0: Just skip it
|
||||
++I;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
for (; I != E; ++I)
|
||||
@ -1015,14 +1020,14 @@ void CWriter::visitLoadInst(LoadInst &I) {
|
||||
}
|
||||
|
||||
void CWriter::visitStoreInst(StoreInst &I) {
|
||||
Out << "*";
|
||||
//Out << "*";
|
||||
writeOperand(I.getPointerOperand());
|
||||
Out << " = ";
|
||||
writeOperand(I.getOperand(0));
|
||||
}
|
||||
|
||||
void CWriter::visitGetElementPtrInst(GetElementPtrInst &I) {
|
||||
Out << "&";
|
||||
//Out << "&";
|
||||
printIndexingExpression(I.getPointerOperand(), I.idx_begin(), I.idx_end());
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user