INT64_T chirp_multi_chmod(const char *volume, const char *path, INT64_T mode, time_t stoptime) { struct file_info info; if(chirp_multi_lookup(volume, path, &info, stoptime)) { return chirp_reli_chmod(info.rhost, info.rpath, mode, stoptime); } else if(errno == EISDIR) { return chirp_reli_chmod(current_volume->host, info.lpath, mode, stoptime); } else { return -1; } }
static INT64_T do_chmod(int argc, char **argv) { char full_path[CHIRP_PATH_MAX]; unsigned mode; sscanf(argv[1], "%o", &mode); complete_remote_path(argv[2], full_path); return chirp_reli_chmod(current_host, full_path, mode, stoptime); }
INT64_T chirp_global_chmod(const char *host, const char *path, INT64_T mode, time_t stoptime) { if(is_multi_path(host)) { char mhost[CHIRP_PATH_MAX]; char mpath[CHIRP_PATH_MAX]; parse_multi_path(path, mhost, mpath); return chirp_multi_chmod(mhost, mpath, mode, stoptime); } else if(not_empty(path)) { return chirp_reli_chmod(host, path, mode, stoptime); } else if(not_empty(host)) { if(server_lookup(host, stoptime)) { errno = EACCES; return -1; } else { errno = ENOENT; return -1; } } else { errno = EACCES; return -1; } }