forked from TrueCloudLab/neoneo-go
compiler, cli: generate manifest.json and debug.json independently
We should be able to generate manifest.json without debug.json and vice versa.
This commit is contained in:
parent
59d1013a8f
commit
4dfb0eb438
2 changed files with 28 additions and 20 deletions
|
@ -351,14 +351,15 @@ func contractCompile(ctx *cli.Context) error {
|
||||||
}
|
}
|
||||||
manifestFile := ctx.String("manifest")
|
manifestFile := ctx.String("manifest")
|
||||||
confFile := ctx.String("config")
|
confFile := ctx.String("config")
|
||||||
if len(manifestFile) != 0 && len(confFile) == 0 {
|
debugFile := ctx.String("debug")
|
||||||
|
if len(confFile) == 0 && (len(manifestFile) != 0 || len(debugFile) != 0) {
|
||||||
return cli.NewExitError(errNoConfFile, 1)
|
return cli.NewExitError(errNoConfFile, 1)
|
||||||
}
|
}
|
||||||
|
|
||||||
o := &compiler.Options{
|
o := &compiler.Options{
|
||||||
Outfile: ctx.String("out"),
|
Outfile: ctx.String("out"),
|
||||||
|
|
||||||
DebugInfo: ctx.String("debug"),
|
DebugInfo: debugFile,
|
||||||
ManifestFile: manifestFile,
|
ManifestFile: manifestFile,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,6 +13,7 @@ import (
|
||||||
|
|
||||||
"github.com/nspcc-dev/neo-go/pkg/smartcontract"
|
"github.com/nspcc-dev/neo-go/pkg/smartcontract"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/smartcontract/nef"
|
"github.com/nspcc-dev/neo-go/pkg/smartcontract/nef"
|
||||||
|
"github.com/pkg/errors"
|
||||||
"golang.org/x/tools/go/loader"
|
"golang.org/x/tools/go/loader"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -112,31 +113,37 @@ func CompileAndSave(src string, o *Options) ([]byte, error) {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return b, err
|
return b, err
|
||||||
}
|
}
|
||||||
if o.DebugInfo == "" {
|
if o.DebugInfo == "" && o.ManifestFile == "" {
|
||||||
return b, nil
|
return b, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
p, err := filepath.Abs(src)
|
p, err := filepath.Abs(src)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return b, err
|
return b, err
|
||||||
}
|
}
|
||||||
di.Documents = append(di.Documents, p)
|
di.Documents = append(di.Documents, p)
|
||||||
data, err := json.Marshal(di)
|
|
||||||
if err != nil {
|
if o.DebugInfo != "" {
|
||||||
return b, err
|
data, err := json.Marshal(di)
|
||||||
|
if err != nil {
|
||||||
|
return b, err
|
||||||
|
}
|
||||||
|
if err := ioutil.WriteFile(o.DebugInfo, data, os.ModePerm); err != nil {
|
||||||
|
return b, err
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if err := ioutil.WriteFile(o.DebugInfo, data, os.ModePerm); err != nil {
|
|
||||||
return b, err
|
if o.ManifestFile != "" {
|
||||||
|
m, err := di.convertToManifest(o.ContractFeatures)
|
||||||
|
if err != nil {
|
||||||
|
return b, errors.Wrap(err, "failed to convert debug info to manifest")
|
||||||
|
}
|
||||||
|
mData, err := json.Marshal(m)
|
||||||
|
if err != nil {
|
||||||
|
return b, errors.Wrap(err, "failed to marshal manifest")
|
||||||
|
}
|
||||||
|
return b, ioutil.WriteFile(o.ManifestFile, mData, os.ModePerm)
|
||||||
}
|
}
|
||||||
if o.ManifestFile == "" {
|
|
||||||
return b, err
|
return b, nil
|
||||||
}
|
|
||||||
m, err := di.convertToManifest(o.ContractFeatures)
|
|
||||||
if err != nil {
|
|
||||||
return b, err
|
|
||||||
}
|
|
||||||
mData, err := json.Marshal(m)
|
|
||||||
if err != nil {
|
|
||||||
return b, err
|
|
||||||
}
|
|
||||||
return b, ioutil.WriteFile(o.ManifestFile, mData, os.ModePerm)
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue