forked from wuxianlin/MIUI_patchrom_Find5
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathreleasetools.py
67 lines (57 loc) · 2.57 KB
/
releasetools.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
import common
import edify_generator
def RemoveDeviceAssert(info):
edify = info.script
for i in xrange(len(edify.script)):
if "ro.product" in edify.script[i]:
edify.script[i] = ''
return
def AddAssertions(info):
edify = info.script
for i in xrange(len(edify.script)):
if " ||" in edify.script[i] and ("ro.product.device" in edify.script[i] or "ro.build.product" in edify.script[i]):
edify.script[i] = edify.script[i].replace(" ||", ' || getprop("ro.build.product") == "find5" || getprop("ro.product.device") == "FIND5" || getprop("ro.build.product") == "FIND5" ||')
return
def AddArgsForSetPermission(info):
edify = info.script
for i in xrange(len(edify.script)):
if "set_perm(" in edify.script[i] and "/system/xbin/lbesec" in edify.script[i]:
edify.script[i] = 'set_perm(0, 0, 06755, "/system/xbin/lbesec");'
return
def AddArgsForFormatSystem(info):
edify = info.script
for i in xrange(len(edify.script)):
if "format(" in edify.script[i] and "/dev/block/platform/msm_sdcc.1/by-name/system" in edify.script[i]:
edify.script[i] = 'format("ext4", "EMMC", "/dev/block/platform/msm_sdcc.1/by-name/system", "0", "/system");'
return
def WritePolicyConfig(info):
try:
file_contexts = info.input_zip.read("META/file_contexts")
common.ZipWriteStr(info.output_zip, "file_contexts", file_contexts)
except KeyError:
print "warning: file_context missing from target;"
def InstallImage(img_name, img_file, partition, info):
common.ZipWriteStr(info.output_zip, img_name, img_file)
info.script.AppendExtra(('package_extract_file("' + img_name + '", "' + partition + '");'))
def FullOTA_InstallRecovery(info):
img_file = info.input_zip.read("BOOTABLE_IMAGES/recovery.img")
info.script.Print("Writing recovery")
InstallImage("recovery.img", img_file, "/dev/block/platform/msm_sdcc.1/by-name/recovery", info)
def IncrementalOTA_InstallRecovery(info):
try:
source_file = info.source_zip.read("BOOTABLE_IMAGES/recovery.img")
target_file = info.target_zip.read("BOOTABLE_IMAGES/recovery.img")
if source_file != target_file:
info.script.Print("Writing recovery")
InstallImage("recovery.img", target_file, "/dev/block/platform/msm_sdcc.1/by-name/recovery", info)
else:
print "recovery unchanged; skipping"
except KeyError:
print "warning: recovery missing from target"
def FullOTA_InstallEnd(info):
WritePolicyConfig(info)
AddArgsForSetPermission(info)
AddAssertions(info)
def IncrementalOTA_InstallEnd(info):
AddArgsForSetPermission(info)
AddAssertions(info)