summaryrefslogtreecommitdiff
path: root/packages/core/src/ide/detect-ide.ts
diff options
context:
space:
mode:
authorRichie Foreman <[email protected]>2025-08-13 17:45:53 -0400
committerGitHub <[email protected]>2025-08-13 21:45:53 +0000
commitd6f74ea2f0a422c86daea2a06284e497db082a16 (patch)
treefab51ccf375da7c7f7de46e2456f16ebac8fbc4c /packages/core/src/ide/detect-ide.ts
parent501b78f3032d8e1d506b5e58d762a30a3593a500 (diff)
chore(telemetry): Add various surface detection to `determineSurface` for logging. (#6074)
Co-authored-by: christine betts <[email protected]> Co-authored-by: Jacob Richman <[email protected]> Co-authored-by: matt korwel <[email protected]>
Diffstat (limited to 'packages/core/src/ide/detect-ide.ts')
-rw-r--r--packages/core/src/ide/detect-ide.ts20
1 files changed, 18 insertions, 2 deletions
diff --git a/packages/core/src/ide/detect-ide.ts b/packages/core/src/ide/detect-ide.ts
index ef07994c..5cc3cb56 100644
--- a/packages/core/src/ide/detect-ide.ts
+++ b/packages/core/src/ide/detect-ide.ts
@@ -5,6 +5,8 @@
*/
export enum DetectedIde {
+ Devin = 'devin',
+ Replit = 'replit',
VSCode = 'vscode',
Cursor = 'cursor',
CloudShell = 'cloudshell',
@@ -19,6 +21,14 @@ export interface IdeInfo {
export function getIdeInfo(ide: DetectedIde): IdeInfo {
switch (ide) {
+ case DetectedIde.Devin:
+ return {
+ displayName: 'Devin',
+ };
+ case DetectedIde.Replit:
+ return {
+ displayName: 'Replit',
+ };
case DetectedIde.VSCode:
return {
displayName: 'VS Code',
@@ -56,19 +66,25 @@ export function detectIde(): DetectedIde | undefined {
if (process.env.TERM_PROGRAM !== 'vscode') {
return undefined;
}
+ if (process.env.__COG_BASHRC_SOURCED) {
+ return DetectedIde.Devin;
+ }
+ if (process.env.REPLIT_USER) {
+ return DetectedIde.Replit;
+ }
if (process.env.CURSOR_TRACE_ID) {
return DetectedIde.Cursor;
}
if (process.env.CODESPACES) {
return DetectedIde.Codespaces;
}
- if (process.env.EDITOR_IN_CLOUD_SHELL) {
+ if (process.env.EDITOR_IN_CLOUD_SHELL || process.env.CLOUD_SHELL) {
return DetectedIde.CloudShell;
}
if (process.env.TERM_PRODUCT === 'Trae') {
return DetectedIde.Trae;
}
- if (process.env.FIREBASE_DEPLOY_AGENT) {
+ if (process.env.FIREBASE_DEPLOY_AGENT || process.env.MONOSPACE_ENV) {
return DetectedIde.FirebaseStudio;
}
return DetectedIde.VSCode;