func (m *infoManager) create(info *datamodel.Info) error { if _, ok := m.info[info.ID()]; ok { return fmt.Errorf(`Sketch of type "%s" with name "%s" already exists`, info.GetType(), info.GetName()) } m.info[info.ID()] = info return nil }
// CreateSketch ... func CreateSketch(info *datamodel.Info) (*SketchProxy, error) { var err error var sketch datamodel.Sketcher sp := &SketchProxy{info, sketch, sync.RWMutex{}} switch datamodel.GetTypeString(info.GetType()) { case datamodel.HLLPP: sp.sketch, err = NewHLLPPSketch(info) case datamodel.CML: sp.sketch, err = NewCMLSketch(info) case datamodel.TopK: sp.sketch, err = NewTopKSketch(info) case datamodel.Bloom: sp.sketch, err = NewBloomSketch(info) default: return nil, fmt.Errorf("Invalid sketch type: %s", sp.GetType()) } if err != nil { return nil, err } return sp, nil }
// LoadSketch ... func LoadSketch(info *datamodel.Info, file *os.File) (*SketchProxy, error) { var sketch datamodel.Sketcher sp := &SketchProxy{info, sketch, sync.RWMutex{}} size, err := utils.GetFileSize(file) if err != nil { return nil, err } data := make([]byte, size, size) _, err = file.Read(data) if err != nil { return nil, fmt.Errorf("Error loading data for sketch: %s", info.ID()) } switch datamodel.GetTypeString(info.GetType()) { case datamodel.HLLPP: sp.sketch = &HLLPPSketch{} err = sp.sketch.Unmarshal(info, data) case datamodel.CML: sp.sketch = &CMLSketch{} err = sp.sketch.Unmarshal(info, data) case datamodel.TopK: sp.sketch = &TopKSketch{} err = sp.sketch.Unmarshal(info, data) case datamodel.Bloom: sp.sketch = &BloomSketch{} err = sp.sketch.Unmarshal(info, data) default: return nil, fmt.Errorf("Invalid sketch type: %s", sp.GetType()) } if err != nil { return nil, err } return sp, nil }
func isValidType(info *datamodel.Info) bool { if info.Type == nil { return false } return len(datamodel.GetTypeString(info.GetType())) != 0 }