sm-blueprint-lib 0.0.4__tar.gz → 0.0.6__tar.gz

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.
Files changed (43) hide show
  1. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/.gitignore +0 -1
  2. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/PKG-INFO +1 -1
  3. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/pyproject.toml +1 -1
  4. sm_blueprint_lib-0.0.6/src/sm_blueprint_lib/__init__.py +10 -0
  5. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/bases/controllers/basecontroller.py +2 -2
  6. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/bases/controllers/baselogiccontroller.py +1 -1
  7. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/bases/controllers/logicgatecontroller.py +1 -1
  8. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/bases/controllers/sensorcontroller.py +1 -1
  9. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/bases/controllers/timercontroller.py +1 -1
  10. sm_blueprint_lib-0.0.6/src/sm_blueprint_lib/bases/parts/baseboundablepart.py +23 -0
  11. sm_blueprint_lib-0.0.6/src/sm_blueprint_lib/bases/parts/baseinteractablepart.py +19 -0
  12. sm_blueprint_lib-0.0.6/src/sm_blueprint_lib/bases/parts/baselogicpart.py +13 -0
  13. sm_blueprint_lib-0.0.6/src/sm_blueprint_lib/bases/parts/basepart.py +34 -0
  14. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/blueprint.py +3 -3
  15. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/body.py +2 -2
  16. sm_blueprint_lib-0.0.6/src/sm_blueprint_lib/parts/barrierblock.py +9 -0
  17. sm_blueprint_lib-0.0.6/src/sm_blueprint_lib/parts/logicgate.py +24 -0
  18. sm_blueprint_lib-0.0.6/src/sm_blueprint_lib/parts/sensor.py +24 -0
  19. sm_blueprint_lib-0.0.6/src/sm_blueprint_lib/parts/switch.py +9 -0
  20. sm_blueprint_lib-0.0.6/src/sm_blueprint_lib/parts/timer.py +20 -0
  21. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/prebuilds/adder.py +4 -4
  22. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/prebuilds/barrel_shifter.py +4 -4
  23. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/prebuilds/clock40hz.py +4 -4
  24. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/prebuilds/comparator.py +4 -4
  25. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/prebuilds/counter.py +4 -4
  26. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/prebuilds/decoder.py +4 -4
  27. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/prebuilds/distance_sensor.py +6 -6
  28. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/prebuilds/ram.py +5 -5
  29. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/prebuilds/register.py +5 -5
  30. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/prebuilds/rom.py +6 -6
  31. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/prebuilds/timer_ram_cached.py +13 -13
  32. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/prebuilds/timer_ram_multiclient.py +9 -9
  33. sm_blueprint_lib-0.0.4/src/sm_blueprint_lib/__init__.py → sm_blueprint_lib-0.0.6/src/sm_blueprint_lib/utils.py +6 -6
  34. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/.gitattributes +0 -0
  35. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/LICENSE +0 -0
  36. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/README.md +0 -0
  37. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/bounds.py +0 -0
  38. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/constants.py +0 -0
  39. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/id.py +0 -0
  40. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/src/sm_blueprint_lib/pos.py +0 -0
  41. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/test_connections.py +0 -0
  42. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/test_prebuilds.py +0 -0
  43. {sm_blueprint_lib-0.0.4 → sm_blueprint_lib-0.0.6}/tests.py +0 -0
@@ -16,7 +16,6 @@ eggs/
16
16
  .eggs/
17
17
  lib/
18
18
  lib64/
19
- parts/
20
19
  sdist/
21
20
  var/
22
21
  wheels/
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: sm_blueprint_lib
3
- Version: 0.0.4
3
+ Version: 0.0.6
4
4
  Summary: Scrap Mechanic Library for Blueprint manipulation.
5
5
  Project-URL: Homepage, https://github.com/MauriceTZ/sm_blueprint_lib
6
6
  Project-URL: Issues, https://github.com/MauriceTZ/sm_blueprint_lib/issues
@@ -4,7 +4,7 @@ build-backend = "hatchling.build"
4
4
 
5
5
  [project]
6
6
  name = "sm_blueprint_lib"
7
- version = "0.0.4"
7
+ version = "0.0.6"
8
8
  dependencies = ["numpy"]
