summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMikalaiR <nikolay.romanovich@narod.ru>2016-01-07 08:38:29 +0000
committerMikalaiR <nikolay.romanovich@narod.ru>2016-01-07 08:38:29 +0000
commit9ce72dec532e793f4f0d3970f5727a788eb11219 (patch)
tree5b7d8cfedf432f4cde18d0a92ff7004caf1fa1d8
parent25c14757fb063259a890bc8fc9702db6ff207ce7 (diff)
MirLua: added CreateNamedPipe function
git-svn-id: http://svn.miranda-ng.org/main/trunk@16042 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
-rw-r--r--plugins/MirLua/src/m_windows.cpp52
1 files changed, 43 insertions, 9 deletions
diff --git a/plugins/MirLua/src/m_windows.cpp b/plugins/MirLua/src/m_windows.cpp
index ce5c53809c..729b050635 100644
--- a/plugins/MirLua/src/m_windows.cpp
+++ b/plugins/MirLua/src/m_windows.cpp
@@ -1135,6 +1135,22 @@ static int global_GetTempPath(lua_State *L) {
}
/***/
+static int global_CreateNamedPipe(lua_State *L)
+{
+ LPCSTR lpName = luaL_checkstring(L, 1);
+ DWORD dwOpenMode = luaL_checknumber(L, 2);
+ DWORD dwPipeMode = luaL_checknumber(L, 3);
+ DWORD nMaxInstances = luaL_checknumber(L, 4);
+ DWORD nOutBufferSize = luaL_checknumber(L, 5);
+ DWORD nInBufferSize = luaL_checknumber(L, 6);
+ DWORD nDefaultTimeOut = luaL_checknumber(L, 7);
+ SECURITY_ATTRIBUTES sa = { sizeof(sa), NULL, false };
+
+ HANDLE hPipe = CreateNamedPipeA(lpName, dwOpenMode, dwPipeMode, nMaxInstances, nOutBufferSize, nInBufferSize, nDefaultTimeOut, &sa);
+ lua_pushnumber(L, (long)hPipe);
+ return 1;
+}
+
/****if* luaw32/global_CreateFile
* NAME
* global_CreateFile
@@ -1883,15 +1899,15 @@ static int global_StartService(lua_State *L) {
return 1;
}
-static int global_mciSendString(lua_State *L) {
- const char *cmd = luaL_checkstring(L, 1); // only one string parameter is used
-
- long lrc = (long)mciSendStringA(cmd, NULL, 0, NULL);
-
- lua_pushnumber(L, lrc);
-
- return(1);
-}
+static int global_mciSendString(lua_State *L) {
+ const char *cmd = luaL_checkstring(L, 1); // only one string parameter is used
+
+ long lrc = (long)mciSendStringA(cmd, NULL, 0, NULL);
+
+ lua_pushnumber(L, lrc);
+
+ return(1);
+}
static int global_MessageBeep(lua_State *L) {
const UINT uType = luaL_checkinteger(L, 1);
@@ -2007,6 +2023,7 @@ static struct {
{ "FILE_ATTRIBUTE_READONLY", FILE_ATTRIBUTE_READONLY },
{ "FILE_ATTRIBUTE_SYSTEM", FILE_ATTRIBUTE_SYSTEM },
{ "FILE_ATTRIBUTE_TEMPORARY", FILE_ATTRIBUTE_TEMPORARY },
+ { "FILE_FLAG_FIRST_PIPE_INSTANCE", FILE_FLAG_FIRST_PIPE_INSTANCE },
{ "FILE_FLAG_WRITE_THROUGH", FILE_FLAG_WRITE_THROUGH },
{ "FILE_FLAG_OVERLAPPED", FILE_FLAG_OVERLAPPED },
{ "FILE_FLAG_NO_BUFFERING", FILE_FLAG_NO_BUFFERING },
@@ -2024,6 +2041,23 @@ static struct {
{ "SECURITY_EFFECTIVE_ONLY", SECURITY_EFFECTIVE_ONLY },
{ "PM_REMOVE", PM_REMOVE },
{ "PM_NOREMOVE", PM_NOREMOVE },
+
+ { "PIPE_ACCESS_DUPLEX", PIPE_ACCESS_DUPLEX },
+ { "PIPE_ACCESS_INBOUND", PIPE_ACCESS_INBOUND },
+ { "PIPE_ACCESS_OUTBOUND", PIPE_ACCESS_OUTBOUND },
+ { "PIPE_TYPE_BYTE", PIPE_TYPE_BYTE },
+ { "PIPE_TYPE_MESSAGE", PIPE_TYPE_MESSAGE },
+ { "PIPE_READMODE_BYTE", PIPE_READMODE_BYTE },
+ { "PIPE_READMODE_MESSAGE", PIPE_READMODE_MESSAGE },
+ { "PIPE_WAIT", PIPE_WAIT },
+ { "PIPE_NOWAIT", PIPE_NOWAIT },
+ { "PIPE_ACCEPT_REMOTE_CLIENTS", PIPE_ACCEPT_REMOTE_CLIENTS },
+ { "PIPE_REJECT_REMOTE_CLIENTS", PIPE_REJECT_REMOTE_CLIENTS },
+ { "WRITE_DAC", WRITE_DAC },
+ { "WRITE_OWNER", WRITE_OWNER },
+ { "ACCESS_SYSTEM_SECURITY", ACCESS_SYSTEM_SECURITY },
+
+
{ "HKEY_CLASSES_ROOT", (unsigned long)HKEY_CLASSES_ROOT },
{ "HKEY_CURRENT_CONFIG", (unsigned long)HKEY_CURRENT_CONFIG },
{ "HKEY_CURRENT_USER", (unsigned long)HKEY_CURRENT_USER },