Merge changes I083907ef,Ie8e0f97a
* changes: Add pom2mk -exclude Add pom2mk -regen
This commit is contained in:
commit
c52e90eda3
1 changed files with 96 additions and 6 deletions
|
@ -15,11 +15,14 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bufio"
|
||||||
|
"bytes"
|
||||||
"encoding/xml"
|
"encoding/xml"
|
||||||
"flag"
|
"flag"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"os"
|
"os"
|
||||||
|
"os/exec"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"regexp"
|
"regexp"
|
||||||
"sort"
|
"sort"
|
||||||
|
@ -85,6 +88,19 @@ func (d ExtraDeps) Set(v string) error {
|
||||||
|
|
||||||
var extraDeps = make(ExtraDeps)
|
var extraDeps = make(ExtraDeps)
|
||||||
|
|
||||||
|
type Exclude map[string]bool
|
||||||
|
|
||||||
|
func (e Exclude) String() string {
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e Exclude) Set(v string) error {
|
||||||
|
e[v] = true
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
var excludes = make(Exclude)
|
||||||
|
|
||||||
var sdkVersion string
|
var sdkVersion string
|
||||||
var useVersion string
|
var useVersion string
|
||||||
var staticDeps bool
|
var staticDeps bool
|
||||||
|
@ -271,6 +287,58 @@ func parse(filename string) (*Pom, error) {
|
||||||
return &pom, nil
|
return &pom, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func rerunForRegen(filename string) error {
|
||||||
|
buf, err := ioutil.ReadFile(filename)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
scanner := bufio.NewScanner(bytes.NewBuffer(buf))
|
||||||
|
|
||||||
|
// Skip the first line in the file
|
||||||
|
for i := 0; i < 2; i++ {
|
||||||
|
if !scanner.Scan() {
|
||||||
|
if scanner.Err() != nil {
|
||||||
|
return scanner.Err()
|
||||||
|
} else {
|
||||||
|
return fmt.Errorf("unexpected EOF")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Extract the old args from the file
|
||||||
|
line := scanner.Text()
|
||||||
|
if strings.HasPrefix(line, "# pom2mk ") {
|
||||||
|
line = strings.TrimPrefix(line, "# pom2mk ")
|
||||||
|
} else {
|
||||||
|
return fmt.Errorf("unexpected second line: %q", line)
|
||||||
|
}
|
||||||
|
args := strings.Split(line, " ")
|
||||||
|
lastArg := args[len(args)-1]
|
||||||
|
args = args[:len(args)-1]
|
||||||
|
|
||||||
|
// Append all current command line args except -regen <file> to the ones from the file
|
||||||
|
for i := 1; i < len(os.Args); i++ {
|
||||||
|
if os.Args[i] == "-regen" {
|
||||||
|
i++
|
||||||
|
} else {
|
||||||
|
args = append(args, os.Args[i])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
args = append(args, lastArg)
|
||||||
|
|
||||||
|
cmd := os.Args[0] + " " + strings.Join(args, " ")
|
||||||
|
// Re-exec pom2mk with the new arguments
|
||||||
|
output, err := exec.Command("/bin/sh", "-c", cmd).Output()
|
||||||
|
if exitErr, _ := err.(*exec.ExitError); exitErr != nil {
|
||||||
|
return fmt.Errorf("failed to run %s\n%s", cmd, string(exitErr.Stderr))
|
||||||
|
} else if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return ioutil.WriteFile(filename, output, 0666)
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
flag.Usage = func() {
|
flag.Usage = func() {
|
||||||
fmt.Fprintf(os.Stderr, `pom2mk, a tool to create Android.mk files from maven repos
|
fmt.Fprintf(os.Stderr, `pom2mk, a tool to create Android.mk files from maven repos
|
||||||
|
@ -278,7 +346,7 @@ func main() {
|
||||||
The tool will extract the necessary information from *.pom files to create an Android.mk whose
|
The tool will extract the necessary information from *.pom files to create an Android.mk whose
|
||||||
aar libraries can be linked against when using AAPT2.
|
aar libraries can be linked against when using AAPT2.
|
||||||
|
|
||||||
Usage: %s [--rewrite <regex>=<replace>] [--extra-deps <module>=<module>[,<module>]] <dir>
|
Usage: %s [--rewrite <regex>=<replace>] [-exclude <module>] [--extra-deps <module>=<module>[,<module>]] [<dir>] [-regen <file>]
|
||||||
|
|
||||||
-rewrite <regex>=<replace>
|
-rewrite <regex>=<replace>
|
||||||
rewrite can be used to specify mappings between Maven projects and Make modules. The -rewrite
|
rewrite can be used to specify mappings between Maven projects and Make modules. The -rewrite
|
||||||
|
@ -286,6 +354,8 @@ Usage: %s [--rewrite <regex>=<replace>] [--extra-deps <module>=<module>[,<module
|
||||||
project, mappings are searched in the order they were specified. The first <regex> matching
|
project, mappings are searched in the order they were specified. The first <regex> matching
|
||||||
either the Maven project's <groupId>:<artifactId> or <artifactId> will be used to generate
|
either the Maven project's <groupId>:<artifactId> or <artifactId> will be used to generate
|
||||||
the Make module name using <replace>. If no matches are found, <artifactId> is used.
|
the Make module name using <replace>. If no matches are found, <artifactId> is used.
|
||||||
|
-exclude <module>
|
||||||
|
Don't put the specified module in the makefile.
|
||||||
-extra-deps <module>=<module>[,<module>]
|
-extra-deps <module>=<module>[,<module>]
|
||||||
Some Android.mk modules have transitive dependencies that must be specified when they are
|
Some Android.mk modules have transitive dependencies that must be specified when they are
|
||||||
depended upon (like android-support-v7-mediarouter requires android-support-v7-appcompat).
|
depended upon (like android-support-v7-mediarouter requires android-support-v7-appcompat).
|
||||||
|
@ -299,20 +369,37 @@ Usage: %s [--rewrite <regex>=<replace>] [--extra-deps <module>=<module>[,<module
|
||||||
Whether to statically include direct dependencies.
|
Whether to statically include direct dependencies.
|
||||||
<dir>
|
<dir>
|
||||||
The directory to search for *.pom files under.
|
The directory to search for *.pom files under.
|
||||||
|
The makefile is written to stdout, to be put in the current directory (often as Android.mk)
|
||||||
The makefile is written to stdout, to be put in the current directory (often as Android.mk)
|
-regen <file>
|
||||||
|
Read arguments from <file> and overwrite it.
|
||||||
`, os.Args[0])
|
`, os.Args[0])
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var regen string
|
||||||
|
|
||||||
|
flag.Var(&excludes, "exclude", "Exclude module")
|
||||||
flag.Var(&extraDeps, "extra-deps", "Extra dependencies needed when depending on a module")
|
flag.Var(&extraDeps, "extra-deps", "Extra dependencies needed when depending on a module")
|
||||||
flag.Var(&rewriteNames, "rewrite", "Regex(es) to rewrite artifact names")
|
flag.Var(&rewriteNames, "rewrite", "Regex(es) to rewrite artifact names")
|
||||||
flag.StringVar(&sdkVersion, "sdk-version", "", "What to write to LOCAL_SDK_VERSION")
|
flag.StringVar(&sdkVersion, "sdk-version", "", "What to write to LOCAL_SDK_VERSION")
|
||||||
flag.StringVar(&useVersion, "use-version", "", "Only read artifacts of a specific version")
|
flag.StringVar(&useVersion, "use-version", "", "Only read artifacts of a specific version")
|
||||||
flag.BoolVar(&staticDeps, "static-deps", false, "Statically include direct dependencies")
|
flag.BoolVar(&staticDeps, "static-deps", false, "Statically include direct dependencies")
|
||||||
|
flag.StringVar(®en, "regen", "", "Rewrite specified file")
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
|
|
||||||
if flag.NArg() != 1 {
|
if regen != "" {
|
||||||
flag.Usage()
|
err := rerunForRegen(regen)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Fprintln(os.Stderr, err)
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
|
os.Exit(0)
|
||||||
|
}
|
||||||
|
|
||||||
|
if flag.NArg() == 0 {
|
||||||
|
fmt.Fprintln(os.Stderr, "Directory argument is required")
|
||||||
|
os.Exit(1)
|
||||||
|
} else if flag.NArg() > 1 {
|
||||||
|
fmt.Fprintln(os.Stderr, "Multiple directories provided:", strings.Join(flag.Args(), " "))
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -373,14 +460,17 @@ The makefile is written to stdout, to be put in the current directory (often as
|
||||||
}
|
}
|
||||||
|
|
||||||
if pom != nil {
|
if pom != nil {
|
||||||
poms = append(poms, pom)
|
|
||||||
key := pom.MkName()
|
key := pom.MkName()
|
||||||
|
if excludes[key] {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
if old, ok := modules[key]; ok {
|
if old, ok := modules[key]; ok {
|
||||||
fmt.Fprintln(os.Stderr, "Module", key, "defined twice:", old.PomFile, pom.PomFile)
|
fmt.Fprintln(os.Stderr, "Module", key, "defined twice:", old.PomFile, pom.PomFile)
|
||||||
duplicate = true
|
duplicate = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
poms = append(poms, pom)
|
||||||
modules[key] = pom
|
modules[key] = pom
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue