modal 1.0.3.dev14__py3-none-any.whl → 1.0.3.dev17__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/client.pyi CHANGED
@@ -31,7 +31,7 @@ class _Client:
31
31
  server_url: str,
32
32
  client_type: int,
33
33
  credentials: typing.Optional[tuple[str, str]],
34
- version: str = "1.0.3.dev14",
34
+ version: str = "1.0.3.dev17",
35
35
  ): ...
36
36
  def is_closed(self) -> bool: ...
37
37
  @property
@@ -94,7 +94,7 @@ class Client:
94
94
  server_url: str,
95
95
  client_type: int,
96
96
  credentials: typing.Optional[tuple[str, str]],
97
- version: str = "1.0.3.dev14",
97
+ version: str = "1.0.3.dev17",
98
98
  ): ...
99
99
  def is_closed(self) -> bool: ...
100
100
  @property
modal/functions.pyi CHANGED
@@ -227,11 +227,11 @@ class Function(
227
227
 
228
228
  _call_generator: ___call_generator_spec[typing_extensions.Self]
229
229
 
230
- class __remote_spec(typing_extensions.Protocol[P_INNER, ReturnType_INNER, SUPERSELF]):
230
+ class __remote_spec(typing_extensions.Protocol[ReturnType_INNER, P_INNER, SUPERSELF]):
231
231
  def __call__(self, /, *args: P_INNER.args, **kwargs: P_INNER.kwargs) -> ReturnType_INNER: ...
232
232
  async def aio(self, /, *args: P_INNER.args, **kwargs: P_INNER.kwargs) -> ReturnType_INNER: ...
233
233
 
234
- remote: __remote_spec[modal._functions.P, modal._functions.ReturnType, typing_extensions.Self]
234
+ remote: __remote_spec[modal._functions.ReturnType, modal._functions.P, typing_extensions.Self]
235
235
 
236
236
  class __remote_gen_spec(typing_extensions.Protocol[SUPERSELF]):
237
237
  def __call__(self, /, *args, **kwargs) -> typing.Generator[typing.Any, None, None]: ...
@@ -246,12 +246,12 @@ class Function(
246
246
  self, *args: modal._functions.P.args, **kwargs: modal._functions.P.kwargs
247
247
  ) -> modal._functions.OriginalReturnType: ...
248
248
 
249
- class ___experimental_spawn_spec(typing_extensions.Protocol[P_INNER, ReturnType_INNER, SUPERSELF]):
249
+ class ___experimental_spawn_spec(typing_extensions.Protocol[ReturnType_INNER, P_INNER, SUPERSELF]):
250
250
  def __call__(self, /, *args: P_INNER.args, **kwargs: P_INNER.kwargs) -> FunctionCall[ReturnType_INNER]: ...
251
251
  async def aio(self, /, *args: P_INNER.args, **kwargs: P_INNER.kwargs) -> FunctionCall[ReturnType_INNER]: ...
252
252
 
253
253
  _experimental_spawn: ___experimental_spawn_spec[
254
- modal._functions.P, modal._functions.ReturnType, typing_extensions.Self
254
+ modal._functions.ReturnType, modal._functions.P, typing_extensions.Self
255
255
  ]
256
256
 
257
257
  class ___spawn_map_inner_spec(typing_extensions.Protocol[P_INNER, SUPERSELF]):
@@ -260,11 +260,11 @@ class Function(
260
260
 
261
261
  _spawn_map_inner: ___spawn_map_inner_spec[modal._functions.P, typing_extensions.Self]
262
262
 
263
- class __spawn_spec(typing_extensions.Protocol[P_INNER, ReturnType_INNER, SUPERSELF]):
263
+ class __spawn_spec(typing_extensions.Protocol[ReturnType_INNER, P_INNER, SUPERSELF]):
264
264
  def __call__(self, /, *args: P_INNER.args, **kwargs: P_INNER.kwargs) -> FunctionCall[ReturnType_INNER]: ...
265
265
  async def aio(self, /, *args: P_INNER.args, **kwargs: P_INNER.kwargs) -> FunctionCall[ReturnType_INNER]: ...
266
266
 
267
- spawn: __spawn_spec[modal._functions.P, modal._functions.ReturnType, typing_extensions.Self]
267
+ spawn: __spawn_spec[modal._functions.ReturnType, modal._functions.P, typing_extensions.Self]
268
268
 
269
269
  def get_raw_f(self) -> collections.abc.Callable[..., typing.Any]: ...
270
270
 
modal/mount.py CHANGED
@@ -810,3 +810,109 @@ def _is_modal_path(remote_path: PurePosixPath):
810
810
  if is_modal_path:
811
811
  return True
812
812
  return False
813
+
814
+ REMOTE_PACKAGES_PATH = "/__modal/deps"
815
+ REMOTE_SITECUSTOMIZE_PATH = "/pkg/sitecustomize.py"
816
+
817
+ SITECUSTOMIZE_CONTENT = f"""
818
+ # This file is automatically generated by Modal.
819
+ # It ensures that Modal's python dependencies are available in the Python PATH,
820
+ # while prioritizing user-installed packages.
821
+ import sys; sys.path.append('{REMOTE_PACKAGES_PATH}')
822
+ """.strip()
823
+
824
+ async def _create_single_mount(
825
+ client: _Client,
826
+ builder_version: str,
827
+ python_version: str,
828
+ platform: str,
829
+ arch: str,
830
+ uv_python_platform: str = None,
831
+ check_if_exists: bool = True,
832
+ ):
833
+ import subprocess
834
+ import tempfile
835
+
836
+ profile_environment = config.get("environment")
837
+ abi_tag = "cp" + python_version.replace(".", "")
838
+ mount_name = f"{builder_version}-{abi_tag}-{platform}-{arch}"
839
+ uv_python_platform = uv_python_platform or f"{arch}-{platform}"
840
+
841
+ if check_if_exists:
842
+ try:
843
+ await Mount.from_name(mount_name, namespace=api_pb2.DEPLOYMENT_NAMESPACE_GLOBAL).hydrate.aio(client)
844
+ print(f"✅ Found existing mount {mount_name} in global namespace.")
845
+ return
846
+ except modal.exception.NotFoundError:
847
+ pass
848
+
849
+ with tempfile.TemporaryDirectory() as tmpd:
850
+ print(f"📦 Building {mount_name}.")
851
+ requirements = os.path.join(os.path.dirname(__file__), f"requirements/{builder_version}.txt")
852
+ subprocess.run(
853
+ [
854
+ "uv",
855
+ "pip",
856
+ "install",
857
+ "--strict",
858
+ "--no-deps",
859
+ "--no-cache",
860
+ "-r",
861
+ requirements,
862
+ "--compile-bytecode",
863
+ "--target",
864
+ tmpd,
865
+ "--python-platform",
866
+ uv_python_platform,
867
+ "--python-version",
868
+ python_version,
869
+ ],
870
+ check=True,
871
+ capture_output=True,
872
+ )
873
+
874
+ print(f"🌐 Downloaded and unpacked packages to {tmpd}.")
875
+
876
+ python_mount = Mount._from_local_dir(tmpd, remote_path=REMOTE_PACKAGES_PATH)
877
+
878
+ with tempfile.NamedTemporaryFile() as sitecustomize:
879
+ sitecustomize.write(
880
+ SITECUSTOMIZE_CONTENT.encode("utf-8"),
881
+ )
882
+ sitecustomize.flush()
883
+
884
+ python_mount = python_mount.add_local_file(
885
+ sitecustomize.name,
886
+ remote_path=REMOTE_SITECUSTOMIZE_PATH,
887
+ )
888
+
889
+ await python_mount._deploy.aio(
890
+ mount_name,
891
+ api_pb2.DEPLOYMENT_NAMESPACE_GLOBAL,
892
+ environment_name=profile_environment,
893
+ client=client,
894
+ )
895
+ print(f"✅ Deployed mount {mount_name} to global namespace.")
896
+
897
+
898
+ async def _create_client_dependency_mounts(client=None, check_if_exists=True):
899
+ for python_version in PYTHON_STANDALONE_VERSIONS:
900
+ # glibc >= 2.17
901
+ await _create_single_mount(
902
+ client,
903
+ "PREVIEW",
904
+ python_version,
905
+ "manylinux_2_17",
906
+ "x86_64",
907
+ check_if_exists=check_if_exists,
908
+ )
909
+ # musl >= 1.2
910
+ await _create_single_mount(
911
+ client,
912
+ "PREVIEW",
913
+ python_version,
914
+ "musllinux_1_2",
915
+ "x86_64",
916
+ uv_python_platform="x86_64-unknown-linux-musl",
917
+ check_if_exists=check_if_exists,
918
+ )
modal/mount.pyi CHANGED
@@ -308,6 +308,16 @@ def _create_client_mount(): ...
308
308
  def create_client_mount(): ...
309
309
  def _get_client_mount(): ...
310
310
  def _is_modal_path(remote_path: pathlib.PurePosixPath): ...
311
+ async def _create_single_mount(
312
+ client: modal.client._Client,
313
+ builder_version: str,
314
+ python_version: str,
315
+ platform: str,
316
+ arch: str,
317
+ uv_python_platform: str = None,
318
+ check_if_exists: bool = True,
319
+ ): ...
320
+ async def _create_client_dependency_mounts(client=None, check_if_exists=True): ...
311
321
 
312
322
  ROOT_DIR: pathlib.PurePosixPath
313
323
 
modal/volume.py CHANGED
@@ -567,8 +567,12 @@ class _Volume(_Object, type_prefix="vo"):
567
567
  like `os.rename()` and then `commit()` the volume. The `copy_files()` method is useful when you don't have
568
568
  the volume mounted as a filesystem, e.g. when running a script on your local computer.
569
569
  """
570
- request = api_pb2.VolumeCopyFilesRequest(volume_id=self.object_id, src_paths=src_paths, dst_path=dst_path)
571
- await retry_transient_errors(self._client.stub.VolumeCopyFiles, request, base_delay=1)
570
+ if self._is_v1:
571
+ request = api_pb2.VolumeCopyFilesRequest(volume_id=self.object_id, src_paths=src_paths, dst_path=dst_path)
572
+ await retry_transient_errors(self._client.stub.VolumeCopyFiles, request, base_delay=1)
573
+ else:
574
+ request = api_pb2.VolumeCopyFiles2Request(volume_id=self.object_id, src_paths=src_paths, dst_path=dst_path)
575
+ await retry_transient_errors(self._client.stub.VolumeCopyFiles2, request, base_delay=1)
572
576
 
573
577
  @live_method
574
578
  async def batch_upload(self, force: bool = False) -> "_AbstractVolumeUploadContextManager":
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: modal
3
- Version: 1.0.3.dev14
3
+ Version: 1.0.3.dev17
4
4
  Summary: Python client library for Modal
5
5
  Author-email: Modal Labs <support@modal.com>
6
6
  License: Apache-2.0
@@ -22,7 +22,7 @@ modal/app.py,sha256=NZ_rJ9TuMfiNiLg8-gOFgufD5flGtXWPHOZI0gdD3hE,46585
22
22
  modal/app.pyi,sha256=4-b_vbe3lNAqQPcMRpQCEDsE1zsVkQRJGUql9B7HvbM,22659
23
23
  modal/call_graph.py,sha256=1g2DGcMIJvRy-xKicuf63IVE98gJSnQsr8R_NVMptNc,2581
24
24
  modal/client.py,sha256=OwISJvkgMb-rHm9Gc4i-7YcDgGiZgwJ7F_PzwZH7a6Q,16847
25
- modal/client.pyi,sha256=zO8e-Sk-qBcJ7c8OGUgvUtDmeA7RJ-SahYGvQyAJKFQ,8459
25
+ modal/client.pyi,sha256=NB4eHSUXATNCpXxNSbegpf1F1tdAZq80Q58_7DvHwYw,8459
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=dBbeARwOWftlKd1cwtM0cHFtQWSWkwVXwVmOV4w0SyI,37907
@@ -39,14 +39,14 @@ modal/file_io.py,sha256=lcMs_E9Xfm0YX1t9U2wNIBPnqHRxmImqjLW1GHqVmyg,20945
39
39
  modal/file_io.pyi,sha256=oB7x-rKq7bmm8cA7Z7W9C9yeko7KK9m9i5GidFnkGK4,9569
40
40
  modal/file_pattern_matcher.py,sha256=wov-otB5M1oTdrYDtR2_VgacYin2srdtAP4McA1Cqzw,6516
41
41
  modal/functions.py,sha256=kcNHvqeGBxPI7Cgd57NIBBghkfbeFJzXO44WW0jSmao,325
42
- modal/functions.pyi,sha256=iqdp5ixtOOlm8bF-QYbD_G8VKqSRt_AVLT7AWjpn6pQ,16236
42
+ modal/functions.pyi,sha256=5T58OucdNU4I-LqhBdwsWSAGka-Wa8nP2GcZ5K1bOL0,16236
43
43
  modal/gpu.py,sha256=Kbhs_u49FaC2Zi0TjCdrpstpRtT5eZgecynmQi5IZVE,6752
44
44
  modal/image.py,sha256=yrI9DCw7GAck3d788GCHJom-_yU55zNu7reNapBhlgE,93284
45
45
  modal/image.pyi,sha256=2xjB6XOZDtm_chDdd90UoIj8pnDt5hCg6bOmu5fNaA4,25625
46
46
  modal/io_streams.py,sha256=YDZVQSDv05DeXg5TwcucC9Rj5hQBx2GXdluan9rIUpw,15467
47
47
  modal/io_streams.pyi,sha256=1UK6kWLREASQfq-wL9wSp5iqjLU0egRZPDn4LXs1PZY,5136
48
- modal/mount.py,sha256=HbpGQbqqT5pTP4dh8j6USWXb2Fr1ro3V1uHIardkya4,30726
49
- modal/mount.pyi,sha256=_qDhjR8Xg0ArdCw0JCivhhLCQO-Q-n_RlG5Ct4yJBQ0,12528
48
+ modal/mount.py,sha256=09D3DZZ_kcvUHGflYZLhEza-216esnY0J_je8dG9Z9U,34136
49
+ modal/mount.pyi,sha256=WXWU-qhOvHzX2sfoToO0l0RR3k3PtfQkk5at8tBbg1g,12839
50
50
  modal/network_file_system.py,sha256=lgtmHYjzA5gDMx0tysH0-WJB2Ao9JD2W15NyYK2A7_w,14612
51
51
  modal/network_file_system.pyi,sha256=58DiUqHGlARmI3cz-Yo7IFObKKFIiGh5UIU5JxGNFfc,8333
52
52
  modal/object.py,sha256=bTeskuY8JFrESjU4_UL_nTwYlBQdOLmVaOX3X6EMxsg,164
@@ -78,7 +78,7 @@ modal/snapshot.pyi,sha256=dIEBdTPb7O3VwkQ8TMPjfyU17RLuS9i0DnACxxHy8X4,676
78
78
  modal/stream_type.py,sha256=A6320qoAAWhEfwOCZfGtymQTu5AfLfJXXgARqooTPvY,417
79
79
  modal/token_flow.py,sha256=0_4KabXKsuE4OXTJ1OuLOtA-b1sesShztMZkkRFK7tA,7605
80
80
  modal/token_flow.pyi,sha256=ILbRv6JsZq-jK8jcJM7eB74e0PsbzwBm7hyPcV9lBlQ,2121
81
- modal/volume.py,sha256=XtOxzvdTJ3H7BEldl5Puj6vvXucev0i6KWI5tgkXe7I,44120
81
+ modal/volume.py,sha256=G7F8G4V72t59MGocex0afRlJgUTQjRHxjQBVf5Vbbm0,44386
82
82
  modal/volume.pyi,sha256=YZqC3-z4bfiTgb1-uO7XylrONvIsHQUZd9pqW_Wxd48,21145
83
83
  modal/_runtime/__init__.py,sha256=MIEP8jhXUeGq_eCjYFcqN5b1bxBM4fdk0VESpjWR0fc,28
84
84
  modal/_runtime/asgi.py,sha256=_2xSTsDD27Cit7xnMs4lzkJA2wzer2_N4Oa3BkXFzVA,22521
@@ -147,7 +147,7 @@ modal/requirements/2024.10.txt,sha256=qD-5cVIVM9wXesJ6JC89Ew-3m2KjEElUz3jaw_MddR
147
147
  modal/requirements/PREVIEW.txt,sha256=qD-5cVIVM9wXesJ6JC89Ew-3m2KjEElUz3jaw_MddRo,296
148
148
  modal/requirements/README.md,sha256=9tK76KP0Uph7O0M5oUgsSwEZDj5y-dcUPsnpR0Sc-Ik,854
149
149
  modal/requirements/base-images.json,sha256=57vMSqzMbLBxw5tFWSaMiIkkVEps4JfX5PAtXGnkS4U,740
150
- modal-1.0.3.dev14.dist-info/licenses/LICENSE,sha256=psuoW8kuDP96RQsdhzwOqi6fyWv0ct8CR6Jr7He_P_k,10173
150
+ modal-1.0.3.dev17.dist-info/licenses/LICENSE,sha256=psuoW8kuDP96RQsdhzwOqi6fyWv0ct8CR6Jr7He_P_k,10173
151
151
  modal_docs/__init__.py,sha256=svYKtV8HDwDCN86zbdWqyq5T8sMdGDj0PVlzc2tIxDM,28
152
152
  modal_docs/gen_cli_docs.py,sha256=c1yfBS_x--gL5bs0N4ihMwqwX8l3IBWSkBAKNNIi6bQ,3801
153
153
  modal_docs/gen_reference_docs.py,sha256=d_CQUGQ0rfw28u75I2mov9AlS773z9rG40-yq5o7g2U,6359
@@ -155,10 +155,10 @@ modal_docs/mdmd/__init__.py,sha256=svYKtV8HDwDCN86zbdWqyq5T8sMdGDj0PVlzc2tIxDM,2
155
155
  modal_docs/mdmd/mdmd.py,sha256=Irx49MCCTlBOP4FBdLR--JrpA3-WhsVeriq0LGgsRic,6232
156
156
  modal_docs/mdmd/signatures.py,sha256=XJaZrK7Mdepk5fdX51A8uENiLFNil85Ud0d4MH8H5f0,3218
157
157
  modal_proto/__init__.py,sha256=MIEP8jhXUeGq_eCjYFcqN5b1bxBM4fdk0VESpjWR0fc,28
158
- modal_proto/api.proto,sha256=YNmqhfRQHFqjUI6UjsVFQBAtTJdDwYJ3S1drkHYkjzA,96321
158
+ modal_proto/api.proto,sha256=W-cvTWRT5LWw6FvfZUWGORQMEkUV4hqBpmbDD24N3C4,96314
159
159
  modal_proto/api_grpc.py,sha256=iY5o_Tm4VDP-Wa1JgA_NpQa_Y-4FYB_RN9wdSUExjwI,117469
160
160
  modal_proto/api_pb2.py,sha256=C0eUCmX2r7X7UgXkNkK30zA8GqQE9JgzShaJz_eay8Q,338564
161
- modal_proto/api_pb2.pyi,sha256=gMkyS-42l-sZNmBtMVLkrTR9ijlAFmX6X5PTZ3LQxfo,463623
161
+ modal_proto/api_pb2.pyi,sha256=51bFLZW74Cy5F4wEm36ZXHKfFht-cfB4RCre4WWAteo,463616
162
162
  modal_proto/api_pb2_grpc.py,sha256=NL5prOS_hh_pA1hVvQP_ZRE1w49N-PR8iNPRZ65i6nA,254089
163
163
  modal_proto/api_pb2_grpc.pyi,sha256=Xxgdcnv1mBnu5_AQxJ6fo0yz7GnqVU0HVObNfZWHVfM,59440
164
164
  modal_proto/modal_api_grpc.py,sha256=0ir2lnwT3-IgPcAWw98yWMAiqZPkjvNro9UBk4u8hnk,17763
@@ -170,10 +170,10 @@ modal_proto/options_pb2.pyi,sha256=l7DBrbLO7q3Ir-XDkWsajm0d0TQqqrfuX54i4BMpdQg,1
170
170
  modal_proto/options_pb2_grpc.py,sha256=1oboBPFxaTEXt9Aw7EAj8gXHDCNMhZD2VXqocC9l_gk,159
171
171
  modal_proto/options_pb2_grpc.pyi,sha256=CImmhxHsYnF09iENPoe8S4J-n93jtgUYD2JPAc0yJSI,247
172
172
  modal_proto/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
173
- modal_version/__init__.py,sha256=dUjdYTeNB6zT7lCOYLDzBREdvSGFfwULra6F8QbGbUw,121
173
+ modal_version/__init__.py,sha256=uPcPQdUgF0iuDk60GQ3Ihk2SeEuLJyqu0INnJzaoN6k,121
174
174
  modal_version/__main__.py,sha256=2FO0yYQQwDTh6udt1h-cBnGd1c4ZyHnHSI4BksxzVac,105
175
- modal-1.0.3.dev14.dist-info/METADATA,sha256=yCK8PZ9xXgWAKUzx4Evs7BxItLfCzOtt9UUw-3hqZsg,2455
176
- modal-1.0.3.dev14.dist-info/WHEEL,sha256=1tXe9gY0PYatrMPMDd6jXqjfpz_B-Wqm32CPfRC58XU,91
177
- modal-1.0.3.dev14.dist-info/entry_points.txt,sha256=An-wYgeEUnm6xzrAP9_NTSTSciYvvEWsMZILtYrvpAI,46
178
- modal-1.0.3.dev14.dist-info/top_level.txt,sha256=4BWzoKYREKUZ5iyPzZpjqx4G8uB5TWxXPDwibLcVa7k,43
179
- modal-1.0.3.dev14.dist-info/RECORD,,
175
+ modal-1.0.3.dev17.dist-info/METADATA,sha256=5hxxPNx4LxkOhRUL2pUREfldQuIvUZ_ZasE2GNPhHg4,2455
176
+ modal-1.0.3.dev17.dist-info/WHEEL,sha256=1tXe9gY0PYatrMPMDd6jXqjfpz_B-Wqm32CPfRC58XU,91
177
+ modal-1.0.3.dev17.dist-info/entry_points.txt,sha256=An-wYgeEUnm6xzrAP9_NTSTSciYvvEWsMZILtYrvpAI,46
178
+ modal-1.0.3.dev17.dist-info/top_level.txt,sha256=4BWzoKYREKUZ5iyPzZpjqx4G8uB5TWxXPDwibLcVa7k,43
179
+ modal-1.0.3.dev17.dist-info/RECORD,,
modal_proto/api.proto CHANGED
@@ -1957,11 +1957,11 @@ message ImageMetadata {
1957
1957
  // package name -> version. Empty if missing
1958
1958
  map<string, string> python_packages = 2;
1959
1959
 
1960
- // The working directory of the image, defaulting to "/". Not set if missing.
1960
+ // The working directory of the image, as an absolute file path.
1961
1961
  //
1962
- // Note that this is NOT the actual working directory of the image, especially
1963
- // for runner tasks. Please see `ImageManifest.workdir` instead. This field
1964
- // should not be used in any future code.
1962
+ // For most images, this is not set, which means to use the default workdir:
1963
+ // - On function runners, the default is `/root` (home directory).
1964
+ // - For image builds and sandbox environments, it is `/`.
1965
1965
  optional string workdir = 3;
1966
1966
 
1967
1967
  // The version of glibc in this image, if any.
modal_proto/api_pb2.pyi CHANGED
@@ -6313,11 +6313,11 @@ class ImageMetadata(google.protobuf.message.Message):
6313
6313
  package name -> version. Empty if missing
6314
6314
  """
6315
6315
  workdir: builtins.str
6316
- """The working directory of the image, defaulting to "/". Not set if missing.
6316
+ """The working directory of the image, as an absolute file path.
6317
6317
 
6318
- Note that this is NOT the actual working directory of the image, especially
6319
- for runner tasks. Please see `ImageManifest.workdir` instead. This field
6320
- should not be used in any future code.
6318
+ For most images, this is not set, which means to use the default workdir:
6319
+ - On function runners, the default is `/root` (home directory).
6320
+ - For image builds and sandbox environments, it is `/`.
6321
6321
  """
6322
6322
  libc_version_info: builtins.str
6323
6323
  """The version of glibc in this image, if any."""
modal_version/__init__.py CHANGED
@@ -1,4 +1,4 @@
1
1
  # Copyright Modal Labs 2025
2
2
  """Supplies the current version of the modal client library."""
3
3
 
4
- __version__ = "1.0.3.dev14"
4
+ __version__ = "1.0.3.dev17"