assert(getprop("ro.product.device") == "TP1803" || getprop("ro.build.product") == "TP1803" || abort("E3004: This package is for device: TP1803; this device is " + getprop("ro.product.device") + "."););
ui_print("Target: Nubia/lineage_TP1803/TP1803:15/BP1A.250505.005/3a65f3a168:userdebug/release-keys");
package_extract_dir("install", "/tmp/install");
set_metadata_recursive("/tmp/install", "uid", 0, "gid", 0, "dmode", 0755, "fmode", 0644);
set_metadata_recursive("/tmp/install/bin", "uid", 0, "gid", 0, "dmode", 0755, "fmode", 0755);
map_partition("vendor");
map_partition("product");
map_partition("system_ext");
run_program("/tmp/install/bin/backuptool.sh", "backup", map_partition("system"), "ext4");

# --- Start patching dynamic partitions ---


# Update dynamic partition metadata

assert(update_dynamic_partitions(package_extract_file("dynamic_partitions_op_list"), package_extract_file("unsparse_super_empty.img")));

# Patch partition system

ui_print("Patching system image unconditionally...");
show_progress(0.500000, 0);
block_image_update(map_partition("system"), package_extract_file("system.transfer.list"), "system.new.dat.br", "system.patch.dat") ||
  abort("E1001: Failed to update system image.");

# Patch partition vendor

ui_print("Patching vendor image unconditionally...");
show_progress(0.100000, 0);
block_image_update(map_partition("vendor"), package_extract_file("vendor.transfer.list"), "vendor.new.dat.br", "vendor.patch.dat") ||
  abort("E2001: Failed to update vendor image.");

# Patch partition product

ui_print("Patching product image unconditionally...");
show_progress(0.100000, 0);
block_image_update(map_partition("product"), package_extract_file("product.transfer.list"), "product.new.dat.br", "product.patch.dat") ||
  abort("E2001: Failed to update product image.");

# Patch partition odm

ui_print("Patching odm image unconditionally...");
show_progress(0.100000, 0);
block_image_update(map_partition("odm"), package_extract_file("odm.transfer.list"), "odm.new.dat.br", "odm.patch.dat") ||
  abort("E2001: Failed to update odm image.");

# Patch partition system_ext

ui_print("Patching system_ext image unconditionally...");
show_progress(0.100000, 0);
block_image_update(map_partition("system_ext"), package_extract_file("system_ext.transfer.list"), "system_ext.new.dat.br", "system_ext.patch.dat") ||
  abort("E2001: Failed to update system_ext image.");

# --- End patching dynamic partitions ---

show_progress(0.020000, 10);
map_partition("vendor");
map_partition("product");
map_partition("system_ext");
run_program("/tmp/install/bin/backuptool.sh", "restore", map_partition("system"), "ext4");
package_extract_file("boot.img", "/dev/block/bootdevice/by-name/boot");
show_progress(0.100000, 10);
ui_print("Patching dtbo image unconditionally...");
package_extract_file("dtbo.img", "/dev/block/bootdevice/by-name/dtbo");
ui_print("Patching vbmeta image unconditionally...");
package_extract_file("vbmeta.img", "/dev/block/bootdevice/by-name/vbmeta");
ui_print("Patching abl image unconditionally...");
package_extract_file("abl.img", "/dev/block/bootdevice/by-name/abl");
ui_print("Patching aop image unconditionally...");
package_extract_file("aop.img", "/dev/block/bootdevice/by-name/aop");
ui_print("Patching bluetooth image unconditionally...");
package_extract_file("bluetooth.img", "/dev/block/bootdevice/by-name/bluetooth");
ui_print("Patching cmnlib image unconditionally...");
package_extract_file("cmnlib.img", "/dev/block/bootdevice/by-name/cmnlib");
ui_print("Patching cmnlib64 image unconditionally...");
package_extract_file("cmnlib64.img", "/dev/block/bootdevice/by-name/cmnlib64");
ui_print("Patching devcfg image unconditionally...");
package_extract_file("devcfg.img", "/dev/block/bootdevice/by-name/devcfg");
ui_print("Patching dsp image unconditionally...");
package_extract_file("dsp.img", "/dev/block/bootdevice/by-name/dsp");
ui_print("Patching hyp image unconditionally...");
package_extract_file("hyp.img", "/dev/block/bootdevice/by-name/hyp");
ui_print("Patching imagefv image unconditionally...");
package_extract_file("imagefv.img", "/dev/block/bootdevice/by-name/imagefv");
ui_print("Patching keymaster image unconditionally...");
package_extract_file("keymaster.img", "/dev/block/bootdevice/by-name/keymaster");
ui_print("Patching multiimgoem image unconditionally...");
package_extract_file("multiimgoem.img", "/dev/block/bootdevice/by-name/multiimgoem");
ui_print("Patching modem image unconditionally...");
package_extract_file("modem.img", "/dev/block/bootdevice/by-name/modem");
ui_print("Patching parameter image unconditionally...");
package_extract_file("parameter.img", "/dev/block/bootdevice/by-name/parameter");
ui_print("Patching qupfw image unconditionally...");
package_extract_file("qupfw.img", "/dev/block/bootdevice/by-name/qupfw");
ui_print("Patching splash image unconditionally...");
package_extract_file("splash.img", "/dev/block/bootdevice/by-name/splash");
ui_print("Patching storsec image unconditionally...");
package_extract_file("storsec.img", "/dev/block/bootdevice/by-name/storsec");
ui_print("Patching tz image unconditionally...");
package_extract_file("tz.img", "/dev/block/bootdevice/by-name/tz");
ui_print("Patching uefisecapp image unconditionally...");
package_extract_file("uefisecapp.img", "/dev/block/bootdevice/by-name/uefisecapp");
ui_print("Patching xbl image unconditionally...");
package_extract_file("xbl.img", "/dev/block/bootdevice/by-name/xbl");
ui_print("Patching xbl_config image unconditionally...");
package_extract_file("xbl_config.img", "/dev/block/bootdevice/by-name/xbl_config");
set_progress(1.000000);
