Skip to main content

Plover plugin to make typing identifier in programming languages easier

Project description

plover-auto-identifier

You don't have to keep typing KPA* or RUPBD while programming.

Example usage

  • Type THRAEUT R*UPBD STROEBG, translate_stroke is printed.
  • From the next time, typing THRAEUT STROEBG will automatically create translate_stroke.
  • The first step is not necessary with editor integration.

This program is available on GitHub and PyPI. Report bugs on GitHub.

Note that this program uses some internal API of Plover, and thus is not guaranteed to work on any given Plover versions.

Configuration

Create a file named plover_auto_identifier_config.json in Plover's configuration folder with the content:

{
"max_size": 100000000
}

Fields:

  • max_size: the maximum size of a file in bytes that a file can be loaded automatically (to read the words from). -1 means unlimited.

  • blacklist: list of files to be used as dictionaries to be excluded.

    To explain, because of how the feature currently work, if you type something like Maybe or are then it will be added to the dictionary, which rules out valid separated-words such as may be or a {re^}. So the blacklist will consist of (Plover-formatted dictionary) files such that words inside it will not be automatically added.

    The path can either be absolute or relative to the configuration directory (e.g. main.json)

Features

  • Define a dictionary entry mapped to =auto_identifier_mark to mark the most recently typed word as an identifier (only works if the identifier is stroked with no more than 10 translations)
    Note that identifiers are also mapped automatically.

  • Define a dictionary entry mapped to =auto_identifier_remove to unmap and revert the most recently automatically converted identifier (only works if the translation is recent)

  • Send to the named pipe \\.\pipe\plover_auto_identifier (Windows) or socket /<tempdir>/plover_auto_identifier_socket (UNIX) a Python string being the file name to read the list of identifiers from that file (with authkey=None).

    The file must be encoded in UTF-8 encoding.

    The existing identifiers will be removed.

    Note that it's necessary to send only one message for each connection.

For example, you can place this code into .vimrc (UNIX system):

function s:NotifyPloverAutoIdentifier()
pythonx << EOF
import vim
from multiprocessing import connection
filepath=vim.eval('expand("%:p")')
if filepath: #if the user edit a new buffer, filepath might be empty
	try:
		c=connection.Client("/tmp/.plover_auto_identifier_socket")
		try:
			c.send(("file", filepath))
		finally:
			c.close()
	except FileNotFoundError:
		pass # the plugin is not listening
	except OSError as e: # weird behavior
		print(e)
		
EOF
endfunction

augroup vimrc_notify_plover_auto_identifier
	auto!
	auto BufEnter,BufWritePost * call s:NotifyPloverAutoIdentifier()
augroup END

Idea:

  • Integrate with some editor to load the word list (done)
  • Also track the output for the word list. (done)
    • But if the word typed is deleted, also remove that word from the word list. (TODO)
    • That is, if there's no editor integration (TODO)
  • Given a word list...
    • If user stroke A/B/C -> "a b c", automatically convert it to "aBC" (assuming camel case)
    • Then if user press * there are two options
      • Revert to "a b c" (note: do not reform the word immediately!)
      • Revert to "a b" (which is the one that makes the most sense with Plover's default meaning of undo)
        • Note: handle the case that the last "formed" word/translation has replaced entries!
      • Delete the whole word
    • In the latter 2 cases there should be a stroke that undo the conversion
    • Do not convert anything if there's any no-op stroke!
      • No-op: for example delete-space TK-LS, camel-case, or underscore.
    • Only change new content...?
      • For example, if the user stroke A/B, then add aB to the word list, then undo to the point with that content "a b" it should not be spontaneously changed to "aB".
      • But what if the user delete the "b" then stroke it back?

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

plover_auto_identifier-0.1.3.tar.gz (22.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

plover_auto_identifier-0.1.3-py3-none-any.whl (22.6 kB view details)

Uploaded Python 3

File details

Details for the file plover_auto_identifier-0.1.3.tar.gz.

File metadata

  • Download URL: plover_auto_identifier-0.1.3.tar.gz
  • Upload date:
  • Size: 22.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.13.1

File hashes

Hashes for plover_auto_identifier-0.1.3.tar.gz
Algorithm Hash digest
SHA256 ed96dc29c061a7cef2cecb81bc912ff7ec4f102f3ead437a8f45ac4470ef208a
MD5 ce8c767787592413a0c9fb794921162b
BLAKE2b-256 3ee47867e365fb200dec2a810e282d40b6157aac176fdd083e747ba36062ae7b

See more details on using hashes here.

File details

Details for the file plover_auto_identifier-0.1.3-py3-none-any.whl.

File metadata

File hashes

Hashes for plover_auto_identifier-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 2018ab155de8afc4883182315dd2f065d80af6a43a2d2d2ab7add1fba44d2699
MD5 4ac5ebc23f9f655597dda78b94b59b40
BLAKE2b-256 8eaf3e49f3ea57bd740079ad573df1a9bc454277b38c587388792ecec14a1d65

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page