本文整理汇总了Golang中github.com/c-darwin/dcoin-go/packages/dcparser.Parser.GetBlocks方法的典型用法代码示例。如果您正苦于以下问题:Golang Parser.GetBlocks方法的具体用法?Golang Parser.GetBlocks怎么用?Golang Parser.GetBlocks使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类github.com/c-darwin/dcoin-go/packages/dcparser.Parser
的用法示例。
在下文中一共展示了Parser.GetBlocks方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: QueueParserBlocks
//.........这里部分代码省略.........
if err != nil {
if d.unlockPrintSleep(utils.ErrInfo(err), d.sleepTime) {
break BEGIN
}
continue BEGIN
}
/*
* Базовая проверка
*/
// проверим, укладывается ли блок в лимит rollback_blocks_1
if utils.StrToInt64(newBlockData["block_id"]) > utils.StrToInt64(prevBlockData["block_id"])+variables.Int64["rollback_blocks_1"] {
d.DeleteQueueBlock(newBlockData["head_hash_hex"], newBlockData["hash_hex"])
if d.unlockPrintSleep(utils.ErrInfo("rollback_blocks_1"), 1) {
break BEGIN
}
continue BEGIN
}
// проверим не старый ли блок в очереди
if utils.StrToInt64(newBlockData["block_id"]) < utils.StrToInt64(prevBlockData["block_id"]) {
d.DeleteQueueBlock(newBlockData["head_hash_hex"], newBlockData["hash_hex"])
if d.unlockPrintSleep(utils.ErrInfo("old block"), 1) {
break BEGIN
}
continue BEGIN
}
if utils.StrToInt64(newBlockData["block_id"]) == utils.StrToInt64(prevBlockData["block_id"]) {
// сравним хэши
hash1 := big.NewInt(0)
hash1.SetString(string(newBlockData["head_hash_hex"]), 16)
hash2 := big.NewInt(0)
hash2.SetString(string(prevBlockData["head_hash_hex"]), 16)
// newBlockData["head_hash_hex"]) <= prevBlockData["head_hash_hex"]
if hash1.Cmp(hash2) < 1 {
// если это тотже блок и его генерил тот же юзер, то могут быть равные head_hash
if hash1.Cmp(hash2) == 0 {
// в этом случае проверяем вторые хэши. Если новый блок имеет больший хэш, то нам он не нужен
// или если тот же хэш, значит блоки одинаковые
hash1 := big.NewInt(0)
hash1.SetString(string(newBlockData["hash_hex"]), 16)
hash2 := big.NewInt(0)
hash2.SetString(string(prevBlockData["hash_hex"]), 16)
// newBlockData["head_hash_hex"]) >= prevBlockData["head_hash_hex"]
if hash1.Cmp(hash2) >= 0 {
d.DeleteQueueBlock(newBlockData["head_hash_hex"], newBlockData["hash_hex"])
if d.unlockPrintSleep(utils.ErrInfo("newBlockData hash_hex == prevBlockData hash_hex"), 1) {
break BEGIN
}
continue BEGIN
}
}
} else {
d.DeleteQueueBlock(newBlockData["head_hash_hex"], newBlockData["hash_hex"])
if d.unlockPrintSleep(utils.ErrInfo("newBlockData head_hash_hex > prevBlockData head_hash_hex"), 1) {
break BEGIN
}
continue BEGIN
}
}
/*
* Загрузка блоков для детальной проверки
*/
host, err := d.Single("SELECT tcp_host FROM miners_data WHERE user_id = ?", newBlockData["user_id"]).String()
if err != nil {
d.DeleteQueueBlock(newBlockData["head_hash_hex"], newBlockData["hash_hex"])
if d.unlockPrintSleep(utils.ErrInfo(err), d.sleepTime) {
break BEGIN
}
continue BEGIN
}
blockId := utils.StrToInt64(newBlockData["block_id"])
p := new(dcparser.Parser)
p.DCDB = d.DCDB
p.GoroutineName = GoroutineName
err = p.GetBlocks(blockId, host, utils.StrToInt64(newBlockData["user_id"]), "rollback_blocks_1", GoroutineName, 7, "")
if err != nil {
log.Error("v", err)
d.DeleteQueueBlock(newBlockData["head_hash_hex"], newBlockData["hash_hex"])
d.NodesBan(utils.StrToInt64(newBlockData["user_id"]), fmt.Sprintf("%v", err))
if d.unlockPrintSleep(utils.ErrInfo(err), 1) {
break BEGIN
}
continue BEGIN
}
d.dbUnlock()
if d.dSleep(d.sleepTime) {
break BEGIN
}
}
log.Debug("break BEGIN %v", GoroutineName)
}