Skip to content

Communicate from VS Dev Containers with the host system.

License

Notifications You must be signed in to change notification settings

vladfolts/dc2host

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Introduction

dc2host python package is intended to be used for interaction between VS Code running Dev Containers and other development tools that run on the host system (e.g. git difftool etc). It also contains a command line interface that can be used without VS Code just to open a source file from a local Git repository in GitLab/GitHub Web UI with the specified line number selected.

git difftool example

Suppose you have your favorite GUI git difftool configured to run from VS Code for the current file. This setup won't work when you start using Dev Containers because your host system is isolated from VS Code Server and file paths are different for what VS Code sees in a container and for what git difftool sees on the host.

To resolve this problem dc2host runs a simple REST server on the host that handles requests from Dev Containers and knows how to translate file paths to use them on the host.

Supported REST endpoints

run command

POST /run
{
    "cwd": <container directory where from to execute the specified command>,
    "args": ["command", "argument1", "argument2"],
    "check": false|true - check for zero exit code
}

Example:

curl -d "{\"args\": [\"git\", \"difftool\", \"file/relative/path\"], \"cwd\": \"/workspace/directory\"}" -H "Content-Type: application/json" host.docker.internal:5000/run

open_in_browser command

Opens the specified file from a local repo in Web browser on GitHub/GitLab.

POST /open_in_browser
{
    "file": <file path in a container directory>,
    "lineNumber": <line number to highlight (optional)>
}

Example:

curl -d "{\"file\": \"file1.txt\", \"lineNumber\": 42}" -H "Content-Type: application/json" host.docker.internal:5000/run

Quick start

Open file "README.md" from a local directory on GitHub:

python -m dc2host open README.md 

Run Flask on Windows host:

python -m flask --app dc2host.app run --debug --host=0.0.0.0

Configure VS Code "tasks.json"

{
    "tasks": [
        {
            "label": "Open in GitHub/GitLab",
            "type": "process",
            "command": "curl",
            "args": [
                "-d",
                "{\"file\": \"${file}\", \"lineNumber\": ${lineNumber}}",
                "-H",
                "Content-Type: application/json",
                "host.docker.internal:5000/open_in_browser"
            ],
        },
        {
            "label": "Diff current file",
            "type": "process",
            "command": "curl",
            "args": [
                "-d",
                "{\"args\": [\"git\", \"difftool\", \"${fileBasename}\"], \"cwd\": \"${fileDirname}\"}",
                "-H",
                "Content-Type: application/json",
                "host.docker.internal:5000/run"
            ],
        },
        {
            "label": "History current file",
            "type": "process",
            "command": "curl",
            "args": [
                "-d",
                "{\"args\": [\"gitk\", \"--\", \"${fileBasename}\"], \"cwd\": \"${fileDirname}\", \"check\": false}",
                "-H",
                "Content-Type: application/json",
                "host.docker.internal:5000/run"
            ],
        }
    ]
}

Configure VS Code "keybindings.json"

[
    {
        "key": "ctrl+k ctrl+d",
        "command": "workbench.action.tasks.runTask",
        "args": "Diff current file"
    }
]

About

Communicate from VS Dev Containers with the host system.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages