當前位置: 首頁>>代碼示例>>Golang>>正文


Golang RcvContext.SetBeeLocal方法代碼示例

本文整理匯總了Golang中github.com/kandoo/beehive.RcvContext.SetBeeLocal方法的典型用法代碼示例。如果您正苦於以下問題:Golang RcvContext.SetBeeLocal方法的具體用法?Golang RcvContext.SetBeeLocal怎麽用?Golang RcvContext.SetBeeLocal使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在github.com/kandoo/beehive.RcvContext的用法示例。


在下文中一共展示了RcvContext.SetBeeLocal方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。

示例1: appendToRoutingTable

func (r Router) appendToRoutingTable(path Path, ctx bh.RcvContext) (Route,
	error) {

	from, err := path.From()
	if err != nil {
		return Route{}, err
	}

	to, err := path.To()
	if err != nil {
		return Route{}, err
	}

	tbl := r.routingTable(from, ctx)
	route, ok := tbl[to]
	if !ok {
		route = Route{
			To: to,
		}
	}

	if route.Contains(path) {
		return route, errors.New("Route already has the path")
	}

	if err := route.AddPath(path); err != nil {
		return route, err
	}

	if route.IsShortestPath(path) {
		route.Updates = append(route.Updates, path)
		// Indication of an update in bee local.
		ctx.SetBeeLocal(true)
	}

	tbl[to] = route
	ctx.Dict(routeDict).Put(from.Key(), tbl)
	return route, nil
}
開發者ID:jyzhe,項目名稱:beehive,代碼行數:39,代碼來源:routing.go

示例2: Rcv

// Rcv handles both Discovery and Advertisement messages.
func (r Router) Rcv(msg bh.Msg, ctx bh.RcvContext) error {
	switch d := msg.Data().(type) {
	case Discovery:
		if err := r.appendNieghbor(Edge(d), ctx); err != nil {
			return err
		}
		if Edge(d).To.Endhost {
			adv, err := Path{}.Append(Edge(d).From, Edge(d).To)
			if err != nil {
				return err
			}
			ctx.Emit(Advertisement(adv))
		}
		// Indication of an update.
		ctx.SetBeeLocal(true)

	case Advertisement:
		path := Path(d)
		if to, err := path.To(); err != nil || !to.Endhost {
			return errors.New("Route is not towards an end-host")
		}
		if _, err := r.appendToRoutingTable(path, ctx); err != nil {
			return err
		}

	case Timeout:
		if !ctx.BeeLocal().(bool) {
			return nil
		}
		ctx.SetBeeLocal(false)

		type keyTable struct {
			k string
			t RoutingTable
		}
		var entries []keyTable
		ctx.Dict(routeDict).ForEach(func(k string, v interface{}) bool {
			tbl := v.(RoutingTable)

			from := Node{
				ID: string(k),
			}

			for to, route := range tbl {
				if len(route.Updates) == 0 {
					continue
				}

				shortestPaths := route.ShortestPaths()
				glog.V(1).Infof("Shortest paths: %v", shortestPaths)
				for _, p := range route.Updates {
					if !route.IsShortestPath(p) {
						continue
					}

					for _, n := range r.neighbors(from, ctx) {
						if np, err := p.Prepend(n.From); err == nil {
							ctx.Emit(Advertisement(np))
						}
					}
				}
				route.Updates = nil
				tbl[to] = route
			}

			entries = append(entries, keyTable{k, tbl})
			return true
		})

		for _, e := range entries {
			ctx.Dict(routeDict).Put(e.k, e.t)
		}
	}

	return nil
}
開發者ID:jyzhe,項目名稱:beehive,代碼行數:77,代碼來源:routing.go


注:本文中的github.com/kandoo/beehive.RcvContext.SetBeeLocal方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。