QuLab 2.10.5__cp312-cp312-macosx_10_13_universal2.whl → 2.10.6__cp312-cp312-macosx_10_13_universal2.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.
qulab/dicttree.py CHANGED
@@ -297,8 +297,8 @@ def update_tree(result, updates):
297
297
  return result
298
298
 
299
299
 
300
- def queryref_tree(q, keys, dct, prefix=[], chain=None):
301
- q = q[1:]
300
+ def queryref_tree(q: str, keys, dct, prefix=[], chain=None):
301
+ q = q.removeprefix('$')
302
302
  if q.startswith('.'):
303
303
  while q.startswith('.'):
304
304
  keys.pop()
@@ -340,7 +340,7 @@ class Env():
340
340
  self.prefix = prefix
341
341
 
342
342
  def get(self, name):
343
- return queryref_tree(name[1:],
343
+ return queryref_tree(name,
344
344
  self.keys,
345
345
  self.dct,
346
346
  prefix=self.prefix,
@@ -405,8 +405,9 @@ internal_functions = {
405
405
 
406
406
 
407
407
  def eval_expr(expression, env=None, functions=None):
408
- from pyparsing import (Forward, Literal, ParseResults, Suppress, Word,
409
- alphanums, delimitedList, infixNotation, oneOf,
408
+ from pyparsing import (Combine, Forward, Literal, MatchFirst, ParseResults,
409
+ Regex, Suppress, Word, ZeroOrMore, alphanums,
410
+ alphas, delimitedList, infixNotation, oneOf,
410
411
  opAssoc, pyparsing_common)
411
412
  if functions is None:
412
413
  functions = internal_functions
@@ -436,8 +437,19 @@ def eval_expr(expression, env=None, functions=None):
436
437
  'e': math.e
437
438
  }.get(t[0]))
438
439
 
439
- variable = Word("$", alphanums +
440
- "._").setParseAction(lambda s, l, t: lookup(t[0]))
440
+ identifier = Word(alphas + '_', alphanums + '_')
441
+ dollar = Literal('$')
442
+ dot_sequence = Regex(r'\.{1,}')
443
+ attr = Combine(Literal('.') + identifier)
444
+ attr_chain = ZeroOrMore(attr)
445
+ dollar_named_chain = Combine(dollar + identifier + attr_chain)
446
+ dollar_dotN_chain = Combine(dollar + dot_sequence + identifier +
447
+ attr_chain)
448
+ dollar_simple = Combine(dollar + identifier)
449
+
450
+ variable = MatchFirst(
451
+ [dollar_dotN_chain, dollar_named_chain,
452
+ dollar_simple]).setParseAction(lambda s, l, t: lookup(t[0]))
441
453
 
442
454
  bracket = Suppress('(') + expr + Suppress(')')
443
455
  bracket.setParseAction(lambda s, l, t: t[0])
qulab/executor/load.py CHANGED
@@ -1,10 +1,10 @@
1
1
  import atexit
2
2
  import inspect
3
- import pickle
4
3
  import os
5
- import time
4
+ import pickle
6
5
  import shutil
7
6
  import tempfile
7
+ import time
8
8
  import warnings
9
9
  from importlib.util import module_from_spec, spec_from_file_location
10
10
  from pathlib import Path
@@ -13,6 +13,7 @@ from typing import Any
13
13
 
14
14
  from loguru import logger
15
15
 
16
+ from .registry import Registry
16
17
  from .storage import Report
17
18
  from .template import (TemplateKeyError, TemplateTypeError, decode_mapping,
18
19
  inject_mapping)
@@ -31,17 +32,16 @@ class SetConfigWorkflow():
31
32
  return []
32
33
 
33
34
  def check_state(self, history: Report) -> bool:
34
- from . import transform
35
+ reg = Registry()
35
36
  try:
36
- return self._equal(history.parameters[self.key],
37
- transform.query_config(self.key))
37
+ return self._equal(history.parameters[self.key], reg.get(self.key))
38
38
  except:
39
39
  return False
40
40
 
41
41
  def calibrate(self):
42
- from . import transform
42
+ reg = Registry()
43
43
  try:
44
- value = transform.query_config(self.key)
44
+ value = reg.get(self.key)
45
45
  except:
46
46
  value = eval(input(f'"{self.key}": '))
47
47
  return value
@@ -129,7 +129,7 @@ def set_config_api(query_method,
129
129
  clear_method: The clear method.
130
130
  the method should clear the config.
131
131
  """
132
- global query_config, update_config, delete_config, export_config, clear_config
132
+ global query_config, update_config, delete_config, export_config, clear_config, _api
133
133
 
134
134
  query_config = query_method
135
135
  update_config = update_method
@@ -159,23 +159,27 @@ _init()
159
159
 
160
160
  class Registry():
161
161
 
162
+ def __init__(self):
163
+ self.api = (query_config, update_config, delete_config, export_config,
164
+ clear_config)
165
+
162
166
  def query(self, key: str) -> Any:
163
- return query_config(key)
167
+ return self.api[0](key)
164
168
 
165
169
  def get(self, key: str) -> Any:
166
170
  return self.query(key)
167
171
 
168
172
  def export(self) -> dict[str, dict[str, Any]]:
169
- return export_config()
173
+ return self.api[3]()
170
174
 
171
175
  def set(self, key: str, value: Any):
172
- return update_config({key: value})
176
+ return self.api[1]({key: value})
173
177
 
174
178
  def delete(self, key: str):
175
- return delete_config(key)
179
+ return self.api[2](key)
176
180
 
177
181
  def clear(self):
178
- return clear_config()
182
+ return self.api[4]()
179
183
 
180
184
  def update(self, parameters: dict[str, Any]):
181
- return update_config(parameters)
185
+ return self.api[1](parameters)
Binary file
qulab/scan/__init__.py CHANGED
@@ -1,3 +1,2 @@
1
- from .expression import Expression, Symbol
2
1
  from .query import get_record, load_record, lookup, lookup_list
3
2
  from .scan import Scan
qulab/scan/scan.py CHANGED
@@ -18,8 +18,8 @@ import dill
18
18
  import numpy as np
19
19
  import zmq
20
20
 
21
+ from ..expression import Env, Expression, Symbol
21
22
  from ..sys.rpc.zmq_socket import ZMQContextManager
22
- from .expression import Env, Expression, Symbol
23
23
  from .optimize import NgOptimizer
24
24
  from .record import Record
25
25
  from .server import default_record_port
@@ -509,7 +509,8 @@ class Scan():
509
509
 
510
510
  if self.config:
511
511
  self.description['config'] = await create_config(
512
- self._raw_config_copy, self.description['database'], self._sock)
512
+ self._raw_config_copy, self.description['database'],
513
+ self._sock)
513
514
  if current_notebook() is None:
514
515
  await create_notebook('untitle', self.description['database'],
515
516
  self._sock)
qulab/scan/utils.py CHANGED
@@ -11,7 +11,7 @@ from typing import Any, Callable
11
11
 
12
12
  import dill
13
13
 
14
- from .expression import Env, Expression
14
+ from ..expression import Env, Expression
15
15
 
16
16
 
17
17
  class Unpicklable:
qulab/version.py CHANGED
@@ -1 +1 @@
1
- __version__ = "2.10.5"
1
+ __version__ = "2.10.6"
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: QuLab
3
- Version: 2.10.5
3
+ Version: 2.10.6
4
4
  Summary: contral instruments and manage data
5
5
  Author-email: feihoo87 <feihoo87@gmail.com>
6
6
  Maintainer-email: feihoo87 <feihoo87@gmail.com>
@@ -1,10 +1,11 @@
1
1
  qulab/__init__.py,sha256=WW0jUmIXEp_8cfLVUtg-C8COIDbZp0X9mIlz3suJkrU,407
2
2
  qulab/__main__.py,sha256=fjaRSL_uUjNIzBGNgjlGswb9TJ2VD5qnkZHW3hItrD4,68
3
- qulab/dicttree.py,sha256=tRRMpGZYVOLw0TEByE3_2Ss8FdOmzuGL9e1DWbs8qoY,13684
4
- qulab/fun.cpython-312-darwin.so,sha256=VrWNWeevnfBiXyna4lKAzG5_hV1vL7DMNCZrbUKpLgM,126864
3
+ qulab/dicttree.py,sha256=QNClEGRFRFJIgAq9bUyxK4iPbkNRdZDona8UZq9jDfw,14236
4
+ qulab/expression.py,sha256=Mk9-hzmTzDszM0p6J_FlrewzQerOBWhRv5_iFApA768,24978
5
+ qulab/fun.cpython-312-darwin.so,sha256=_1ZPLCeDfMYHJIpUWUPVcwJGpbEiOJr9LtIDJLlawVM,126864
5
6
  qulab/typing.py,sha256=vg62sGqxuD9CI5677ejlzAmf2fVdAESZCQjAE_xSxPg,69
6
7
  qulab/utils.py,sha256=BdLdlfjpe6m6gSeONYmpAKTTqxDaYHNk4exlz8kZxTg,2982
7
- qulab/version.py,sha256=SB3sQYH0e-iHrGpjw5MXxU2T-sxkpouM4O_fyPlJPXQ,22
8
+ qulab/version.py,sha256=9LJkGNy79PoPvb-ypqzJeCk2XlpeUgkGouuN08RGMH4,22
8
9
  qulab/cli/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
9
10
  qulab/cli/commands.py,sha256=F1LATmSC9lOAdnrOTMK7DRjETCEcOmMsocovWRyjWTc,597
10
11
  qulab/cli/config.py,sha256=fWeWHiX-Oxodvfv4g0B-UFisJlYcF1Hv6V1fKib2mOM,5447
@@ -12,8 +13,8 @@ qulab/cli/decorators.py,sha256=oImteZVnDPPWdyhJ4kzf2KYGJLON7VsKGBvZadWLQZo,621
12
13
  qulab/executor/__init__.py,sha256=LosPzOMaljSZY1thy_Fxtbrgq7uubJszMABEB7oM7tU,101
13
14
  qulab/executor/analyze.py,sha256=4Hau5LrKUdpweh7W94tcG4ahgxucHOevbM0hm57T7zE,5649
14
15
  qulab/executor/cli.py,sha256=bmuFPpPhHiRzTjIjhvlp2tQYp0jEwXSETILX8Nu2tLE,14901
15
- qulab/executor/load.py,sha256=0-EtO4dkP6jB1vsgQlniv-OtPH1AZLjbtuvaWHsgbPs,20335
16
- qulab/executor/registry.py,sha256=qqj90HVYun-DDI9HPmwyOQI87M2mQ0jyw4vWwPMfYjg,4592
16
+ qulab/executor/load.py,sha256=C5qepxC9QALMgfG_twxvGts6i0bCsnVg9lS05PXZZRM,20291
17
+ qulab/executor/registry.py,sha256=gym9F5FIDY5eV-cSCZsP99wC4l-6jkx9VMjJMaPOLaQ,4730
17
18
  qulab/executor/schedule.py,sha256=7gAJFwj13j1niGjVa1fSzwOS22eNFEN1hdrN3dfTY6A,21410
18
19
  qulab/executor/storage.py,sha256=8K73KGLAVgchJdtd4rKHXkr1CQOJORWH-Gi57w8IYsw,21081
19
20
  qulab/executor/template.py,sha256=_HEtsUQ5_jSujCw8FBDAK1PRTMRCa4iD4DduHIpjo3c,10569
@@ -28,17 +29,16 @@ qulab/monitor/monitor.py,sha256=7E4bnTsO6qC85fs2ONrccGHfaYKv7SW74mtXzv6QjVc,2305
28
29
  qulab/monitor/ploter.py,sha256=CbiIjmohgtwDDTVeGzhXEGVo3XjytMdhLwU9VUkg9vo,3601
29
30
  qulab/monitor/qt_compat.py,sha256=OK71_JSO_iyXjRIKHANmaK4Lx4bILUzmXI-mwKg3QeI,788
30
31
  qulab/monitor/toolbar.py,sha256=WEag6cxAtEsOLL14XvM7pSE56EA3MO188_JuprNjdBs,7948
31
- qulab/scan/__init__.py,sha256=ZX4WsvqYxvJeHLgGSrtJoAnVU94gxY7EHKMxYooMERg,130
32
+ qulab/scan/__init__.py,sha256=Z88CzGsvr1VdKbF6aYgQv3j-fsEkKmqvpvX4LlzOM98,87
32
33
  qulab/scan/curd.py,sha256=ZcwO5SKO95OcDgpUPDHcK5FW_BrJbUzuBk71UG_pqnM,6888
33
- qulab/scan/expression.py,sha256=Mk9-hzmTzDszM0p6J_FlrewzQerOBWhRv5_iFApA768,24978
34
34
  qulab/scan/models.py,sha256=JFofv-RH0gpS3--M6izXiQg7iGkS9a_em2DwhS5kTTk,17626
35
35
  qulab/scan/optimize.py,sha256=VT9TpuqDkG7FdJJkYy60r5Pfrmjvfu5i36Ru6XvIiTI,2561
36
36
  qulab/scan/query.py,sha256=-5uHMhXSyGovK1oy_uUbGVEbRFzaMBkP78ZMNfI3jD0,11809
37
37
  qulab/scan/record.py,sha256=yIHPANf6nuBXy8Igf-dMtGJ7wuFTLYlBaaAUc0AzwyU,21280
38
- qulab/scan/scan.py,sha256=iXvbnXLZvHa4v88MlYiZ_LYubEB7ZfbX7OiFTMhl_1o,39479
38
+ qulab/scan/scan.py,sha256=6ksam9jQ5yplt-VxCo9Mntys5NJ_00TCuitDmRSYHoY,39496
39
39
  qulab/scan/server.py,sha256=QhUo-TxdTb_PDBd4sDRiI5L1WHmuEOAYEmUiFhjNqc4,16995
40
40
  qulab/scan/space.py,sha256=OQLepiNNP5TNYMHXeVFT59lL5n4soPmnMoMy_o9EHt0,6696
41
- qulab/scan/utils.py,sha256=SzJ_c4cLZJzERZr_CJO1_4juOxjfwCpU2K1mkc1PWGM,6124
41
+ qulab/scan/utils.py,sha256=WFVzwtVebvfYRgMo1ofaWLx90grjMKuoUB8RaK0DMts,6125
42
42
  qulab/storage/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
43
43
  qulab/storage/__main__.py,sha256=3emxxRry8BB0m8hUZvJ_oBqkPy7ksV7flHB_KEDXZuI,1692
44
44
  qulab/storage/base_dataset.py,sha256=4aKhqBNdZfdlm_z1Qy5dv0HrvgpvMdy8pbyfua8uE-4,11865
@@ -99,9 +99,9 @@ qulab/visualization/plot_seq.py,sha256=UWTS6p9nfX_7B8ehcYo6UnSTUCjkBsNU9jiOeW2ca
99
99
  qulab/visualization/qdat.py,sha256=ZeevBYWkzbww4xZnsjHhw7wRorJCBzbG0iEu-XQB4EA,5735
100
100
  qulab/visualization/rot3d.py,sha256=lMrEJlRLwYe6NMBlGkKYpp_V9CTipOAuDy6QW_cQK00,734
101
101
  qulab/visualization/widgets.py,sha256=6KkiTyQ8J-ei70LbPQZAK35wjktY47w2IveOa682ftA,3180
102
- qulab-2.10.5.dist-info/licenses/LICENSE,sha256=PRzIKxZtpQcH7whTG6Egvzl1A0BvnSf30tmR2X2KrpA,1065
103
- qulab-2.10.5.dist-info/METADATA,sha256=YoyVkSlWyuWsJ0G71thGPi8_AQDCKCkTPYEbM77BxZw,3753
104
- qulab-2.10.5.dist-info/WHEEL,sha256=9_3tTSxMJq-dgdzMiScNvtT5eTBVd3l6RgHS7HwTzpA,115
105
- qulab-2.10.5.dist-info/entry_points.txt,sha256=b0v1GXOwmxY-nCCsPN_rHZZvY9CtTbWqrGj8u1m8yHo,45
106
- qulab-2.10.5.dist-info/top_level.txt,sha256=3T886LbAsbvjonu_TDdmgxKYUn939BVTRPxPl9r4cEg,6
107
- qulab-2.10.5.dist-info/RECORD,,
102
+ qulab-2.10.6.dist-info/licenses/LICENSE,sha256=PRzIKxZtpQcH7whTG6Egvzl1A0BvnSf30tmR2X2KrpA,1065
103
+ qulab-2.10.6.dist-info/METADATA,sha256=Fmj-XQg6wrotuM0aRpAoSWF7x8JiYNAmRMjFFAsbqJs,3753
104
+ qulab-2.10.6.dist-info/WHEEL,sha256=9_3tTSxMJq-dgdzMiScNvtT5eTBVd3l6RgHS7HwTzpA,115
105
+ qulab-2.10.6.dist-info/entry_points.txt,sha256=b0v1GXOwmxY-nCCsPN_rHZZvY9CtTbWqrGj8u1m8yHo,45
106
+ qulab-2.10.6.dist-info/top_level.txt,sha256=3T886LbAsbvjonu_TDdmgxKYUn939BVTRPxPl9r4cEg,6
107
+ qulab-2.10.6.dist-info/RECORD,,
File without changes
File without changes