summaryrefslogtreecommitdiff
path: root/java/genpom
diff options
context:
space:
mode:
authorRajith Muditha Attapattu <rajith@apache.org>2011-05-27 15:44:23 +0000
committerRajith Muditha Attapattu <rajith@apache.org>2011-05-27 15:44:23 +0000
commit66765100f4257159622cefe57bed50125a5ad017 (patch)
treea88ee23bb194eb91f0ebb2d9b23ff423e3ea8e37 /java/genpom
parent1aeaa7b16e5ce54f10c901d75c4d40f9f88b9db6 (diff)
parent88b98b2f4152ef59a671fad55a0d08338b6b78ca (diff)
downloadqpid-python-rajith_jms_client.tar.gz
Creating a branch for experimenting with some ideas for JMS client.rajith_jms_client
git-svn-id: https://svn.apache.org/repos/asf/qpid/branches/rajith_jms_client@1128369 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'java/genpom')
-rwxr-xr-xjava/genpom177
1 files changed, 0 insertions, 177 deletions
diff --git a/java/genpom b/java/genpom
deleted file mode 100755
index 39eccd4c3e..0000000000
--- a/java/genpom
+++ /dev/null
@@ -1,177 +0,0 @@
-#!/usr/bin/python
-#
-# Licensed to the Apache Software Foundation (ASF) under one
-# or more contributor license agreements. See the NOTICE file
-# distributed with this work for additional information
-# regarding copyright ownership. The ASF licenses this file
-# to you under the Apache License, Version 2.0 (the
-# "License"); you may not use this file except in compliance
-# with the License. You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing,
-# software distributed under the License is distributed on an
-# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
-# KIND, either express or implied. See the License for the
-# specific language governing permissions and limitations
-# under the License.
-#
-
-import sys, re, os, mllib, optparse
-
-def die(msg):
- print >> sys.stderr, msg
- sys.exit(1)
-
-parser = optparse.OptionParser(usage="usage: %prog [options] JARs ...",
- description="Generates a pom.")
-parser.add_option("-n", "--name")
-parser.add_option("-g", "--group")
-parser.add_option("-a", "--artifact")
-parser.add_option("-v", "--version")
-parser.add_option("-d", "--description", default="")
-parser.add_option("-u", "--url", default="")
-parser.add_option("-m", "--modules", help="modules dependencies")
-parser.add_option("-p", "--prefix", help="prefix of the project's artifacts names")
-parser.add_option("-i", "--ignore", action="store_true", help="ignore missing deps")
-parser.add_option("-s", "--search-path", action="append",
- help="the path to search for deps")
-parser.add_option("-S", "--scope", metavar="ARTIFACT=SCOPE", action="append",
- default=[],
- help="specify scope for an artifact")
-parser.add_option("-o", "--output")
-
-opts, jars = parser.parse_args()
-
-if opts.search_path is None:
- path=["%s/.m2" % os.environ["HOME"]]
-else:
- path = []
- for p in opts.search_path:
- path.extend(p.split(os.pathsep))
-
-expanded_path = []
-for p in path:
- os.path.walk(p, lambda a, d, fs: expanded_path.append(d), None)
-
-if opts.group is None:
- die("the group option is required")
-
-if opts.version is None:
- die("the version option is required")
-
-if opts.name is None and opts.artifact is None:
- die("one of name or artifact must be supplied")
-
-if opts.prefix is not None:
- opts.artifact = opts.prefix + "-" + opts.artifact
-
-if opts.name is None:
- opts.name = opts.artifact
-
-if opts.artifact is None:
- opts.artifact = opts.name
-
-def lookup(dep, attr):
- nd = dep["dep"][attr]
- if nd is None:
- if nd is None:
- return None
- return nd.text()
-
-def search(path, file):
- for d in path:
- f = os.path.join(d, file)
- if os.path.exists(f):
- return mllib.xml_parse(f)
-
-scopes = {}
-for s in opts.scope:
- m = re.match(r"(.*)=(.*)", s)
- if not m:
- die("bad scope specifier: %s" % s)
- scopes[m.group(1)] = m.group(2)
-
-deps = []
-module_depends = []
-if opts.modules is not None:
- module_depends = opts.modules.replace("/", "-").split();
-
-for module in module_depends:
- if opts.prefix is None:
- artifactId = module
- else:
- artifactId = opts.prefix + "-" + module
-
- deps.append("""
- <dependency>
- <groupId>%s</groupId>
- <artifactId>%s</artifactId>
- <version>%s</version>
- </dependency>
-""" % (opts.group, artifactId, opts.version))
-
-for jar in jars:
- base, ext = os.path.splitext(os.path.basename(jar))
- dep = search(expanded_path, "%s.xml" % base)
- if dep is None:
- if opts.ignore:
- continue
- else:
- die("unable to locate xml for %s" % jar)
- group = lookup(dep, "groupId")
- artifactId = lookup(dep, "artifactId")
- version = lookup(dep, "version")
- deps.append("""
- <dependency>
- <groupId>%s</groupId>
- <artifactId>%s</artifactId>
- <version>%s</version>
- <scope>%s</scope>
- </dependency>
-""" % (group, artifactId, version,
- scopes.get(artifactId, "compile")))
-
-TEMPLATE = """<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd ">
- <modelVersion>4.0.0</modelVersion>
- <groupId>%(group)s</groupId>
- <artifactId>%(artifact)s</artifactId>
- <version>%(version)s</version>
-
- <name>%(name)s</name>
- <url>%(url)s</url>
- <description>%(description)s</description>
-
- <organization>
- <name>The Apache Software Foundation</name>
- <url>http://www.apache.org</url>
- </organization>
-
- <licenses>
- <license>
- <name>The Apache Software License, Version 2.0</name>
- <url>http://www.apache.org/licenses/LICENSE-2.0.html</url>
- </license>
- </licenses>
-
- <dependencies>
- %(dependencies)s
- </dependencies>
-
-</project>
-"""
-
-vars = {}
-vars.update(opts.__dict__)
-vars["dependencies"] = "".join(deps)
-
-if opts.output is None:
- out = sys.stdout
-else:
- out = open(opts.output, "w")
-out.write(TEMPLATE % vars)
-out.close()