(!less_than_int(1760582621, getprop("ro.build.date.utc"))) || abort("E3003: Can't install this package (Thu Oct 16 11:43:41 KST 2025) over newer build (" + getprop("ro.build.date") + ").");
getprop("ro.product.device") == "odroidm1" || abort("E3004: This package is for \"odroidm1\" devices; this is a \"" + getprop("ro.product.device") + "\".");
ui_print("Target: hardkernel/odroidm1/odroidm1:13/TQ3C.230805.001.B2/61:userdebug/release-keys");

# --- Start patching dynamic partitions ---


# Update dynamic partition metadata

assert(update_dynamic_partitions(package_extract_file("dynamic_partitions_op_list")));

# Patch partition system

ui_print("Patching system image unconditionally...");
show_progress(0.200000, 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.");

# Patch partition vendor_dlkm

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

# Patch partition odm_dlkm

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

# Patch partition system_dlkm

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

# --- End patching dynamic partitions ---

package_extract_file("boot.img", "/dev/block/by-name/boot");
show_progress(0.100000, 10);
ui_print("Writing fat loader img...");
package_extract_file("fat.img", "/dev/block/by-name/fat");
set_progress(1.000000);
