Modlr plugin
No edit summary
No edit summary
Line 1: Line 1:
A Plugin interface is an easy way to allow for you to add your own extensions.
A Plugin interface is an easy way to allow for you to add your own extensions.


We have now extended the Plugin with yet another interface to facilitate the adding of custom ocl operations. This way the design time functions like CheckModel, ViewModels and OclEditor can be made to recognize your custom operations.
We have now extended the Plugin with yet another interface to facilitate the addition of custom OCL operations. This way, the design time functions like CheckModel, ViewModels, and OclEditor can be made to recognize your custom operations.
  namespace Modlr.Plugins
  namespace Modlr.Plugins
  {
  {
Line 30: Line 30:
I added an example in the demos folder called ModlrPluginCodeGenEventsAndCustomOCLOperations
I added an example in the demos folder called ModlrPluginCodeGenEventsAndCustomOCLOperations


Not going to repeat everything here but a few goodies.
I'm not going to repeat everything here, but a few key things to note:
  namespace ModlrPluginCodeGenEventsAndCustomOCLOperations
  namespace ModlrPluginCodeGenEventsAndCustomOCLOperations
  {
  {
Line 70: Line 70:
  }
  }
  }
  }
So this is really super because my model validates in design time even if I use the custom operation:
This is exciting because my model validates in design time even if I use the custom operation:


[[File:Modlr plugin - 1.png|frameless|472x472px]]
[[File:Modlr plugin - 1.png|frameless|472x472px]]


Viewmodel columns that use the custom expression are evaluated correctly:
ViewModel columns that use the custom expression are evaluated correctly:


[[File:Modlr plugin - 2.png|frameless|473x473px]]
[[File:Modlr plugin - 2.png|frameless|473x473px]]
Line 82: Line 82:
[[File:Modlr plugin - 3.png|frameless|473x473px]]
[[File:Modlr plugin - 3.png|frameless|473x473px]]


And of course the prototyping actually executes your operations:
And of course, the prototyping actually executes your operations:


[[File:Modlr plugin - 4.png|frameless|472x472px]]
[[File:Modlr plugin - 4.png|frameless|472x472px]]


= Modlr plugins =
= Modlr plugins =
We added a plugin interface for Gaffr and ECO. We want to enable you to extend Modlr so that you can implement a special file format import, or export, or what have you.
We added a plugin interface for Gaffr and ECO. We want to enable you to extend Modlr so that you can implement a special file format import, or export, or do something other than that.


This is how it works:
This is how it works:


Given these two interfaces…
Given these two interfaces:
  namespace Modlr.Plugins
  namespace Modlr.Plugins
  {
  {
Line 105: Line 105:
  }
  }
  }
  }
