对于很多狂热于刷机爱好的机友们来说最高的追求就是自制刷机包,那么自制刷机包最重要的不是程序的内置收集,也不是美化或者精简,最重要的是对于刷机包的刷机脚本的编写,鉴于很多同学想学却又找不到资料,今天拉拉果断决定给大家分享一份自己收集整理的刷机脚本函数释义教程。

例如: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代表用户为root2000代表用户组为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

不得不说,编写刷机脚本还是需要一定的基础知识来领悟的。如果对此类事件比较好奇的话可以去看一些编程方面的书。因为程序的逻辑性和依附性都比较高,并不是每个普通人都可以做到的。

android 刷机 zip,安卓自制zip刷机包 zip包刷机脚本函数详细例举教程相关推荐

  1. android root工具twrp,安卓手机没有twrp的情况,如何下刷入magisk并获得root权限.

    安装adb工具 从以上地址下载,然后解压到任意目录(例如C:\adb). 将此目录添加到windows环境变量path中. 在cmd中输入adb, fastboot等命令,如果"显示&quo ...

  2. 360手机 360手机刷机最高安卓版本参考

    360手机 360手机刷机最高安卓版本参考 参考:360手机-360刷机360刷机包twrp.root 360刷机包360手机刷机:360rom.github.io [360手机(最高)安卓版本] 以 ...

  3. android 5.0 刷机教程,一加手机怎么升级安卓5.0系统?一加手机刷Android 5.0教程

    谷歌今天正式发布了最新的安卓5.0正式版,作为一次非常大的系统升级,安卓5.0带来了非常多明显的升级,体验上相比安卓4.4要精进不少.在众多手机纷纷向Android 5.0发起冲击之时,日一加手机官方 ...

  4. android rom 刷数据吗,安卓手机如何刷入rom包 安卓机刷入rom包方法

    安卓机刷入rom包方法流程: 一.鉴别ROM包是卡刷还是线刷包 想要刷机最先当然是要下载一个ROM包,那么在下载之前应该搞清楚刷机包是线刷还是卡刷包.一般在下载的时候作者都会标注ROM包是使用线刷还是 ...

  5. 刷原生android 8.0,怎样刷入安卓原生系统 小米古董机刷完安卓8.0健步如飞!感觉比MIUI9还快...

    原标题:小米古董机刷完安卓8.0健步如飞!感觉比MIUI9还快 小米2S算是小米手机史上的一代神机,雷布斯当年主持发布会时,更是激动说出了"小米2S性能屌爆了"的经典语句.怎样刷入 ...

  6. Android手机刷入Windows,Windows手机刷成安卓 第二款神机诞生

    中关村在线消息:相信大家一定对HTC HD2不陌生,被称为刷机神器,可以刷Windows系统.安卓2.3-6.0,Ubuntu手机系统等.不过今天,诺基亚的一款手机"继承"了HD2 ...

  7. 小米 mix2 android,小米MIX2|crDroid|安卓11.0|超多定义|清新流畅|超高跑分|酷爽唯美|极力推荐-刷机之家...

    详情 小米MIX2|crDroid|安卓11.0|超多定义|清新流畅|超高跑分|酷爽唯美|极力推荐下载地址分享,4月最新版本crDroid原生首选类刷机包,新增添了很多实用的功能,具有安卓11系统的特 ...

  8. android版本不一样可以刷机嘛,安卓手机怎么刷系统?不用软件直接刷手机系统图解...

    一般新买的手机如果用的时候觉得挺好,那就不用刷机了,也不要太在意网上的评论,使用因人而异.但玩机的人都爱刷机,那是因为能删除系统没用的软件,解放系统更多的空间,有更多的机会按照自己的意愿对系统进行优化 ...

  9. 魅族16th操作系统android,魅族16th|crDroid|安卓11.0|超多定义|清新流畅|超高跑分|酷爽唯美|极力推荐-刷机之家...

    详情 魅族16th|crDroid|安卓11.0|超多定义|清新流畅|超高跑分|酷爽唯美|极力推荐下载地址分享,具有crDroid原生首选系统的刷机包,添加了很多实用的新功能,整个系统清新流畅超级好用 ...

最新文章

  1. FPGA在人工智能时代的独特优势
  2. SLAM:VSLAM简介之详细攻略
  3. socket编程 (PHP实现)
  4. jquery右键菜单
  5. Alictf 2015决赛题目设计和解题思路
  6. C语言(CED)输出前k大的数(分治法/局部快速排序):给定一个数组,统计前k大的数并且把这k个数从大到小输出。
  7. MATLAB每个字母等宽,等宽文本文件的导入选项对象
  8. 客户价值分析—RFM模型及变形
  9. eclipse中编译java_eclipse编译java文件
  10. OpenCV3.1.0安装在ubuntu16.40(Linux)步骤(电赛AM5708板子可用)
  11. 用 VS2005 类设计器设计类
  12. 伯禹 动手学深度学习 打卡08 之 深度卷积神经网络(AlexNet)
  13. python目标识别_10行Python代码实现目标检测
  14. Musixtex写五线谱
  15. 【嵌入式烧录/刷写文件】-5.1-详解map格式文件
  16. For循环的简单实例
  17. PHOTOSHOP基本概念解释【转】
  18. 二叉树转树(数据结构)(图解)
  19. 人机交互——人机交互设备
  20. 华为OD机试 - 网上商城优惠活动(Java JS Python)

热门文章

  1. 全球及中国融媒体行业建设发展机遇及运营前景调研报告2021-2027年
  2. Android 多启动图标icon,多启动页面
  3. java gps轨迹_记录 GPS 轨迹 LogGPS
  4. Android程序员面试必备的知识点,Android程序员
  5. pboot 将编码转换为实体html_PbootCms在模板中对定制标签中的内容进行二次处理
  6. 华星充电:什么是新能源充电桩
  7. 日志特征选择汇总(基于天池比赛)
  8. 2021-02-17
  9. (Java)类的接口实验
  10. 机器翻译 MXNet(使用含注意力机制的编码器—解码器,即 Encoder编码器-Decoder解码器框架 + Attention注意力机制)