当前位置: 首页>移动开发>正文

reboot update reboot updater

Android系统recovery刷机脚本updater-script语法说明
这篇教程部分说明来源于网络,主要为了让大家了解updater-script语法和使用,以及熟悉权限的定义和如何使用

unmount 

 
•  unmount(mount_point);
•  mount_point---是mount设置产生的值。作用与挂载相对应,卸载分区或设备。此函数与mount配套使用。
•  unmount("/system");   卸载/system分区
• 复制代码
•  format(type, location);
•  type="MTD"  location=partition(分区),location参数代表分区。
•  format("MTD", "system");  格式化system分区
• 复制代码
•  mount(type, location, mount_point);
•  type="MTD"   location="" 挂载yaffs2文件系统分区;type="vfat"  location="/dev/block/"  挂载设备。
•  mount("MTD", "system", "/system");         挂载system分区,返回值"/system”
•  mount("ext4", "/dev/block/mmcblk1p2", "/system");     挂载/dev/block/mmcblk1p2,返回值"/system”/system分区格式为ext4
•  mount("vfat", "/dev/block/mmcblk1p2", "/system");     挂载/dev/block/mmcblk1p2,返回值"/system”/system分区格式为vfat
• 复制代码
•  delete();删除文件
•  delete("/data/zipalign.log");    删除文件/data/zipalign.log
• 复制代码
•  delete_recursive();删除文件夹
•  delete_recursive("/data/dalvik-cache");删除文件夹/data/dalvik-cache
• 复制代码
•  show_progress(,);为下面进行的程序操作显示进度条,进度条会根据设置的参数前进
•  show_progress(0.1, 10);show_progress下面的操作可能进行10s,完成后进度条前进0.1(也就是10%)
• 复制代码
•  package_extract_dir(package_path, destination_path);解压package_path文件夹到destination_path目录
•  package_extract_dir("system", "/system");  解压ROM包里system文件夹下所有文件和子文件夹至/system目录
• 复制代码
•  package_extract_file(package_path, destination_path);解压package_path文件到destination_path目录
•  package_extract_dir("my.zip", "/system");  解压ROM包里的my.zip文件到/system目录
• 复制代码
•  symlink(...);建立指向target符号链接src1,src2,也就是软链接
•  symlink("toolbox", "/system/bin/ps");建立指向toolbox的符号链接/system/bin/ps
• 复制代码
•  set_perm(...);设置文件的用户为uid,用户组为gid,权限为mode
•  set_perm(1002, 1002, 0440, "/system/etc/dbus.conf");  设置文件/system/etc/dbus.conf的所有者为1002,所属用户组为1002,权限为:所有者有读权限,所属用户组有读权限,其他无任何权限。
  • 复制代码

【语法】set_perm(<uid>,<gid>,<mode>, "<path>"); 
   
 <uid>表示用户名称 
   
 <gid>表示用户组名称 
   
 <mode>表示权限模式 
   
 <path> 表示文件路径,可以使多个,用空格隔开  
   
 【作用】设置单个文件或目录的所有者和权限,像linux中的chmod、chown或chgrp命令一样,只是集中在了一个命令当中  
   
 【举例】set_perm(0,2000,0550,"system/etc/init.goldfish.sh")(设置手机system中的etc/init.goldfish.sh的用户为root,用户组为shell,所有者以及所属用户组成员可以进行读取和执行操作,其他用户无操作权限) 
   
 【说明】在此命令中最难明白的是0 2000 0550这几组参数所代表的意思,这是Linux相关的参数 
   
 具体如下: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 ××× (每个人都有读和写以及执行的权限)   
   
 范例 :  
   
 -rw------- (600) -- 只有用户有读写权限。  
   
 -rw-r--r-- (644) -- 只有用户有读写权限;而组用户和其他用户只有读权限。  
   
 -rwx------ (700) -- 只有用户有读、写、执行权限。  
   
 -rwxr-xr-x (755) -- 用户有读、写、执行权限;而组用户和其他用户只有读、执行权限。  
   
 -rwx--x--x (711) -- 用户有读、写、执行权限;而组用户和其他用户只有执行权限。  
   
 -rw-rw-rw- (666) -- 所有用户都有文件读、写权限。这种做法不可取。  
   
 -rwxrwxrwx (777) -- 所有用户都有读、写、执行权限。更不可取的做法。


  • set_perm_recursive(...);设置文件夹和文件夹内文件的权限
  • set_perm_recursive(1000, 1000, 0771, 0644, "/data/app");   设置/data/app的所有者和所属用户组为1000,app文件夹的权限是:所有者和所属组拥有全部权限,其他有执行权限;
  • app文件夹下的文件权限是:所有者有读写权限,所属组有读权限,其他有读权限。
  • 复制代码

【语法】set_perm_recursive <uid> <gid> <dir-mode> <file-mode> <path> [...<pathN>] 
   
 <uid>表示用户,<gid>表示用户组,<dir-mode>表示文件夹的权限,<file-mode>表示文件的权限,<path> [... <pathN>]表示文件夹的路径,可以多个,用空格分开  
   
 【作用】设置文件夹及文件夹中的文件的所有者和用户组  
   
 【说明】其中<dir-mode> <file-mode>分别代表目录和file的权限,具体参数如上述  
   
 【举例】set_perm_recursive 0 0 0755 0644 SYSTEM:app(设置手机system/app文件夹及其中文件的用户为root,用户组为root,app文件夹权限为所有者可以进行读、写、执行操作,其他用户可以进行读取和执行操作,其中的文件的权限为所有者可以进行读写操作,其他用户可以进行读取操作)  
   
 下面是我们常用的两组修改权限的命令: 
   
 一组是常规程序用RE管理器拷贝到system/app后修改的权限命令如下:  
   
 set_perm(0,0,0644,"/system/app/Calendar.apk");  
   
 一组是我们要移动dalvik-cache到cache过程中拷贝修改mot_boot_mode.bin命令如下: 
   
 set_perm(0,0,0755,"/system/bin");
•  ui_print("pwelyn");屏幕打印输出"pwelyn"
•  ui_print("GR[GreatRom/GfanRom]");    屏幕打印GR[GreatRom/GfanRom]
• 复制代码
•  run_program();运行shell脚本
•  run_program("/system/xbin/installbusybox.sh");    运行installbusybox.sh脚本文件
• 复制代码
•  write_raw_image(, partition);写入至partition分区
•  write_raw_image("/tmp/boot.img", "boot")将boot.img直接写入boot分区
• 复制代码
•  assert(...);如果执行sub1不返回错误则执行sub2,如果sub2不返回错误则执行sub3一次类推。
•  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
• 复制代码
•  run_program("/sbin/sleep", "3");
•  run_program("/sbin/reboot");

https://www.xamrdz.com/mobile/4u31937296.html

相关文章: