cfg = tools.config.load(args)
args.arch = helpers.arch.host()
cfg["waydroid"]["arch"] = args.arch
+
+ preinstalled_images = tools.config.defaults["preinstalled_images_path"]
+ if not args.images_path:
+ if os.path.isdir(preinstalled_images):
+ if os.path.isfile(preinstalled_images + "/system.img") and os.path.isfile(preinstalled_images + "/vendor.img"):
+ args.images_path = preinstalled_images
+ else:
+ logging.error("Missing system or vendor on preinstalled images dir, fallback to default")
+ if not args.images_path:
+ args.images_path = tools.config.defaults["images_path"]
cfg["waydroid"]["images_path"] = args.images_path
channels_cfg = tools.config.load_channels()
"/waydroid_" + args.arch + "/" + args.system_type + ".json"
system_request = requests.get(args.system_ota)
if system_request.status_code != 200:
- raise ValueError(
- "Failed to get system OTA channel: {}".format(args.system_ota))
+ if args.images_path != preinstalled_images:
+ raise ValueError(
+ "Failed to get system OTA channel: {}".format(args.system_ota))
+ else:
+ args.system_ota = "None"
device_codename = helpers.props.host_get(args, "ro.product.device")
args.vendor_type = None
break
if not args.vendor_type:
- raise ValueError(
- "Failed to get vendor OTA channel: {}".format(vendor_ota))
+ if args.images_path != preinstalled_images:
+ raise ValueError(
+ "Failed to get vendor OTA channel: {}".format(vendor_ota))
+ else:
+ args.vendor_ota = "None"
+ args.vendor_type = get_vendor_type(args)
cfg["waydroid"]["vendor_type"] = args.vendor_type
cfg["waydroid"]["system_ota"] = args.system_ota
logging.info("Stopping container")
helpers.lxc.stop(args)
helpers.images.umount_rootfs(args)
- helpers.images.get(args)
+ if args.images_path != tools.config.defaults["preinstalled_images_path"]:
+ helpers.images.get(args)
if not os.path.isdir(tools.config.defaults["rootfs"]):
os.mkdir(tools.config.defaults["rootfs"])
helpers.lxc.setup_host_perms(args)
helpers.images.umount_rootfs(args)
helpers.drivers.loadBinderNodes(args)
if not args.offline:
- helpers.images.get(args)
+ if args.images_path != tools.config.defaults["preinstalled_images_path"]:
+ helpers.images.get(args)
helpers.lxc.setup_host_perms(args)
helpers.lxc.set_lxc_config(args)
helpers.lxc.make_base_props(args)
"work": "/home/.waydroid",
"vendor_type": "MAINLINE",
"system_datetime": "0",
- "vendor_datetime": "0"
+ "vendor_datetime": "0",
+ "preinstalled_images_path": "/usr/share/waydroid-extra/images"
}
defaults["images_path"] = defaults["work"] + "/images"
defaults["rootfs"] = defaults["work"] + "/rootfs"
ret = subparser.add_parser("init", help="set up waydroid specific"
" configs and install images")
ret.add_argument("-i", "--images_path",
- default=tools.config.defaults["images_path"],
help="custom path to waeiod images (default in"
" /home/.waydroid/images)")
ret.add_argument("-f", "--force", action="store_true",