Skip to content

Commit

Permalink
fix: move generic schema writing to the JVM plugin
Browse files Browse the repository at this point in the history
  • Loading branch information
stuartwdouglas committed Dec 19, 2024
1 parent b9f8209 commit cf539f8
Show file tree
Hide file tree
Showing 7 changed files with 80 additions and 37 deletions.
41 changes: 41 additions & 0 deletions common/schema/schema.go
Original file line number Diff line number Diff line change
Expand Up @@ -215,3 +215,44 @@ func FromProto(s *schemapb.Schema) (*Schema, error) {
}
return ValidateSchema(schema)
}

// ModuleDependencies returns the modules that the given module depends on
// Dependency modules are the ones that are called by the given module, or that publish topics that the given module subscribes to
func (s *Schema) ModuleDependencies(module string) map[string]*Module {
mods := map[string]*Module{}
for _, sch := range s.Modules {
mods[sch.Name] = sch
}
deps := make(map[string]*Module)
toProcess := []string{module}
for len(toProcess) > 0 {
dep := toProcess[0]
toProcess = toProcess[1:]
if deps[dep] != nil {
continue
}
dm := mods[dep]
deps[dep] = dm
for _, m := range dm.Decls {
if ref, ok := m.(*Verb); ok {
for _, ref := range ref.Metadata {
switch md := ref.(type) {
case *MetadataCalls:
for _, calls := range md.Calls {
if calls.Module != "" {
toProcess = append(toProcess, calls.Module)
}
}
case *MetadataSubscriber:
if md.Topic.Module != "" {
toProcess = append(toProcess, md.Topic.Module)
}
default:
}
}
}
}
}
delete(deps, module)
return deps
}
2 changes: 1 addition & 1 deletion frontend/cli/cmd_new.go
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ func prepareNewCmd(ctx context.Context, k *kong.Kong, args []string) (optionalPl
return optionalPlugin, fmt.Errorf("could not load project config: %w", err)
}

plugin, err := languageplugin.New(ctx, filepath.Dir(projConfigPath), language, "new", false)
plugin, err := languageplugin.New(ctx, filepath.Dir(projConfigPath), language, "new")

if err != nil {
return optionalPlugin, fmt.Errorf("could not create plugin for %v: %w", language, err)
Expand Down
2 changes: 1 addition & 1 deletion internal/buildengine/engine.go
Original file line number Diff line number Diff line change
Expand Up @@ -1051,7 +1051,7 @@ func (e *Engine) gatherSchemas(
}

func (e *Engine) newModuleMeta(ctx context.Context, config moduleconfig.UnvalidatedModuleConfig) (moduleMeta, error) {
plugin, err := languageplugin.New(ctx, config.Dir, config.Language, config.Module, e.devMode)
plugin, err := languageplugin.New(ctx, config.Dir, config.Language, config.Module)
if err != nil {
return moduleMeta{}, fmt.Errorf("could not create plugin for %s: %w", config.Module, err)
}
Expand Down
4 changes: 2 additions & 2 deletions internal/buildengine/languageplugin/plugin.go
Original file line number Diff line number Diff line change
Expand Up @@ -96,8 +96,8 @@ type BuildContext struct {

var ErrPluginNotRunning = errors.New("language plugin no longer running")

// PluginFromConfig creates a new language plugin from the given config.
func New(ctx context.Context, dir, language, name string, devMode bool) (p *LanguagePlugin, err error) {
// New creates a new language plugin from the given config.
func New(ctx context.Context, dir, language, name string) (p *LanguagePlugin, err error) {
impl, err := newClientImpl(ctx, dir, language, name)
if err != nil {
return nil, err
Expand Down
33 changes: 1 addition & 32 deletions internal/buildengine/stubs.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ func GenerateStubs(ctx context.Context, projectRoot string, modules []*schema.Mo
if err != nil {
return err
}
return writeGenericSchemaFiles(modules, metas)
return nil
}

// CleanStubs removes all generated stubs.
Expand Down Expand Up @@ -107,34 +107,3 @@ func generateStubsForEachLanguage(ctx context.Context, projectRoot string, modul
}
return nil
}

func writeGenericSchemaFiles(modules []*schema.Module, metas map[string]moduleMeta) error {
sch := &schema.Schema{Modules: modules}
for _, meta := range metas {
module := meta.module.Config
if module.GeneratedSchemaDir == "" {
continue
}

modPath := module.Abs().GeneratedSchemaDir
err := os.MkdirAll(modPath, 0750)
if err != nil {
return fmt.Errorf("failed to create directory %s: %w", modPath, err)
}

for _, mod := range sch.Modules {
if mod.Name == module.Module {
continue
}
data, err := schema.ModuleToBytes(mod)
if err != nil {
return fmt.Errorf("failed to export module schema for module %s %w", mod.Name, err)
}
err = os.WriteFile(filepath.Join(modPath, mod.Name+".pb"), data, 0600)
if err != nil {
return fmt.Errorf("failed to write schema file for module %s %w", mod.Name, err)
}
}
}
return nil
}
2 changes: 1 addition & 1 deletion jvm-runtime/plugin/common/java_plugin_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,7 @@ func TestJavaConfigDefaults(t *testing.T) {
dir, err := filepath.Abs(tt.dir)
assert.NoError(t, err)

plugin, err := languageplugin.New(ctx, t.TempDir(), "java", "test", false)
plugin, err := languageplugin.New(ctx, t.TempDir(), "java", "test")
assert.NoError(t, err)
t.Cleanup(func() {
_ = plugin.Kill() //nolint:errcheck
Expand Down
33 changes: 33 additions & 0 deletions jvm-runtime/plugin/common/jvmcommon.go
Original file line number Diff line number Diff line change
Expand Up @@ -166,6 +166,10 @@ func (s *Service) Build(ctx context.Context, req *connect.Request[langpb.BuildRe
if err != nil {
return err
}
err = s.writeGenericSchemaFiles(buildCtx)
if err != nil {
return err
}
if req.Msg.RebuildAutomatically {
return s.runDevMode(ctx, req, buildCtx, stream)
}
Expand Down Expand Up @@ -519,6 +523,10 @@ func (s *Service) BuildContextUpdated(ctx context.Context, req *connect.Request[
if err != nil {
return nil, err
}
err = s.writeGenericSchemaFiles(buildCtx)
if err != nil {
return nil, err
}

s.updatesTopic.Publish(buildContextUpdatedEvent{
buildCtx: buildCtx,
Expand Down Expand Up @@ -795,3 +803,28 @@ func loadProtoErrors(config moduleconfig.AbsModuleConfig) (*langpb.ErrorList, er
func ptr(s string) *string {
return &s
}

func (s *Service) writeGenericSchemaFiles(buildContext buildContext) error {

modPath := buildContext.Config.GeneratedSchemaDir
err := os.MkdirAll(modPath, 0750)
if err != nil {
return fmt.Errorf("failed to create directory %s: %w", modPath, err)
}

for _, mod := range buildContext.Schema.Modules {
if mod.Name == buildContext.Config.Module {
continue
}
data, err := schema.ModuleToBytes(mod)
if err != nil {
return fmt.Errorf("failed to export module schema for module %s %w", mod.Name, err)
}
err = os.WriteFile(filepath.Join(modPath, mod.Name+".pb"), data, 0600)
if err != nil {
return fmt.Errorf("failed to write schema file for module %s %w", mod.Name, err)
}
}

return nil
}

0 comments on commit cf539f8

Please sign in to comment.