2019-02-26 14:40:28 +00:00
|
|
|
package mux
|
|
|
|
|
|
|
|
import (
|
|
|
|
"sync"
|
|
|
|
)
|
|
|
|
|
|
|
|
type connMap struct {
|
|
|
|
connMap map[int32]*conn
|
2019-11-21 15:53:06 +00:00
|
|
|
//closeCh chan struct{}
|
2019-02-26 14:40:28 +00:00
|
|
|
sync.RWMutex
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewConnMap() *connMap {
|
|
|
|
connMap := &connMap{
|
|
|
|
connMap: make(map[int32]*conn),
|
2019-11-21 15:53:06 +00:00
|
|
|
//closeCh: make(chan struct{}),
|
2019-02-26 14:40:28 +00:00
|
|
|
}
|
2019-11-21 15:53:06 +00:00
|
|
|
//go connMap.clean()
|
2019-02-26 14:40:28 +00:00
|
|
|
return connMap
|
|
|
|
}
|
|
|
|
|
2019-10-13 14:45:40 +00:00
|
|
|
func (s *connMap) Size() (n int) {
|
2019-11-21 15:53:06 +00:00
|
|
|
s.Lock()
|
|
|
|
n = len(s.connMap)
|
|
|
|
s.Unlock()
|
|
|
|
return
|
2019-10-13 14:45:40 +00:00
|
|
|
}
|
|
|
|
|
2019-02-26 14:40:28 +00:00
|
|
|
func (s *connMap) Get(id int32) (*conn, bool) {
|
|
|
|
s.Lock()
|
2019-11-21 15:53:06 +00:00
|
|
|
v, ok := s.connMap[id]
|
|
|
|
s.Unlock()
|
|
|
|
if ok && v != nil {
|
2019-02-26 14:40:28 +00:00
|
|
|
return v, true
|
|
|
|
}
|
|
|
|
return nil, false
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *connMap) Set(id int32, v *conn) {
|
|
|
|
s.Lock()
|
|
|
|
s.connMap[id] = v
|
2019-11-21 15:53:06 +00:00
|
|
|
s.Unlock()
|
2019-02-26 14:40:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *connMap) Close() {
|
2019-11-21 15:53:06 +00:00
|
|
|
//s.closeCh <- struct{}{} // stop the clean goroutine first
|
2019-02-26 14:40:28 +00:00
|
|
|
for _, v := range s.connMap {
|
2019-11-21 15:53:06 +00:00
|
|
|
v.Close() // close all the connections in the mux
|
2019-02-26 14:40:28 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-03-15 06:03:49 +00:00
|
|
|
func (s *connMap) Delete(id int32) {
|
|
|
|
s.Lock()
|
|
|
|
delete(s.connMap, id)
|
2019-11-21 15:53:06 +00:00
|
|
|
s.Unlock()
|
2019-03-15 06:03:49 +00:00
|
|
|
}
|
|
|
|
|
2019-11-21 15:53:06 +00:00
|
|
|
//func (s *connMap) clean() {
|
|
|
|
// ticker := time.NewTimer(time.Minute * 1)
|
|
|
|
// for {
|
|
|
|
// select {
|
|
|
|
// case <-ticker.C:
|
|
|
|
// s.Lock()
|
|
|
|
// for _, v := range s.connMap {
|
|
|
|
// if v.isClose {
|
|
|
|
// delete(s.connMap, v.connId)
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// s.Unlock()
|
|
|
|
// case <-s.closeCh:
|
|
|
|
// ticker.Stop()
|
|
|
|
// return
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
//}
|