mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-10 07:20:56 +00:00
fixup! refactor(core): abstract cache and context [no changelog]
This commit is contained in:
parent
76455464aa
commit
f180c32bb8
@ -23,9 +23,8 @@ gc.collect()
|
|||||||
|
|
||||||
|
|
||||||
def clear_all() -> None:
|
def clear_all() -> None:
|
||||||
from .cache_common import clear
|
global autolock_last_touch
|
||||||
|
autolock_last_touch = None
|
||||||
clear()
|
|
||||||
_SESSIONLESS_CACHE.clear()
|
_SESSIONLESS_CACHE.clear()
|
||||||
_PROTOCOL_CACHE.clear_all()
|
_PROTOCOL_CACHE.clear_all()
|
||||||
|
|
||||||
@ -42,3 +41,19 @@ def get_int_all_sessions(key: int) -> builtins.set[int]:
|
|||||||
|
|
||||||
def get_sessionless_cache() -> SessionlessCache:
|
def get_sessionless_cache() -> SessionlessCache:
|
||||||
return _SESSIONLESS_CACHE
|
return _SESSIONLESS_CACHE
|
||||||
|
|
||||||
|
|
||||||
|
# === Homescreen storage ===
|
||||||
|
# This does not logically belong to the "cache" functionality, but the cache module is
|
||||||
|
# a convenient place to put this.
|
||||||
|
# When a Homescreen layout is instantiated, it checks the value of `homescreen_shown`
|
||||||
|
# to know whether it should render itself or whether the result of a previous instance
|
||||||
|
# is still on. This way we can avoid unnecessary fadeins/fadeouts when a workflow ends.
|
||||||
|
HOMESCREEN_ON = object()
|
||||||
|
LOCKSCREEN_ON = object()
|
||||||
|
BUSYSCREEN_ON = object()
|
||||||
|
homescreen_shown: object | None = None
|
||||||
|
|
||||||
|
# Timestamp of last autolock activity.
|
||||||
|
# Here to persist across main loop restart between workflows.
|
||||||
|
autolock_last_touch: int | None = None
|
||||||
|
@ -33,27 +33,6 @@ APP_MISC_COSI_COMMITMENT = const(5 | SESSIONLESS_FLAG)
|
|||||||
APP_RECOVERY_REPEATED_BACKUP_UNLOCKED = const(6 | SESSIONLESS_FLAG)
|
APP_RECOVERY_REPEATED_BACKUP_UNLOCKED = const(6 | SESSIONLESS_FLAG)
|
||||||
|
|
||||||
|
|
||||||
# === Homescreen storage ===
|
|
||||||
# This does not logically belong to the "cache" functionality, but the cache module is
|
|
||||||
# a convenient place to put this.
|
|
||||||
# When a Homescreen layout is instantiated, it checks the value of `homescreen_shown`
|
|
||||||
# to know whether it should render itself or whether the result of a previous instance
|
|
||||||
# is still on. This way we can avoid unnecessary fadeins/fadeouts when a workflow ends.
|
|
||||||
HOMESCREEN_ON = object()
|
|
||||||
LOCKSCREEN_ON = object()
|
|
||||||
BUSYSCREEN_ON = object()
|
|
||||||
homescreen_shown: object | None = None
|
|
||||||
|
|
||||||
# Timestamp of last autolock activity.
|
|
||||||
# Here to persist across main loop restart between workflows.
|
|
||||||
autolock_last_touch: int | None = None
|
|
||||||
|
|
||||||
|
|
||||||
def clear() -> None:
|
|
||||||
global autolock_last_touch
|
|
||||||
autolock_last_touch = None
|
|
||||||
|
|
||||||
|
|
||||||
if TYPE_CHECKING:
|
if TYPE_CHECKING:
|
||||||
from typing import Sequence, TypeVar, overload
|
from typing import Sequence, TypeVar, overload
|
||||||
|
|
||||||
@ -109,16 +88,14 @@ class DataCache:
|
|||||||
self.data[key][1:] = value
|
self.data[key][1:] = value
|
||||||
|
|
||||||
def set_bool(self, key: int, value: bool) -> None:
|
def set_bool(self, key: int, value: bool) -> None:
|
||||||
utils.ensure(
|
assert self._get_length(key) == 0 # skipping get_length in production build
|
||||||
self._get_length(key) == 0, "Field does not have zero length!"
|
|
||||||
) # skipping get_length in production build
|
|
||||||
if value:
|
if value:
|
||||||
self.set(key, b"")
|
self.set(key, b"")
|
||||||
else:
|
else:
|
||||||
self.delete(key)
|
self.delete(key)
|
||||||
|
|
||||||
def set_int(self, key: int, value: int) -> None:
|
def set_int(self, key: int, value: int) -> None:
|
||||||
length = self.fields[key]
|
length = self._get_length(key)
|
||||||
encoded = value.to_bytes(length, "big")
|
encoded = value.to_bytes(length, "big")
|
||||||
|
|
||||||
# Ensure that the value fits within the length. Micropython's int.to_bytes()
|
# Ensure that the value fits within the length. Micropython's int.to_bytes()
|
||||||
|
Loading…
Reference in New Issue
Block a user