Logo Search packages:      
Sourcecode: gretl version File versions  Download package

clipboard.c

/* 
 *  gretl -- Gnu Regression, Econometrics and Time-series Library
 *  Copyright (C) 2001 Allin Cottrell and Riccardo "Jack" Lucchetti
 * 
 *  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 3 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, see <http://www.gnu.org/licenses/>.
 * 
 */

#include "gretl.h"
#include "textutil.h"

#define CLIPDEBUG 0

static gchar *clipboard_buf; 

GtkTargetEntry text_targets[] = {
    { "UTF8_STRING",     0, TARGET_UTF8_STRING },
    { "STRING",          0, TARGET_STRING },
    { "TEXT",            0, TARGET_TEXT }, 
    { "COMPOUND_TEXT",   0, TARGET_COMPOUND_TEXT }
};

GtkTargetEntry rtf_targets[] = {
    { "application/rtf",   0, TARGET_RTF },
    { "application/x-rtf", 0, TARGET_RTF },
    { "text/rtf",          0, TARGET_RTF },
    { "text/richtext",     0, TARGET_RTF },
    { "STRING",            0, TARGET_STRING },
    { "TEXT",              0, TARGET_TEXT }
};

static int n_text = sizeof text_targets / sizeof text_targets[0];
static int n_rtf = sizeof rtf_targets / sizeof rtf_targets[0];

static void gretl_clipboard_set (int copycode);

static void gretl_clipboard_free (void)
{
    free(clipboard_buf);
    clipboard_buf = NULL;
}

int buf_to_clipboard (const char *buf)
{
    int err = 0;

    if (buf == NULL || *buf == '\0') {
      return 0;
    }

    gretl_clipboard_free();
    clipboard_buf = gretl_strdup(buf);
    if (clipboard_buf == NULL) {
      err = 1;
    } else {
      gretl_clipboard_set(GRETL_FORMAT_TXT);
    }

    return err;
}

#if CLIPDEBUG

static const char *fmt_label (int f)
{
    if (f == TARGET_UTF8_STRING) {
      return "TARGET_UTF8_STRING";
    } else if (f == TARGET_STRING) {
      return "TARGET_STRING";
    } else if (f == TARGET_TEXT) {
      return "TARGET_STRING";
    } else if (f == TARGET_COMPOUND_TEXT) {
      return "TARGET_COMPOUND_STRING";
    } else if (f == TARGET_RTF) {
      return "TARGET_RTF";
    } else {
      return "unknown";
    }
}

#endif  

static void gretl_clipboard_get (GtkClipboard *clip,
                         GtkSelectionData *selection_data,
                         guint info,
                         gpointer p)
{
    gchar *str = clipboard_buf; /* global */

#if CLIPDEBUG
    fprintf(stderr, "gretl_clipboard_get: info = %d (%s)\n", 
          (int) info, fmt_label(info));
#endif   

    if (str == NULL || *str == '\0') {
      return;
    }

    if (info != TARGET_UTF8_STRING) {
      /* need to remove any UTF-8 minuses? */
      str = strip_utf_minus(str);
    }

    if (info == TARGET_RTF) {
      gtk_selection_data_set(selection_data,
                         GDK_SELECTION_TYPE_STRING,
                         8, (guchar *) str, 
                         strlen(str));
    } else {
      gtk_selection_data_set_text(selection_data, str, -1);
    }
}

static void gretl_clipboard_clear (GtkClipboard *clip, gpointer p)
{
    gretl_clipboard_free();
}

static void gretl_clipboard_set (int fmt)
{
    static GtkClipboard *clip;
    GtkTargetEntry *targs;
    gint n_targs;

#ifdef OSX_BUILD
    if (fmt == GRETL_FORMAT_RTF || fmt == GRETL_FORMAT_RTF_TXT) {
      FILE *fp = popen("/usr/bin/pbcopy", "w");

      if (fp != NULL) {
          fputs(clipboard_buf, fp);
          pclose(fp);
          return;
      }
    }
#endif

    if (clip == NULL) {
      clip = gtk_clipboard_get(GDK_SELECTION_CLIPBOARD);
    }

    if (fmt == GRETL_FORMAT_RTF || fmt == GRETL_FORMAT_RTF_TXT) {
      targs = rtf_targets;
      n_targs = n_rtf;
    } else {
      targs = text_targets;
      n_targs = n_text;
    }

#if CLIPDEBUG
    fprintf(stderr, "gretl_clipboard_set: fmt = %d\n", fmt);
#endif

    if (!gtk_clipboard_set_with_owner(clip, targs, n_targs,
                              gretl_clipboard_get,
                              gretl_clipboard_clear,
                              G_OBJECT(mdata->main))) {
      fprintf(stderr, "Failed to initialize clipboard\n");
    }
}

int prn_to_clipboard (PRN *prn, int fmt)
{
    const char *buf = gretl_print_get_buffer(prn);
    int err = 0;

    if (buf == NULL || *buf == '\0') {
      return 0;
    }

    gretl_clipboard_free();

    if (fmt == GRETL_FORMAT_RTF || fmt == GRETL_FORMAT_RTF_TXT) { 
      /* RTF: ensure that we're not in UTF-8 */
      if (string_is_utf8((const unsigned char *) buf)) {
          gchar *trbuf = utf8_to_cp(buf);

          if (trbuf != NULL) {
            if (fmt == GRETL_FORMAT_RTF_TXT) {
                clipboard_buf = dosify_buffer(trbuf, fmt);
            } else {
                clipboard_buf = gretl_strdup(trbuf);
            }
            g_free(trbuf);
          }
      } else if (fmt == GRETL_FORMAT_RTF_TXT) {
          clipboard_buf = dosify_buffer(buf, fmt);
      } else {
          clipboard_buf = gretl_strdup(buf);
      }
    } else {
      /* plain text, TeX, CSV */
      clipboard_buf = gretl_strdup(buf);
    }

    if (clipboard_buf == NULL) {
      err = 1;
    } else {
      gretl_clipboard_set(fmt);
    }

    return err;
}



Generated by  Doxygen 1.6.0   Back to index