லினக்ஸிற்கான Xswitcher லேஅவுட் கரெக்டர்: படி இரண்டு

முதல் முந்தைய வெளியீடு ("கருத்துக்கான ஆதாரம்" கட்டத்தில் xswitcher) நிறைய ஆக்கபூர்வமான கருத்துக்களைப் பெற்றது (இது நன்றாக இருக்கிறது), நான் எனது ஓய்வு நேரத்தை திட்டத்தை உருவாக்க தொடர்ந்து செலவழித்தேன். இப்போது நான் உன்னுடையதை கொஞ்சம் செலவிட விரும்புகிறேன். இரண்டாவது படி மிகவும் வழக்கமானதாக இருக்காது: கட்டமைப்பு வடிவமைப்பு பற்றிய முன்மொழிவு/ கலந்துரையாடல்.

லினக்ஸிற்கான Xswitcher லேஅவுட் கரெக்டர்: படி இரண்டு

எப்படியோ சாதாரண புரோகிராமர்கள் இந்தக் கட்டுப்பாடுகள் அனைத்தையும் அமைப்பது நம்பமுடியாத அளவிற்கு சலிப்பை ஏற்படுத்துகிறது.

ஆதாரமற்றதாக இருக்கக்கூடாது என்பதற்காக, நான் என்ன கையாள்கிறேன் என்பதற்கு உள்ளே ஒரு எடுத்துக்காட்டு.
ஒட்டுமொத்தமாக சிறந்த முறையில் உருவாக்கப்பட்ட (நன்றாக செயல்படுத்தப்பட்ட) அப்பாச்சி காஃப்கா & ஜூ கீப்பர்.
- கட்டமைப்பு? ஆனால் சலிப்பாக இருக்கிறது! ஊமை எக்ஸ்எம்எல் (இது "பெட்டிக்கு வெளியே" இருப்பதால்).
- ஓ, உங்களுக்கும் ACL வேண்டுமா? ஆனால் அது மிகவும் சலிப்பாக இருக்கிறது! டப்-ப்ளூப்பர்... அப்படி ஏதாவது.

ஆனால் என் வேலையில் அது நேர்மாறானது. சரி (ஐயோ, கிட்டத்தட்ட முதல் முறையாக இல்லை) கட்டப்பட்ட மாதிரி உங்களை மேலும் எளிதாகவும் இயற்கையாகவும் தொடர அனுமதிக்கிறது (கிட்டத்தட்ட) ஒரு வரைபடத்தை இணைக்கவும்.

தரவு விஞ்ஞானிகளின் கடின உழைப்பு பற்றி ஹப்ரேயில் ஒரு கட்டுரையை சமீபத்தில் பார்த்தேன்.
இந்த தருணம் அவர்களுக்கு முழுமையாக உணரப்பட்டது என்று மாறிவிடும். என் நடைமுறையில், அவர்கள் சொல்வது போல், "ஒளி பதிப்பு". மல்டி-வால்யூம் மாடல்கள், தயார் நிலையில் உள்ள OOP உடன் அனுபவமுள்ள புரோகிராமர்கள் போன்றவை. - இவை அனைத்தும் பின்னர் எப்போது/அது எடுக்கப்பட்டால் தோன்றும். ஆனால் வடிவமைப்பாளர் இங்கே மற்றும் இப்போது எங்காவது தொடங்க வேண்டும்.

முக்கியமான விசயத்திற்கு வா. நான் TOML ஐ ஒரு தொடரியல் அடிப்படையாக எடுத்துக் கொண்டேன் இந்த குடிமகனிடமிருந்து.

ஏனென்றால் அவன் (TOML) ஒருபுறம், மனிதனால் திருத்தக்கூடியது. மறுபுறம், இது 1:1 மிகவும் பொதுவான தொடரியல்களாக மொழிபெயர்க்கப்பட்டுள்ளது: XML, JSON, YAML.
மேலும், "github.com/BurntSushi/toml" இலிருந்து நான் பயன்படுத்திய செயலாக்கம், மிகவும் நாகரீகமாக இல்லாவிட்டாலும் (இன்னும் 1.4 தொடரியல்), அதே ("உள்ளமைக்கப்பட்ட") JSON உடன் தொடரியல் ரீதியாக இணக்கமானது.

