- if (dev->is_dvd()) {
- char ed1[50], ed2[50];
- if (dev->VolCatInfo.VolCatBytes == dev->part_start + dev->part_size) {
- Jmsg(jcr, M_INFO, 0, _("Ready to append to end of Volume \"%s\""
- " part=%d size=%s\n"), dcr->VolumeName,
- dev->part, edit_uint64(dev->VolCatInfo.VolCatBytes,ed1));
- } else {
- Jmsg(jcr, M_ERROR, 0, _("I cannot write on DVD Volume \"%s\" because: "
- "The sizes do not match! Volume=%s Catalog=%s\n"),
- dcr->VolumeName,
- edit_uint64(dev->part_start + dev->part_size, ed1),
- edit_uint64(dev->VolCatInfo.VolCatBytes, ed2));
- mark_volume_in_error(dcr);
- goto mount_next_vol;
- }
- } else if (dev->is_tape()) {
- /*
- * Check if we are positioned on the tape at the same place
- * that the database says we should be.
- */
- if (dev->VolCatInfo.VolCatFiles == dev->get_file()) {
- Jmsg(jcr, M_INFO, 0, _("Ready to append to end of Volume \"%s\" at file=%d.\n"),
- dcr->VolumeName, dev->get_file());
- } else {
- Jmsg(jcr, M_ERROR, 0, _("I cannot write on tape Volume \"%s\" because:\n"
- "The number of files mismatch! Volume=%u Catalog=%u\n"),
- dcr->VolumeName, dev->get_file(), dev->VolCatInfo.VolCatFiles);
- mark_volume_in_error(dcr);
- goto mount_next_vol;
- }
- } else if (dev->is_file()) {
- char ed1[50], ed2[50];
- boffset_t pos;
- pos = dev->lseek(dcr, (boffset_t)0, SEEK_END);
- if (dev->VolCatInfo.VolCatBytes == (uint64_t)pos) {
- Jmsg(jcr, M_INFO, 0, _("Ready to append to end of Volume \"%s\""
- " size=%s\n"), dcr->VolumeName,
- edit_uint64(dev->VolCatInfo.VolCatBytes, ed1));
- } else {
- Jmsg(jcr, M_ERROR, 0, _("I cannot write on disk Volume \"%s\" because: "
- "The sizes do not match! Volume=%s Catalog=%s\n"),
- dcr->VolumeName,
- edit_uint64(pos, ed1),
- edit_uint64(dev->VolCatInfo.VolCatBytes, ed2));
- mark_volume_in_error(dcr);
- goto mount_next_vol;
- }