tools.py
Some utility functions.
Style
¶
Common color styles.
Source code in copier/tools.py
26 27 28 29 30 31 32 33 |
|
cast_to_bool(value)
¶
Parse anything to bool.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
value |
Any
|
Anything to be casted to a bool. Tries to be as smart as possible.
|
required |
Source code in copier/tools.py
112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 |
|
cast_to_str(value)
¶
Parse anything to str.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
value |
Any
|
Anything to be casted to a str. |
required |
Source code in copier/tools.py
96 97 98 99 100 101 102 103 104 105 106 107 108 109 |
|
copier_version()
¶
Get closest match for the installed copier version.
Source code in copier/tools.py
49 50 51 52 53 54 55 56 57 58 59 60 |
|
escape_git_path(path)
¶
Escape paths that will be used as literal gitwildmatch patterns.
If the path was returned by a Git command, it should be unescaped completely.
normalize_git_path
can be used for this purpose.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
path |
str
|
The Git path to escape. |
required |
Returns:
Name | Type | Description |
---|---|---|
str |
str
|
The escaped Git path. |
Source code in copier/tools.py
215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 |
|
force_str_end(original_str, end='\n')
¶
Make sure a original_str
ends with end
.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
original_str |
str
|
String that you want to ensure ending. |
required |
end |
str
|
String that must exist at the end of |
'\n'
|
Source code in copier/tools.py
139 140 141 142 143 144 145 146 147 148 |
|
get_git_objects_dir(path)
¶
Get the absolute path of a Git repository's objects directory.
Source code in copier/tools.py
237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 |
|
handle_remove_readonly(func, path, exc)
¶
Handle errors when trying to remove read-only files through shutil.rmtree
.
On Windows, shutil.rmtree
does not handle read-only files very well. This handler
makes sure the given file is writable, then re-execute the given removal function.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
func |
Callable[[str], None]
|
An OS-dependant function used to remove a file. |
required |
path |
str
|
The path to the file to remove. |
required |
exc |
BaseException | tuple[type[BaseException], BaseException, TracebackType]
|
An exception (Python >= 3.12) or |
required |
Source code in copier/tools.py
151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 |
|
normalize_git_path(path)
¶
Convert weird characters returned by Git to normal UTF-8 path strings.
A filename like âñ will be reported by Git as "\303\242\303\261" (octal notation).
Similarly, a filename like "git config core.quotepath off
.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
path |
str
|
The Git path to normalize. |
required |
Returns:
Name | Type | Description |
---|---|---|
str |
str
|
The normalized Git path. |
Source code in copier/tools.py
191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 |
|
printf(action, msg='', style=None, indent=10, quiet=False, file_=sys.stdout)
¶
Print string with common format.
Source code in copier/tools.py
63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 |
|
printf_exception(e, action, msg='', indent=0, quiet=False)
¶
Print exception with common format.
Source code in copier/tools.py
84 85 86 87 88 89 90 91 92 93 |
|
readlink(link)
¶
A custom version of os.readlink/pathlib.Path.readlink.
pathlib.Path.readlink is what we ideally would want to use, but it is only available on python>=3.9.
Source code in copier/tools.py
177 178 179 180 181 182 183 184 185 |
|
set_git_alternates(*repos, path=Path('.'))
¶
Set Git alternates to borrow Git objects from other repositories.
Alternates are paths of other repositories' object directories written to
$GIT_DIR/objects/info/alternates
and delimited by the newline character.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
*repos |
Path
|
The paths of repositories from which to borrow Git objects. |
()
|
path |
Path
|
The path of the repository where to set Git alternates. Defaults to the current working directory. |
Path('.')
|
Source code in copier/tools.py
256 257 258 259 260 261 262 263 264 265 266 267 268 269 |
|