xoscar 0.6.1__cp312-cp312-macosx_11_0_arm64.whl → 0.6.2__cp312-cp312-macosx_11_0_arm64.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.

Potentially problematic release.


This version of xoscar might be problematic. Click here for more details.

Binary file
@@ -134,6 +134,31 @@ class SubpoolStatus:
134
134
  traceback: TracebackType | None = None
135
135
 
136
136
 
137
+ _PRE_SET_ENV_LOCK = asyncio.Lock()
138
+
139
+
140
+ @contextlib.asynccontextmanager
141
+ async def _pre_set_env_in_main(env: dict[str, str]):
142
+ # Normally, `env` is set in sub pool,
143
+ # but something may have happened during initialization,
144
+ # e.g. CUDA_VISIBLE_DEVICES is too late to set when some actions may have polluted cuda
145
+ # we have to set environ before new process started
146
+ # enable this only when XOSCAR_PRE_SET_ENV=1
147
+ enable_pre_set_env = bool(int(os.getenv("XOSCAR_PRE_SET_ENV", 0)))
148
+ if not enable_pre_set_env or not env:
149
+ yield
150
+ return
151
+
152
+ global_environ = os.environ.copy()
153
+ async with _PRE_SET_ENV_LOCK:
154
+ try:
155
+ logger.debug("Updating environment variables in main: %s", env)
156
+ os.environ.update(env)
157
+ yield
158
+ finally:
159
+ os.environ = global_environ # type: ignore
160
+
161
+
137
162
  @_register_message_handler
138
163
  class MainActorPool(MainActorPoolBase):
139
164
  @classmethod
@@ -223,9 +248,12 @@ class MainActorPool(MainActorPoolBase):
223
248
 
224
249
  _patch_spawn_get_preparation_data()
225
250
  loop = asyncio.get_running_loop()
226
- with futures.ThreadPoolExecutor(1) as executor:
227
- create_pool_task = loop.run_in_executor(executor, start_pool_in_process)
228
- return await create_pool_task
251
+ async with _pre_set_env_in_main(
252
+ actor_pool_config.get_pool_config(process_index)["env"]
253
+ ):
254
+ with futures.ThreadPoolExecutor(1) as executor:
255
+ create_pool_task = loop.run_in_executor(executor, start_pool_in_process)
256
+ return await create_pool_task
229
257
 
230
258
  @classmethod
231
259
  async def wait_sub_pools_ready(cls, create_pool_tasks: List[asyncio.Task]):
@@ -394,9 +422,10 @@ class MainActorPool(MainActorPoolBase):
394
422
  return process, process_status
395
423
 
396
424
  loop = asyncio.get_running_loop()
397
- with futures.ThreadPoolExecutor(1) as executor:
398
- create_pool_task = loop.run_in_executor(executor, start_pool_in_process)
399
- process, process_status = await create_pool_task
425
+ async with _pre_set_env_in_main(env): # type: ignore
426
+ with futures.ThreadPoolExecutor(1) as executor:
427
+ create_pool_task = loop.run_in_executor(executor, start_pool_in_process)
428
+ process, process_status = await create_pool_task
400
429
 
