SMath plugins - can they do an action on SMath workbook being closed?

SMath plugins - can they do an action on SMath workbook being closed? - Сообщения

#1 Опубликовано: 20.11.2015 12:22:35
Alexander O. Melnik

Alexander O. Melnik

127 сообщений из 498 понравились пользователям.

Группа: Moderator

Hi All,

Is it possible for a SMath plugin to perform a certain action when SMath workbook is closed? If yes, how can it be implemented? I would like my EXCEL plugin to close all the workbooks it opened automatically right before I quit SMath, rather than by hand.

Thank you
#2 Опубликовано: 20.11.2015 14:37:03
Davide Carpi

Davide Carpi

1 434 сообщений из 2 910 понравились пользователям.

Группа: Moderator

If you want to perform an action when you exit the SMath Executable, add your code in the Dispose() member (in ExcelIO.vb, in your case)


#region IDisposable Members

void IDisposable.Dispose()
{
    MessageBox.Show("Bye!";
}

#endregion


AFAIK to perform an action when you close a worksheet you must have a RegionBase (I may be wrong here), then you can attach an event to OnBeforeWorksheetUnoad

this.Parent.OnBeforeWorksheetUnoad += ...
If you like my plugins please consider to support the program buying a license; for personal contributions to me: paypal.me/dcprojects
1 пользователям понравился этот пост
Alexander O. Melnik 20.11.2015 14:40:00
#3 Опубликовано: 20.11.2015 18:31:35
Alexander O. Melnik

Alexander O. Melnik

127 сообщений из 498 понравились пользователям.

Группа: Moderator

Thank you, Davide, I take I can use the first code example if I want to carry out an action on quitting SMath .exe

Also could you give me some guidance on how I can log an open workbook name every time a plugin call is made? I am not quite sure how to "save" a variable in memory that can be used in the Dispose() member.

My idea is to create a string(), where each member is a workbook name. To do that, every time a plugin call is made i need to store the wb.name to some string in memory, which will be used in the Dispose() member and further cleared on exit.

Any help is appreciated.

Thanks
#4 Опубликовано: 20.11.2015 21:21:57
Davide Carpi

Davide Carpi

1 434 сообщений из 2 910 понравились пользователям.

Группа: Moderator

You can get the file name from the Store.FileName property in any function you have. A way to store this variable (as well as any other parameter you need) for further usage inside Dispose() is to use a static class.

When you process the FileName remember to check if it is null or empty (in this case the worksheet where the function is running is not yet saved anywhere)


The static class:

Namespace ExcelIO
	''' <summary>
	''' Global Stuff.
	''' </summary>
	Public NotInheritable Class GlobalEnvironment
		Private Sub New()
		End Sub
		Public Shared FileName As String
		Public Shared AnInterestingNumber As Double
		''' And so on...
	End Class
End Namespace


Inside your function:

Public Function ExpressionEvaluation(ByVal root As SMath.Manager.Term, ByVal args()() As SMath.Manager.Term, ByRef store As SMath.Manager.Store, ByRef result() As SMath.Manager.Term) As Boolean Implements SMath.Manager.IPluginLowLevelEvaluation.ExpressionEvaluation
	''' ...
	GlobalEnvironment.FileName = store.FileName
	''' ...
End Function


Inside Dispose:

Public Sub Dispose() Implements IDisposable.Dispose
	''' ...
	DoSomething(GlobalEnvironment.FileName)
	''' ...
End Sub
If you like my plugins please consider to support the program buying a license; for personal contributions to me: paypal.me/dcprojects
1 пользователям понравился этот пост
Alexander O. Melnik 20.11.2015 22:39:00
#5 Опубликовано: 20.11.2015 22:38:57
Alexander O. Melnik

Alexander O. Melnik

127 сообщений из 498 понравились пользователям.

Группа: Moderator

Davide, your code should be enough to achieve what I would like to do (if I don't run into too many errors). Just fyi you might have misunderstood my intentions - I would like to store the names of excel workbook (which I can get easily), so I believe I do not need the 2nd part of you code dealing with store.Filename.

If everything works I will get my EXCEL plugin to close all .xlsx workbooks opened during its work - which would be great!

Thanks again
1 пользователям понравился этот пост
Davide Carpi 21.11.2015 05:00:00
  • Новые сообщения
  • Нет новых сообщений