9
9
  authors = [
10
10
  { name="Maurice", email="mauriciotorrez00@gmail.com" },
@@ -0,0 +1,10 @@
1
+ from .blueprint import Blueprint
2
+ from .body import *
3
+ from .bounds import *
4
+ from .constants import *
5
+ from .id import *
6
+ from .pos import *
7
+ from .utils import *
8
+
9
+ from .parts import *
10
+ from .prebuilds import *
@@ -1,8 +1,8 @@
1
1
  from dataclasses import dataclass, field
2
2
  from typing import Any, Optional
3
3
 
4
- from sm_blueprint_lib.constants import get_new_id
5
- from sm_blueprint_lib.id import ID
4
+ from ...constants import get_new_id
5
+ from ...id import ID
6
6
 
7
7
 
8
8
  @dataclass
@@ -1,6 +1,6 @@
1
1
  from dataclasses import dataclass, field
2
2
 
3
- from sm_blueprint_lib.bases.controllers.basecontroller import BaseController
3
+ from .basecontroller import BaseController
4
4
 
5
5
 
6
6
  @dataclass
@@ -1,6 +1,6 @@
1
1
  from dataclasses import dataclass, field
2
2
 
3
- from sm_blueprint_lib.bases.controllers.baselogiccontroller import BaseLogicController
3
+ from .baselogiccontroller import BaseLogicController
4
4
 
5
5
 
6
6
  @dataclass
@@ -1,6 +1,6 @@
1
1
  from dataclasses import dataclass, field
2
2
 
3
- from sm_blueprint_lib.bases.controllers.basecontroller import BaseController
3
+ from .basecontroller import BaseController
4
4
 
5
5
 
6
6
  @dataclass
@@ -1,6 +1,6 @@
1
1
  from dataclasses import dataclass, field
2
2
 
3
- from sm_blueprint_lib.bases.controllers.baselogiccontroller import BaseLogicController
3
+ from .baselogiccontroller import BaseLogicController
4
4
 
5
5
 
6
6
  @dataclass
@@ -0,0 +1,23 @@
1
+ from dataclasses import dataclass, field
2
+
3
+ from .basepart import BasePart
4
+ from ...bounds import Bounds
5
+ from ...constants import AXIS
6
+
7
+
8
+ @dataclass
9
+ class BaseBoundablePart(BasePart):
10
+ """Base class for all Boundable parts (those that are draggable)
11
+ """
12
+ bounds: Bounds
13
+ xaxis: int = field(kw_only=True, default=AXIS.DEFAULT_XAXIS)
14
+ zaxis: int = field(kw_only=True, default=AXIS.DEFAULT_ZAXIS)
15
+
16
+ def __post_init__(self):
17
+ super().__post_init__()
18
+ if not isinstance(self.bounds, Bounds):
19
+ try:
20
+ self.bounds = Bounds(**self.bounds)
21
+ except TypeError:
22
+ self.bounds = Bounds(
23
+ self.bounds[0], self.bounds[1], self.bounds[2])
@@ -0,0 +1,19 @@
1
+ from dataclasses import dataclass, field
2
+
3
+ from ..controllers.basecontroller import BaseController
4
+ from .basepart import BasePart
5
+ from ...id import ID
6
+
7
+
8
+ @dataclass
9
+ class BaseInteractablePart(BasePart):
10
+ """Base class for Interactable parts
11
+ """
12
+ controller: BaseController = field(default_factory=BaseController)
13
+
14
+ def connect(self, o: "BaseInteractablePart"):
15
+ if not self.controller.controllers:
16
+ self.controller.controllers = []
17
+
18
+ self.controller.controllers.append(ID(o.controller.id))
19
+ return o
@@ -0,0 +1,13 @@
1
+ from dataclasses import dataclass, field
2
+
3
+ from .baseinteractablepart import BaseInteractablePart
4
+ from ..controllers.baselogiccontroller import BaseLogicController
5
+
6
+
7
+ @dataclass
8
+ class BaseLogicPart(BaseInteractablePart):
9
+ """Base class for Logic parts with active state (mostly Logic Gate and Timer)
10
+ """
11
+ controller: BaseLogicController = field(default_factory=BaseLogicController)
12
+ xaxis: int = field(kw_only=True, default=1)
13
+ zaxis: int = field(kw_only=True, default=-2)
@@ -0,0 +1,34 @@
1
+ from dataclasses import dataclass, field
2
+
3
+ from ...constants import AXIS, SHAPEID
4
+ from ...pos import Pos
5
+
6
+
7
+ @dataclass
8
+ class BasePart:
9
+ """Base class for all in-game parts
10
+ """
11
+ shapeId: str
12
+ pos: Pos
13
+ color: str
14
+ xaxis: int = field(kw_only=True, default=AXIS.DEFAULT_XAXIS)
15
+ zaxis: int = field(kw_only=True, default=AXIS.DEFAULT_ZAXIS)
16
+
17
+ def __post_init__(self):
18
+ # if pos given as {"x": ..., "y": ..., "z": ...} or (x, y, z) then convert to Pos class
19
+ if not isinstance(self.pos, Pos):
20
+ try:
21
+ self.pos = Pos(**self.pos)
22
+ except TypeError:
23
+ self.pos = Pos(self.pos[0], self.pos[1], self.pos[2])
24
+ # if color given as (r, g, b) then convert to hex string
25
+ if not isinstance(self.color, str):
26
+ self.color = "%02X%02X%02X" % (
27
+ self.color[0], self.color[1], self.color[2])
28
+
29
+ def __init_subclass__(cls):
30
+ super().__init_subclass__()
31
+ try:
32
+ SHAPEID.SHAPEID_TO_CLASS[cls.shapeId.default] = cls
33
+ except AttributeError:
34
+ pass
@@ -1,8 +1,8 @@
1
1
  from dataclasses import dataclass, field
2
2
 
3
- from sm_blueprint_lib.bases.parts.basepart import BasePart
4
- from sm_blueprint_lib.body import Body
5
- from sm_blueprint_lib.constants import VERSION
3
+ from .bases.parts.basepart import BasePart
4
+ from .body import Body
5
+ from .constants import VERSION
6
6
 
7
7
 
8
8
  @dataclass
@@ -1,7 +1,7 @@
1
1
  from dataclasses import dataclass, field
2
2
 
3
- from sm_blueprint_lib.bases.parts.basepart import BasePart
4
- from sm_blueprint_lib.constants import SHAPEID
3
+ from .bases.parts.basepart import BasePart
4
+ from .constants import SHAPEID
5
5
 
6
6
 
7
7
  @dataclass
@@ -0,0 +1,9 @@
1
+ from dataclasses import dataclass, field
2
+
3
+ from ..bases.parts.baseboundablepart import BaseBoundablePart
4
+ from ..constants import SHAPEID
5
+
6
+
7
+ @dataclass
8
+ class BarrierBlock(BaseBoundablePart):
9
+ shapeId: str = field(kw_only=True, default=SHAPEID.BARRIER_BLOCK)
@@ -0,0 +1,24 @@
1
+ from dataclasses import dataclass, field
2
+
3
+ from ..bases.parts.baselogicpart import BaseLogicPart
4
+ from ..bases.controllers.logicgatecontroller import LogicGateController
5
+ from ..constants import SHAPEID
6
+
7
+
8
+ @dataclass
9
+ class LogicGate(BaseLogicPart):
10
+ controller: LogicGateController = field(
11
+ default_factory=LogicGateController)
12
+ shapeId: str = field(kw_only=True, default=SHAPEID.LOGIC_GATE)
13
+
14
+ def __post_init__(self):
15
+ super().__post_init__()
16
+ # Can specify mode as a dict, a tuple (mode,) or just the parameter mode
17
+ if not isinstance(self.controller, LogicGateController):
18
+ try:
19
+ self.controller = LogicGateController(**self.controller)
20
+ except TypeError:
21
+ try:
22
+ self.controller = LogicGateController(*self.controller)
23
+ except TypeError:
24
+ self.controller = LogicGateController(self.controller)
@@ -0,0 +1,24 @@
1
+ from dataclasses import dataclass, field
2
+
3
+ from ..bases.controllers.sensorcontroller import SensorController
4
+ from ..bases.parts.baseinteractablepart import BaseInteractablePart
5
+ from ..constants import SHAPEID
6
+
7
+
8
+ @dataclass
9
+ class Sensor5(BaseInteractablePart):
10
+ controller: SensorController = field(
11
+ default_factory=SensorController)
12
+ shapeId: str = field(kw_only=True, default=SHAPEID.SENSOR5)
13
+
14
+ def __post_init__(self):
15
+ super().__post_init__()
16
+ # Can specify sensor controller as a dict, a tuple (audioEnable, buttonMode, color, colorMode, range) or just the parameter mode
17
+ if not isinstance(self.controller, SensorController):
18
+ try:
19
+ self.controller = SensorController(**self.controller)
20
+ except TypeError:
21
+ try:
22
+ self.controller = SensorController(*self.controller)
23
+ except TypeError:
24
+ self.controller = SensorController(self.controller)
@@ -0,0 +1,9 @@
1
+ from dataclasses import dataclass, field
2
+
3
+ from ..bases.parts.baseinteractablepart import BaseInteractablePart
4
+ from ..constants import SHAPEID
5
+
6
+
7
+ @dataclass
8
+ class Switch(BaseInteractablePart):
9
+ raise NotImplemented
@@ -0,0 +1,20 @@
1
+ from dataclasses import dataclass, field
2
+
3
+ from ..bases.controllers.timercontroller import TimerController
4
+ from ..bases.parts.baselogicpart import BaseLogicPart
5
+ from ..constants import SHAPEID
6
+
7
+
8
+ @dataclass
9
+ class Timer(BaseLogicPart):
10
+ controller: TimerController = field(default_factory=TimerController)
11
+ shapeId: str = field(kw_only=True, default=SHAPEID.TIMER)
12
+
13
+ def __post_init__(self):
14
+ super().__post_init__()
15
+ # Can provide seconds and ticks as a the TimerController class itself, a dict or a tuple (seconds, tick)
16
+ if not isinstance(self.controller, TimerController):
17
+ try:
18
+ self.controller = TimerController(**self.controller)
19
+ except TypeError:
20
+ self.controller = TimerController(*self.controller)
@@ -1,9 +1,9 @@
1
1
  from typing import Sequence
2
2
  from numpy import ndarray
3
- from sm_blueprint_lib import get_bits_required, check_pos, connect, num_to_bit_list
4
- from sm_blueprint_lib.blueprint import Blueprint
5
- from sm_blueprint_lib.parts.logicgate import LogicGate
6
- from sm_blueprint_lib.pos import Pos
3
+ from ..utils import get_bits_required, check_pos, connect, num_to_bit_list
4
+ from ..blueprint import Blueprint
5
+ from ..parts.logicgate import LogicGate
6
+ from ..pos import Pos
7
7
 
8
8
 
9
9
  def simple_adder_subtractor(bp: Blueprint,
@@ -1,9 +1,9 @@
1
1
  from typing import Sequence
2
2
  from numpy import ndarray
3
- from sm_blueprint_lib import get_bits_required, check_pos, connect, num_to_bit_list
4
- from sm_blueprint_lib.blueprint import Blueprint
5
- from sm_blueprint_lib.parts.logicgate import LogicGate
6
- from sm_blueprint_lib.pos import Pos
3
+ from ..utils import get_bits_required, check_pos, connect, num_to_bit_list
4
+ from ..blueprint import Blueprint
5
+ from ..parts.logicgate import LogicGate
6
+ from ..pos import Pos
7
7
 
8
8
 
9
9
  def barrel_shifter(bp: Blueprint, bit_length: int, num_bit_shift: int, pos: Pos | Sequence = (0, 0, 0)):
@@ -1,9 +1,9 @@
1
1
  from typing import Sequence
2
2
  from numpy import ndarray
3
- from sm_blueprint_lib import get_bits_required, check_pos, connect, num_to_bit_list
4
- from sm_blueprint_lib.blueprint import Blueprint
5
- from sm_blueprint_lib.parts.logicgate import LogicGate
6
- from sm_blueprint_lib.pos import Pos
3
+ from ..utils import get_bits_required, check_pos, connect, num_to_bit_list
4
+ from ..blueprint import Blueprint
5
+ from ..parts.logicgate import LogicGate
6
+ from ..pos import Pos
7
7
 
8
8
 
9
9
  def clock40hz(bp: Blueprint, bit_length: int, pos: Pos | Sequence = (0, 0, 0)):
@@ -1,9 +1,9 @@
1
1
  from typing import Sequence
2
2
  from numpy import ndarray
3
- from sm_blueprint_lib import check_pos, connect
4
- from sm_blueprint_lib.blueprint import Blueprint
5
- from sm_blueprint_lib.parts.logicgate import LogicGate
6
- from sm_blueprint_lib.pos import Pos
3
+ from ..utils import check_pos, connect
4
+ from ..blueprint import Blueprint
5
+ from ..parts.logicgate import LogicGate
6
+ from ..pos import Pos
7
7
 
8
8
 
9
9
  def comparator(bp: Blueprint,
@@ -1,9 +1,9 @@
1
1
  from typing import Sequence
2
2
  from numpy import ndarray
3
- from sm_blueprint_lib import get_bits_required, check_pos, connect, num_to_bit_list
4
- from sm_blueprint_lib.blueprint import Blueprint
5
- from sm_blueprint_lib.parts.logicgate import LogicGate
6
- from sm_blueprint_lib.pos import Pos
3
+ from ..utils import get_bits_required, check_pos, connect, num_to_bit_list
4
+ from ..blueprint import Blueprint
5
+ from ..parts.logicgate import LogicGate
6
+ from ..pos import Pos
7
7
 
8
8
 
9
9
  def counter(bp: Blueprint,
@@ -1,9 +1,9 @@
1
1
  from typing import Sequence
2
2
  from numpy import ndarray
3
- from sm_blueprint_lib import get_bits_required, check_pos, connect, num_to_bit_list
4
- from sm_blueprint_lib.blueprint import Blueprint
5
- from sm_blueprint_lib.parts.logicgate import LogicGate
6
- from sm_blueprint_lib.pos import Pos
3
+ from ..utils import get_bits_required, check_pos, connect, num_to_bit_list
4
+ from ..blueprint import Blueprint
5
+ from ..parts.logicgate import LogicGate
6
+ from ..pos import Pos
7
7
 
8
8
 
9
9
  def decoder(bp: Blueprint, num_address: int, pos: Pos | Sequence = (0, 0, 0),
@@ -1,11 +1,11 @@
1
1
  from typing import Sequence
2
2
  from numpy import array, ndarray
3
- from sm_blueprint_lib import get_bits_required, check_pos, connect, num_to_bit_list
4
- from sm_blueprint_lib.blueprint import Blueprint
5
- from sm_blueprint_lib.parts.logicgate import LogicGate
6
- from sm_blueprint_lib.parts.sensor import Sensor5
7
- from sm_blueprint_lib.parts.timer import Timer
8
- from sm_blueprint_lib.pos import Pos
3
+ from ..utils import get_bits_required, check_pos, connect, num_to_bit_list
4
+ from ..blueprint import Blueprint
5
+ from ..parts.logicgate import LogicGate
6
+ from ..parts.sensor import Sensor5
7
+ from ..parts.timer import Timer
8
+ from ..pos import Pos
9
9
 
10
10
 
11
11
  def distance_sensor(bp: Blueprint,
@@ -1,11 +1,11 @@
1
1
  from itertools import cycle
2
2
  from typing import Sequence
3
3
  from numpy import ndarray
4
- from sm_blueprint_lib import get_bits_required, check_pos, connect
5
- from sm_blueprint_lib.blueprint import Blueprint
6
- from sm_blueprint_lib.parts.logicgate import LogicGate
7
- from sm_blueprint_lib.pos import Pos
8
- from sm_blueprint_lib.prebuilds.decoder import decoder
4
+ from ..utils import get_bits_required, check_pos, connect
5
+ from ..blueprint import Blueprint
6
+ from ..parts.logicgate import LogicGate
7
+ from ..pos import Pos
8
+ from ..prebuilds.decoder import decoder
9
9
 
10
10
 
11
11
  def ram(bp: Blueprint, bit_length: int, num_address: int, pos: Pos | Sequence = (0, 0, 0),
@@ -1,10 +1,10 @@
1
1
  from typing import Sequence
2
2
  from numpy import ndarray
3
- from sm_blueprint_lib import check_pos
4
- from sm_blueprint_lib.blueprint import Blueprint
5
- from sm_blueprint_lib.parts.logicgate import LogicGate
6
- from sm_blueprint_lib.pos import Pos
7
- from sm_blueprint_lib.prebuilds.counter import counter, counter_decrement
3
+ from ..utils import check_pos
4
+ from ..blueprint import Blueprint
5
+ from ..parts.logicgate import LogicGate
6
+ from ..pos import Pos
7
+ from ..prebuilds.counter import counter, counter_decrement
8
8
 
9
9
 
10
10
  def register(bp: Blueprint,
@@ -2,12 +2,12 @@ from itertools import batched, cycle
2
2
  from math import ceil
3
3
  from typing import Sequence
4
4
  from numpy import ndarray
5
- from sm_blueprint_lib import get_bits_required, check_pos, connect, num_to_bit_list
6
- from sm_blueprint_lib.blueprint import Blueprint
7
- from sm_blueprint_lib.parts.logicgate import LogicGate
8
- from sm_blueprint_lib.prebuilds.decoder import decoder
9
- from sm_blueprint_lib.parts.timer import Timer
10
- from sm_blueprint_lib.pos import Pos
5
+ from ..utils import get_bits_required, check_pos, connect, num_to_bit_list
6
+ from ..blueprint import Blueprint
7
+ from ..parts.logicgate import LogicGate
8
+ from ..prebuilds.decoder import decoder
9
+ from ..parts.timer import Timer
10
+ from ..pos import Pos
11
11
 
12
12
 
13
13
  def rom(
@@ -1,19 +1,19 @@
1
1
  from itertools import cycle
2
2
  from typing import Sequence
3
3
  from numpy import array, clip, ndarray
4
- from sm_blueprint_lib import get_bits_required, check_pos, connect, num_to_bit_list
5
- from sm_blueprint_lib.bases.parts.baseinteractablepart import BaseInteractablePart
6
- from sm_blueprint_lib.bases.parts.baselogicpart import BaseLogicPart
7
- from sm_blueprint_lib.blueprint import Blueprint
8
- from sm_blueprint_lib.constants import TICKS_PER_SECOND
9
- from sm_blueprint_lib.parts.logicgate import LogicGate
10
- from sm_blueprint_lib.parts.timer import Timer
11
- from sm_blueprint_lib.pos import Pos
12
- from sm_blueprint_lib.prebuilds.clock40hz import clock40hz
13
- from sm_blueprint_lib.prebuilds.counter import counter
14
- from sm_blueprint_lib.prebuilds.decoder import decoder
15
- from sm_blueprint_lib.prebuilds.ram import ram
16
- from sm_blueprint_lib.prebuilds.register import register
4
+ from ..utils import get_bits_required, check_pos, connect, num_to_bit_list
5
+ from ..bases.parts.baseinteractablepart import BaseInteractablePart
6
+ from ..bases.parts.baselogicpart import BaseLogicPart
7
+ from ..blueprint import Blueprint
8
+ from ..constants import TICKS_PER_SECOND
9
+ from ..parts.logicgate import LogicGate
10
+ from ..parts.timer import Timer
11
+ from ..pos import Pos
12
+ from ..prebuilds.clock40hz import clock40hz
13
+ from ..prebuilds.counter import counter
14
+ from ..prebuilds.decoder import decoder
15
+ from ..prebuilds.ram import ram
16
+ from ..prebuilds.register import register
17
17
 
18
18
 
19
19
  def timer_ram_cached(
@@ -1,14 +1,14 @@
1
1
  from typing import Sequence
2
2
  from numpy import ndarray
3
- from sm_blueprint_lib import get_bits_required, check_pos, connect
4
- from sm_blueprint_lib.blueprint import Blueprint
5
- from sm_blueprint_lib.parts.logicgate import LogicGate
6
- from sm_blueprint_lib.parts.timer import Timer
7
- from sm_blueprint_lib.pos import Pos
8
- from sm_blueprint_lib.prebuilds.clock40hz import clock40hz
9
- from sm_blueprint_lib.prebuilds.decoder import decoder
10
- from sm_blueprint_lib.prebuilds.ram import ram
11
- from sm_blueprint_lib.prebuilds.register import register
3
+ from ..utils import get_bits_required, check_pos, connect
4
+ from ..blueprint import Blueprint
5
+ from ..parts.logicgate import LogicGate
6
+ from ..parts.timer import Timer
7
+ from ..pos import Pos
8
+ from ..prebuilds.clock40hz import clock40hz
9
+ from ..prebuilds.decoder import decoder
10
+ from ..prebuilds.ram import ram
11
+ from ..prebuilds.register import register
12
12
 
13
13
 
14
14
  def timer_ram_multiclient(bp: Blueprint, bit_length: int, num_address: int, num_clients=1, pos: Pos | Sequence = (0, 0, 0)):
@@ -4,12 +4,12 @@ from math import ceil, log2
4
4
 
5
5
  from numpy import ndarray
6
6
 
7
- from sm_blueprint_lib.bases.parts.baseinteractablepart import BaseInteractablePart
8
- from sm_blueprint_lib.blueprint import Blueprint
9
- from sm_blueprint_lib.parts.barrierblock import BarrierBlock
10
- from sm_blueprint_lib.parts.logicgate import LogicGate
11
- from sm_blueprint_lib.parts.timer import Timer
12
- from sm_blueprint_lib.pos import Pos
7
+ from .bases.parts.baseinteractablepart import BaseInteractablePart
8
+ from .blueprint import Blueprint
9
+ from .parts.barrierblock import BarrierBlock
10
+ from .parts.logicgate import LogicGate
11
+ from .parts.timer import Timer
12
+ from .pos import Pos
13
13
 
14
14
 
15
15
  def load_blueprint(path):