அதாவது, நீங்கள் விரும்பினால், "உங்களுடைய TOML ஐக் கொண்டு காடுகளின் வழியாகச் செல்லுங்கள், எனக்கு XXX வேண்டும்" மற்றும் குறியீட்டை ஒரு வரியுடன் "பேட்ச்" செய்யலாம்.

எனவே, நீங்கள் xswitcher ஐ கட்டமைக்க சில சாளரங்களை எழுத விரும்பினால் (என்னால் உறுதியாக சொல்ல முடியாது) "உங்களுடைய இந்த மோசமான கட்டமைப்பில்" எந்த பிரச்சனையும் எதிர்பார்க்கப்படாது.

மற்ற அனைவருக்கும், தொடரியல் "விசை = மதிப்பு" அடிப்படையிலானது (மற்றும் இன்னும் சில சிக்கலான விருப்பங்கள், = [சில, அது, வரிசை]) நான் ஊகிக்கிறேன்
உள்ளுணர்வாக வசதியானது.
இதில் சுவாரஸ்யமான விஷயம் என்னவென்றால் "எரிந்த" அதே நேரத்தில் (சுமார் 2013). என்னைப் போலல்லாமல், TOML இன் ஆசிரியர் சரியான அளவில் நுழைந்தார்.

எனவே, அதன் செயலாக்கத்தை எனக்கு ஏற்றவாறு சரிசெய்வது இப்போது எனக்கு எளிதானது, மாறாக அல்ல.

பொதுவாக, நாங்கள் TOML ஐ எடுத்துக்கொள்கிறோம் (பழைய Windows INI ஐப் போலவே). எங்களிடம் ஒரு உள்ளமைவு உள்ளது, அதில் விசைப்பலகையில் இருந்து சமீபத்திய ஸ்கேன் குறியீடுகளின் தொகுப்பைப் பொறுத்து தொடர்ச்சியான கொக்கிகளை எவ்வாறு இணைப்பது என்பதை விவரிக்கிறோம். கீழே, துண்டு துண்டாக, இதுவரை நடந்தவை. நான் ஏன் இப்படி முடிவு செய்தேன் என்பதற்கான விளக்கமும்.

0 அடிப்படை சுருக்கங்கள்

  • குறியீட்டு பெயர்களை ஸ்கேன் செய்யவும். இதைப் பற்றி நிச்சயமாக ஏதாவது செய்ய வேண்டும், ஏனென்றால் டிஜிட்டல் குறியீடுகள் முற்றிலும் மனிதர்களால் படிக்க முடியாது (அது நான் மட்டுமே லோஸ்விட்சர்).
    நான் "golang-evdev" இலிருந்து "ecode.go" ஐ அசைத்தேன் (அசல் மூலத்தைப் பார்க்க நான் மிகவும் சோம்பேறியாக இருந்தேன், இருப்பினும் ஆசிரியர் அதை கலாச்சார ரீதியாக சுட்டிக்காட்டினார்). நான் கொஞ்சம் (இப்போதைக்கு) மிகவும் பயமாக இருந்த ஒன்றை சரிசெய்தேன். "LEFTBRACE" → "L_BRACE" போல.
  • கூடுதலாக, அவர் "மாநில விசைகள்" என்ற கருத்தை அறிமுகப்படுத்தினார். வழக்கமான இலக்கணம் நீண்ட பத்திகளை அனுமதிக்காது என்பதால். (ஆனால் இது குறைந்தபட்ச மேல்நிலையுடன் சரிபார்க்க உங்களை அனுமதிக்கிறது. நீங்கள் "நேரடி" பதிவை மட்டுமே பயன்படுத்தினால்.)
  • அழுத்தப்பட்டவற்றின் உள்ளமைக்கப்பட்ட "டியூப்ளிகேட்டர்" இருக்கும். இதனால், "repeat"=2 என்ற நிலை எழுதப்படும் один நேரம்.

1. டெம்ப்ளேட்கள் பிரிவு