…you can implement a plugin in an assembly like this:
You can implement a plugin in an assembly like this:
  public class Class1 : IModlrPlugin
  public class Class1 : IModlrPlugin
  {
  {
Line 124: Line 124:
The code above installs two Operations; OperationShowDialog and OperationActOnClass.
The code above installs two Operations; OperationShowDialog and OperationActOnClass.


Looking closer on the operation ActOnClass:
Looking closely at the operation ActOnClass:
  public class OperationActOnClass : IModlrPluginMenuOperation
  public class OperationActOnClass : IModlrPluginMenuOperation
  {
  {
Line 146: Line 146:
  <nowiki>#</nowiki>endregion
  <nowiki>#</nowiki>endregion
  }
  }
The code checks that the context is a class, and if it is the code says that the operation should be enabled. If this was an “execute” call we perform the desired logic – in this case I just add an “X” to the back of the class name.
The code checks that the context is a class, and if it is, the code says that the operation should be enabled. If this was an “execute” call, we would perform the desired logic – in this case, I just add an “X” to the back of the class name.


You can do a lot of stuff in a plugin. You get access to the IEcoServerProvider for the EcoModelLayer. The Modlr application is a standard ECO-built-application so you can use the IOCLService to get to any object, of any class that builds up your model content. You can access Diagrams, PlacedClasses, StateMachines etc. You can inspect and set TaggedValues, you can run thru every Attribute and check for spelling errors. You can create reports that you share with other ECO/Gaffr users…
You can do a lot of stuff in a plugin. You get access to the IEcoServerProvider for the EcoModelLayer. The Modlr application is a standard ECO-built application. You can use the IOCLService to get to any object of any class that builds up your model content. You can access Diagrams, PlacedClasses, StateMachines etc. You can inspect and set TaggedValues. You can run through every Attribute and check for spelling errors. You can create reports that you share with other ECO/Gaffr users…


So even if the interface is very small and simple, it is very powerful.
Even though the interface is very small and simple, it is very powerful.


When you build your Plugin you will want to reference the following assemblies (found in the eco or gaffr install directory):
When you build your Plugin, you will want to reference the following assemblies (found in the ECO or GAFFR install directory):


[[File:Modlr plugin - 5.png|frameless]]
[[File:Modlr plugin - 5.png|frameless]]
Line 158: Line 158:
Compile your plugin and put the assembly in the folder %ProgramData%/CapableObjects/Plugins
Compile your plugin and put the assembly in the folder %ProgramData%/CapableObjects/Plugins


Restart Gaffr.net or VisualStudio and you will find your plugin operations in the context menu:
Restart Gaffr.net or VisualStudio. You will find your plugin operations in the context menu:


[[File:Modlr plugin - 6.png|frameless|358x358px]]
[[File:Modlr plugin - 6.png|frameless|358x358px]]

Revision as of 08:20, 1 February 2023

A Plugin interface is an easy way to allow for you to add your own extensions.

We have now extended the Plugin with yet another interface to facilitate the addition of custom OCL operations. This way, the design time functions like CheckModel, ViewModels, and OclEditor can be made to recognize your custom operations.

namespace Modlr.Plugins
{
public interface IModlrPlugin
{
string GetName();
List<IModlrPluginMenuOperation> ProvideOperations();
}
public interface IModlrPluginMenuOperation
{
string GetName();
void CheckEnableOrExecute(IEcoServiceProvider esp, bool execute, IEcoObject maincontext, IEcoObject subcontext,out bool enabled );
}
public enum CallbackEventKind {CodeGen,ForcedCodeGen };
public interface IModlrPluginImportantEventCallbackHandler
{
void ImportantEventAboutToHappen(IEcoServiceProvider esp, CallbackEventKind eventkind, ref bool stop, ref string message);
void ImportantEventHasHappend(IEcoServiceProvider esp, CallbackEventKind eventkind);
}
public interface IModlrPluginModelAccessOclType
{
/// <summary>
/// Possible usage - add custom ocl operations that can then be correctly executed by WECPOF and correctly evaluated in OCL design time
/// </summary>
void RuntimeModelAccess(IOclTypeService ocl);
}
}

I added an example in the demos folder called ModlrPluginCodeGenEventsAndCustomOCLOperations

I'm not going to repeat everything here, but a few key things to note:

namespace ModlrPluginCodeGenEventsAndCustomOCLOperations
{
public class Plugindemo : IModlrPlugin, IModlrPluginMenuOperation, IModlrPluginModelAccessOclType, IModlrPluginImportantEventCallbackHandler
{
public string GetName()
{
return "AnotherPlugin";
}

The IModlrPluginImportantEventCallback can do things on codegen>

public void ImportantEventAboutToHappen(Eco.ObjectRepresentation.IEcoServiceProvider esp, CallbackEventKind eventkind, ref bool stop, ref string message)
{
// Here you can perform checks before codegen, and optionally stop the codegen
System.Windows.Forms.MessageBox.Show("You are updating the code, this annoying message came from plugin ModlrPluginCodeGenEventsAndCustomOCLOperations");
}

But the brand new interface is the IModlrPluginModelAccessOclType>

public void RuntimeModelAccess(IOclTypeService ocl)
{
ocl.InstallOperation(new CustomOCL_SplitAtSemi());
}

And the operation (really a different subject) looks like this:

public class CustomOCL_SplitAtSemi : OclOperationBase
{
public CustomOCL_SplitAtSemi()
{
}
protected override void Init()
{
InternalInit("SplitAtSemi", new IOclType[] { Support.StringType }, Support.StringType);
}
public override void Evaluate(IOclOperationParameters __Params)
{
string s = Support.GetAsString(__Params.Values[0]);
string[] ss=s.Split(';');
string first = "";
if (ss.Length > 0)
first = ss[0];
Support.MakeNewString(__Params.Result, first);
}
}

This is exciting because my model validates in design time even if I use the custom operation:

Modlr plugin - 1.png

ViewModel columns that use the custom expression are evaluated correctly:

Modlr plugin - 2.png

CheckModel stays empty since everything is validated:

Modlr plugin - 3.png

And of course, the prototyping actually executes your operations:

Modlr plugin - 4.png

Modlr plugins

We added a plugin interface for Gaffr and ECO. We want to enable you to extend Modlr so that you can implement a special file format import, or export, or do something other than that.

This is how it works:

Given these two interfaces:

namespace Modlr.Plugins
{
Public Interface IModlrPlugin
{
string GetName();
List<IModlrPluginMenuOperation> ProvideOperations();
}
Public Interface IModlrPluginMenuOperation
{
string GetName();
void CheckEnableOrExecute(IEcoServiceProvider esp, bool execute,
}
}

You can implement a plugin in an assembly like this:

public class Class1 : IModlrPlugin
{
#region IModlrPlugin Members
public string GetName()
{
return "Demo plugin";
}
public List<IModlrPluginMenuOperation> ProvideOperations()
{
List<IModlrPluginMenuOperation> ops = new List<IModlrPluginMenuOperation>();
ops.Add(new OperationShowDialog());
ops.Add(new OperationActOnClass());
return ops;
}
#endregion
}

The code above installs two Operations; OperationShowDialog and OperationActOnClass.

Looking closely at the operation ActOnClass:

public class OperationActOnClass : IModlrPluginMenuOperation
{
#region IModlrPluginMenuAction Members
public void CheckEnableOrExecute(IEcoServiceProvider esp,
{
enabled = false;
if (maincontext != null && maincontext.AsIObject().AsObject is Eco.ModelLayer.Class)
{
enabled = true;
if (execute)
{
(maincontext.AsIObject().AsObject as Eco.ModelLayer.Class).Name += "X";
}
}
}
public string GetName()
{
return "Operation on class";
}
#endregion
}

The code checks that the context is a class, and if it is, the code says that the operation should be enabled. If this was an “execute” call, we would perform the desired logic – in this case, I just add an “X” to the back of the class name.

You can do a lot of stuff in a plugin. You get access to the IEcoServerProvider for the EcoModelLayer. The Modlr application is a standard ECO-built application. You can use the IOCLService to get to any object of any class that builds up your model content. You can access Diagrams, PlacedClasses, StateMachines etc. You can inspect and set TaggedValues. You can run through every Attribute and check for spelling errors. You can create reports that you share with other ECO/Gaffr users…

Even though the interface is very small and simple, it is very powerful.

When you build your Plugin, you will want to reference the following assemblies (found in the ECO or GAFFR install directory):

Modlr plugin - 5.png

Compile your plugin and put the assembly in the folder %ProgramData%/CapableObjects/Plugins

Restart Gaffr.net or VisualStudio. You will find your plugin operations in the context menu:

Modlr plugin - 6.png

Simple and powerful.

This page was edited more than 11 months ago on 02/10/2024. What links here