aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJeffrey Wilcke <jeffrey@ethereum.org>2015-06-12 19:39:38 +0800
committerJeffrey Wilcke <jeffrey@ethereum.org>2015-06-12 19:39:38 +0800
commitaaac1f0cdd7a583448b71b26866f70f5f065378d (patch)
treeb062611219238127f6cd60daae698751a396acd3
parent4bb9a61049882f427e2742773c69b969849da1c2 (diff)
parent55a796b7c3a9560f27b0bfc7fe064e84d1b36608 (diff)
downloadgo-tangerine-aaac1f0cdd7a583448b71b26866f70f5f065378d.tar
go-tangerine-aaac1f0cdd7a583448b71b26866f70f5f065378d.tar.gz
go-tangerine-aaac1f0cdd7a583448b71b26866f70f5f065378d.tar.bz2
go-tangerine-aaac1f0cdd7a583448b71b26866f70f5f065378d.tar.lz
go-tangerine-aaac1f0cdd7a583448b71b26866f70f5f065378d.tar.xz
go-tangerine-aaac1f0cdd7a583448b71b26866f70f5f065378d.tar.zst
go-tangerine-aaac1f0cdd7a583448b71b26866f70f5f065378d.zip
Merge pull request #1254 from bas-vk/ipcwindowspathfix
Invalid named pipe name
-rw-r--r--cmd/console/main.go3
-rw-r--r--cmd/geth/main.go4
-rw-r--r--cmd/utils/flags.go21
-rw-r--r--common/path.go3
4 files changed, 26 insertions, 5 deletions
diff --git a/cmd/console/main.go b/cmd/console/main.go
index 9020a12fe..e8dd412ba 100644
--- a/cmd/console/main.go
+++ b/cmd/console/main.go
@@ -52,7 +52,6 @@ func init() {
app.Action = run
app.Flags = []cli.Flag{
- utils.IPCDisabledFlag,
utils.IPCPathFlag,
utils.VerbosityFlag,
utils.JSpathFlag,
@@ -93,7 +92,7 @@ func main() {
func run(ctx *cli.Context) {
jspath := ctx.GlobalString(utils.JSpathFlag.Name)
- ipcpath := ctx.GlobalString(utils.IPCPathFlag.Name)
+ ipcpath := utils.IpcSocketPath(ctx)
repl := newJSRE(jspath, ipcpath)
repl.welcome(ipcpath)
diff --git a/cmd/geth/main.go b/cmd/geth/main.go
index 11ea23165..0f2438cfd 100644
--- a/cmd/geth/main.go
+++ b/cmd/geth/main.go
@@ -308,7 +308,7 @@ func console(ctx *cli.Context) {
ethereum,
ctx.String(utils.JSpathFlag.Name),
ctx.GlobalString(utils.RPCCORSDomainFlag.Name),
- filepath.Join(ctx.GlobalString(utils.DataDirFlag.Name), "geth.ipc"),
+ utils.IpcSocketPath(ctx),
true,
nil,
)
@@ -330,7 +330,7 @@ func execJSFiles(ctx *cli.Context) {
ethereum,
ctx.String(utils.JSpathFlag.Name),
ctx.GlobalString(utils.RPCCORSDomainFlag.Name),
- ctx.GlobalString(utils.IPCPathFlag.Name),
+ utils.IpcSocketPath(ctx),
false,
nil,
)
diff --git a/cmd/utils/flags.go b/cmd/utils/flags.go
index 80f21d50a..ec29598fb 100644
--- a/cmd/utils/flags.go
+++ b/cmd/utils/flags.go
@@ -385,9 +385,28 @@ func MakeAccountManager(ctx *cli.Context) *accounts.Manager {
return accounts.NewManager(ks)
}
+func IpcSocketPath(ctx *cli.Context) (ipcpath string) {
+ if common.IsWindows() {
+ ipcpath = common.DefaultIpcPath()
+ if ipcpath != ctx.GlobalString(IPCPathFlag.Name) {
+ ipcpath = ctx.GlobalString(IPCPathFlag.Name)
+ }
+ } else {
+ ipcpath = common.DefaultIpcPath()
+ if ctx.GlobalString(IPCPathFlag.Name) != common.DefaultIpcPath() {
+ ipcpath = ctx.GlobalString(IPCPathFlag.Name)
+ } else if ctx.GlobalString(DataDirFlag.Name) != "" &&
+ ctx.GlobalString(DataDirFlag.Name) != common.DefaultDataDir() {
+ ipcpath = filepath.Join(ctx.GlobalString(DataDirFlag.Name), "geth.ipc")
+ }
+ }
+
+ return
+}
+
func StartIPC(eth *eth.Ethereum, ctx *cli.Context) error {
config := comms.IpcConfig{
- Endpoint: filepath.Join(ctx.GlobalString(DataDirFlag.Name), "geth.ipc"),
+ Endpoint: IpcSocketPath(ctx),
}
xeth := xeth.New(eth, nil)
diff --git a/common/path.go b/common/path.go
index 63a23abcd..6e3259656 100644
--- a/common/path.go
+++ b/common/path.go
@@ -95,6 +95,9 @@ func DefaultDataDir() string {
}
func DefaultIpcPath() string {
+ if runtime.GOOS == "windows" {
+ return `\\.\pipe\geth.ipc`
+ }
return filepath.Join(DefaultDataDir(), "geth.ipc")
}