[Templates] # "@name@" to simplify expressions
 # Words can consist of these chars (regex)
 "WORD" = "([0-9A-Z`;']|[LR]_BRACE|COMMA|DOT|SLASH|KP[0-9])"

ஒலிப்புக் குறியீடு கொண்ட மனித மொழிச் சொல் எதைக் கொண்டுள்ளது? ("ஹைரோகிளிஃப்ஸ்" எனப்படும் கிராஃபிம்களின் விஷயங்களில் ஒன்று)? சில வகையான பயங்கரமான "தாள்". எனவே, நான் உடனடியாக "வார்ப்புரு" என்ற கருத்தை அறிமுகப்படுத்துகிறேன்.

2. ஏதாவது கிளிக் செய்தால் என்ன செய்வது (மற்றொரு ஸ்கேன் குறியீடு வந்துவிட்டது)

[ActionKeys]
 # Collect key and do the test for command sequence
 # !!! Repeat codes (code=2) must be collected once per key!
 Add = ["1..0", "=", "BS", "Q..]", "L_CTRL..CAPS", "N_LOCK", "S_LOCK",
        "KP7..KPDOT", "R_CTRL", "KPSLASH", "R_ALT", "KPEQUAL..PAUSE",
        "KPCOMMA", "L_META..COMPOSE", "KPLEFTPAREN", "KPRIGHTPAREN"]

 # Drop all collected keys, including this.  This is default action.
 Drop = ["ESC", "-", "TAB", "ENTER", "KPENTER", "LINEFEED..POWER"]
 # Store extra map for these keys, when any is in "down" state.
 # State is checked via "OFF:"|"ON:" conditions in action.
 # (Also, state of these keys must persist between buffer drops.)
 # ??? How to deal with CAPS and "LOCK"-keys ???
 StateKeys = ["L_CTRL", "L_SHIFT", "L_ALT", "L_META", "CAPS", "N_LOCK", "S_LOCK",
              "R_CTRL", "R_SHIFT", "R_ALT", "R_META"]

 # Test only, but don't collect.
 # E.g., I use F12 instead of BREAK on dumb laptops whith shitty keyboards (new ThinkPads)
 Test = ["F1..F10", "ZENKAKUHANKAKU", "102ND", "F11", "F12",
          "RO..KPJPCOMMA", "SYSRQ", "SCALE", "HANGEUL..YEN",
          "STOP..SCROLLDOWN", "NEW..MAX"]

மொத்தம் 768 குறியீடுகள் உள்ளன. (ஆனால் "ஒருவேளை" நான் xswitcher குறியீட்டில் "ஆச்சரியங்களை" செருகினேன்).
உள்ளே "என்ன செய்வது" செயல்பாடுகளுக்கான இணைப்புகளுடன் வரிசையை நிரப்புவதை விவரித்தேன். கோலாங்கில் இது (திடீரென்று) இது வசதியானதாகவும் வெளிப்படையானதாகவும் மாறியது.

  • இந்த இடத்தில் "துளி" என்பதை குறைந்தபட்சமாக குறைக்க திட்டமிட்டுள்ளேன். மிகவும் நெகிழ்வான செயலாக்கத்திற்கு ஆதரவாக (நான் அதை கீழே காண்பிக்கிறேன்).

3. சாளர வகுப்புகள் கொண்ட அட்டவணை

# Some behaviour can depend on application currently doing the input.
[[WindowClasses]]
 # VNC, VirtualBox, qemu etc. emulates there input independently, so never intercept.
 # With the exception of some stupid VNC clients, which does high-level (layout-based) keyboard input.
 Regex = "^VirtualBox"
 Actions = "" # Do nothing while focus stays in VirtualBox

[[WindowClasses]]
 Regex = "^konsole"
 # In general, mouse clicks leads to unpredictable (at the low-level where xswitcher resides) cursor jumps.
 # So, it's good choise to drop all buffers after click.
 # But some windows, e.g. terminals, can stay out of this problem.
 MouseClickDrops = 0
 Actions = "Actions"

[[WindowClasses]] # Default behaviour: no Regex (or wildcard like ".")
 MouseClickDrops = 1
 Actions = "Actions"

