// Copyright 2016 The Go Authors. All rights reserved. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. package main import ( "fmt" "log" "path/filepath" "plugin" "common" ) func init() { common.X *= 5 } func main() { if got, want := common.X, 3*5; got != want { log.Fatalf("before plugin load common.X=%d, want %d", got, want) } p, err := plugin.Open("plugin1.so") if err != nil { log.Fatalf("plugin.Open failed: %v", err) } const wantX = 3 * 5 * 7 if got := common.X; got != wantX { log.Fatalf("after plugin load common.X=%d, want %d", got, wantX) } seven, err := p.Lookup("Seven") if err != nil { log.Fatalf(`Lookup("Seven") failed: %v`, err) } if got, want := *seven.(*int), 7; got != want { log.Fatalf("plugin1.Seven=%d, want %d", got, want) } readFunc, err := p.Lookup("ReadCommonX") if err != nil { log.Fatalf(`plugin1.Lookup("ReadCommonX") failed: %v`, err) } if got := readFunc.(func() int)(); got != wantX { log.Fatalf("plugin1.ReadCommonX()=%d, want %d", got, wantX) } // sub/plugin1.so is a different plugin with the same name as // the already loaded plugin. It also depends on common. Test // that we can load the different plugin, it is actually // different, and that it sees the same common package. subpPath, err := filepath.Abs("sub/plugin1.so") if err != nil { log.Fatalf("filepath.Abs(%q) failed: %v", subpPath, err) } subp, err := plugin.Open(subpPath) if err != nil { log.Fatalf("plugin.Open(%q) failed: %v", subpPath, err) } readFunc, err = subp.Lookup("ReadCommonX") if err != nil { log.Fatalf(`sub/plugin1.Lookup("ReadCommonX") failed: %v`, err) } if got := readFunc.(func() int)(); got != wantX { log.Fatalf("sub/plugin1.ReadCommonX()=%d, want %d", got, wantX) } subf, err := subp.Lookup("F") if err != nil { log.Fatalf(`sub/plugin1.Lookup("F") failed: %v`, err) } if gotf := subf.(func() int)(); gotf != 17 { log.Fatalf(`sub/plugin1.F()=%d, want 17`, gotf) } f, err := p.Lookup("F") if err != nil { log.Fatalf(`plugin1.Lookup("F") failed: %v`, err) } if gotf := f.(func() int)(); gotf != 3 { log.Fatalf(`plugin1.F()=%d, want 17`, gotf) } fmt.Println("PASS") }