Merge pull request #2381 from karalabe/fix-abigen-tuples
accounts/abi/bind: fix double pointer in generated code
This commit is contained in:
		@@ -196,6 +196,38 @@ var bindTests = []struct {
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		`,
 | 
							`,
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
 | 
						// Tests that tuples can be properly returned and deserialized
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							`Tupler`,
 | 
				
			||||||
 | 
							`
 | 
				
			||||||
 | 
								contract Tupler {
 | 
				
			||||||
 | 
								    function tuple() returns (string a, int b, bytes32 c) {
 | 
				
			||||||
 | 
								        return ("Hi", 1, sha3(""));
 | 
				
			||||||
 | 
								    }
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							`,
 | 
				
			||||||
 | 
							`606060405260dc8060106000396000f3606060405260e060020a60003504633175aae28114601a575b005b600060605260c0604052600260809081527f486900000000000000000000000000000000000000000000000000000000000060a05260017fc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a47060e0829052610100819052606060c0908152600261012081905281906101409060a09080838184600060046012f1505081517fffff000000000000000000000000000000000000000000000000000000000000169091525050604051610160819003945092505050f3`,
 | 
				
			||||||
 | 
							`[{"constant":true,"inputs":[],"name":"tuple","outputs":[{"name":"a","type":"string"},{"name":"b","type":"int256"},{"name":"c","type":"bytes32"}],"type":"function"}]`,
 | 
				
			||||||
 | 
							`
 | 
				
			||||||
 | 
								// Generate a new random account and a funded simulator
 | 
				
			||||||
 | 
								key := crypto.NewKey(rand.Reader)
 | 
				
			||||||
 | 
								sim := backends.NewSimulatedBackend(core.GenesisAccount{Address: key.Address, Balance: big.NewInt(10000000000)})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								// Convert the tester key to an authorized transactor for ease of use
 | 
				
			||||||
 | 
								auth := bind.NewKeyedTransactor(key)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								// Deploy a tuple tester contract and execute a structured call on it
 | 
				
			||||||
 | 
								_, _, tupler, err := DeployTupler(auth, sim)
 | 
				
			||||||
 | 
								if err != nil {
 | 
				
			||||||
 | 
									t.Fatalf("Failed to deploy tupler contract: %v", err)
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
								sim.Commit()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								if _, err := tupler.Tuple(nil); err != nil {
 | 
				
			||||||
 | 
									t.Fatalf("Failed to call structure retriever: %v", err)
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							`,
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Tests that packages generated by the binder can be successfully compiled and
 | 
					// Tests that packages generated by the binder can be successfully compiled and
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -158,9 +158,9 @@ package {{.Package}}
 | 
				
			|||||||
		// {{.Normalized.Name}} is a free data retrieval call binding the contract method 0x{{printf "%x" .Original.Id}}.
 | 
							// {{.Normalized.Name}} is a free data retrieval call binding the contract method 0x{{printf "%x" .Original.Id}}.
 | 
				
			||||||
		//
 | 
							//
 | 
				
			||||||
		// Solidity: {{.Original.String}}
 | 
							// Solidity: {{.Original.String}}
 | 
				
			||||||
		func (_{{$contract.Type}} *{{$contract.Type}}Caller) {{.Normalized.Name}}(opts *bind.CallOpts {{range .Normalized.Inputs}}, {{.Name}} {{bindtype .Type}} {{end}}) ({{if .Structured}}*{{.Normalized.Name}}Result,{{else}}{{range .Normalized.Outputs}}{{bindtype .Type}},{{end}}{{end}} error) {
 | 
							func (_{{$contract.Type}} *{{$contract.Type}}Caller) {{.Normalized.Name}}(opts *bind.CallOpts {{range .Normalized.Inputs}}, {{.Name}} {{bindtype .Type}} {{end}}) ({{if .Structured}}{{.Normalized.Name}}Result,{{else}}{{range .Normalized.Outputs}}{{bindtype .Type}},{{end}}{{end}} error) {
 | 
				
			||||||
			var (
 | 
								var (
 | 
				
			||||||
				{{if .Structured}}ret = new(*{{.Normalized.Name}}Result){{else}}{{range $i, $_ := .Normalized.Outputs}}ret{{$i}} = new({{bindtype .Type}})
 | 
									{{if .Structured}}ret = new({{.Normalized.Name}}Result){{else}}{{range $i, $_ := .Normalized.Outputs}}ret{{$i}} = new({{bindtype .Type}})
 | 
				
			||||||
				{{end}}{{end}}
 | 
									{{end}}{{end}}
 | 
				
			||||||
			)
 | 
								)
 | 
				
			||||||
			out := {{if .Structured}}ret{{else}}{{if eq (len .Normalized.Outputs) 1}}ret0{{else}}[]interface{}{
 | 
								out := {{if .Structured}}ret{{else}}{{if eq (len .Normalized.Outputs) 1}}ret0{{else}}[]interface{}{
 | 
				
			||||||
@@ -174,14 +174,14 @@ package {{.Package}}
 | 
				
			|||||||
		// {{.Normalized.Name}} is a free data retrieval call binding the contract method 0x{{printf "%x" .Original.Id}}.
 | 
							// {{.Normalized.Name}} is a free data retrieval call binding the contract method 0x{{printf "%x" .Original.Id}}.
 | 
				
			||||||
		//
 | 
							//
 | 
				
			||||||
		// Solidity: {{.Original.String}}
 | 
							// Solidity: {{.Original.String}}
 | 
				
			||||||
		func (_{{$contract.Type}} *{{$contract.Type}}Session) {{.Normalized.Name}}({{range $i, $_ := .Normalized.Inputs}}{{if ne $i 0}},{{end}} {{.Name}} {{bindtype .Type}} {{end}}) ({{if .Structured}}*{{.Normalized.Name}}Result, {{else}} {{range .Normalized.Outputs}}{{bindtype .Type}},{{end}} {{end}} error) {
 | 
							func (_{{$contract.Type}} *{{$contract.Type}}Session) {{.Normalized.Name}}({{range $i, $_ := .Normalized.Inputs}}{{if ne $i 0}},{{end}} {{.Name}} {{bindtype .Type}} {{end}}) ({{if .Structured}}{{.Normalized.Name}}Result, {{else}} {{range .Normalized.Outputs}}{{bindtype .Type}},{{end}} {{end}} error) {
 | 
				
			||||||
		  return _{{$contract.Type}}.Contract.{{.Normalized.Name}}(&_{{$contract.Type}}.CallOpts {{range .Normalized.Inputs}}, {{.Name}}{{end}})
 | 
							  return _{{$contract.Type}}.Contract.{{.Normalized.Name}}(&_{{$contract.Type}}.CallOpts {{range .Normalized.Inputs}}, {{.Name}}{{end}})
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		// {{.Normalized.Name}} is a free data retrieval call binding the contract method 0x{{printf "%x" .Original.Id}}.
 | 
							// {{.Normalized.Name}} is a free data retrieval call binding the contract method 0x{{printf "%x" .Original.Id}}.
 | 
				
			||||||
		//
 | 
							//
 | 
				
			||||||
		// Solidity: {{.Original.String}}
 | 
							// Solidity: {{.Original.String}}
 | 
				
			||||||
		func (_{{$contract.Type}} *{{$contract.Type}}CallerSession) {{.Normalized.Name}}({{range $i, $_ := .Normalized.Inputs}}{{if ne $i 0}},{{end}} {{.Name}} {{bindtype .Type}} {{end}}) ({{if .Structured}}*{{.Normalized.Name}}Result, {{else}} {{range .Normalized.Outputs}}{{bindtype .Type}},{{end}} {{end}} error) {
 | 
							func (_{{$contract.Type}} *{{$contract.Type}}CallerSession) {{.Normalized.Name}}({{range $i, $_ := .Normalized.Inputs}}{{if ne $i 0}},{{end}} {{.Name}} {{bindtype .Type}} {{end}}) ({{if .Structured}}{{.Normalized.Name}}Result, {{else}} {{range .Normalized.Outputs}}{{bindtype .Type}},{{end}} {{end}} error) {
 | 
				
			||||||
		  return _{{$contract.Type}}.Contract.{{.Normalized.Name}}(&_{{$contract.Type}}.CallOpts {{range .Normalized.Inputs}}, {{.Name}}{{end}})
 | 
							  return _{{$contract.Type}}.Contract.{{.Normalized.Name}}(&_{{$contract.Type}}.CallOpts {{range .Normalized.Inputs}}, {{.Name}}{{end}})
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	{{end}}
 | 
						{{end}}
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user