Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Input event with origin #550

Merged
merged 37 commits into from
Dec 15, 2022
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
fdbe5d4
Update InputEvent to include origin and analog threshold
jonasBoss Nov 20, 2022
4738843
preset save file migration
jonasBoss Nov 20, 2022
df386bd
Merge branch 'beta' into input-event-with-origin
jonasBoss Nov 21, 2022
5b321f0
Use the InputEvent.analog_threshold field instead of value
jonasBoss Nov 22, 2022
fb1d407
Merge branch 'beta' into input-event-with-origin
jonasBoss Nov 24, 2022
56501b8
Make tests start in pycharm again
jonasBoss Nov 24, 2022
2fadc1f
Seperate InputEvent and InputConfiguration
jonasBoss Nov 24, 2022
db652a5
integration tests
jonasBoss Nov 26, 2022
3f6e81d
simplyfied InputEvent
jonasBoss Nov 26, 2022
af96ce1
move find_analog_input_event to InputCombination
jonasBoss Nov 26, 2022
53f2a49
rename InputConfiguration to InputConfig
jonasBoss Nov 26, 2022
b41bcce
move input_configuration.py to configs/input_config.py
jonasBoss Nov 26, 2022
0b88d79
simplified imports
jonasBoss Nov 26, 2022
e76c30b
rename event_combination to input_combination
jonasBoss Nov 26, 2022
705d97b
mypy
jonasBoss Dec 1, 2022
e518a05
use event origin information
jonasBoss Dec 2, 2022
0f724e4
fix reader-service and use md5 hashing
jonasBoss Dec 2, 2022
fc95635
Updated Mapping handlers
jonasBoss Dec 2, 2022
9da39c6
Updated Tests
jonasBoss Dec 2, 2022
2f168a1
Merge branch 'beta' into input-event-with-origin
jonasBoss Dec 6, 2022
11dce4c
fix test_injector
jonasBoss Dec 6, 2022
b7ca337
mypy
jonasBoss Dec 6, 2022
d67dd32
integration tests
jonasBoss Dec 7, 2022
c3b30cf
added unit tests
jonasBoss Dec 9, 2022
e5f0159
usage.md
jonasBoss Dec 10, 2022
9af4a59
refactor injector grab deviece logic
jonasBoss Dec 11, 2022
6c1d8f9
InputConfig docstring
jonasBoss Dec 11, 2022
6067285
refactor migrations._input_combination_from_string
jonasBoss Dec 11, 2022
f94e5e7
amend
jonasBoss Dec 11, 2022
61fe702
refactor temprary preset migration
jonasBoss Dec 11, 2022
5943fd0
made notify_callbacks private
jonasBoss Dec 12, 2022
925ffad
constrain origin to lowercase
jonasBoss Dec 12, 2022
7639422
tabs 'n spaces
jonasBoss Dec 12, 2022
7010955
mypy
jonasBoss Dec 12, 2022
aa3d868
mypy
jonasBoss Dec 13, 2022
699a6f8
Signal no longer inherits Message protocol
jonasBoss Dec 13, 2022
a1d1641
rename origin to origin_hash
jonasBoss Dec 14, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
preset save file migration
  • Loading branch information
jonasBoss committed Nov 20, 2022
commit 4738843f070385bd5fb4733a190df27fd95d77a8
45 changes: 33 additions & 12 deletions inputremapper/configs/preset.py
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,8 @@
)

from pydantic import ValidationError
from evdev.ecodes import EV_KEY

from inputremapper.logger import logger
from inputremapper.configs.mapping import Mapping, UIMapping
from inputremapper.configs.paths import touch
Expand Down Expand Up @@ -184,7 +186,7 @@ def save(self) -> None:

logger.info("Saving preset to %s", self.path)

preset_dict = {}
preset_list = []
saved_mappings = {}
for mapping in self:
if not mapping.is_valid():
Expand All @@ -195,24 +197,24 @@ def save(self) -> None:
continue

if self._is_mapped_multiple_times(mapping.event_combination):
# todo: is this ever executed? it should not be possible to
# reach this
logger.debug(
"skipping mapping with duplicate event combination %s",
mapping,
)
continue

mapping_dict = mapping.dict(exclude_defaults=True)
mapping_dict["event_combination"] = mapping.event_combination.to_config()
combination = mapping.event_combination
if "event_combination" in mapping_dict:
# used as key, don't store it redundantly
del mapping_dict["event_combination"]
preset_dict[combination.json_key()] = mapping_dict
preset_list.append(mapping_dict)

saved_mappings[combination] = mapping.copy()
saved_mappings[combination].remove_combination_changed_callback()

with open(self.path, "w") as file:
json.dump(preset_dict, file, indent=4)
json.dump(preset_list, file, indent=4)
file.write("\n")

self._saved_mappings = saved_mappings
Expand Down Expand Up @@ -287,20 +289,39 @@ def _get_mappings_from_disc(self) -> Dict[EventCombination, MappingModel]:

with open(self.path, "r") as file:
try:
preset_dict = json.load(file)
preset_list = json.load(file)
except json.JSONDecodeError:
logger.error("unable to decode json file: %s", self.path)
return mappings

for combination, mapping_dict in preset_dict.items():
if isinstance(preset_list, dict):
# todo: remove this before merge into main
# adds compatibility with older beta versions
for c, d in preset_list.items():
tmp = EventCombination.from_string(c)
tmp2 = []
for event in tmp:
tmp2.append(
InputEvent.from_config(
event.type,
event.code,
origin=None,
analog_threshold=event.value
if event.type != EV_KEY
else None,
).to_config()
)

d["event_combination"] = tmp2
preset_list = list(preset_list.values())

for mapping_dict in preset_list:
try:
mapping = self._mapping_factory(
event_combination=combination, **mapping_dict
)
mapping = self._mapping_factory(**mapping_dict)
except ValidationError as error:
logger.error(
"failed to Validate mapping for %s: %s",
combination,
mapping_dict["event_combination"],
error,
)
continue
Expand Down
3 changes: 3 additions & 0 deletions inputremapper/event_combination.py
Original file line number Diff line number Diff line change
Expand Up @@ -94,6 +94,9 @@ def from_config(cls, init_dicts: Iterable[Dict[str, int]]) -> EventCombination:
"""Create a InputCombination from dicts"""
return cls((InputEvent.from_config(**d) for d in init_dicts))

def to_config(self) -> Tuple[Dict[str, int], ...]:
return tuple(event.to_config() for event in self)

@classmethod
def from_string(cls, init_string: str) -> EventCombination:
"""Create a EventCombination form a string like '1,2,3+4,5,6'."""
Expand Down
8 changes: 7 additions & 1 deletion inputremapper/input_event.py
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,13 @@ def to_config(self) -> Dict[str, int]:
return d

@classmethod
def from_config(cls, type: int, code: int, origin: int, analog_threshold: int):
def from_config(
cls,
type: int,
code: int,
origin: Optional[int] = None,
analog_threshold: Optional[int] = None,
):
return cls(
0, 0, type, code, 0, origin=origin, analog_threshold=analog_threshold
)
Expand Down