src/rexx/mailread.c
/***************************************************************************
YAM - Yet Another Mailer
Copyright (C) 1995-2000 Marcel Beck
Copyright (C) 2000-2022 YAM Open Source Team
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
YAM Official Support Site : http://www.yam.ch
YAM OpenSource project : http://sourceforge.net/projects/yamos/
$Id$
***************************************************************************/
#include <clib/alib_protos.h>
#include <libraries/mui.h>
#include <proto/exec.h>
#include "extrasrc.h"
#include "YAM.h"
#include "YAM_main.h"
#include "YAM_read.h"
#include "mui/ClassesExtra.h"
#include "mui/ReadWindow.h"
#include "MUIObjects.h"
#include "Rexx.h"
#include "Debug.h"
struct args
{
struct RexxResult varStem;
int *window;
long quiet;
};
struct results
{
int *window;
};
void rx_mailread(UNUSED struct RexxHost *host, struct RexxParams *params, enum RexxAction action, UNUSED struct RexxMsg *rexxmsg)
{
struct args *args = params->args;
struct results *results = params->results;
ENTER();
switch(action)
{
case RXIF_INIT:
{
params->args = AllocVecPooled(G->SharedMemPool, sizeof(*args));
params->results = AllocVecPooled(G->SharedMemPool, sizeof(*results));
}
break;
case RXIF_ACTION:
{
static int winNumber = -1;
results->window = &winNumber;
if(args->window == NULL)
{
struct Mail *mail;
if((mail = MA_GetActiveMail(NULL, NULL, NULL)) != NULL)
{
struct ReadMailData *rmData;
if((rmData = CreateReadWindow(TRUE)) != NULL)
{
if(args->quiet == FALSE)
SafeOpenWindow(rmData->readWindow);
if(DoMethod(rmData->readWindow, MUIM_ReadWindow_ReadMail, mail) == FALSE)
{
// on any error we make sure to delete the read window
// immediatly again.
CleanupReadMailData(rmData, TRUE);
params->rc = RETURN_ERROR;
}
else
{
// Set the active Rexx RMData again, as this might have been overwritten
// in the meantime by the read window itself. In this case the read window
// will try to cleanup all the stuff allocated for a previous mail.
G->ActiveRexxRMData = rmData;
winNumber = xget(rmData->readWindow, MUIA_ReadWindow_Num);
}
}
else
params->rc = RETURN_ERROR;
}
else
params->rc = RETURN_WARN;
}
else
{
// if a window number was specified with the command we have to search
// through our ReadDataList and find the window with this particular
// number
BOOL found = FALSE;
int winnr = *args->window;
struct ReadMailData *rmData;
IterateList(&G->readMailDataList, struct ReadMailData *, rmData)
{
if(rmData->readWindow != NULL &&
(int)xget(rmData->readWindow, MUIA_ReadWindow_Num) == winnr)
{
G->ActiveRexxRMData = rmData;
found = TRUE;
winNumber = winnr;
// bring the window to the user's attention
if(args->quiet == FALSE)
set(rmData->readWindow, MUIA_Window_Activate, TRUE);
break;
}
}
// check if we successfully found the window with that
// number or if we have to return an error message
if(found == FALSE)
params->rc = RETURN_ERROR;
}
}
break;
case RXIF_FREE:
{
if(args != NULL)
FreeVecPooled(G->SharedMemPool, args);
if(results != NULL)
FreeVecPooled(G->SharedMemPool, results);
}
break;
}
LEAVE();
}