这是Android系统来运行updater-scripts的Edify语言的基本介绍。 大部分的Edify命名都是函数,当调用这些函数结束的时候,会返回数据给脚本。当然,你也可以使用这些函数的返 回 值来确认成功与否,例如: ifelse(mount("yaffs2", "MTD", "system", "/system") == "system", ui_print("Successfully Mounted!"), ui_print("Mount Failed!"); 这个命令会尝试去挂载命名为“system”的“MTD”分区到“/system”。如果挂载成功,脚本会显示“Successfully Mounted!”,否则会显示“Mount Failed!”。
现面是用在Edify的Updater-script中的函数例子:
函数名称: mount 函数语法: mount(fs_type, partition_type, location, mount_point) 参数详解: fs_type-----------------"yaffs2" 或 "ext4" partition_type----------"MTD" 或 "EMMC" location-----------------分区(partition) 或 驱动器(device) mount_poin------------挂载文件系统的目标文件夹(target folder to mount FS) 作用解释: 挂载一个文件系统到指定的挂载点 返 回 值: 挂载成功则返回挂载点,失败返回null 函数示例: mount("MTD", "system", "/system");挂载system分区,设置返回指针"/system” mount("vfat", "/dev/block/mmcblk1p2", "/system"); 挂载/dev/block/mmcblk1p2,返回指针"/system”
函数名称: is_mounted 函数语法: is_mounted(mount_point) 参数详解: mount_point-----------字符串,检查是否已经挂载的挂载点 作用解释: 检查文件系统是否挂载 返 回 值: 挂载成功则返回挂载点,失败返回null 函数示例:
函数名称: unmount 函数语法: unmount(mount_point) 参数详解: mount_point-----------字符串,要解除挂载的挂载点 作用解释: 解除文件系统挂载 返 回 值: 解除挂载成功则返回挂载点,失败返回null 函数示例: unmount("/system"); 卸载/system分区
函数名称: format 函数语法: format(fs_type, partition_type, location) 参数详解: fs_type-----------------字符串,数据为"yaffs2" 或 "ext4" partition_type----------字符串, "MTD" 或 "EMMC" location-----------------字符串, 分区(partition) 或 驱动器(device) 作用解释: 格式化为指定的文件系统 函数示例: format("MTD", "system");格式化system分区
函数名称: delete 函数语法: delete(file1, file2, ..., fileN) 参数详解: 字符串,要删除的文件 作用解释: 删除一个文件。最少指定一个文件;多个文件可以做为多个参数指定 函数示例: delete("/data/zipalign.log");删除文件/data/zipalign.log
函数名称: delete_recursive 函数语法: delete_recursive(dir1, dir2,...,dirN) 参数详解: 字符串,要递归删除的目录 作用解释: 删除文件夹及其包含的所有内容。最少指定1个目录;多个目录可以做为多个参数指定 函数示例: delete_recursive("/data/dalvik-cache");删除文件夹/data/dalvik-cache
函数名称: show_progress 函数语法: show_progress(frac, sec) 参数详解: frac----------------------进度完成数值 Sec----------------------总秒数 作用解释: 显示在Recovery系统中进度 函数示例: show_progress(0.1, 10);show_progress下面的操作可能进行10s,完成后进度条前进0.1(也就是10%)
函数名称: set_progress 函数语法: set_prograss(frac) 参数详解: frac---------------------进度数值 函数示例:
函数名称: package_extract_dir 函数语法: package_extract_dir(package_path, destination_path) 参数详解: package_path----------字符串,升级包内要提取的目录 destination_path--------字符串,提取文件的目标目录 作用解释: 提取升级包内目录中的所有文件到指定的目标目录 函数示例: package_extract_dir("system", "/system");释放ROM包里system文件夹下所有文件和子文件夹至/system
函数名称: package_extract_file 函数语法: package_extract_file(package_path) 或 package_extract_file(package_path, destination_path) 参数详解: package_path----------字符串,升级包内要提取的文件 destination_path-------字符串,提取文件的目标目录 作用解释: 提取升级包内的单个文件到指定的目标目录 函数示例: package_extract_file("my.zip", "/system");解压ROM包里的my.zip文件至/system
函数名称: file_getprop 函数语法: file_getprop(file, key) 参数详解: file----------------------字符串,要检查的文件名 Key----------------------字符串,返回数据中的文件的键名字 作用解释: 在格式"key"="value"的文件中取得文件属性值 函数示例:
函数名称: symlink 函数语法: symlink(target, src1, src2, ..., srcN) 参数详解: target-------------------字符串,符号链接的目标 srcX ---------------------字符串,要创建的符号链接的目标点 作用解释: 在创建新的符号链接之前,要断开已经存在的符号链接 函数示例: symlink("toolbox", "/system/bin/ps");建立指向toolbox的符号链接/system/bin/ps
函数名称: set_perm 函数语法: set_perm(uid, gid, mode, file1, file2, ..., fileN) 参数详解: uid----------------------用户ID(user id) Gid----------------------用户组ID(group id) Mode--------------------权限模式(permission mode) fileX---------------------要设置许可的文件(file to set permission on) 作用解释: 设置单个文件或一系列文件的权限,最少指定1个文件,前4个参数是必须的 函数示例: set_perm(0,2000,0550, "system/etc/init.goldfish.sh");设置手机system中的etc/init.goldfish.sh的用户为root,用户组为shell,所有者以及所属用户组成员可以进行读取和执行操作,其他用户无操作权限) 这里0代表用户为root 2000代表用户组为shell 我们来说明0550这组数据,这组数据的最后三位550,分别代表“所有者\组用户\其他用户”的权限,也就是我们在RE管理中“用户\群组\其他”三行。 我们以XXX来表示这三组权限,其中: ×=4 读的权限 ×=2 写的权限 ×=1 执行的权限 我们必须首先了解用数字表示的属性的含义:0表示没有权限,1表示可执行权限,2表示可写权限,4表示可读权限,然后将其相加。所以数字属性的格式应为3个从0到7的八进制数。 例如,如果想让某个文件的属主有"读/写"二种权限,需要把4(可读)+2(可写)=6(读/写)。若要rwx属性则4+2+1=7;若要rw-属性则4+2=6;若要r-x属性则4+1=5。 常用修改权限的命令: Set_perm 0 0 0600 ××× (只有所有者有读和写的权限) Set_perm 0 0 0644 ××× (所有者有读和写的权限,组用户只有读的权限) Set_perm 0 0 0700 ××× (只有所有者有读和写以及执行的权限) Set_perm 0 0 0666 ××× (每个人都有读和写的权限) Set_perm 0 0 0777 ××× (每个人都有读和写以及执行的权限)
函数名称: set_perm_recursive 函数语法: set_perm_recursive(uid, gid, dirmode, filemode, dir1, dir2, ...dirN) 参数详解: uid----------------------用户ID(user id) Gid----------------------用户组ID(group id) Dirmode----------------指定目录内的目录的权限 Filemode---------------指定目录内的文件的权限 dirX---------------------要设置权限的目标 作用解释: 设置单个目录或一系列目录的里面的所有文件的权限,最少指定1个目录,5个参数都是必须的 函数示例: set_perm_recursive 0 0 0755 0644 SYSTEM:app;设置手机system/app文件夹及其中文件的用户为root,用户组为root,app文件夹权限为所有者可以进行读、写、执行操作,其他用户可以进行读取和执行操作,其中的文件的权限为所有者可以进行读写操作,其他用户可以进行读取操作
函数名称: getprop 函数语法: getprop(key) 参数详解: key---------------------字符串,想要系统返回的属性 作用解释: 这个函数是用来返指定的属性的值。它是用来从build.props文件中查询手机的信息的。 函数示例:
函数名称: write_raw_image 函数语法: write_raw_image(file, partition) 参数详解: file----------------------字符串,要读取的Img源文件 Partition-----------------字符串,要写入Img文件的目标分区 作用解释: 这个函数是用来写Img文件到分区 函数示例: write_raw_image("/tmp/boot.img", "boot")将yaffs2格式的boot包直接写入boot分区
函数名称: apply_patch 函数语法: apply_patch(srcfile, tgtfile, tgtsha1, tgtsize, sha1_1, patch_1, ..., sha1_x, patch1_x) 参数详解: srcfile-------------------字符串,要打补丁的源文件(要读入的文件) Tgtfile-------------------字符串,补丁文件要写入的目标文件 tgtsha1-----------------字符串,写入补丁文件的目标文件的sha1哈希值 sha1_x------------------字符串,要写入目标文件的补丁数据的sha1哈希值 patch1_x----------------字符串,实际上应用到目标文件的补丁 作用解释: 这个函数是用来打补丁到文件。 函数示例:
函数名称: apply_patch_check 函数语法: apply_patch_check(file, sha1_1, ..., sha1_x) 参数详解: file----------------------字符串,要检查的文件 sha1_x------------------要检查的哈希值 作用解释: 检查文件是否已经被打补丁,或者能不能被打补丁。需要检查“applypatch_check ”函数调用的源代码。 函数示例:
函数名称: apply_patch_space 函数语法: apply_patch_space(bytes) 参数详解: bytes-------------------检查的字节的数字 作用解释: 检查缓存来确定是否有足够的空间来写入补丁文件并返回一些数据。 函数示例:
函数名称: read_file 函数语法: read_file(filename) 参数详解: filename----------------字符串,要读取内容的文件名 作用解释: 这个函数返回文件的内容 函数示例:
函数名称: sha1_check 函数语法: sha1_check(data) 或 sha1_check(data, sha1_hex, ..., sha1_hexN) 参数详解: data---------------------要计算sha1哈希值的文件的内容-必须是只读文件格式 sha1_hexN--------------文件数据要匹配的特定的十六进制sha1_hex哈希值字符串 作用解释: 如果只指定data参数,这个函数返回data参数的十六进制sha1_hex哈希值字符串。其他参数用来确认你检查的文件是不是列表中的哈希值的一个。 它返回匹配的哈希值,或者在没有匹配任何哈希值时返回空。
函数示例:
函数名称: ui_print 函数语法: ui_print(msg1, ..., msgN) 参数详解: msg----------------------字符串,要处理过程中输出给用户的信息 作用解释: 在脚本运行的时候,在控制台显示的信息。最少要指定1个参数,你可以指定额外的msg参数,并且它们会连接起来输了 函数示例: ui_print("It's ready!");屏幕打印It's ready!
函数名称: run_program 函数语法: run_program(prog, arg1, .., argN) 参数详解: prog--------------------字符串,要执行的程序 argN--------------------字符串,要执行的程序的运行参数 作用解释: 以指定的参执行程序 函数示例: run_program("/system/xbin/installbusybox.sh");运行installbusybox.sh脚本文件
函数名称: ifelse 函数语法: ifelse(condition, truecondition, falsecondition) 参数详解: condition----------------要运算的表达式 Truecondition-----------当值为True时执行的 Edify脚本块 Falsecodnition-----------当值为False时执行的 Edify脚本块 作用解释: 这是If-then结构的 Edify脚本语言。在真条件或非条件下语句可以是单条Edify命令或者脚本块。脚本块可以用圆括号来界定,用分号来隔开。 函数示例:
函数名称: abort 函数语法: abort() 参数详解: 没有参数 作用解释: 中止脚本执行 函数示例:
函数名称: assert 函数语法: assert(condition) 参数详解: condition---------------boolean 作用解释: 如果condition参数的计算结果为False,则停止脚本执行,否则继续执行脚本 函数示例: assert(package_extract_file("boot.img","/tmp/boot.img"),write_raw_image("/tmp/boot.img","boot"),delete("/tmp/boot.img")) 执行package_extract_file,如果不返回错误则执行write_raw_image,如果write_raw_image不出错则执行delete
|
|
相关推荐
`updater-script`是一种用于定制固件更新流程的脚本语言,主要用于Android系统的OTA(Over-the-Air)升级过程中。它通过一系列预定义的命令来控制更新过程中的文件挂载、格式化、权限设置等操作。本文将详细介绍`...
【updater-script自制升级包】是一种在Android系统中进行自定义升级的方法,它涉及到Android系统的更新机制和脚本语言的应用。updater-script是Android刷机过程中执行的一段控制脚本,用于指导系统如何处理更新包中...
本文档所描述的updater-script脚本是基于Android开源项目(AOSP)环境下的一些基础操作,如果设备使用的不是AOSP系统或者有特殊的定制化,可能需要额外的处理或调整脚本内容以适应特定的设备环境。在开发和使用...
"Android_ROM_刷机脚本_updater-script_的基本流程和初级语句说明" Android ROM 刷机脚本 updater-script 的基本流程和初级语句说明是 Android ROM 刷机的核心内容之一。刷机脚本的主要作用是指导刷机的整个过程,...
pojo-updater-compile Android apt plugin for pojo-updater License Copyright 2015 杭州树洞网络科技有限公司 Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file ...
"updater-0.2.5-py3-none-any.whl" 是一个针对Python开发的特定版本库,名为"updater",版本号为0.2.5。这个库通常是一个已经打包好的可安装文件,它采用whl(Wheel)格式,这是一种预编译的Python包格式,旨在简化...
最后,`Android系统Recovery工作原理之使用update.zip升级过程分析(九)---updater-script脚本语法简介以及执行流程.docx`文档对`updater-script`的语法和执行流程做了介绍,这对于理解Recovery如何按照脚本指令...
更新脚本-Linux 这是一个更新,升级和自动删除Linux软件包的简单脚本。 该脚本支持yum,apt和dnf软件包管理器。 警告:此脚本使用SUDO命令,然后需要root特权,并使用APT,YUM和/或DNF。 注意自动删除,因为此命令...
《Python库foreman-dlm-updater-0.0.2:深入解析与应用》 在IT行业中,Python作为一门简洁高效、易于学习的编程语言,受到了广大开发者的热烈追捧。而Python库则扮演着扩展其功能、提升开发效率的重要角色。今天...
标题中的"PyPI 官网下载 | updater-0.1.14-py3-none-any.whl"表明我们正在讨论的是一个从PyPI官方获取的Python库的特定版本,即`updater`库的0.1.14版。 描述中提到"资源来自pypi官网,解压后可用",这暗示我们下载...
htc one m7 刷机脚本 META-INF\com\google\android\
《Updater-源码》分析与探索 在信息技术领域,源码是软件开发的核心,它揭示了程序运行的底层逻辑和实现细节。本篇文章将深入探讨《Updater-源码.rar》这个压缩包文件中的内容,旨在解析Updater的源代码,帮助读者...
"ais-commons-infrastructure.zip" 就是一个这样的开源项目,其主要包含的子项目是 "nuiton-updater-3.0-alpha-1.zip",这是一个用于更新管理的组件,专为ais-commons-infrastructure提供服务。 ais-commons-...
资源来自pypi官网。 资源全名:updater-0.2.5-py3-none-any.whl
在解压的"Cabal-online-updater-master"文件夹中,我们可以找到项目的主要组成部分,包括源代码文件(.cpp和.h)、资源文件(如图标和配置文件)以及编译脚本。源码通常分为以下几个关键模块: 1. 更新检查模块:...
python库。 资源全名:kali_source_updater-1.0-py3-none-any.whl
updater-script 的语法规则 updater-script 支持多种语法结构,用于定义不同的操作: - `package("path/to/file")`: 指定要升级的文件路径。 - `delete("/system/app/UnwantedApp.apk")`: 删除指定文件。 - `copy...
You just point it to the zip you want to flash, (be it a kernel, a mod, gapps...) and it will interpret the updater-script of this package and install its content just like a recovery would. ...