API cleanup, be less strict with file name arguments.
diff --git a/lib/zip_set_file_comment.c b/lib/zip_set_file_comment.c
index 0621ad2..654c64f 100644
--- a/lib/zip_set_file_comment.c
+++ b/lib/zip_set_file_comment.c
@@ -41,77 +41,7 @@
 
 
 ZIP_EXTERN int
-zip_set_file_comment(struct zip *za, zip_uint64_t idx,
-		     const char *comment, int len)
+zip_set_file_comment(struct zip *za, zip_uint64_t idx, const char *comment, int len)
 {
-    struct zip_entry *e;
-    struct zip_string *cstr;
-    struct zip_dirent *de;
-    enum zip_encoding_type com_enc, name_enc;
-    int changed;
-
-    if ((de=_zip_get_dirent(za, idx, 0, NULL)) == NULL)
-	return -1;
-
-    if (ZIP_IS_RDONLY(za)) {
-	_zip_error_set(&za->error, ZIP_ER_RDONLY, 0);
-	return -1;
-    }
-
-    if (len < 0 || len > MAXCOMLEN
-	|| (len > 0 && comment == NULL)) {
-	_zip_error_set(&za->error, ZIP_ER_INVAL, 0);
-	return -1;
-    }
-
-    if (len > 0) {
-	if ((cstr=_zip_string_new((const zip_uint8_t *)comment, len, &za->error)) == NULL)
-	    return -1;
-
-	if ((com_enc=_zip_guess_encoding(cstr, ZIP_ENCODING_UTF8_KNOWN)) == ZIP_ENCODING_ERROR) {
-	    _zip_string_free(cstr);
-	    _zip_error_set(&za->error, ZIP_ER_INVAL, 0);
-	    return -1;
-	}
-    }
-    else {
-	cstr = NULL;
-	com_enc = ZIP_ENCODING_ASCII;
-    }
-
-    name_enc = _zip_guess_encoding(de->filename, ZIP_ENCODING_UNKNOWN);
-
-    if (name_enc == ZIP_ENCODING_CP437 && com_enc == ZIP_ENCODING_UTF8_KNOWN) {
-	_zip_error_set(&za->error, ZIP_ER_ENCMISMATCH, 0);
-	return -1;
-    }
-
-    e = za->entry+idx;
-
-    if (e->changes) {
-	_zip_string_free(e->changes->comment);
-	e->changes->comment = NULL;
-	e->changes->changed &= ~ZIP_DIRENT_COMMENT;
-    }
-
-    if (e->orig && e->orig->comment)
-	changed = !_zip_string_equal(e->orig->comment, cstr);
-    else
-	changed = (cstr != NULL);
-	
-    if (changed) {
-	if (e->changes == NULL)
-	    e->changes = _zip_dirent_clone(e->orig);
-	e->changes->comment = cstr;
-	e->changes->changed |= ZIP_DIRENT_COMMENT;
-    }
-    else {
-	_zip_string_free(cstr);
-	if (e->changes && e->changes->changed == 0) {
-	    _zip_dirent_free(e->changes);
-	    e->changes = NULL;
-	}
-    }
-
-    return 0;
+    return zip_file_set_comment(za, idx, comment, len, 0);
 }