அட்டவணையின் வரிசைகள் அதன் பெயருடன் இரட்டை சதுர அடைப்புக்குறிக்குள் உள்ளன. பேட்டிங்கில் இருந்து இது எளிதாக இருந்திருக்க முடியாது. தற்போது செயலில் உள்ள சாளரத்தைப் பொறுத்து, நீங்கள் பின்வரும் விருப்பங்களைத் தேர்ந்தெடுக்கலாம்:

  • உங்கள் சொந்த "ஹாட் கீகள்" "செயல்கள் = ...". இல்லை என்றால்/காலியாக இருந்தால், எதுவும் செய்ய வேண்டாம்.
  • "MouseClickDrops" ஐ மாற்றவும் - மவுஸ் கிளிக் கண்டறியப்பட்டால் என்ன செய்வது. xswitcher ஆன் செய்யப்பட்ட இடத்தில் “அவர்கள் எங்கு கிளிக் செய்கிறார்கள்” என்பது பற்றிய விவரங்கள் எதுவும் இல்லாததால், இயல்பாகவே இடையகத்தை மீட்டமைக்கிறோம். ஆனால் டெர்மினல்களில் (உதாரணமாக) நீங்கள் இதைச் செய்ய வேண்டியதில்லை (பொதுவாக).

4. கிளிக்குகளின் ஒன்று (அல்லது பல) வரிசைகள் ஒன்று அல்லது மற்றொரு கொக்கியைத் தூண்டுகின்றன

# action = [ regex1, regex2, ... ]
# "CLEAN" state: all keys are released
[Actions]
# Inverse regex is hard to understand, so extract negation to external condition.
# Expresions will be checked in direct order, one-by-one. Condition succceds when ALL results are True.
 # Maximum key sequence length, extra keys will be dropped. More length - more CPU.
 SeqLength = 8
 # Drop word buffer and start collecting new one
 NewWord = [ "OFF:(CTRL|ALT|META)  SEQ:(((BACK)?SPACE|[LR]_SHIFT):[01],)*(@WORD@:1)", # "@WORD@:0" then collects the char
             "SEQ:(@WORD@:2,@WORD@:0)", # Drop repeated char at all: unlikely it needs correction
             "SEQ:((KP)?MINUS|(KP)?ENTER|ESC|TAB)" ] # Be more flexible: chars line "-" can start new word, but must not completelly invalidate buffer!
 # Drop all buffers
 NewSentence = [ "SEQ:(ENTER:0)" ]

 # Single char must be deleted by single BS, so there is need in compose sequence detector.
 Compose = [ "OFF:(CTRL|L_ALT|META|SHIFT)  SEQ:(R_ALT:1,(R_ALT:2,)?(,@WORD@:1,@WORD@:0){2},R_ALT:0)" ]

 "Action.RetypeWord" = [ "OFF:(CTRL|ALT|META|SHIFT)  SEQ:(PAUSE:0)" ]
 "Action.CyclicSwitch" = [ "OFF:(R_CTRL|ALT|META|SHIFT)  SEQ:(L_CTRL:1,L_CTRL:0)" ] # Single short LEFT CONTROL
 "Action.Respawn" = [ "OFF:(CTRL|ALT|META|SHIFT)  SEQ:(S_LOCK:2,S_LOCK:0)" ] # Long-pressed SCROLL LOCK

 "Action.Layout0" = [ "OFF:(CTRL|ALT|META|R_SHIFT)  SEQ:(L_SHIFT:1,L_SHIFT:0)" ] # Single short LEFT SHIFT
 "Action.Layout1" = [ "OFF:(CTRL|ALT|META|L_SHIFT)  SEQ:(R_SHIFT:1,R_SHIFT:0)" ] # Single short RIGHT SHIFT

 "Action.Hook1" = [ "OFF:(CTRL|R_ALT|META|SHIFT)  SEQ:(L_ALT:1,L_ALT:0)" ]

கொக்கிகள் இரண்டு வகைகளாக பிரிக்கப்பட்டுள்ளன. உள்ளமைக்கப்பட்ட, சுய விளக்கப் பெயர்கள் (புதிய வார்த்தை, புதிய வாக்கியம், எழுதுதல்) மற்றும் நிரல்படுத்தக்கூடியவை.

