better text entry

This commit is contained in:
kepler155c@gmail.com 2019-03-29 10:44:21 -04:00
parent c9ef150605
commit 78402e89cd
3 changed files with 14 additions and 5 deletions

View File

@ -361,7 +361,7 @@ function Entry:process(ie)
local action = mappings[ie.code]
self.textChanged = false
_debug(ie)
if action then
local pos = self.pos
local line = self.value

View File

@ -76,11 +76,18 @@ function input:translate(event, code, p1, p2)
if p1 then -- key is held down
if not modifiers[code] then
self.fired = true
return { code = input:toCode(keys.getName(code), code) }
local ch = input:toCode(keys.getName(code), code)
if #ch == 1 then
return {
code = 'char',
ch = ch,
}
end
return { code = ch }
end
else
self.state[code] = true
if self:modifierPressed() and not modifiers[code] or code == 57 then
if self:modifierPressed() and not modifiers[code] then --or code == 57 then
self.fired = true
return { code = input:toCode(keys.getName(code), code) }
else
@ -89,8 +96,7 @@ function input:translate(event, code, p1, p2)
end
elseif event == 'char' then
if not keyboard.state[keys.leftAlt] and
not keyboard.state[keys.rightAlt] then
if not self.fired then
self.fired = true
return { code = event, ch = code }
-- return { code = event, ch = input:toCode(code) }

View File

@ -362,6 +362,7 @@ local Config = require('config')
local Entry = require('entry')
local History = require('history')
local Input = require('input')
local Sound = require('sound')
local Terminal = require('terminal')
local colors = _G.colors
@ -640,6 +641,8 @@ local function shellRead(history)
entry:unmark()
entry:updateScroll()
redraw()
else
Sound.play('entity.villager.no')
end
end