From: Kendall Shaw <kshaw@kendallshaw.com>
To: help-gnu-emacs@gnu.org
Subject: Re: Stumped by pasting to another application in linux
Date: Thu, 16 Nov 2017 19:08:30 -0800 [thread overview]
Message-ID: <0702c5aa-6876-2dc5-5a0a-0fd0e88ab8dc@kendallshaw.com> (raw)
In-Reply-To: <EDF57D5E-1788-421D-A2D8-579B44392829@mac.com>
On 11/15/2017 11:38 AM, Bill Rising wrote:
> Hi all,
>
> I've been getting very vexed by the following.
>
> Goal: Take the clipboard contents and paste them into another application by using a shell script called by Emacs, followed by a Return. [This is for entering a command in another application.]
>
> Problem: A shell script using automation tools (to simulate typing) which works from a Terminal window acts goofy when called by Emacs, because all paste actions happen only after the Emacs function has completed, so the Return precedes the pasting. [Negating the value of entering the command from Emacs.]
>
> I put steps to illustrate the problem below.
>
> The simplified example uses -xdotool-, but I had the same problem when using -xte-. The example pastes into gedit, but the problem exists for other applications as well. Finally, I tried both (shell-command) and (call-process-shell-command) and tried all possible settings of select-enable-clipboard and select-enable-primary, all to no avail. If only I could trip the paste before the Return, I would be happy.
>
> FWIW, I've tried such things as shell-scripts calling shell-scripts and emacs functions calling emacs functions, but all I can get is having the paste happen at the very end. I'm clearly very lost.
>
> Any ideas about how to get the paste to happen when it happens in the script?
>
> Thanks,
>
> Bill
>
> Steps to duplicate problem, because the explanation above is likely not sufficient.
>
> Here is hunh.sh---copy, paste, save it, make it executable.
>
> ---------------------------- cut here ----------------------------
> #!/bin/bash
> xdotool search --name --onlyvisible "gedit" windowactivate
>
> # select text to replace
> xdotool key ctrl+a
> # paste in the clipboard
> xdotool key ctrl+v
> # do stupid stuff before finally hitting Return, so that it's clear
> # that the paste (ctrl-v) gets misplaced
> xdotool key space space h u n h
> sleep 1
> xdotool key BackSpace BackSpace BackSpace BackSpace BackSpace BackSpace
> sleep 1
> xdotool key Return
> ---------------------------- cut here ----------------------------
>
> Here is in hunh.el. Copy it, paste it, save it as hunh.el, then load it in Emacs
>
> ---------------------------- cut here ----------------------------
> (defun hunh ()
> (interactive)
> (funcall interprogram-cut-function "Fighting with clipboards is no fun")
> (shell-command "hunh.sh")
> )
> ---------------------------- cut here ----------------------------
>
> Be sure that you have xdotool.
>
> Assuming you have it, open a single window for gedit.
>
> Type a bunch of garbage in the gedit window so that it can get replaced later.
>
> Run the script hunh.sh from the place you're working
> ./hunh.sh
>
> --> Everything will work fine, with the text being replaced, some extra typing and deleting, and then a Return.
>
> Start emacs
>
> Within emacs, load hunh.el, then run its one function
> M-x hunh
>
> --> The text in gedit will be replaced with the extra typing and deleting, then a Return, and finally the paste of the text.
>
I would like to know how this is happening. In any case, I thought of a
sort of hackish solution.
Here is revised hunh.sh:
======= cut here ===========
#!/bin/sh
trap go SIGUSR1
go()
{
xdotool search --name --onlyvisible "gedit" windowactivate
# select text to replace
xdotool key ctrl+a
# paste in the clipboard
xdotool key ctrl+v
# do stupid stuff before finally hitting Return, so that it's clear
# that the paste (ctrl-v) gets misplaced
xdotool key space space h u n h
sleep 1
xdotool key BackSpace BackSpace BackSpace BackSpace BackSpace BackSpace
sleep 1
xdotool key Return
exit 0
}
======= cut here ===========
And here is uh.sh:
======= cut here ===========
#!/bin/sh
pid=`ps -Chunh.sh -opid=`
kill -USR1 $pid
======= cut here ===========
Both hunh.sh and uh.sh are on the system path.
Run hunh.sh outside of emacs. It loops waiting to be interrupted.
Change the defun hunh to use uh.sh instead.
Essentially, this makes it so that emacs is not an ancestor process.
Kendall
prev parent reply other threads:[~2017-11-17 3:08 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-11-15 19:38 Stumped by pasting to another application in linux Bill Rising
2017-11-15 22:06 ` Emanuel Berg
2017-11-16 3:12 ` Kendall Shaw
2017-11-17 3:08 ` Kendall Shaw [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=0702c5aa-6876-2dc5-5a0a-0fd0e88ab8dc@kendallshaw.com \
--to=kshaw@kendallshaw.com \
--cc=help-gnu-emacs@gnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/emacs.git
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.