diff options
author | A. Wilcox <AWilcox@Wilcox-Tech.com> | 2019-11-01 20:28:11 -0500 |
---|---|---|
committer | A. Wilcox <AWilcox@Wilcox-Tech.com> | 2019-11-01 20:28:11 -0500 |
commit | 810000aff2404c2e602217fdd8ed2a2448a48133 (patch) | |
tree | a8b66d8a3b5261df056401d3fa4122213b0b1d5d /hscript | |
parent | a0359c1d388ef1e5d3e3ac3e20bf52a1c8da89cb (diff) | |
download | horizon-810000aff2404c2e602217fdd8ed2a2448a48133.tar.gz horizon-810000aff2404c2e602217fdd8ed2a2448a48133.tar.bz2 horizon-810000aff2404c2e602217fdd8ed2a2448a48133.tar.xz horizon-810000aff2404c2e602217fdd8ed2a2448a48133.zip |
hscript: Implement Partition::execute, as yet untested
Diffstat (limited to 'hscript')
-rw-r--r-- | hscript/disk.cc | 80 |
1 files changed, 78 insertions, 2 deletions
diff --git a/hscript/disk.cc b/hscript/disk.cc index 0d332a7..31143cc 100644 --- a/hscript/disk.cc +++ b/hscript/disk.cc @@ -452,8 +452,84 @@ bool Partition::validate(ScriptOptions opts) const { return true; } -bool Partition::execute(ScriptOptions) const { - return false; +bool Partition::execute(ScriptOptions opts) const { + if(opts.test(Simulate)) { + output_error("installfile:" + std::to_string(this->lineno()), + "partition: Not supported in Simulation mode"); + return false; + } + +#ifdef HAS_INSTALL_ENV + PedDevice *dev = ped_device_get(this->device().c_str()); + if(dev == nullptr) { + output_error("installfile:" + std::to_string(this->lineno()), + "partition: error opening device " + this->device()); + return false; + } + + PedDisk *disk = ped_disk_new(dev); + if(disk == nullptr) { + output_error("installfile:" + std::to_string(this->lineno()), + "partition: error reading device " + this->device()); + return false; + } + + int last = ped_disk_get_last_partition_num(disk); + + /* no partitions = 0 partitions */ + if(last == -1) last = 0; + + if(last != (this->partno() - 1)) { + output_error("installfile:" + std::to_string(this->lineno()), + "partition: consistency error on " + this->device(), + "Partition #" + std::to_string(this->partno()) + + " has been requested, but the disk has " + + std::to_string(last) + " partitions"); + ped_disk_destroy(disk); + return false; + } + + PedPartition *before, *me; + PedSector start = 0; + PedSector size; + if(last > 0) { + before = ped_disk_get_partition(disk, last); + if(before == nullptr) { + output_error("installfile:" + std::to_string(this->lineno()), + "partition: error reading partition table on " + + this->device()); + ped_disk_destroy(disk); + return false; + } + start = before->geom.end + 1; + } + + switch(this->size_type()) { + case SizeType::Bytes: + size = static_cast<int64_t>(this->size()) / dev->sector_size; + break; + case SizeType::Percent: + size = dev->length * (this->size() / 100.0); + break; + case SizeType::Fill: + size = dev->length - start; + break; + } + + me = ped_partition_new(disk, PED_PARTITION_NORMAL, nullptr, + start, start + size); + if(me == nullptr) { + output_error("installfile:" + std::to_string(this->lineno()), + "partition: error creating partition on " + + this->device()); + ped_disk_destroy(disk); + return false; + } + + ped_disk_add_partition(disk, me, ped_constraint_any(dev)); + ped_disk_destroy(disk); +#endif /* HAS_INSTALL_ENV */ + return true; } |