| 
									
										
										
										
											2017-05-02 17:35:27 +08:00
										 |  |  | // +build !windows
 | 
					
						
							| 
									
										
										
										
											2016-06-13 17:53:09 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-14 02:32:47 +08:00
										 |  |  | /* | 
					
						
							| 
									
										
										
										
											2017-02-09 14:27:35 +08:00
										 |  |  |  * Minio Cloud Storage, (C) 2016, 2017 Minio, Inc. | 
					
						
							| 
									
										
										
										
											2016-04-14 02:32:47 +08:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Licensed under the Apache License, Version 2.0 (the "License"); | 
					
						
							|  |  |  |  * you may not use this file except in compliance with the License. | 
					
						
							|  |  |  |  * You may obtain a copy of the License at | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *     http://www.apache.org/licenses/LICENSE-2.0
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Unless required by applicable law or agreed to in writing, software | 
					
						
							|  |  |  |  * distributed under the License is distributed on an "AS IS" BASIS, | 
					
						
							|  |  |  |  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
					
						
							|  |  |  |  * See the License for the specific language governing permissions and | 
					
						
							|  |  |  |  * limitations under the License. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-19 07:23:42 +08:00
										 |  |  | package cmd | 
					
						
							| 
									
										
										
										
											2016-04-14 02:32:47 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-29 17:28:46 +08:00
										 |  |  | import "os" | 
					
						
							| 
									
										
										
										
											2016-04-14 02:32:47 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-02 17:35:27 +08:00
										 |  |  | // osStat returns a FileInfo structure describing the named file.
 | 
					
						
							|  |  |  | // If there is an error, it will be of type *PathError.
 | 
					
						
							|  |  |  | func osStat(name string) (os.FileInfo, error) { | 
					
						
							|  |  |  | 	return os.Stat(name) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-13 17:53:09 +08:00
										 |  |  | // isValidVolname verifies a volname name in accordance with object
 | 
					
						
							|  |  |  | // layer requirements.
 | 
					
						
							|  |  |  | func isValidVolname(volname string) bool { | 
					
						
							| 
									
										
										
										
											2016-06-29 17:28:46 +08:00
										 |  |  | 	return !(len(volname) < 3 || len(volname) > 63) | 
					
						
							| 
									
										
										
										
											2016-04-17 03:48:41 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-13 17:53:09 +08:00
										 |  |  | // mkdirAll creates a directory named path,
 | 
					
						
							|  |  |  | // along with any necessary parents, and returns nil,
 | 
					
						
							|  |  |  | // or else returns an error. The permission bits perm are used
 | 
					
						
							|  |  |  | // for all directories that mkdirAll creates. If path is already
 | 
					
						
							|  |  |  | // a directory, mkdirAll does nothing and returns nil.
 | 
					
						
							|  |  |  | func mkdirAll(path string, perm os.FileMode) error { | 
					
						
							|  |  |  | 	return os.MkdirAll(path, perm) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // removeAll removes path and any children it contains.
 | 
					
						
							|  |  |  | // It removes everything it can but returns the first error
 | 
					
						
							|  |  |  | // it encounters.  If the path does not exist, RemoveAll
 | 
					
						
							|  |  |  | // returns nil (no error).
 | 
					
						
							|  |  |  | func removeAll(path string) error { | 
					
						
							|  |  |  | 	return os.RemoveAll(path) | 
					
						
							| 
									
										
										
										
											2016-04-17 03:48:41 +08:00
										 |  |  | } |