mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-10-31 14:02:25 -05:00 
			
		
		
		
	[chore]: Bump github.com/KimMachineGun/automemlimit from 0.2.4 to 0.2.5 (#1666)
Bumps [github.com/KimMachineGun/automemlimit](https://github.com/KimMachineGun/automemlimit) from 0.2.4 to 0.2.5. - [Release notes](https://github.com/KimMachineGun/automemlimit/releases) - [Commits](https://github.com/KimMachineGun/automemlimit/compare/v0.2.4...v0.2.5) --- updated-dependencies: - dependency-name: github.com/KimMachineGun/automemlimit dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
This commit is contained in:
		
					parent
					
						
							
								3f9b2336c0
							
						
					
				
			
			
				commit
				
					
						57dc742c76
					
				
			
		
					 200 changed files with 16392 additions and 38190 deletions
				
			
		
							
								
								
									
										106
									
								
								vendor/github.com/containerd/cgroups/v3/cgroup1/paths.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										106
									
								
								vendor/github.com/containerd/cgroups/v3/cgroup1/paths.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,106 @@ | |||
| /* | ||||
|    Copyright The containerd Authors. | ||||
| 
 | ||||
|    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. | ||||
| */ | ||||
| 
 | ||||
| package cgroup1 | ||||
| 
 | ||||
| import ( | ||||
| 	"errors" | ||||
| 	"fmt" | ||||
| 	"path/filepath" | ||||
| ) | ||||
| 
 | ||||
| type Path func(subsystem Name) (string, error) | ||||
| 
 | ||||
| func RootPath(subsystem Name) (string, error) { | ||||
| 	return "/", nil | ||||
| } | ||||
| 
 | ||||
| // StaticPath returns a static path to use for all cgroups | ||||
| func StaticPath(path string) Path { | ||||
| 	return func(_ Name) (string, error) { | ||||
| 		return path, nil | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // NestedPath will nest the cgroups based on the calling processes cgroup | ||||
| // placing its child processes inside its own path | ||||
| func NestedPath(suffix string) Path { | ||||
| 	paths, err := ParseCgroupFile("/proc/self/cgroup") | ||||
| 	if err != nil { | ||||
| 		return errorPath(err) | ||||
| 	} | ||||
| 	return existingPath(paths, suffix) | ||||
| } | ||||
| 
 | ||||
| // PidPath will return the correct cgroup paths for an existing process running inside a cgroup | ||||
| // This is commonly used for the Load function to restore an existing container | ||||
| func PidPath(pid int) Path { | ||||
| 	p := fmt.Sprintf("/proc/%d/cgroup", pid) | ||||
| 	paths, err := ParseCgroupFile(p) | ||||
| 	if err != nil { | ||||
| 		return errorPath(fmt.Errorf("parse cgroup file %s: %w", p, err)) | ||||
| 	} | ||||
| 	return existingPath(paths, "") | ||||
| } | ||||
| 
 | ||||
| // ErrControllerNotActive is returned when a controller is not supported or enabled | ||||
| var ErrControllerNotActive = errors.New("controller is not supported") | ||||
| 
 | ||||
| func existingPath(paths map[string]string, suffix string) Path { | ||||
| 	// localize the paths based on the root mount dest for nested cgroups | ||||
| 	for n, p := range paths { | ||||
| 		dest, err := getCgroupDestination(n) | ||||
| 		if err != nil { | ||||
| 			return errorPath(err) | ||||
| 		} | ||||
| 		rel, err := filepath.Rel(dest, p) | ||||
| 		if err != nil { | ||||
| 			return errorPath(err) | ||||
| 		} | ||||
| 		if rel == "." { | ||||
| 			rel = dest | ||||
| 		} | ||||
| 		paths[n] = filepath.Join("/", rel) | ||||
| 	} | ||||
| 	return func(name Name) (string, error) { | ||||
| 		root, ok := paths[string(name)] | ||||
| 		if !ok { | ||||
| 			if root, ok = paths["name="+string(name)]; !ok { | ||||
| 				return "", ErrControllerNotActive | ||||
| 			} | ||||
| 		} | ||||
| 		if suffix != "" { | ||||
| 			return filepath.Join(root, suffix), nil | ||||
| 		} | ||||
| 		return root, nil | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func subPath(path Path, subName string) Path { | ||||
| 	return func(name Name) (string, error) { | ||||
| 		p, err := path(name) | ||||
| 		if err != nil { | ||||
| 			return "", err | ||||
| 		} | ||||
| 		return filepath.Join(p, subName), nil | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func errorPath(err error) Path { | ||||
| 	return func(_ Name) (string, error) { | ||||
| 		return "", err | ||||
| 	} | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue