Mercurial > vim
view src/if_ole.idl @ 34105:c4ad4778946c v9.1.0017
patch 9.1.0017: [security]: use-after-free in eval1_emsg()
Commit: https://github.com/vim/vim/commit/28d71b566a29ceea3a2d05bcee9264ed5d630d42
Author: Yegappan Lakshmanan <yegappan@yahoo.com>
Date: Fri Jan 12 17:21:55 2024 +0100
patch 9.1.0017: [security]: use-after-free in eval1_emsg()
Problem: use-after-free in eval1_emsg() when an empty
line follows a lambda (by @yu3s)
Solution: only set evalarg->eval_using_cmdline = FALSE when
the *arg pointer is not null
fixes: #13833
closes: #13841
Signed-off-by: Yegappan Lakshmanan <yegappan@yahoo.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
author | Christian Brabandt <cb@256bit.org> |
---|---|
date | Fri, 12 Jan 2024 17:30:06 +0100 |
parents | 9fbb40a1228a |
children |
line wrap: on
line source
// if_ole.idl - IDL source for the Vim OLE Automation interface // // Processed by the IDL compiler (MIDL) to generate the type library // (Vim.tlb). // // Command line: // MIDL /proxy nul /iid iid_ole.c /h if_ole.h /tlb vim.tlb if_ole.idl [ object, uuid(0F0BFAE2-4C90-11d1-82D7-0004AC368519), // IID_IVim helpstring("IVim"), pointer_default(unique), dual, oleautomation ] interface IVim : IDispatch { import "oaidl.idl"; HRESULT SendKeys([in]BSTR keys); HRESULT Eval([in]BSTR expr, [out, retval]BSTR* result); HRESULT SetForeground(void); HRESULT GetHwnd([out, retval]UINT_PTR* result); }; // Component and type library definitions [ uuid(0F0BFAE0-4C90-11d1-82D7-0004AC368519), // LIBID_Vim helpstring("Vim OLE Interface 1.1 Type Library"), version(1.1) ] library Vim { importlib("stdole32.tlb"); // Component [ uuid(0F0BFAE1-4C90-11d1-82D7-0004AC368519), // CLSID_Vim helpstring("Vim OLE Interface") ] coclass Vim { [default] interface IVim; }; };