commands: Fix broken --appendPort=false
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Fri, 24 Nov 2017 07:43:09 +0000 (08:43 +0100)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Fri, 24 Nov 2017 10:29:01 +0000 (11:29 +0100)
Also make sure to log the correct server URL to the console.

Fixes #4111

commands/commandeer.go
commands/server.go

index b08566613b7c3b130ae94b6c5edafe832bca0171..f538ba6199776dc73a7a354ee37cfbed913c241f 100644 (file)
@@ -25,6 +25,8 @@ type commandeer struct {
        pathSpec    *helpers.PathSpec
        visitedURLs *types.EvictingStringQueue
 
+       serverPorts []int
+
        configured bool
 }
 
index 666f255e3bd4fe5f49050a0560f681f4f3558c8a..e1cc5674957cd7d1d0805e04db81af332a678f12 100644 (file)
@@ -145,6 +145,9 @@ func server(cmd *cobra.Command, args []string) error {
        serverPorts := make([]int, 1)
 
        if languages.IsMultihost() {
+               if !serverAppend {
+                       return newSystemError("--appendPort=false not supported when in multihost mode")
+               }
                serverPorts = make([]int, len(languages))
        }
 
@@ -171,6 +174,8 @@ func server(cmd *cobra.Command, args []string) error {
                currentServerPort = serverPorts[i] + 1
        }
 
+       c.serverPorts = serverPorts
+
        c.Set("port", serverPort)
        if liveReloadPort != -1 {
                c.Set("liveReloadPort", liveReloadPort)
@@ -246,16 +251,15 @@ func server(cmd *cobra.Command, args []string) error {
 }
 
 type fileServer struct {
-       ports    []int
        baseURLs []string
        roots    []string
        c        *commandeer
 }
 
-func (f *fileServer) createEndpoint(i int) (*http.ServeMux, string, error) {
+func (f *fileServer) createEndpoint(i int) (*http.ServeMux, string, string, error) {
        baseURL := f.baseURLs[i]
        root := f.roots[i]
-       port := f.ports[i]
+       port := f.c.serverPorts[i]
 
        publishDir := f.c.Cfg.GetString("publishDir")
 
@@ -286,7 +290,7 @@ func (f *fileServer) createEndpoint(i int) (*http.ServeMux, string, error) {
        // We're only interested in the path
        u, err := url.Parse(baseURL)
        if err != nil {
-               return nil, "", fmt.Errorf("Invalid baseURL: %s", err)
+               return nil, "", "", fmt.Errorf("Invalid baseURL: %s", err)
        }
 
        decorate := func(h http.Handler) http.Handler {
@@ -317,7 +321,7 @@ func (f *fileServer) createEndpoint(i int) (*http.ServeMux, string, error) {
 
        endpoint := net.JoinHostPort(serverInterface, strconv.Itoa(port))
 
-       return mu, endpoint, nil
+       return mu, u.String(), endpoint, nil
 }
 
 func (c *commandeer) serve() {
@@ -327,24 +331,20 @@ func (c *commandeer) serve() {
        var (
                baseURLs []string
                roots    []string
-               ports    []int
        )
 
        if isMultiHost {
                for _, s := range Hugo.Sites {
                        baseURLs = append(baseURLs, s.BaseURL.String())
                        roots = append(roots, s.Language.Lang)
-                       ports = append(ports, s.Info.ServerPort())
                }
        } else {
                s := Hugo.Sites[0]
                baseURLs = []string{s.BaseURL.String()}
                roots = []string{""}
-               ports = append(ports, s.Info.ServerPort())
        }
 
        srv := &fileServer{
-               ports:    ports,
                baseURLs: baseURLs,
                roots:    roots,
                c:        c,
@@ -357,13 +357,13 @@ func (c *commandeer) serve() {
        }
 
        for i, _ := range baseURLs {
-               mu, endpoint, err := srv.createEndpoint(i)
+               mu, serverURL, endpoint, err := srv.createEndpoint(i)
 
                if doLiveReload {
                        mu.HandleFunc("/livereload.js", livereload.ServeJS)
                        mu.HandleFunc("/livereload", livereload.Handler)
                }
-               jww.FEEDBACK.Printf("Web Server is available at %s (bind address %s)\n", endpoint, serverInterface)
+               jww.FEEDBACK.Printf("Web Server is available at %s (bind address %s)\n", serverURL, serverInterface)
                go func() {
                        err = http.ListenAndServe(endpoint, mu)
                        if err != nil {