modal 0.73.60__py3-none-any.whl → 0.73.62__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- modal/cli/profile.py +2 -0
- modal/client.pyi +2 -2
- modal/config.py +1 -1
- modal/functions.pyi +6 -6
- modal/image.py +7 -5
- modal/mount.py +5 -3
- {modal-0.73.60.dist-info → modal-0.73.62.dist-info}/METADATA +1 -1
- {modal-0.73.60.dist-info → modal-0.73.62.dist-info}/RECORD +13 -13
- modal_version/_version_generated.py +1 -1
- {modal-0.73.60.dist-info → modal-0.73.62.dist-info}/LICENSE +0 -0
- {modal-0.73.60.dist-info → modal-0.73.62.dist-info}/WHEEL +0 -0
- {modal-0.73.60.dist-info → modal-0.73.62.dist-info}/entry_points.txt +0 -0
- {modal-0.73.60.dist-info → modal-0.73.62.dist-info}/top_level.txt +0 -0
modal/cli/profile.py
CHANGED
@@ -46,6 +46,8 @@ async def list_(json: Optional[bool] = False):
|
|
46
46
|
active = profile == _profile
|
47
47
|
if isinstance(resp, AuthError):
|
48
48
|
workspace = "Unknown (authentication failure)"
|
49
|
+
elif isinstance(resp, TimeoutError):
|
50
|
+
workspace = "Unknown (timed out)"
|
49
51
|
elif isinstance(resp, Exception):
|
50
52
|
# Catch-all for other exceptions, like incorrect server url
|
51
53
|
workspace = "Unknown (profile misconfigured)"
|
modal/client.pyi
CHANGED
@@ -27,7 +27,7 @@ class _Client:
|
|
27
27
|
_snapshotted: bool
|
28
28
|
|
29
29
|
def __init__(
|
30
|
-
self, server_url: str, client_type: int, credentials: typing.Optional[tuple[str, str]], version: str = "0.73.
|
30
|
+
self, server_url: str, client_type: int, credentials: typing.Optional[tuple[str, str]], version: str = "0.73.62"
|
31
31
|
): ...
|
32
32
|
def is_closed(self) -> bool: ...
|
33
33
|
@property
|
@@ -85,7 +85,7 @@ class Client:
|
|
85
85
|
_snapshotted: bool
|
86
86
|
|
87
87
|
def __init__(
|
88
|
-
self, server_url: str, client_type: int, credentials: typing.Optional[tuple[str, str]], version: str = "0.73.
|
88
|
+
self, server_url: str, client_type: int, credentials: typing.Optional[tuple[str, str]], version: str = "0.73.62"
|
89
89
|
): ...
|
90
90
|
def is_closed(self) -> bool: ...
|
91
91
|
@property
|
modal/config.py
CHANGED
@@ -133,7 +133,7 @@ async def _lookup_workspace(server_url: str, token_id: str, token_secret: str) -
|
|
133
133
|
|
134
134
|
credentials = (token_id, token_secret)
|
135
135
|
async with _Client(server_url, api_pb2.CLIENT_TYPE_CLIENT, credentials) as client:
|
136
|
-
return await client.stub.WorkspaceNameLookup(Empty())
|
136
|
+
return await client.stub.WorkspaceNameLookup(Empty(), timeout=3)
|
137
137
|
|
138
138
|
|
139
139
|
def config_profiles():
|
modal/functions.pyi
CHANGED
@@ -198,11 +198,11 @@ class Function(
|
|
198
198
|
|
199
199
|
_call_generator_nowait: ___call_generator_nowait_spec[typing_extensions.Self]
|
200
200
|
|
201
|
-
class __remote_spec(typing_extensions.Protocol[
|
201
|
+
class __remote_spec(typing_extensions.Protocol[ReturnType_INNER, P_INNER, SUPERSELF]):
|
202
202
|
def __call__(self, *args: P_INNER.args, **kwargs: P_INNER.kwargs) -> ReturnType_INNER: ...
|
203
203
|
async def aio(self, *args: P_INNER.args, **kwargs: P_INNER.kwargs) -> ReturnType_INNER: ...
|
204
204
|
|
205
|
-
remote: __remote_spec[modal._functions.
|
205
|
+
remote: __remote_spec[modal._functions.ReturnType, modal._functions.P, typing_extensions.Self]
|
206
206
|
|
207
207
|
class __remote_gen_spec(typing_extensions.Protocol[SUPERSELF]):
|
208
208
|
def __call__(self, *args, **kwargs) -> typing.Generator[typing.Any, None, None]: ...
|
@@ -217,19 +217,19 @@ class Function(
|
|
217
217
|
self, *args: modal._functions.P.args, **kwargs: modal._functions.P.kwargs
|
218
218
|
) -> modal._functions.OriginalReturnType: ...
|
219
219
|
|
220
|
-
class ___experimental_spawn_spec(typing_extensions.Protocol[
|
220
|
+
class ___experimental_spawn_spec(typing_extensions.Protocol[ReturnType_INNER, P_INNER, SUPERSELF]):
|
221
221
|
def __call__(self, *args: P_INNER.args, **kwargs: P_INNER.kwargs) -> FunctionCall[ReturnType_INNER]: ...
|
222
222
|
async def aio(self, *args: P_INNER.args, **kwargs: P_INNER.kwargs) -> FunctionCall[ReturnType_INNER]: ...
|
223
223
|
|
224
224
|
_experimental_spawn: ___experimental_spawn_spec[
|
225
|
-
modal._functions.
|
225
|
+
modal._functions.ReturnType, modal._functions.P, typing_extensions.Self
|
226
226
|
]
|
227
227
|
|
228
|
-
class __spawn_spec(typing_extensions.Protocol[
|
228
|
+
class __spawn_spec(typing_extensions.Protocol[ReturnType_INNER, P_INNER, SUPERSELF]):
|
229
229
|
def __call__(self, *args: P_INNER.args, **kwargs: P_INNER.kwargs) -> FunctionCall[ReturnType_INNER]: ...
|
230
230
|
async def aio(self, *args: P_INNER.args, **kwargs: P_INNER.kwargs) -> FunctionCall[ReturnType_INNER]: ...
|
231
231
|
|
232
|
-
spawn: __spawn_spec[modal._functions.
|
232
|
+
spawn: __spawn_spec[modal._functions.ReturnType, modal._functions.P, typing_extensions.Self]
|
233
233
|
|
234
234
|
def get_raw_f(self) -> collections.abc.Callable[..., typing.Any]: ...
|
235
235
|
|
modal/image.py
CHANGED
@@ -85,6 +85,8 @@ AUTO_DOCKERIGNORE = _AutoDockerIgnoreSentinel()
|
|
85
85
|
COPY_DEPRECATION_MESSAGE_PATTERN = """modal.Image.copy_* methods will soon be deprecated.
|
86
86
|
|
87
87
|
Use {replacement} instead, which is functionally and performance-wise equivalent.
|
88
|
+
|
89
|
+
See https://modal.com/docs/guide/modal-1-0-migration for more details.
|
88
90
|
"""
|
89
91
|
|
90
92
|
|
@@ -801,7 +803,7 @@ class _Image(_Object, type_prefix="im"):
|
|
801
803
|
works in a `Dockerfile`.
|
802
804
|
"""
|
803
805
|
deprecation_warning(
|
804
|
-
(
|
806
|
+
(2025, 1, 13), COPY_DEPRECATION_MESSAGE_PATTERN.format(replacement="image.add_local_file"), pending=True
|
805
807
|
)
|
806
808
|
basename = str(Path(local_path).name)
|
807
809
|
|
@@ -911,7 +913,7 @@ class _Image(_Object, type_prefix="im"):
|
|
911
913
|
```
|
912
914
|
"""
|
913
915
|
deprecation_warning(
|
914
|
-
(
|
916
|
+
(2025, 1, 13), COPY_DEPRECATION_MESSAGE_PATTERN.format(replacement="image.add_local_dir"), pending=True
|
915
917
|
)
|
916
918
|
|
917
919
|
def build_dockerfile(version: ImageBuilderVersion) -> DockerfileSpec:
|
@@ -1418,7 +1420,7 @@ class _Image(_Object, type_prefix="im"):
|
|
1418
1420
|
"`Image.conda` is deprecated."
|
1419
1421
|
" Please use the faster and more reliable `Image.micromamba` constructor instead."
|
1420
1422
|
)
|
1421
|
-
deprecation_error((
|
1423
|
+
deprecation_error((2025, 5, 2), message)
|
1422
1424
|
|
1423
1425
|
def conda_install(
|
1424
1426
|
self,
|
@@ -1433,7 +1435,7 @@ class _Image(_Object, type_prefix="im"):
|
|
1433
1435
|
"`Image.conda_install` is deprecated."
|
1434
1436
|
" Please use the faster and more reliable `Image.micromamba_install` instead."
|
1435
1437
|
)
|
1436
|
-
deprecation_error((
|
1438
|
+
deprecation_error((2025, 5, 2), message)
|
1437
1439
|
|
1438
1440
|
def conda_update_from_environment(
|
1439
1441
|
self,
|
@@ -1448,7 +1450,7 @@ class _Image(_Object, type_prefix="im"):
|
|
1448
1450
|
"Image.conda_update_from_environment` is deprecated."
|
1449
1451
|
" Please use the `Image.micromamba_install` method (with the `spec_file` parameter) instead."
|
1450
1452
|
)
|
1451
|
-
deprecation_error((
|
1453
|
+
deprecation_error((2025, 5, 2), message)
|
1452
1454
|
|
1453
1455
|
@staticmethod
|
1454
1456
|
def micromamba(
|
modal/mount.py
CHANGED
@@ -51,6 +51,8 @@ PYTHON_STANDALONE_VERSIONS: dict[str, tuple[str, str]] = {
|
|
51
51
|
MOUNT_DEPRECATION_MESSAGE_PATTERN = """modal.Mount usage will soon be deprecated.
|
52
52
|
|
53
53
|
Use {replacement} instead, which is functionally and performance-wise equivalent.
|
54
|
+
|
55
|
+
See https://modal.com/docs/guide/modal-1-0-migration for more details.
|
54
56
|
"""
|
55
57
|
|
56
58
|
|
@@ -408,7 +410,7 @@ class _Mount(_Object, type_prefix="mo"):
|
|
408
410
|
```
|
409
411
|
"""
|
410
412
|
deprecation_warning(
|
411
|
-
(
|
413
|
+
(2025, 1, 8), MOUNT_DEPRECATION_MESSAGE_PATTERN.format(replacement="image.add_local_dir"), pending=True
|
412
414
|
)
|
413
415
|
return _Mount._from_local_dir(local_path, remote_path=remote_path, condition=condition, recursive=recursive)
|
414
416
|
|
@@ -465,7 +467,7 @@ class _Mount(_Object, type_prefix="mo"):
|
|
465
467
|
```
|
466
468
|
"""
|
467
469
|
deprecation_warning(
|
468
|
-
(
|
470
|
+
(2025, 1, 8), MOUNT_DEPRECATION_MESSAGE_PATTERN.format(replacement="image.add_local_file"), pending=True
|
469
471
|
)
|
470
472
|
return _Mount._from_local_file(local_path, remote_path)
|
471
473
|
|
@@ -636,7 +638,7 @@ class _Mount(_Object, type_prefix="mo"):
|
|
636
638
|
```
|
637
639
|
"""
|
638
640
|
deprecation_warning(
|
639
|
-
(
|
641
|
+
(2025, 1, 8),
|
640
642
|
MOUNT_DEPRECATION_MESSAGE_PATTERN.format(replacement="image.add_local_python_source"),
|
641
643
|
pending=True,
|
642
644
|
)
|
@@ -22,12 +22,12 @@ modal/app.py,sha256=o5mHoHtn41nkvskX_ekJkyfG6MXwj5rqerRi_nnPd0w,44725
|
|
22
22
|
modal/app.pyi,sha256=0MMCgskIL4r3eq8oBcfm2lLyeao2gXjS3iXaIfmaJ-o,25959
|
23
23
|
modal/call_graph.py,sha256=1g2DGcMIJvRy-xKicuf63IVE98gJSnQsr8R_NVMptNc,2581
|
24
24
|
modal/client.py,sha256=8SQawr7P1PNUCq1UmJMUQXG2jIo4Nmdcs311XqrNLRE,15276
|
25
|
-
modal/client.pyi,sha256=
|
25
|
+
modal/client.pyi,sha256=LAARCMR4SACJAiYNFoAXrwo8ASCJAquwbcg814Ux220,7593
|
26
26
|
modal/cloud_bucket_mount.py,sha256=YOe9nnvSr4ZbeCn587d7_VhE9IioZYRvF9VYQTQux08,5914
|
27
27
|
modal/cloud_bucket_mount.pyi,sha256=30T3K1a89l6wzmEJ_J9iWv9SknoGqaZDx59Xs-ZQcmk,1607
|
28
28
|
modal/cls.py,sha256=wztMTYkhJyW9iUVqx4_Gga4bJJpUiPgGsS6iacUqy-A,30001
|
29
29
|
modal/cls.pyi,sha256=4Ms1i4Wty1qe49Dh_wsGhJDCiJz7t-XGqXLcpzwhUqs,9084
|
30
|
-
modal/config.py,sha256=
|
30
|
+
modal/config.py,sha256=E1bCdwNziBorqXal6Cble7gfLNzGqSuEgprRJwzYqg4,11160
|
31
31
|
modal/container_process.py,sha256=WTqLn01dJPVkPpwR_0w_JH96ceN5mV4TGtiu1ZR2RRA,6108
|
32
32
|
modal/container_process.pyi,sha256=Hf0J5JyDdCCXBJSKx6gvkPOo0XrztCm78xzxamtzUjQ,2828
|
33
33
|
modal/dict.py,sha256=vc5lQVqzeDUCb4fRjnOlqYK2GmBb0fIhZmvB0xIBG0U,12921
|
@@ -41,13 +41,13 @@ modal/file_io.py,sha256=lcMs_E9Xfm0YX1t9U2wNIBPnqHRxmImqjLW1GHqVmyg,20945
|
|
41
41
|
modal/file_io.pyi,sha256=NTRft1tbPSWf9TlWVeZmTlgB5AZ_Zhu2srWIrWr7brk,9445
|
42
42
|
modal/file_pattern_matcher.py,sha256=trosX-Bp7dOubudN1bLLhRAoidWy1TcoaR4Pv8CedWw,6497
|
43
43
|
modal/functions.py,sha256=kcNHvqeGBxPI7Cgd57NIBBghkfbeFJzXO44WW0jSmao,325
|
44
|
-
modal/functions.pyi,sha256=
|
44
|
+
modal/functions.pyi,sha256=24XrtwZ3yqfv68bWH8zXWUdu-q4NbekyX_4h515faLE,14247
|
45
45
|
modal/gpu.py,sha256=Kbhs_u49FaC2Zi0TjCdrpstpRtT5eZgecynmQi5IZVE,6752
|
46
|
-
modal/image.py,sha256=
|
46
|
+
modal/image.py,sha256=W3SnV-DjUuaWwUWkk9keQko7jZ_p_pYERqdeMXNccSk,91542
|
47
47
|
modal/image.pyi,sha256=Oc2ndYHSdQTcRpZKHSfTdj-m_2oQAsnc2EWTthbNn-s,26380
|
48
48
|
modal/io_streams.py,sha256=QkQiizKRzd5bnbKQsap31LJgBYlAnj4-XkV_50xPYX0,15079
|
49
49
|
modal/io_streams.pyi,sha256=bJ7ZLmSmJ0nKoa6r4FJpbqvzdUVa0lEe0Fa-MMpMezU,5071
|
50
|
-
modal/mount.py,sha256=
|
50
|
+
modal/mount.py,sha256=JII0zTS1fPCcCbZgO18okkOuTDqYCxY1DIVa6i1E9cI,32196
|
51
51
|
modal/mount.pyi,sha256=CmHa7zKSxHA_7-vMQLnGfw_ZXvAvHlafvUEVJcQ1LQA,12535
|
52
52
|
modal/network_file_system.py,sha256=WXdyL7du_fvjvuG6hSAREyJ83sSEP2xSLAIAhBsisdI,14869
|
53
53
|
modal/network_file_system.pyi,sha256=4N3eqMbTSlqmS8VV_aJK-uvrgJC8xnf_YtW5FHfRfc8,8156
|
@@ -126,7 +126,7 @@ modal/cli/environment.py,sha256=Ayddkiq9jdj3XYDJ8ZmUqFpPPH8xajYlbexRkzGtUcg,4334
|
|
126
126
|
modal/cli/import_refs.py,sha256=kbjWZxSyLc6Bp6UxtB7iJ7qp10DG5j7i4bbbA1bSIXQ,13529
|
127
127
|
modal/cli/launch.py,sha256=0_sBu6bv2xJEPWi-rbGS6Ri9ggnkWQvrGlgpYSUBMyY,3097
|
128
128
|
modal/cli/network_file_system.py,sha256=eq3JnwjbfFNsJodIyANHL06ByYc3BSavzdmu8C96cHA,7948
|
129
|
-
modal/cli/profile.py,sha256=
|
129
|
+
modal/cli/profile.py,sha256=0TYhgRSGUvQZ5LH9nkl6iZllEvAjDniES264dE57wOM,3201
|
130
130
|
modal/cli/queues.py,sha256=6gTu76dzBtPN5eQVsLrvQpuru5jI9ZCWK5Eh8J8XhaM,4498
|
131
131
|
modal/cli/run.py,sha256=rCd-lB6p-l2vd0OrvXcioVN6wn_1EkCiRQLJRC3Z7J4,22764
|
132
132
|
modal/cli/secret.py,sha256=iDsaFUJBq3333ZBVzKPcqyey68w0j82PNddGhRgP2pA,4206
|
@@ -168,10 +168,10 @@ modal_proto/options_pb2_grpc.pyi,sha256=CImmhxHsYnF09iENPoe8S4J-n93jtgUYD2JPAc0y
|
|
168
168
|
modal_proto/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
169
169
|
modal_version/__init__.py,sha256=wiJQ53c-OMs0Xf1UeXOxQ7FwlV1VzIjnX6o-pRYZ_Pk,470
|
170
170
|
modal_version/__main__.py,sha256=2FO0yYQQwDTh6udt1h-cBnGd1c4ZyHnHSI4BksxzVac,105
|
171
|
-
modal_version/_version_generated.py,sha256=
|
172
|
-
modal-0.73.
|
173
|
-
modal-0.73.
|
174
|
-
modal-0.73.
|
175
|
-
modal-0.73.
|
176
|
-
modal-0.73.
|
177
|
-
modal-0.73.
|
171
|
+
modal_version/_version_generated.py,sha256=z6YdQ_-Z50wDtogabh3eqHCJflf4Fmlj3_Fd1S7Z31w,149
|
172
|
+
modal-0.73.62.dist-info/LICENSE,sha256=psuoW8kuDP96RQsdhzwOqi6fyWv0ct8CR6Jr7He_P_k,10173
|
173
|
+
modal-0.73.62.dist-info/METADATA,sha256=i3cVtHfRYxuDcjKnux7u5PGO-_1CmGuQ9lYvZU5FR7Q,2452
|
174
|
+
modal-0.73.62.dist-info/WHEEL,sha256=In9FTNxeP60KnTkGw7wk6mJPYd_dQSjEZmXdBdMCI-8,91
|
175
|
+
modal-0.73.62.dist-info/entry_points.txt,sha256=An-wYgeEUnm6xzrAP9_NTSTSciYvvEWsMZILtYrvpAI,46
|
176
|
+
modal-0.73.62.dist-info/top_level.txt,sha256=4BWzoKYREKUZ5iyPzZpjqx4G8uB5TWxXPDwibLcVa7k,43
|
177
|
+
modal-0.73.62.dist-info/RECORD,,
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|