#include "TGMimeTypes.h"
#include "TOrdCollection.h"
#include "TSystem.h"
#include "TDatime.h"
#include "TRegexp.h"
ClassImp(TGMimeTypes)
TGMimeTypes::TGMimeTypes(TGClient *client, const char *filename)
{
char line[1024];
char mime[1024];
char pattern[256];
char icon[256];
char sicon[256];
char action[256];
char *s;
fClient = client;
fFilename = filename;
fChanged = kFALSE;
fList = new TOrdCollection(50);
FILE *mfp;
mfp = fopen(filename, "r");
if (!mfp) {
Warning("TGMimeTypes", "error opening mime type file %s", filename);
return;
}
int cnt = 0;
while (fgets(line, 1024, mfp)) {
s = line;
s[strlen(line)-1] = 0;
while (*s == ' ') s++;
if (*s == '#') continue;
if (!strlen(s)) continue;
if (*s == '[') {
strcpy(mime, line);
cnt = 0;
continue;
}
if (!strncmp(s, "pattern", 7)) {
if (!(s = strchr(line, '='))) {
Error("TGMimeTypes", "malformed pattern line, = missing");
pattern[0] = 0;
} else {
s++;
s = Strip(s);
strcpy(pattern, s);
delete [] s;
}
cnt++;
} else if (!strncmp(s, "icon", 4)) {
if (!(s = strchr(line, '='))) {
Error("TGMimeTypes", "malformed icon line, = missing");
icon[0] = 0;
} else {
s++;
s = Strip(s);
char *s2;
if ((s2 = strchr(s, ' '))) {
*s2 = 0;
strcpy(icon, s);
s2++;
s2 = Strip(s2);
strcpy(sicon, s2);
delete [] s2;
} else {
strcpy(icon, s);
strcpy(sicon, s);
}
delete [] s;
}
cnt++;
} else if (!strncmp(s, "action", 6)) {
if (!(s = strchr(line, '='))) {
Error("TGMimeTypes", "malformed action line, = missing");
action[0] = 0;
} else {
s++;
s = Strip(s);
strcpy(action, s);
delete [] s;
}
cnt++;
}
if (cnt == 3) {
if (strchr(pattern, ' ')) {
char *tmppattern = strtok(pattern, " ");
while (tmppattern && (*tmppattern != ' ')) {
AddType(mime, tmppattern, icon, sicon, action);
tmppattern = strtok(0, " ");
}
} else {
AddType(mime, pattern, icon, sicon, action);
}
}
}
fclose(mfp);
fChanged = kFALSE;
}
TGMimeTypes::~TGMimeTypes()
{
if (fChanged) SaveMimes();
fList->Delete();
delete fList;
}
TGMimeTypes::TGMimeTypes(const TGMimeTypes& gmt) :
TObject(gmt),
fClient(gmt.fClient),
fFilename(gmt.fFilename),
fChanged(gmt.fChanged),
fList(gmt.fList)
{
}
TGMimeTypes& TGMimeTypes::operator=(const TGMimeTypes& gmt)
{
if(this!=&gmt) {
TObject::operator=(gmt);
fClient=gmt.fClient;
fFilename=gmt.fFilename;
fChanged=gmt.fChanged;
fList=gmt.fList;
}
return *this;
}
TGMime *TGMimeTypes::Find(const char *filename)
{
if (!filename) return 0;
TString fn = filename;
TGMime *mime;
TIter next(fList);
while ((mime = (TGMime *) next()))
if (fn.Index(*(mime->fReg)) != kNPOS) return mime;
return 0;
}
const TGPicture *TGMimeTypes::GetIcon(const char *filename, Bool_t small_icon)
{
TGMime *mime;
const TGPicture *mypic = 0;
if ((mime = Find(filename))) {
Bool_t thumb = (mime->fType == "[thumbnail]");
if (small_icon) {
mypic = thumb ? fClient->GetPicture(mime->fSIcon.Data(), 32, 32) :
fClient->GetPicture(mime->fSIcon.Data(), 16, 16);
} else {
mypic = thumb ? fClient->GetPicture(mime->fIcon.Data(), 64, 64) :
fClient->GetPicture(mime->fIcon.Data(), 32, 32);
}
return mypic;
}
return 0;
}
Bool_t TGMimeTypes::GetAction(const char *filename, char *action)
{
TGMime *mime;
action[0] = 0;
if ((mime = Find(filename))) {
strcpy(action, mime->fAction.Data());
return (strlen(action) > 0);
}
return kFALSE;
}
Bool_t TGMimeTypes::GetType(const char *filename, char *type)
{
TGMime *mime;
memset(type, 0, strlen(type));
if ((mime = Find(filename))) {
strcpy(type, mime->fType.Data());
return (strlen(type) > 0);
}
return kFALSE;
}
void TGMimeTypes::Print(Option_t *) const
{
TGMime *m;
TIter next(fList);
while ((m = (TGMime *) next())) {
printf("Type: %s\n", m->fType.Data());
printf("Pattern: %s\n", m->fPattern.Data());
if (m->fIcon != m->fSIcon)
printf("Icon: %s %s\n", m->fIcon.Data(), m->fSIcon.Data());
else
printf("Icon: %s\n", m->fIcon.Data());
printf("Action: %s\n", m->fAction.Data());
printf("------------\n\n");
}
}
void TGMimeTypes::SaveMimes()
{
char filename[1024];
#ifdef WIN32
sprintf(filename, "%s\\.root.mimes", gSystem->HomeDirectory());
#else
sprintf(filename, "%s/.root.mimes", gSystem->HomeDirectory());
#endif
FILE *fp = fopen(filename, "w");
if (!fp) {
Error("SaveMimes", "can not open %s to store mime types", filename);
return;
}
TDatime dt;
fprintf(fp, "# %s written on %s\n\n", filename, dt.AsString());
TGMime *m;
TIter next(fList);
while ((m = (TGMime *) next())) {
fprintf(fp, "%s\n", m->fType.Data());
fprintf(fp, "pattern = %s\n", m->fPattern.Data());
if (m->fIcon != m->fSIcon)
fprintf(fp, "icon = %s %s\n", m->fIcon.Data(), m->fSIcon.Data());
else
fprintf(fp, "icon = %s\n", m->fIcon.Data());
fprintf(fp, "action = %s\n\n", m->fAction.Data());
}
fclose(fp);
fChanged = kFALSE;
}
void TGMimeTypes::AddType(const char *type, const char *pattern, const char *icon,
const char *sicon, const char *action)
{
TGMime *mime = new TGMime;
mime->fType = type;
mime->fPattern = pattern;
mime->fIcon = icon;
mime->fSIcon = sicon;
mime->fAction = action;
mime->fReg = new TRegexp(pattern, kTRUE);
fList->AddFirst(mime);
fChanged = kTRUE;
}
TGMime::~TGMime()
{
delete fReg;
}
ROOT page - Class index - Class Hierarchy - Top of the page
This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.