நிரல்படுத்தக்கூடிய பெயர்கள் "செயல்" உடன் தொடங்குகின்றன. ஏனெனில் TOML v1.4, புள்ளிகளைக் கொண்ட பெயர்கள் மேற்கோள்களில் இருக்க வேண்டும்.

ஒவ்வொரு பகுதியும் கீழே விவரிக்கப்பட வேண்டும் அதே பெயரில்.

"நிர்வாண" வழக்கமான (அனுபவத்திலிருந்து, அவர்களின் எழுதபத்தில் ஒன்று இருக்கலாம் தொழில் வல்லுநர்கள்), நான் உடனடியாக கூடுதல் தொடரியல் செயல்படுத்துகிறேன்.

  • "ஆஃப்:" (அல்லது "ஆன்:") regexp (வழக்கமான வெளிப்பாடு) முன் பின்வரும் பொத்தான்கள் வெளியிடப்பட வேண்டும் (அல்லது அழுத்தவும்).
    அடுத்து நான் ஒரு "நியாயமற்ற" வழக்கமான வெளிப்பாட்டைச் செய்யப் போகிறேன். குழாய்களுக்கு இடையில் துண்டுகளை தனித்தனியாக சரிபார்த்து "|". "[LR]_SHIFT" போன்ற பதிவுகளின் எண்ணிக்கையைக் குறைப்பதற்காக (இது தெளிவாகத் தேவையில்லை).
  • "SEQ:" முந்தைய நிபந்தனை பூர்த்தி செய்யப்பட்டால் (அல்லது இல்லாவிட்டால்), "சாதாரண" வழக்கமான வெளிப்பாட்டிற்கு எதிராக நாங்கள் சரிபார்க்கிறோம். விவரங்களுக்கு, நான் உடனடியாக ^W "regexp" நூலகத்திற்கு அனுப்புகிறேன். ஏனென்றால் எனக்குப் பிடித்த pcre (“perl compatible”) உடன் இணக்கத்தன்மையின் அளவைக் கண்டறிய நான் இன்னும் கவலைப்படவில்லை.
  • வெளிப்பாடு வடிவத்தில் எழுதப்பட்டுள்ளது "BUTTON_1: CODE1, BUTTON_2: CODE2" முதலியன, ஸ்கேன் குறியீடுகள் பெறப்படும் வரிசையில்.
  • காசோலை எப்போதுமே வரிசையின் முடிவில் "பக்கமாக" இருக்கும், எனவே வால் "$" ஐ சேர்க்க வேண்டிய அவசியமில்லை.
  • ஒரு வரியில் உள்ள அனைத்து சோதனைகளும் ஒன்றன் பின் ஒன்றாக செய்யப்படுகின்றன மற்றும் "நான்" மூலம் இணைக்கப்படுகின்றன. ஆனால் மதிப்பு வரிசையாக விவரிக்கப்பட்டுள்ளதால், காற்புள்ளிக்குப் பிறகு மாற்றுச் சரிபார்ப்பை எழுதலாம். சில காரணங்களால் இது தேவைப்பட்டால்.
  • மதிப்பு "SeqLength = 8" அனைத்து சோதனைகளும் செய்யப்படும் இடையகத்தின் அளவைக் கட்டுப்படுத்துகிறது. ஏனெனில் நான் (இதுவரை) என் வாழ்க்கையில் முடிவில்லாத வளங்களை சந்தித்ததில்லை.

5. முந்தைய பிரிவில் விவரிக்கப்பட்டுள்ள கொக்கிகளை அமைத்தல்

# Action is the array, so actions could be chained (m.b., infinitely... Have I to check this?).
# For each action type, extra named parameters could be collected. Invalid parameters will be ignored(?).
[Action.RetypeWord] # Switch layout, drop last word and type it again
 Action = [ "Action.CyclicSwitch", "RetypeWord" ] # Call Switch() between layouts tuned below, then RetypeWord()

[Action.CyclicSwitch] # Cyclic layout switching
 Action = [ "Switch" ] # Internal layout switcher func
 Layouts = [0, 1]