401
430
  self._config.reset_pool_external_address(
402
431
  process_index, process_status.external_addresses[0]
Binary file
Binary file
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: xoscar
3
- Version: 0.6.1
3
+ Version: 0.6.2
4
4
  Summary: Python actor framework for heterogeneous computing.
5
5
  Home-page: http://github.com/xorbitsai/xoscar
6
6
  Author: Qin Xuye
@@ -1,7 +1,7 @@
1
- xoscar-0.6.1.dist-info/RECORD,,
2
- xoscar-0.6.1.dist-info/WHEEL,sha256=zT4bWmTpgvLb-CO5IGKhtulo8JdnX1gd0cgiqom_p-o,109
3
- xoscar-0.6.1.dist-info/top_level.txt,sha256=vYlqqY4Nys8Thm1hePIuUv8eQePdULVWMmt7lXtX_ZA,21
4
- xoscar-0.6.1.dist-info/METADATA,sha256=9fv3VVarAR1QSCiE-ufI-_7w9qXAYxsTeDVzbAAWdC4,9131
1
+ xoscar-0.6.2.dist-info/RECORD,,
2
+ xoscar-0.6.2.dist-info/WHEEL,sha256=s3SCZeN-G9VuOPYdbIQ149WhzOgcaPLKGJFMWgov7lM,109
3
+ xoscar-0.6.2.dist-info/top_level.txt,sha256=vYlqqY4Nys8Thm1hePIuUv8eQePdULVWMmt7lXtX_ZA,21
4
+ xoscar-0.6.2.dist-info/METADATA,sha256=wovBXhCiwv2yIjh04jbMYRBrA9ZQpBtml6gVCW7YSTs,9131
5
5
  xoscar/_utils.pyx,sha256=6iqO4eTwEI-n9i39n_TKz7MWqbytMRnVNubdJ5egL6o,7279
6
6
  xoscar/backend.py,sha256=is436OPkZfSpQXaoqTRVta5eoye_pp45RFgCstAk2hU,1850
7
7
  xoscar/core.pxd,sha256=I_C2ka7XryyGnnAVXUVm8xfS1gtIrCs6X-9rswgOcUU,1317
@@ -10,16 +10,16 @@ xoscar/context.pxd,sha256=qKa0OyDPZtVymftSh447m-RzFZgmz8rGqQBa7qlauvc,725
10
10
  xoscar/batch.py,sha256=DpArS0L3WYJ_HVPG-6hSYEwoAFY1mY2-mlC4Jp5M_Dw,7872
11
11
  xoscar/nvutils.py,sha256=qmW4mKLU0WB2yCs198ccQOgLL02zB7Fsa-AotO3NOmg,20412
12
12
  xoscar/constants.py,sha256=QHHSREw6uWBBjQDCFqlNfTvBZgniJPGy42KSIsR8Fqw,787
13
- xoscar/core.cpython-312-darwin.so,sha256=MHNO5qn5RWaVUrESGK_bs2VsT8oTTfV6GHXkl74wUZ8,441432
13
+ xoscar/core.cpython-312-darwin.so,sha256=8N74L3IQXMBbLIyXynQTHuZmI_OdinZnk9cyhPXAQug,441432
14
14
  xoscar/__init__.py,sha256=0zX8kKaio3ZIrlzB79WybcravMJw1OxPWjDspTgJFyQ,1608
15
- xoscar/context.cpython-312-darwin.so,sha256=NfX20K0mWqjbGZV-wpWkR_Ugxz3onFqqG0uXnTXlN_8,210096
15
+ xoscar/context.cpython-312-darwin.so,sha256=0uT3Hh6uOxHzLt2AdQ5inuNk8nxbroDEsc4T8PwoZdU,210096
16
16
  xoscar/api.py,sha256=3hztPoOxg8A_mlhWyWgVP7FMXG0PATA1TP4Rbaj7A-g,13327
17
17
  xoscar/utils.py,sha256=jUw6OICZUPBbmS1b3GE4vLctJf6fCKXrYtLtBuK-Oqc,16483
18
18
  xoscar/debug.py,sha256=9Z8SgE2WaKYQcyDo-5-DxEJQ533v7kWjrvCd28pSx3E,5069
19
19
  xoscar/libcpp.pxd,sha256=DJqBxLFOKL4iRr9Kale5UH3rbvPRD1x5bTSOPHFpz9I,1147
20
20
  xoscar/context.pyx,sha256=8CdgPnWcE9eOp3N600WgDQ03MCi8P73eUOGcfV7Zksg,10942
21
21
  xoscar/errors.py,sha256=wBlQOKsXf0Fc4skN39tDie0YZT-VIAuLNRgoDl2pZcA,1241
22
- xoscar/_utils.cpython-312-darwin.so,sha256=fWAzrdkm19T_ihMjahogiheVGhgLcxDrkESEZBBuTc8,167168
22
+ xoscar/_utils.cpython-312-darwin.so,sha256=JOe8mI5185T479F2ZvhaxcP3zUzPRSUtVADrjzO4kTY,167168
23
23
  xoscar/core.pyx,sha256=phN-yYV0A0QI8WFi2jCu0nc4CnShTepfDi0V7ZrLYPY,22092
24
24
  xoscar/driver.py,sha256=498fowtJr6b3FE8FIOA_Tc1Vwx88nfZw7p0FxrML0h4,1372
25
25
  xoscar/profiling.py,sha256=BC5OF0HzSaXv8V7w-y-B8r5gV5DgxHFoTEIF6jCMioQ,8015
@@ -43,7 +43,7 @@ xoscar/serialization/exception.py,sha256=Jy8Lsk0z-VJyEUaWeuZIwkmxqaoB-nLKMa1D15C
43
43
  xoscar/serialization/pyfury.py,sha256=sifOnVMYoS82PzZEkzkfxesmMHei23k5UAUUKUyoOYQ,1163
44
44
  xoscar/serialization/core.pxd,sha256=k4RoJgX5E5LGs4jdCQ7vvcn26MabXbrWoWhkO49X6YI,985
45
45
  xoscar/serialization/core.pyi,sha256=-pQARSj91rt3iU4ftWGFH6jYwsSKYCT_Ya7EJsaGEjg,1874
46
- xoscar/serialization/core.cpython-312-darwin.so,sha256=xcAv3cxUIO3sJGVz58GoMt95rinT_OUhIcdgpJt1KwY,378616
46
+ xoscar/serialization/core.cpython-312-darwin.so,sha256=PDuDgUJYGXTZAg1EkXmZHzJYPhXeckQCbxfRVdCoctA,378616
47
47
  xoscar/serialization/__init__.py,sha256=v76XC2OQLp-Yk4_U3_IVguEylMeyRw1UrkU_DPDMh0U,856
48
48
  xoscar/serialization/numpy.py,sha256=5Kem87CvpJmzUMp3QHk4WeHU30FoQWTJJP2SwIcaQG0,2919
49
49
  xoscar/serialization/cuda.py,sha256=iFUEnN4SiquBIhyieyOrfw3TnKnW-tU_vYgqOxO_DrA,3758
@@ -58,13 +58,13 @@ xoscar/backends/__init__.py,sha256=VHEBQcUWM5bj027W8EUf9PiJUAP7JoMrRw3Tsvy5ySw,6
58
58
  xoscar/backends/core.py,sha256=EH-fHlV9x3bnruEHaUtGYO7osKLfLJ4AQHtuzA_mr2g,10857
59
59
  xoscar/backends/context.py,sha256=XfDPG2eDhAhE6hWBEkEsHTnyyOYN9R3houlMjAL7BFw,16329
60
60
  xoscar/backends/router.py,sha256=MVl5naz-FYf-Wla7XRn3kRxOpWV0SjKDsKNluifVA8M,10532
61
- xoscar/backends/message.cpython-312-darwin.so,sha256=QKper0LRYloF9IDuKVatLKyEE1Lc3fZ_Hu3EOx3Zggg,381056
61
+ xoscar/backends/message.cpython-312-darwin.so,sha256=Fuwl6iCpzldAR33hXOgwRCks786j5RfnmNi6cOFcshI,381056
62
62
  xoscar/backends/message.pyx,sha256=krGVtZ1YDaZX8yWhaNHwZiudQooLvcGlw6x3Sq7jxjE,19685
63
63
  xoscar/backends/pool.py,sha256=OezOhvvXAV3TpODhLHmJVgqCfowb3aA_fWZKPodm8bE,61003
64
64
  xoscar/backends/indigen/backend.py,sha256=znl_fZzWGEtLH8hZ9j9Kkf0fva25jEem2_KO7I1RVvc,1612
65
65
  xoscar/backends/indigen/__init__.py,sha256=tKHP5ClzedBRBpZsLRVErR3EUNbbDm4CY4u0rCFJr44,685
66
66
  xoscar/backends/indigen/driver.py,sha256=VGzkacYKykegW5qhCuhx01gdgBZEKJjNIyfNCnA6Nm8,952
67
- xoscar/backends/indigen/pool.py,sha256=v0Ps79W0WyeFSt2YxCJnh7q_1dnRQmo9887gcW3pNoc,17226
67
+ xoscar/backends/indigen/pool.py,sha256=eeT29MDwou7UQrfY9B9Z7iY6TI7DlWvrZxg0euz96eA,18287
68
68
  xoscar/backends/test/backend.py,sha256=nv9WFhH5Bbq4Q1HB9yfpciZBaeHT4IQAtzugBWESrUY,1263
69
69
  xoscar/backends/test/__init__.py,sha256=j2ZfD6prD9WjUxRUDC7Eq5Z7N7TkL6fFr59oNyc_vY4,682
70
70
  xoscar/backends/test/pool.py,sha256=TW4X6J-92Pti66103poQBNDBznX6CBD3RLOc_zixjTo,7257
@@ -1,5 +1,5 @@
1
1
  Wheel-Version: 1.0
2
- Generator: setuptools (78.1.0)
2
+ Generator: setuptools (79.0.0)
3
3
  Root-Is-Purelib: false
4
4
  Tag: cp312-cp312-macosx_11_0_arm64
5
5