本文整理匯總了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)
}