[Action.Layout0] # Direct layout selection
 Action = [ "Layout" ] # Internal layout selection func
 Layout = 0

[Action.Layout1] # Direct layout selection
 Action = [ "Layout" ] # Internal layout selection func
 Layout = 1

[Action.Respawn] # Completely respawn xswitcher. Reload config as well
 Action = [ "Respawn" ]

[Action.Hook1] # Run external commands
  Action = [ "Exec" ]
  Exec = "/path/to/exec -a -b --key_x"
  Wait = 1
  SendBuffer = "Word" # External hook can process collected buffer by it's own means.

இங்கே முக்கிய விஷயம் "செயல் = [வரிசை]". முந்தைய பிரிவைப் போலவே, உள்ளமைக்கப்பட்ட செயல்களின் வரையறுக்கப்பட்ட தொகுப்பு உள்ளது. மற்றும் நறுக்குவதற்கான சாத்தியக்கூறு கொள்கையளவில் மட்டுப்படுத்தப்படவில்லை (“Action.XXX” என்று எழுதவும், அதற்கு மற்றொரு பகுதியை எழுத சோம்பேறியாக இருக்க வேண்டாம்).
குறிப்பாக, திருத்தப்பட்ட அமைப்பில் ஒரு வார்த்தையை மீண்டும் தட்டச்சு செய்வது இரண்டு பகுதிகளாக பிரிக்கப்பட்டுள்ளது: "அங்கே குறிப்பிட்டபடி அமைப்பை மாற்றவும்" и “மறுவகை” (“RetypeWord”).

மீதமுள்ள அளவுருக்கள் "அகராதியில்" எழுதப்பட்டுள்ளன. ("வரைபடம்" கோலாங்கில்) கொடுக்கப்பட்ட செயலுக்கு, அவற்றின் பட்டியல் "செயல்" இல் எழுதப்பட்டதைப் பொறுத்தது.

ஒரு குவியலில் பல்வேறு செயல்களை விவரிக்கலாம் (பிரிவுகள்). அல்லது நீங்கள் அதை பிரிக்கலாம். நான் மேலே காட்டியபடி.

வெளிப்புற ஸ்கிரிப்டை இயக்க "Exec" செயலை உடனடியாக அமைத்தேன். பதிவு செய்யப்பட்ட இடையகத்தை stdin க்குள் தள்ளும் விருப்பத்துடன்.

  • "காத்திரு = 1" - இயங்கும் செயல்முறை முடிவடையும் வரை காத்திருக்கவும்.
  • ஒருவேளை, "குவியல்" நீங்கள் சூழலில் கூடுதல் நபர்களை வைக்க விரும்புவீர்கள். அது இடைமறித்த சாளர வகுப்பின் பெயர் போன்ற தகவல்கள்.
    "உங்கள் ஹேண்ட்லரை இணைக்க விரும்புகிறீர்களா? இங்குதான் நீங்கள் செல்ல வேண்டும். ”

பியூ (வெளியேற்றப்பட்டது). நான் எதையும் மறக்கவில்லை போலும்.

அச்சச்சோ! ஆம், நான் மறக்கவில்லை ...
துவக்க உள்ளமைவு எங்கே? கடினமான குறியீட்டில்? அது போல:

[ScanDevices]
 # Must exist on start. Self-respawn in case it is younger then 30s
 Test = "/dev/input/event0"
 Respawn = 30
 # Search mask
 Search = "/dev/input/event*"
 # In my thinkPads there are such a pseudo-keyboards whith tons of unnecessary events
 Bypass = "(?i)Video|Camera" # "(?i)" obviously differs from "classic" pcre's.

நான் எங்கே மறந்துவிட்டேன்/தவறு செய்தேன்? (இது இல்லாமல் வழியில்லை), கவனமுள்ள வாசகர்கள் மூக்கைக் குத்துவதற்கு மிகவும் சோம்பேறியாக இருக்க மாட்டார்கள் என்று நான் நம்புகிறேன்.

நல்ல அதிர்ஷ்டம்!

ஆதாரம்: www.habr.com

கருத்தைச் சேர்