亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? client.c

?? libminigui-1.3.0.tar.gz。 miniGUI的庫函數源代碼!
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*** $Id: client.c,v 1.46 2003/09/04 06:02:53 weiym Exp $** ** client.c: maintain the clients in server.** ** Copyright (C) 2003 Feynman Software** Copyright (C) 2000 ~ 2002 Wei Yongming.**** Current maintainer: Wei Yongming.**** Create date: 2000/12/20**** NOTE: The idea comes from sample code in APUE.*//*** This program is free software; you can redistribute it and/or modify** it under the terms of the GNU General Public License as published by** the Free Software Foundation; either version 2 of the License, or** (at your option) any later version.**** This program is distributed in the hope that it will be useful,** but WITHOUT ANY WARRANTY; without even the implied warranty of** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the** GNU General Public License for more details.**** You should have received a copy of the GNU General Public License** along with this program; if not, write to the Free Software** Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA*//*** TODO:*/#include <sys/types.h>#include <signal.h>#include "common.h"#include "minigui.h"#include "gdi.h"#include "window.h"#include "cliprect.h"#include "internals.h"#include "ourhdr.h"#include "sockio.h"#include "client.h"#include "server.h"#include "sharedres.h"#include "drawsemop.h"#define    NALLOC       4        /* #Client structs to alloc/realloc for */extern unsigned int __mg_timer_counter;MG_Client* mgClients = NULL;int mgClientSize = 0;MG_Layer* mgLayers = NULL;MG_Layer* mgTopmostLayer = NULL;ON_CHANGE_LAYER OnChangeLayer = NULL;#define CHANGE_TOPMOST_LAYER(layer)             \    lock_draw_sem ();                           \    SHAREDRES_TOPMOST_LAYER = (GHANDLE)layer;   \    unlock_draw_sem ();    #define SET_CLIENT_SCREEN(rc)                   \    lock_draw_sem ();                           \    SHAREDRES_CLI_SCR_LX = new_rc.left;         \    SHAREDRES_CLI_SCR_TY = new_rc.top;          \    SHAREDRES_CLI_SCR_RX = new_rc.right;        \    SHAREDRES_CLI_SCR_BY = new_rc.bottom;       \    unlock_draw_sem ();static void offset_pointers (MG_Client* new_head, int size, int off){    int i;    MG_Layer* layer;    if (off == 0) return;    for (i = 0; i < size; i++) {        if (new_head [i].next)            (char*)new_head [i].next += off;        if (new_head [i].prev)            (char*)new_head [i].prev += off;    }    layer = mgLayers;    while (layer) {        if (layer->cli_head)            (char*)layer->cli_head += off;        if (layer->cli_active)            (char*)layer->cli_active += off;        layer = layer->next;    }}static BOOL client_alloc (void)        /* alloc more entries in the client[] array */{    int i;    if (mgClients == NULL)        mgClients = malloc (NALLOC * sizeof(MG_Client));    else {        char* new_head = realloc (mgClients, (mgClientSize + NALLOC) * sizeof(MG_Client));        if (new_head) {            offset_pointers ((MG_Client*) new_head, mgClientSize,                             new_head - (char*)mgClients);        }        mgClients = (MG_Client*) new_head;    }    if (mgClients == NULL)        return FALSE;    /* have to initialize the new entries */    for (i = mgClientSize; i < mgClientSize + NALLOC; i++) {        memset (mgClients + i, 0, sizeof (MG_Client));        mgClients[i].fd        = -1;    /* fd of -1 means entry available */    }    mgClientSize += NALLOC;    return TRUE;}/*  * Called by IdleHandler4Server() when connection request  * from a new client arrives  */int client_add (int fd, pid_t pid, uid_t uid){    int i;    if (mgClients == NULL)        /* first time we're called */        if (!client_alloc ())            return -1;again:    for (i = 0; i < mgClientSize; i++) {        if (mgClients[i].fd == -1) {    /* find an available entry */            mgClients[i].fd = fd;            mgClients[i].pid = pid;            mgClients[i].uid = uid;            mgClients[i].last_live_time = __mg_timer_counter;            return (i);    /* return index in client[] array */        }    }    /* client array full, time to realloc for more */    if (!client_alloc ())        return -1;    goto again;        /* and search again (will work this time) */}/* Called by IdleHandler4Server() when we're done with a client */void client_del (int cli){    MG_Client* client;    MG_Client* deleting = mgClients + cli;    MG_Layer* layer = deleting->layer;#ifdef _DEBUG    printf ("Remove a client: %s\n", deleting->name);#endif    if (layer == NULL)        goto ret;    if (deleting->global_res)        release_global_res (cli);    if (deleting->next)        deleting->next->prev = deleting->prev;    if (deleting->prev)         deleting->prev->next = deleting->next;    if (deleting == layer->cli_head) {        layer->cli_head = deleting->next;        if (layer->cli_head == NULL) {            if (remove_layer (layer)) {                SendMessage (HWND_DESKTOP, MSG_TOPMOSTCHANGED, 0, 0);                PostMessage (HWND_DESKTOP, MSG_ERASEDESKTOP, 0, 0);            }            goto ret;        }    }    if (deleting == layer->cli_active) {        layer->cli_active = deleting->next;        if (layer->cli_active == NULL) {            layer->cli_active = layer->cli_head;        }    }    // Recalc spare rects of this layer    SetClipRgn (layer->spare_rects, SHAREDRES_LAYER_RC);    client = layer->cli_head;    while (client) {        SubtractClipRect (layer->spare_rects, &client->rc);        client = client->next;    }    if (layer == mgTopmostLayer) {        // erase server area here        SendMessage (HWND_DESKTOP, MSG_DELCLIENT, (WPARAM)cli, (LPARAM)(&deleting->rc));        SendMessage (HWND_DESKTOP, MSG_ERASEDESKTOP, 0, (LPARAM)(&deleting->rc));    }ret:    memset (deleting, 0, sizeof (MG_Client));    deleting->fd = -1;}int my_send2client (MSG* msg, MG_Client* client){    int ret;    if (__mg_timer_counter < (client->last_live_time + THRES_LIVE)) {        ret = sock_write_t (client->fd, msg, sizeof (MSG), TO_SOCKIO);        switch (ret) {        case SOCKERR_TIMEOUT:            client->last_live_time = 0;            break;        case SOCKERR_CLOSED:            {                int cli = client - mgClients;                if (OnNewDelClient) OnNewDelClient (LCO_DEL_CLIENT, cli);                remove_client (cli, client->fd);                break;            }        }        return ret;    }    else        return SOCKERR_OK;}MG_Layer* get_layer (const char* layer_name, BOOL does_create){    MG_Layer* layer = mgLayers;    MG_Layer* new_layer;    while (layer) {        if (strncmp (layer->name, layer_name, LEN_LAYER_NAME) == 0)            return layer;        layer = layer->next;    }    if (!does_create)        return NULL;    if (!(new_layer = malloc (sizeof (MG_Layer))))        return NULL;    if (!(new_layer->spare_rects = malloc (sizeof (CLIPRGN)))) {        free (new_layer);        return NULL;    }#ifdef _DEBUG    printf ("Create a new layer: %s\n", layer_name);#endif    strcpy (new_layer->name, layer_name);    new_layer->cli_head = NULL;    new_layer->cli_active = NULL;    // chain it    if (mgLayers)        mgLayers->prev = new_layer;    new_layer->prev = NULL;    new_layer->next = mgLayers;    mgLayers = new_layer;    // Notify that a new layer created.    if (OnChangeLayer) OnChangeLayer (LCO_NEW_LAYER, new_layer, NULL);    mgTopmostLayer = mgLayers;    // Topmost layer changed    lock_draw_sem ();    SHAREDRES_TOPMOST_LAYER = (GHANDLE)mgTopmostLayer;    unlock_draw_sem ();    SendMessage (HWND_DESKTOP, MSG_TOPMOSTCHANGED, 0, 0);    PostMessage (HWND_DESKTOP, MSG_ERASEDESKTOP, 0, 0);    InitClipRgn (new_layer->spare_rects, &__mg_free_spare_rect_list);    SetClipRgn (new_layer->spare_rects, SHAREDRES_LAYER_RC);    // Notify that a new topmost layer have been set.    if (OnChangeLayer) OnChangeLayer (LCO_TOPMOST_CHANGED, mgTopmostLayer, NULL);    return new_layer;}void get_layer_info (int cli, const char* layer_name, LAYERINFO* info){    MG_Layer* layer;    MG_Client* client;    PCLIPRECT spare, max = NULL;    unsigned int max_area = 0, area;    memset (info, 0, sizeof (LAYERINFO));    info->cli_active = -1;    if (layer_name [0])        layer = get_layer (layer_name, FALSE);    else        layer = mgClients[cli].layer;    info->handle = (GHANDLE)layer;    if (info->handle) {        spare = layer->spare_rects->head;        while (spare) {            area = (RECTW (spare->rc) * RECTH (spare->rc));            if (area > max_area) {                max_area = area;                max = spare;            }            spare = spare->next;        }        client = layer->cli_head;        while (client) {            info->nr_clients ++;            client = client->next;        }        if (max)            info->max_rect = max->rc;        if (mgTopmostLayer == layer)            info->is_topmost = TRUE;        info->cli_active = layer->cli_active - mgClients;    }}BOOL remove_layer (MG_Layer* layer){#ifdef _DEBUG    printf ("Remove a layer: %s\n", layer->name);#endif    if (layer->prev)        layer->prev->next = layer->next;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日日嗨av一区二区三区四区| 不卡一区在线观看| 午夜精品福利在线| 亚洲一区电影777| 一区二区三区在线免费播放| 亚洲精品欧美在线| 亚洲精品视频在线观看网站| 亚洲精品乱码久久久久久黑人| 亚洲欧洲99久久| 亚洲婷婷在线视频| 一区二区三区四区在线免费观看 | 欧美日韩国产片| 欧美视频精品在线观看| 欧美日本视频在线| 91精选在线观看| 日韩亚洲欧美综合| 久久影院午夜片一区| 久久精品一区八戒影视| 国产精品久久久久影院亚瑟| 亚洲人吸女人奶水| 亚洲一区视频在线观看视频| 亚洲va欧美va国产va天堂影院| 五月天激情综合网| 奇米精品一区二区三区在线观看| 日产精品久久久久久久性色| 蜜臀av一区二区| 丁香啪啪综合成人亚洲小说 | 欧美日韩在线精品一区二区三区激情| 欧美专区日韩专区| 日韩免费看网站| 国产精品日日摸夜夜摸av| 亚洲欧美电影一区二区| 视频在线观看一区二区三区| 黑人精品欧美一区二区蜜桃| 99精品视频在线播放观看| 欧美私人免费视频| 精品国产sm最大网站免费看| 国产精品久久久久7777按摩| 亚洲丰满少妇videoshd| 久久成人久久爱| bt欧美亚洲午夜电影天堂| 欧美在线观看禁18| 精品少妇一区二区| 亚洲欧美日韩中文字幕一区二区三区 | 777久久久精品| 国产欧美日韩三区| 香蕉久久一区二区不卡无毒影院| 国产精品自拍网站| 色哦色哦哦色天天综合| 欧美mv日韩mv亚洲| 亚洲精品乱码久久久久久| 美女视频黄免费的久久| 91在线视频播放| 精品噜噜噜噜久久久久久久久试看| 国产精品理伦片| 日韩国产成人精品| 不卡av电影在线播放| 在线播放国产精品二区一二区四区 | 亚洲精品一区在线观看| 亚洲色图.com| 国模套图日韩精品一区二区| 欧美在线视频日韩| 国产欧美一区二区精品性色超碰| 视频一区二区中文字幕| 97久久精品人人澡人人爽| 日韩小视频在线观看专区| 一区二区三区精品在线| 国产+成+人+亚洲欧洲自线| 欧美狂野另类xxxxoooo| 亚洲欧洲色图综合| 国产麻豆精品一区二区| 欧美日韩午夜影院| 日韩一区欧美一区| 国产精品自拍三区| 欧美一区二区三区在线视频| 亚洲综合偷拍欧美一区色| 国产99久久久精品| 精品裸体舞一区二区三区| 亚洲一区二区三区四区五区黄 | 欧美日韩国产综合久久| 最近日韩中文字幕| 国产不卡在线播放| 久久伊人蜜桃av一区二区| 视频一区中文字幕国产| 欧美伊人精品成人久久综合97| 国产精品国产精品国产专区不蜜| 麻豆成人免费电影| 91精品国产综合久久久久| 亚洲网友自拍偷拍| 91麻豆国产精品久久| 日韩毛片在线免费观看| 成年人午夜久久久| 欧美高清在线一区| 丁香天五香天堂综合| 国产三级精品三级| 国产成人精品免费一区二区| 精品99久久久久久| 激情小说欧美图片| 日韩美一区二区三区| 日韩av一二三| 欧美精品一二三| 午夜国产精品一区| 欧美精品久久天天躁| 亚洲永久精品大片| 欧美中文字幕一区二区三区| 一区二区三区鲁丝不卡| 欧美日韩在线直播| 天天综合网 天天综合色| 欧美专区日韩专区| 日韩国产一区二| 91精品国产麻豆| 精品亚洲成av人在线观看| 欧美电影免费观看高清完整版在线| 日韩成人一区二区| 日韩免费在线观看| 国产精品一区二区三区99| 久久久久久久综合色一本| 国产酒店精品激情| 国产精品色一区二区三区| av电影天堂一区二区在线| 亚洲视频一二三区| 欧美在线看片a免费观看| 亚洲成人动漫在线免费观看| 欧美日韩国产一区二区三区地区| 青青草国产成人av片免费| 精品久久久久久久一区二区蜜臀| 国内精品国产成人国产三级粉色| 亚洲国产成人自拍| 色中色一区二区| 日韩精品视频网站| 久久丝袜美腿综合| 成人午夜精品在线| 亚洲黄色免费网站| 91麻豆精品国产无毒不卡在线观看| 麻豆精品视频在线观看免费| 国产日产欧美一区| 91久久久免费一区二区| 丝袜美腿亚洲色图| 久久久久一区二区三区四区| 本田岬高潮一区二区三区| 亚洲亚洲精品在线观看| 欧美一级xxx| 成人黄色电影在线| 亚洲超丰满肉感bbw| 精品国产91洋老外米糕| 99视频在线观看一区三区| 亚洲成人午夜影院| 亚洲精品在线网站| 日本韩国欧美在线| 激情综合五月天| 亚洲色图欧美偷拍| 欧美电影免费观看高清完整版 | 国产一区二区三区香蕉| 中文字幕一区日韩精品欧美| 欧美一区二区高清| 成人a区在线观看| 午夜精品爽啪视频| 欧美一区二区三区小说| 亚洲精品免费在线播放| 亚洲欧洲制服丝袜| 美国av一区二区| 国产乱色国产精品免费视频| 91在线无精精品入口| 国产精品欧美极品| 欧美一区二区视频在线观看2020| 成人综合婷婷国产精品久久| 亚洲成人黄色影院| 国产日韩欧美综合在线| 51精品秘密在线观看| jizzjizzjizz欧美| 精品综合免费视频观看| 一区二区三区四区五区视频在线观看| 欧美成人a∨高清免费观看| 91国产免费看| 成人app在线观看| 久久99热99| 亚洲高清一区二区三区| 亚洲欧美综合色| wwwwxxxxx欧美| 欧美一级二级在线观看| 在线观看91视频| 成人18视频日本| 国产精品1区二区.| 日本不卡中文字幕| 亚洲国产欧美日韩另类综合 | 欧美精品一区二区三区在线| 国产一区欧美一区| 欧美国产一区在线| 日韩三级高清在线| 欧美三级蜜桃2在线观看| 成人高清av在线| 国产精品一区在线观看乱码| 日韩国产欧美在线播放| 午夜欧美电影在线观看| 一区二区三区四区在线| 一区在线观看视频| 亚洲国产精品ⅴa在线观看| 精品国产麻豆免费人成网站| 制服丝袜中文字幕一区| 欧美日韩精品一区二区|