Browse Source

bugfix: contract type as param.

cl-refactor
yann300 10 years ago
parent
commit
e33ae2e946
  1. 16
      mix/ClientModel.cpp
  2. 1
      mix/ClientModel.h
  3. 3
      mix/qml/Debugger.qml
  4. 13
      mix/qml/QAddressView.qml
  5. 14
      mix/qml/StateDialog.qml
  6. 11
      mix/qml/StructView.qml

16
mix/ClientModel.cpp

@ -237,7 +237,7 @@ void ClientModel::executeSequence(vector<TransactionSettings> const& _sequence,
{
try
{
map<Address, QString> deployedContracts;
vector<Address> deployedContracts;
onStateReset();
for (TransactionSettings const& transaction: _sequence)
{
@ -249,7 +249,7 @@ void ClientModel::executeSequence(vector<TransactionSettings> const& _sequence,
TransactionSettings stdTransaction = transaction;
stdTransaction.gasAuto = true;
Address address = deployContract(stdContractCode, stdTransaction);
deployedContracts.insert(make_pair(address, transaction.contractId));
deployedContracts.push_back(address);
m_stdContractAddresses[stdTransaction.contractId] = address;
m_stdContractNames[address] = stdTransaction.contractId;
}
@ -284,13 +284,9 @@ void ClientModel::executeSequence(vector<TransactionSettings> const& _sequence,
QVariant value = transaction.parameterValues.value(p->name());
if (type->type().type == SolidityType::Type::Address && value.toString().startsWith("<"))
{
for (auto it = deployedContracts.begin(); it != deployedContracts.end(); ++it)
{
if (value.toString().remove("<").remove(">") == it->second)
{
value = QVariant(QString::fromStdString(toHex(it->first.ref())));
}
}
value = value.toString().remove("<").remove(">");
QStringList nb = value.toString().split(" - ");
value = QVariant(QString::fromStdString("0x" + toHex(deployedContracts.at(nb.back().toInt()).ref())));
}
encoder.encode(value, type->type());
}
@ -300,7 +296,7 @@ void ClientModel::executeSequence(vector<TransactionSettings> const& _sequence,
bytes param = encoder.encodedData();
contractCode.insert(contractCode.end(), param.begin(), param.end());
Address newAddress = deployContract(contractCode, transaction);
deployedContracts.insert(make_pair(newAddress, transaction.contractId));
deployedContracts.push_back(newAddress);
auto contractAddressIter = m_contractAddresses.find(transaction.contractId);
if (contractAddressIter == m_contractAddresses.end() || newAddress != contractAddressIter->second)
{

1
mix/ClientModel.h

@ -71,6 +71,7 @@ struct TransactionSettings
QString stdContractUrl;
/// Sender
Secret sender;
};

3
mix/qml/Debugger.qml

@ -641,9 +641,6 @@ Rectangle {
}
}
Rectangle
{
id: storageRect

13
mix/qml/QAddressView.qml

@ -1,12 +1,13 @@
import QtQuick 2.0
import QtQuick.Controls 1.3
import QtQuick.Controls.Styles 1.3
Item
{
property alias value: textinput.text
property alias contractCreationTr: ctrModel
id: editRoot
height: 30
height: 20
width: 200
SourceSansProBold
@ -16,6 +17,7 @@ Item
function init()
{
trCombobox.visible = ctrModel.count > 1; //index 0 is a blank value.
if (value.indexOf("<") === 0)
{
for (var k = 0; k < ctrModel.count; k++)
@ -34,11 +36,13 @@ Item
Rectangle {
anchors.fill: parent
radius: 4
anchors.verticalCenter: parent.verticalCenter
height: 20
TextInput {
id: textinput
text: value
width: parent.width
height: 30
height: parent.width
wrapMode: Text.WrapAnywhere
clip: true
font.family: boldFont.name
@ -70,9 +74,12 @@ Item
id: trCombobox
model: ctrModel
textRole: "functionId"
height: 20
anchors.verticalCenter: parent.verticalCenter
anchors.left: textinput.parent.right
anchors.leftMargin: 3
onCurrentIndexChanged: {
trCombobox.selected = false;
if (currentText === "")
return;
else if (currentText !== " - ")
@ -81,7 +88,9 @@ Item
trCombobox.selected = true;
}
else if (textinput.text.indexOf("<") === 0)
{
textinput.text = "";
}
}
}
}

14
mix/qml/StateDialog.qml

@ -366,7 +366,17 @@ Dialog {
DefaultLabel {
Layout.preferredWidth: 150
text: styleData.row >= 0 ? transactionsModel.get(styleData.row).functionId : ""
text: {
if (styleData.row >= 0)
{
if (transactionsModel.get(styleData.row).label !== undefined)
return transactionsModel.get(styleData.row).label;
else if (transactionsModel.get(styleData.row).functionId !== undefined)
return transactionsModel.get(styleData.row).functionId;
}
else
return "";
}
}
}
}
@ -378,7 +388,6 @@ Dialog {
}
}
}
}
RowLayout
@ -456,7 +465,6 @@ Dialog {
onAccepted:
{
var item = transactionDialog.getItem();
if (transactionDialog.transactionIndex < transactionsModel.count) {
transactionsModel.set(transactionDialog.transactionIndex, item);
stateTransactions[transactionDialog.transactionIndex] = item;

11
mix/qml/StructView.qml

@ -20,7 +20,7 @@ Column
RowLayout
{
id: row
height: 20 + (members[index].type.category === QSolidityType.Struct ? (20 * members[index].type.members.length) : 0)
height: 30 + (members[index].type.category === QSolidityType.Struct ? (20 * members[index].type.members.length) : 0)
Layout.fillWidth: true
DefaultLabel {
height: 20
@ -70,13 +70,18 @@ Column
if (ptype.category === QSolidityType.Address)
{
item.contractCreationTr.append({"functionId": " - "});
var trCr = -1;
for (var k = 0; k < transactionsModel.count; k++)
{
if (k >= transactionIndex)
break;
var tr = transactionsModel.get(k);
if (tr.functionId === tr.contractId && modelData.type.name === qsTr("contract") + " " + tr.contractId)
item.contractCreationTr.append(tr);
if (tr.functionId === tr.contractId)
{
trCr++;
if (modelData.type.name === qsTr("contract") + " " + tr.contractId)
item.contractCreationTr.append({ "functionId": tr.contractId + " - " + trCr });
}
}
item.value = getValue();
item.init();

Loading…
Cancel
Save