xtool/llvm/install_name_tool: Exec
This commit is contained in:
@@ -40,6 +40,7 @@ func New(app string) *Cmd {
|
|||||||
return &Cmd{app, os.Stdout, os.Stderr}
|
return &Cmd{app, os.Stdout, os.Stderr}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Exec executes a clang command.
|
||||||
func (p *Cmd) Exec(args ...string) error {
|
func (p *Cmd) Exec(args ...string) error {
|
||||||
cmd := exec.Command(p.app, args...)
|
cmd := exec.Command(p.app, args...)
|
||||||
cmd.Stdout = p.Stdout
|
cmd.Stdout = p.Stdout
|
||||||
|
|||||||
@@ -38,6 +38,14 @@ func New(app string) *Cmd {
|
|||||||
return &Cmd{app: app}
|
return &Cmd{app: app}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Exec executes a install_name_tool command.
|
||||||
|
func (p *Cmd) Exec(args ...string) error {
|
||||||
|
cmd := exec.Command(p.app, args...)
|
||||||
|
cmd.Stdout = p.Stdout
|
||||||
|
cmd.Stderr = p.Stderr
|
||||||
|
return cmd.Run()
|
||||||
|
}
|
||||||
|
|
||||||
// Change represents a dependent shared library install name change.
|
// Change represents a dependent shared library install name change.
|
||||||
type Change struct {
|
type Change struct {
|
||||||
Old string
|
Old string
|
||||||
@@ -51,17 +59,15 @@ func (p *Cmd) Change(target string, chgs ...Change) error {
|
|||||||
args = append(args, "-change", chg.Old, chg.New)
|
args = append(args, "-change", chg.Old, chg.New)
|
||||||
}
|
}
|
||||||
args = append(args, target)
|
args = append(args, target)
|
||||||
cmd := exec.Command(p.app, args...)
|
return p.Exec(args...)
|
||||||
cmd.Stdout = p.Stdout
|
|
||||||
cmd.Stderr = p.Stderr
|
|
||||||
return cmd.Run()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// ChangeToRpath changes dependent shared library install name to @rpath.
|
// ChangeToRpath changes dependent shared library install name to @rpath.
|
||||||
func (p *Cmd) ChangeToRpath(target string, dylibDeps ...string) error {
|
func (p *Cmd) ChangeToRpath(target string, dylibDeps ...string) error {
|
||||||
chgs := make([]Change, len(dylibDeps))
|
args := make([]string, len(dylibDeps)*3+1)
|
||||||
for i, dep := range dylibDeps {
|
for _, dep := range dylibDeps {
|
||||||
chgs[i] = Change{Old: dep, New: "@rpath/" + filepath.Base(dep)}
|
args = append(args, "-change", dep, "@rpath/"+filepath.Base(dep))
|
||||||
}
|
}
|
||||||
return p.Change(target, chgs...)
|
args = append(args, target)
|
||||||
|
return p.Exec(args...)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user