bionic (3) minput_config_command.3m17n.gz

Provided by: m17n-docs_1.6.2-2_all bug

NAME

       minput_config_command - Configure the key sequence of an input method command.

SYNOPSIS

       int minput_config_command (MSymbol language, MSymbol name, MSymbol command, MPlist * keyseqlist)

DESCRIPTION

       Configure the key sequence of an input method command. The minput_config_command() function assigns a
       list of key sequences keyseqlist to the command command of the input method specified by language and
       name.

       If keyseqlist is a non-empty plist, it must be a list of key sequences, and each key sequence must be a
       plist of symbols.

       If keyseqlist is an empty plist, any configuration and customization of the command are cancelled, and
       default key sequences become effective.

       If keyseqlist is NULL, the configuration of the command is canceled, and the original key sequences (what
       saved in per-user customization file, or the default one) become effective.

       In the latter two cases, command can be Mnil to make all the commands of the input method the target of
       the operation.

       If name is Mnil, this function configures the key assignment of a global command, not that of a specific
       input method.

       The configuration takes effect for input methods opened or re-opened later in the current session. In
       order to make the configuration take effect for the future session, it must be saved in a per-user
       customization file by the function minput_save_config().

RETURN VALUE

           If the operation was successful, this function returns 0, otherwise returns -1. The operation fails
           in these cases:

           • keyseqlist is not in a valid form.
           • command is not available for the input method.
           • language and name do not specify an existing input method.

SEE ALSO

           minput_get_commands(), minput_save_config().

Example:

           /* Add 'C-x u' to the 'start' command of Unicode input method.  */
           {
             MSymbol start_command = msymbol ('start');
             MSymbol unicode = msymbol ('unicode');
             MPlist *cmd, *plist, *key_seq_list, *key_seq;

             /* At first get the current key-sequence assignment.  */
             cmd = minput_get_command (Mt, unicode, start_command);
             if (! cmd)
               {
                 /* The input method does not have the command 'start'.  Here
                    should come some error handling code.  */
               }
             /* Now CMD == ((start DESCRIPTION STATUS KEY-SEQUENCE ...) ...).
                Extract the part (KEY-SEQUENCE ...).  */
             plist = mplist_next (mplist_next (mplist_next (mplist_value (cmd))));
             /* Copy it because we should not modify it directly.  */
             key_seq_list = mplist_copy (plist);

             key_seq = mplist();
             mplist_add (key_seq, Msymbol, msymbol ('C-x'));
             mplist_add (key_seq, Msymbol, msymbol ('u'));
             mplist_add (key_seq_list, Mplist, key_seq);
             m17n_object_unref (key_seq);

             minput_config_command (Mt, unicode, start_command, key_seq_list);
             m17n_object_unref (key_seq_list);
           }

       Copyright (C) 2001 Information-technology Promotion Agency (IPA)
       Copyright (C) 2001-2011 National Institute of Advanced Industrial Science and Technology (AIST)
       Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free
       Documentation License <http://www.gnu.org/licenses/fdl.html>.