本文整理匯總了Golang中github.com/FactomProject/factomd/common/interfaces.DatabaseBatchable類的典型用法代碼示例。如果您正苦於以下問題:Golang DatabaseBatchable類的具體用法?Golang DatabaseBatchable怎麽用?Golang DatabaseBatchable使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了DatabaseBatchable類的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: SaveJSON
func SaveJSON(block interfaces.DatabaseBatchable) error {
data, err := block.(interfaces.Printable).JSONByte()
if err != nil {
return err
}
var out bytes.Buffer
json.Indent(&out, data, "", "\t")
data = out.Bytes()
strChainID := fmt.Sprintf("%x", block.GetChainID())
dir := DataStorePath + strChainID
if FileNotExists(dir) {
err := os.MkdirAll(dir, 0777)
if err == nil {
fmt.Println("Created directory " + dir)
} else {
return err
}
}
err = ioutil.WriteFile(fmt.Sprintf(dir+"/storeJSON.%09d.block", block.GetDatabaseHeight()), data, 0777)
if err != nil {
return err
}
return nil
}
示例2: SaveEntryJSON
func SaveEntryJSON(entry interfaces.DatabaseBatchable, blockHeight uint32) error {
data, err := entry.(interfaces.Printable).JSONByte()
if err != nil {
return err
}
var out bytes.Buffer
json.Indent(&out, data, "", "\t")
data = out.Bytes()
strChainID := fmt.Sprintf("%x", entry.GetChainID())
dir := DataStorePath + strChainID + "/entries"
if FileNotExists(dir) {
err := os.MkdirAll(dir, 0777)
if err == nil {
fmt.Println("Created directory " + dir)
} else {
return err
}
}
err = ioutil.WriteFile(fmt.Sprintf(dir+"/storeJSON.%09d.%v.entry", blockHeight, entry.DatabasePrimaryIndex().String()), data, 0777)
if err != nil {
return err
}
return nil
}
示例3: Insert
func (db *Overlay) Insert(bucket []byte, entry interfaces.DatabaseBatchable) error {
err := db.DB.Put(bucket, entry.DatabasePrimaryIndex().Bytes(), entry)
if err != nil {
return err
}
return nil
}
示例4: ProcessBlockBatchWithoutHead
func (db *Overlay) ProcessBlockBatchWithoutHead(blockBucket, numberBucket, secondaryIndexBucket []byte, block interfaces.DatabaseBatchable) error {
if block == nil {
return nil
}
batch := []interfaces.Record{}
batch = append(batch, interfaces.Record{blockBucket, block.DatabasePrimaryIndex().Bytes(), block})
if numberBucket != nil {
bytes := make([]byte, 4)
binary.BigEndian.PutUint32(bytes, block.GetDatabaseHeight())
batch = append(batch, interfaces.Record{numberBucket, bytes, block.DatabasePrimaryIndex()})
}
if secondaryIndexBucket != nil {
batch = append(batch, interfaces.Record{secondaryIndexBucket, block.DatabaseSecondaryIndex().Bytes(), block.DatabasePrimaryIndex()})
}
err := db.DB.PutInBatch(batch)
if err != nil {
return err
}
return nil
}
示例5: SaveEntryBinary
func SaveEntryBinary(entry interfaces.DatabaseBatchable, blockHeight uint32) error {
data, err := entry.MarshalBinary()
if err != nil {
return err
}
strChainID := fmt.Sprintf("%x", entry.GetChainID())
dir := DataStorePath + strChainID + "/entries"
if FileNotExists(dir) {
err := os.MkdirAll(dir, 0777)
if err == nil {
fmt.Println("Created directory " + dir)
} else {
return err
}
}
err = ioutil.WriteFile(fmt.Sprintf(dir+"/store.%09d.%v.entry", blockHeight, entry.DatabasePrimaryIndex().String()), data, 0777)
if err != nil {
return err
}
return nil
}
示例6: SaveBinary
func SaveBinary(block interfaces.DatabaseBatchable) error {
data, err := block.MarshalBinary()
if err != nil {
return err
}
strChainID := fmt.Sprintf("%x", block.GetChainID())
dir := DataStorePath + strChainID
if FileNotExists(dir) {
err := os.MkdirAll(dir, 0777)
if err == nil {
fmt.Println("Created directory " + dir)
} else {
return err
}
}
err = ioutil.WriteFile(fmt.Sprintf(dir+"/store.%09d.block", block.GetDatabaseHeight()), data, 0777)
if err != nil {
return err
}
return nil
}
示例7: ProcessBlockBatch
func (db *Overlay) ProcessBlockBatch(blockBucket, numberBucket, secondaryIndexBucket []byte, block interfaces.DatabaseBatchable) error {
if block == nil {
return nil
}
batch := []interfaces.Record{}
batch = append(batch, interfaces.Record{blockBucket, block.DatabasePrimaryIndex().Bytes(), block})
if numberBucket != nil {
bytes := make([]byte, 4)
binary.BigEndian.PutUint32(bytes, block.GetDatabaseHeight())
batch = append(batch, interfaces.Record{numberBucket, bytes, block.DatabasePrimaryIndex()})
}
if secondaryIndexBucket != nil {
batch = append(batch, interfaces.Record{secondaryIndexBucket, block.DatabaseSecondaryIndex().Bytes(), block.DatabasePrimaryIndex()})
}
batch = append(batch, interfaces.Record{[]byte{CHAIN_HEAD}, block.GetChainID(), block.DatabasePrimaryIndex()})
err := db.DB.PutInBatch(batch)
if err != nil {
return err
}
if db.ExportData {
err = blockExtractor.ExportBlock(block)
if err != nil {
return err
}
}
return nil
}
示例8: ProcessEBlockBatch
// ProcessEBlockBatche inserts the EBlock and update all it's ebentries in DB
func (db *Overlay) ProcessEBlockBatch(eblock interfaces.DatabaseBatchable) error {
//Each chain has its own number bucket, otherwise we would have conflicts
numberBucket := append([]byte{byte(ENTRYBLOCK_CHAIN_NUMBER)}, eblock.GetChainID()...)
return db.ProcessBlockBatch([]byte{byte(ENTRYBLOCK)}, numberBucket, []byte{byte(ENTRYBLOCK_KEYMR)}, eblock)
}