From: Hyoyoung Chang Date: Thu, 21 Oct 2010 07:15:34 +0000 (+0900) Subject: add html atom to targets X-Git-Tag: 2.0_alpha~237 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=de718cf2bd1ea18fe0cdf731f7beaa3bb02c2554;p=framework%2Fuifw%2Fcbhm.git add html atom to targets --- diff --git a/src/xcnphandler.c b/src/xcnphandler.c index aa76c35..8deada5 100755 --- a/src/xcnphandler.c +++ b/src/xcnphandler.c @@ -70,7 +70,7 @@ static int _init_atoms() /* all atoms are global variables */ atomPrimary = XA_PRIMARY; atomSecondary = XA_SECONDARY; - atomTarget = XA_STRING; +// atomTarget = XA_STRING; atomClipboard = XInternAtom(g_disp, ATOM_CLIPBOARD_NAME, False); atomCBHM = XInternAtom (g_disp, ATOM_CLIPBOARD_MANAGER_NAME, False); atomCBOut = XInternAtom(g_disp, ATOM_CBHM_OUTBUF, False); @@ -152,7 +152,6 @@ int print_storage_buffer() int send_convert_selection() { -// XConvertSelection(g_disp, atomClipboard, atomTarget, atomCBOut, g_evtwin, CurrentTime); XConvertSelection(g_disp, atomClipboard, atomUTF8String, atomCBOut, g_evtwin, CurrentTime); DTRACE("sent convert selection\n"); return 0; @@ -250,11 +249,17 @@ int processing_selection_request(Ecore_X_Event_Selection_Request *ev) req_win = ev->requestor; req_atom = ev->property; + DTRACE("## wanted target = %d\n", ev->target); + DTRACE("## wanted target = %s\n", XGetAtomName(g_disp, ev->target)); + /* TODO : if there are request which cbhm doesn't understand, then reply None property to requestor */ if (ev->target == atomTargets) { - Atom types[2] = { atomTargets, atomTarget }; +// Atom types[2] = { atomTargets, atomUTF8String }; + Atom atomHtml = XInternAtom(g_disp, "text/html;charset=utf-8", False); + + Atom types[3] = { atomTargets, atomUTF8String, atomHtml }; // send all (not using INCR) XChangeProperty(g_disp, req_win, req_atom, XA_ATOM, @@ -279,7 +284,6 @@ int processing_selection_request(Ecore_X_Event_Selection_Request *ev) else { // send all (not using INCR) -// XChangeProperty(g_disp, req_win, req_atom, atomTarget, XChangeProperty(g_disp, req_win, req_atom, atomUTF8String, 8, PropModeReplace, (unsigned char *) g_lastest_content, (int) txt_len); } @@ -498,7 +502,7 @@ static int _xclient_msg_cb(void *data, int ev_type, void *event) { if (get_storage_start_addr != NULL) { - XChangeProperty(g_disp, reqwin, atomCBHM_cRAW, XA_STRING, + XChangeProperty(g_disp, reqwin, atomCBHM_cRAW, atomUTF8String, 8, PropModeReplace, (unsigned char *) get_storage_start_addr(), (int) get_total_storage_size()); diff --git a/src/xcnphandler.h b/src/xcnphandler.h index 1757f3a..6c395d9 100755 --- a/src/xcnphandler.h +++ b/src/xcnphandler.h @@ -50,7 +50,7 @@ static Ecore_X_Window g_evtwin = None; /* all atoms are global variables */ static Atom atomPrimary; static Atom atomSecondary; -static Atom atomTarget; +//static Atom atomTarget; static Atom atomClipboard; static Atom atomCBHM; static Atom atomCBOut;