本文整理汇总了Golang中github.com/FactomProject/FactomCode/common.AdminBlock.MarshalBinary方法的典型用法代码示例。如果您正苦于以下问题:Golang AdminBlock.MarshalBinary方法的具体用法?Golang AdminBlock.MarshalBinary怎么用?Golang AdminBlock.MarshalBinary使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类github.com/FactomProject/FactomCode/common.AdminBlock
的用法示例。
在下文中一共展示了AdminBlock.MarshalBinary方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: exportABlock
func exportABlock(block *common.AdminBlock) {
if block == nil || procLog.Level() < factomlog.Info {
return
}
data, err := block.MarshalBinary()
if err != nil {
panic(err)
}
strChainID := block.Header.AdminChainID.String()
if fileNotExists(dataStorePath + strChainID) {
err := os.MkdirAll(dataStorePath+strChainID, 0777)
if err == nil {
procLog.Info("Created directory " + dataStorePath + strChainID)
} else {
procLog.Error(err)
}
}
err = ioutil.WriteFile(fmt.Sprintf(dataStorePath+strChainID+"/store.%09d.block", block.Header.DBHeight), data, 0777)
if err != nil {
panic(err)
}
}
示例2: ProcessABlockBatch
// ProcessABlockBatch inserts the AdminBlock
func (db *LevelDb) ProcessABlockBatch(block *common.AdminBlock) error {
if block != nil {
if db.lbatch == nil {
db.lbatch = new(leveldb.Batch)
}
defer db.lbatch.Reset()
binaryBlock, err := block.MarshalBinary()
if err != nil {
return err
}
abHash, err := block.PartialHash()
if err != nil {
return err
}
// Insert the binary factom block
var key []byte = []byte{byte(TBL_AB)}
key = append(key, abHash.Bytes()...)
db.lbatch.Put(key, binaryBlock)
// Insert the admin block number cross reference
key = []byte{byte(TBL_AB_NUM)}
key = append(key, block.Header.AdminChainID.Bytes()...)
bytes := make([]byte, 4)
binary.BigEndian.PutUint32(bytes, block.Header.DBHeight)
key = append(key, bytes...)
db.lbatch.Put(key, abHash.Bytes())
// Update the chain head reference
key = []byte{byte(TBL_CHAIN_HEAD)}
key = append(key, common.ADMIN_CHAINID...)
db.lbatch.Put(key, abHash.Bytes())
err = db.lDb.Write(db.lbatch, db.wo)
if err != nil {
log.Println("batch failed %v\n", err)
return err
}
}
return nil
}
示例3: ProcessABlockMultiBatch
func (db *LevelDb) ProcessABlockMultiBatch(block *common.AdminBlock) error {
if block == nil {
return nil
}
if db.lbatch == nil {
return fmt.Errorf("db.lbatch == nil")
}
binaryBlock, err := block.MarshalBinary()
if err != nil {
return err
}
abHash, err := block.PartialHash()
if err != nil {
return err
}
// Insert the binary factom block
var key = []byte{byte(TBL_AB)}
key = append(key, abHash.Bytes()...)
db.lbatch.Put(key, binaryBlock)
// Insert the admin block number cross reference
key = []byte{byte(TBL_AB_NUM)}
key = append(key, common.ADMIN_CHAINID...)
bytes := make([]byte, 4)
binary.BigEndian.PutUint32(bytes, block.Header.DBHeight)
key = append(key, bytes...)
db.lbatch.Put(key, abHash.Bytes())
// Update the chain head reference
key = []byte{byte(TBL_CHAIN_HEAD)}
key = append(key, common.ADMIN_CHAINID...)
db.lbatch.Put(key, abHash.Bytes())
return nil
}