// We are going to Create an 'information_schema' for given schema func loadSystemSchema(ss *schema.SchemaSource) error { s := ss.Schema if s == nil { return fmt.Errorf("Must have schema but was nil") } infoSchema := s.InfoSchema var infoSchemaSource *schema.SchemaSource if infoSchema == nil { infoSchemaSource = schema.NewSchemaSource("schema", "schema") //u.Infof("reg p:%p ds %#v tables:%v", registry, ds, ds.Tables()) schemaDb := NewSchemaDb(s) infoSchemaSource.DS = schemaDb infoSchema = schema.NewSchema("schema") schemaDb.is = infoSchema //u.Debugf("schema:%p ss:%p loadSystemSchema: NEW infoschema:%p s:%s ss:%s", s, ss, infoSchema, s.Name, ss.Name) infoSchemaSource.Schema = infoSchema infoSchemaSource.AddTableName("tables") infoSchema.SchemaSources["schema"] = infoSchemaSource infoSchema.InfoSchema = infoSchema } else { infoSchemaSource = infoSchema.SchemaSources["schema"] } // For each table in source schema for _, tableName := range ss.Tables() { //u.Debugf("adding table: %q to infoSchema %p", tableName, infoSchema) _, err := ss.Table(tableName) if err != nil { u.Warnf("Missing table?? %q", tableName) continue } infoSchemaSource.AddTableName(tableName) } s.InfoSchema = infoSchema s.RefreshSchema() //u.Debugf("s:%p ss:%p infoschema:%p name:%s", s, ss, infoSchema, s.Name) return nil }