-
Notifications
You must be signed in to change notification settings - Fork 30.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Allowing richer integration with integrated terminal (co-processes) #13337
Comments
So triggers seem to be mainly used for syntax highlighting based on some Googling. Moving the tasks framework to an extension built on top of the integrated terminal (#15584) could probably be done using some form of triggers that run a callback as it allows matching on a particular line. It also doesn't expose the potential security holes that coprocesses do as it doesn't touch |
@jrieken can you go into a little more detail for your particular co-process? Could this be done with a trigger if you could grab stdout and listen for a line matching a regex? |
My co-process goes like this: #!/usr/local/bin/node
// process.stdin.setEncoding('utf8');
const hook = process.argv[process.argv.length - 1];
const {createConnection} = require('net');
function onError(err) {
console.error(err);
process.exit(1);
}
const socket = createConnection(hook, () => {
socket.removeListener('error', onError);
process.stdin.pipe(socket);
});
socket.once('error', onError); It gets started by iTerm and simply pipes The interesting bit is that The trigger bit in this is more that the trigger can be used to start a process. Like so
|
I'm concerned about extensions listening to stdin (eg. credentials) without the users knowledge. We could always do something like this not as part of an extension without worrying about that though. |
It's not
|
Ah I was thinking the wrong thing for some reason. Is there anything else other than a var coprocessNotRunning = false;
var t = window.createTerminal();
t.addTrigger(/tsc -w/, line => {
console.log('tsc -w started: ' + data);
if (coprocessNotRunning) {
coprocessNotRunning = true;
t.on('data', data => coprocess(data));
}
});
function coprocess(data) {
// Do something with the data sent from the pty process
// Terminate at some point?
// t.off('data', coprocess);
} |
I was looking at problemMatcher.ts yesterday for @dbaeumer's use case which is similar (if not the same) to yours which scans for "problems" and registers them as problems in the product. This is what I was leaning towards for the solution for that: const tscMatcher = /^([^\s].*)\((\d+|\d+,\d+|\d+,\d+,\d+,\d+)\):\s+(error|warning|info)\s+(TS\d+)\s*:\s*(.*)$/;
t.addTrigger(tscMatcher, lineMatch => {
const file = lineMatch[1];
const location = lineMatch[2];
const severity = lineMatch[3];
const code = lineMatch[4];
const message = lineMatch[5];
// register as a problem
}); It's not critical to turn the trigger on and off here as the tasks framework would launch the process and add the trigger immediately, when the process closes the terminal will no longer accept input. |
Yeah - I think we don't need to copy the concept on co-process one-by-one but get inspired by the idea of being a 'terminal reader' |
@Tyriar I am not sure if adding the concept of a problem matcher to the terminal (although only done by regexp) is a good idea. ESLint for example needs multiline matching which would complicate things in the terminal. If I am interested in every line would I add a trigger /.*/ ? |
@dbaeumer so from your perspective |
@Tyriar yes, that would be sufficient for me. |
How to use |
@KalitaAlexey right now this is only an internal api, good to know though. |
@Tyriar, |
It sends whatever is sent to the terminal including escape sequences. This is being changed though to what is printed to the terminal, something like I'm not sure we can differentiate between stderr from stdout as the process is not being called directly but being run within a pseudoterminal. |
@Tyriar, |
I think it's a limitation of the library we use to only have a single fd for stderr and stdout. But anyway it's probably some time out before something like this manifests itself in the terminal api. I would need to investigate more deeply at that point. |
@Tyriar you mentioned this thread on #18453 (comment) So I continue here. What I try to do is to get the response from the commands in the terminal window into an extension (to evaluate the result and give suggestions). You said that the ondata will not be exposed to extensions. Or is it possible to create a custom xterm.js integrated terminal? |
@BartNetJS no it's not possible to get the data right now and needs this or a similar feature to be implemented. |
@Tyriar so i understand security issues that could occur if extension was able to access Terminal's stdin/stdout. This way extension could create its own process, or SSH connection or whatever, and then create custom terminal for that connection. |
This case should be covered by #46192, merging into that |
Popular terminal emulators such as iTerm2 and ConEmu allow for user defined interaction with the content being displayed. For instance there are coprocesses and triggers in iTerm2 which allow for very powerful interactions. For instance I have a coprocess that automagically make diagnostics in VS Code when running
tsc -w
in iTerm2.I think VS Code would greatly benefit from such rich interaction capabilities between the terminal and the outside-world
The text was updated successfully, but these errors were encountered: