1
0
mirror of https://gitlab.com/fdroid/fdroidserver.git synced 2024-11-09 00:40:11 +01:00

New update checking mode

This commit is contained in:
Ciaran Gultnieks 2012-03-10 12:50:34 +00:00
parent 7be0d0be30
commit f3d7092dbe
3 changed files with 82 additions and 22 deletions

View File

@ -28,6 +28,56 @@ import HTMLParser
import common import common
# Check for a new version by looking at the AndroidManifest.xml at the HEAD
# of the source repo. Whether this can be used reliably or not depends on
# the development procedures used by the project's developers. Use it with
# caution, because it's inappropriate for many projects.
# Returns (None, "a message") if this didn't work, or (version, vercode) for
# the details of the current version.
def check_repomanifest(app):
try:
build_dir = 'build/' + app['id']
if app['Repo Type'] != 'git':
return (None, 'RepoManifest update mode only works for git repositories currently')
# Set up vcs interface and make sure we have the latest code...
vcs = common.getvcs(app['Repo Type'], app['Repo'], build_dir)
vcs.gotorevision('origin/master')
if len(app['builds']) == 0:
return (None, "Can't use RepoManifest with no builds defined")
manifest = build_dir
if app['builds'][-1].has_key('subdir'):
manifest = os.path.join(manifest, app['builds'][-1]['subdir'])
manifest = os.path.join(manifest, 'AndroidManifest.xml')
version, vercode, package = common.parse_androidmanifest(manifest)
if not package:
return (None, "Couldn't find ipackage ID")
if package != app['id']:
return (None, "Package ID mismatch")
if not version:
return (None,"Couldn't find latest version name")
if not vercode:
return (None,"Couldn't find latest version code")
return (version, vercode)
except BuildException as be:
msg = "Could not scan app %s due to BuildException: %s" % (app['id'], be)
return (None, msg)
except VCSException as vcse:
msg = "VCS error while scanning app %s: %s" % (app['id'], vcse)
return (None, msg)
except Exception:
msg = "Could not scan app %s due to unknown error: %s" % (app['id'], traceback.format_exc())
return (None, msg)
# Check for a new version by looking at the Google market. # Check for a new version by looking at the Google market.
# Returns (None, "a message") if this didn't work, or (version, vercode) for # Returns (None, "a message") if this didn't work, or (version, vercode) for
# the details of the current version. # the details of the current version.
@ -91,6 +141,8 @@ def main():
mode = app['Update Check Mode'] mode = app['Update Check Mode']
if mode == 'Market': if mode == 'Market':
(version, vercode) = check_market(app) (version, vercode) = check_market(app)
elif mode == 'RepoManifest':
(version, vercode) = check_repomanifest(app)
elif mode == 'None': elif mode == 'None':
version = None version = None
vercode = 'Checking disabled' vercode = 'Checking disabled'

View File

@ -563,6 +563,32 @@ def parse_description(lines):
return text return text
# Extract some information from the AndroidManifest.xml at the given path.
# Returns (version, vercode, package), any or all of which might be None.
def parse_androidmanifest(manifest):
vcsearch = re.compile(r'.*android:versionCode="([^"]+)".*').search
vnsearch = re.compile(r'.*android:versionName="([^"]+)".*').search
psearch = re.compile(r'.*package="([^"]+)".*').search
version = None
vercode = None
package = None
for line in file(manifest):
if not package:
matches = psearch(line)
if matches:
package = matches.group(1)
if not version:
matches = vnsearch(line)
if matches:
version = matches.group(1)
if not vercode:
matches = vcsearch(line)
if matches:
vercode = matches.group(1)
return (version, vercode, package)
class BuildException(Exception): class BuildException(Exception):
def __init__(self, value, stdout = None, stderr = None): def __init__(self, value, stdout = None, stderr = None):
self.value = value self.value = value
@ -967,9 +993,9 @@ def scan_source(build_dir, root_dir, thisbuild):
msg = 'Found DexClassLoader in ' + fp msg = 'Found DexClassLoader in ' + fp
problems.append(msg) problems.append(msg)
if line.lower().find('all rights reserved') != -1: # if line.lower().find('all rights reserved') != -1:
msg = 'All rights reserved in ' + fp # msg = 'All rights reserved in ' + fp
problems.append(msg) # problems.append(msg)
# Presence of a jni directory without buildjni=yes might # Presence of a jni directory without buildjni=yes might
# indicate a problem... # indicate a problem...

View File

@ -189,25 +189,7 @@ def main():
sys.exit(1) sys.exit(1)
# Extract some information... # Extract some information...
vcsearch = re.compile(r'.*android:versionCode="([^"]+)".*').search version, vercode, package = common.parse_androidmanifest(manifest)
vnsearch = re.compile(r'.*android:versionName="([^"]+)".*').search
psearch = re.compile(r'.*package="([^"]+)".*').search
version = None
vercode = None
package = None
for line in file(manifest):
if not package:
matches = psearch(line)
if matches:
package = matches.group(1)
if not version:
matches = vnsearch(line)
if matches:
version = matches.group(1)
if not vercode:
matches = vcsearch(line)
if matches:
vercode = matches.group(1)
if not package: if not package:
print "Couldn't find package ID" print "Couldn't find package ID"
sys.exit(1) sys.exit(1)