qemu-img: Suppress unhelpful extra errors in convert, resize
add_old_style_options() for img_convert() and img_resize() use
qemu_opt_set(), which reports errors with qerror_report_err().  Its
error messages aren't helpful here, the caller reports one that
actually makes sense.  Reproducer:
    $ qemu-img convert -B raw in.img out.img
    qemu-img: Invalid parameter 'backing_file'
    qemu-img: Backing file not supported for file format 'raw'
Switch to qemu_opt_set_err() to get rid of the unwanted messages.
Signed-off-by: Markus Armbruster <armbru@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
			
			
This commit is contained in:
		
							parent
							
								
									79087c782e
								
							
						
					
					
						commit
						6750e795b1
					
				
							
								
								
									
										16
									
								
								qemu-img.c
								
								
								
								
							
							
						
						
									
										16
									
								
								qemu-img.c
								
								
								
								
							| 
						 | 
				
			
			@ -332,17 +332,23 @@ static int add_old_style_options(const char *fmt, QemuOpts *opts,
 | 
			
		|||
                                 const char *base_filename,
 | 
			
		||||
                                 const char *base_fmt)
 | 
			
		||||
{
 | 
			
		||||
    Error *err = NULL;
 | 
			
		||||
 | 
			
		||||
    if (base_filename) {
 | 
			
		||||
        if (qemu_opt_set(opts, BLOCK_OPT_BACKING_FILE, base_filename)) {
 | 
			
		||||
        qemu_opt_set_err(opts, BLOCK_OPT_BACKING_FILE, base_filename, &err);
 | 
			
		||||
        if (err) {
 | 
			
		||||
            error_report("Backing file not supported for file format '%s'",
 | 
			
		||||
                         fmt);
 | 
			
		||||
            error_free(err);
 | 
			
		||||
            return -1;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
    if (base_fmt) {
 | 
			
		||||
        if (qemu_opt_set(opts, BLOCK_OPT_BACKING_FMT, base_fmt)) {
 | 
			
		||||
        qemu_opt_set_err(opts, BLOCK_OPT_BACKING_FMT, base_fmt, &err);
 | 
			
		||||
        if (err) {
 | 
			
		||||
            error_report("Backing file format not supported for file "
 | 
			
		||||
                         "format '%s'", fmt);
 | 
			
		||||
            error_free(err);
 | 
			
		||||
            return -1;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
| 
						 | 
				
			
			@ -2750,6 +2756,7 @@ out:
 | 
			
		|||
 | 
			
		||||
static int img_resize(int argc, char **argv)
 | 
			
		||||
{
 | 
			
		||||
    Error *err = NULL;
 | 
			
		||||
    int c, ret, relative;
 | 
			
		||||
    const char *filename, *fmt, *size;
 | 
			
		||||
    int64_t n, total_size;
 | 
			
		||||
| 
						 | 
				
			
			@ -2821,8 +2828,9 @@ static int img_resize(int argc, char **argv)
 | 
			
		|||
 | 
			
		||||
    /* Parse size */
 | 
			
		||||
    param = qemu_opts_create(&resize_options, NULL, 0, &error_abort);
 | 
			
		||||
    if (qemu_opt_set(param, BLOCK_OPT_SIZE, size)) {
 | 
			
		||||
        /* Error message already printed when size parsing fails */
 | 
			
		||||
    qemu_opt_set_err(param, BLOCK_OPT_SIZE, size, &err);
 | 
			
		||||
    if (err) {
 | 
			
		||||
        error_report_err(err);
 | 
			
		||||
        ret = -1;
 | 
			
		||||
        qemu_opts_del(param);
 | 
			
		||||
        goto out;
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in New Issue