mirror of
https://github.com/rn10950/RetroZilla.git
synced 2024-11-16 12:30:13 +01:00
291 lines
8.5 KiB
C++
291 lines
8.5 KiB
C++
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
|
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
*
|
|
* The contents of this file are subject to the Mozilla Public License Version
|
|
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
* the License. You may obtain a copy of the License at
|
|
* http://www.mozilla.org/MPL/
|
|
*
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
* for the specific language governing rights and limitations under the
|
|
* License.
|
|
*
|
|
* The Original Code is Mozilla Communicator client code, released
|
|
* March 31, 1998.
|
|
*
|
|
* The Initial Developer of the Original Code is
|
|
* Netscape Communications Corporation.
|
|
* Portions created by the Initial Developer are Copyright (C) 1998
|
|
* the Initial Developer. All Rights Reserved.
|
|
*
|
|
* Contributor(s):
|
|
* Samir Gehani <sgehani@netscape.com>
|
|
*
|
|
* Alternatively, the contents of this file may be used under the terms of
|
|
* either of the GNU General Public License Version 2 or later (the "GPL"),
|
|
* or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
* of those above. If you wish to allow use of your version of this file only
|
|
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
* use your version of this file under the terms of the MPL, indicate your
|
|
* decision by deleting the provisions above and replace them with the notice
|
|
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
* the provisions above, a recipient may use your version of this file under
|
|
* the terms of any one of the MPL, the GPL or the LGPL.
|
|
*
|
|
* ***** END LICENSE BLOCK ***** */
|
|
|
|
#include "nsWelcomeDlg.h"
|
|
#include "nsXInstaller.h"
|
|
#include <sys/stat.h>
|
|
|
|
|
|
nsWelcomeDlg::nsWelcomeDlg() :
|
|
mReadmeFile(NULL)
|
|
{
|
|
}
|
|
|
|
nsWelcomeDlg::~nsWelcomeDlg()
|
|
{
|
|
if (mReadmeFile)
|
|
free (mReadmeFile);
|
|
}
|
|
|
|
void
|
|
nsWelcomeDlg::Next(GtkWidget *aWidget, gpointer aData)
|
|
{
|
|
DUMP("Next");
|
|
if (aData != gCtx->wdlg) return;
|
|
#ifdef MOZ_WIDGET_GTK
|
|
if (gCtx->bMoving)
|
|
{
|
|
gCtx->bMoving = FALSE;
|
|
return;
|
|
}
|
|
#endif
|
|
|
|
// hide this notebook page
|
|
gCtx->wdlg->Hide();
|
|
|
|
// show the next dlg
|
|
gCtx->ldlg->Show();
|
|
#ifdef MOZ_WIDGET_GTK
|
|
gCtx->bMoving = TRUE;
|
|
#endif
|
|
}
|
|
|
|
int
|
|
nsWelcomeDlg::Parse(nsINIParser *aParser)
|
|
{
|
|
int err = OK;
|
|
int bufsize = 0;
|
|
char *showDlg = NULL;
|
|
|
|
/* compulsory keys*/
|
|
XI_ERR_BAIL(aParser->GetStringAlloc(DLG_WELCOME, README, &mReadmeFile,
|
|
&bufsize));
|
|
if (bufsize == 0 || !mReadmeFile)
|
|
return E_INVALID_KEY;
|
|
|
|
/* optional keys */
|
|
bufsize = 5;
|
|
XI_ERR_BAIL(aParser->GetStringAlloc(DLG_WELCOME, SHOW_DLG, &showDlg,
|
|
&bufsize));
|
|
if (bufsize != 0 && showDlg)
|
|
{
|
|
if (0 == strncmp(showDlg, "TRUE", 4))
|
|
mShowDlg = nsXInstallerDlg::SHOW_DIALOG;
|
|
else if (0 == strncmp(showDlg, "FALSE", 5))
|
|
mShowDlg = nsXInstallerDlg::SKIP_DIALOG;
|
|
}
|
|
|
|
bufsize = 0;
|
|
XI_ERR_BAIL(aParser->GetStringAlloc(DLG_WELCOME, TITLE, &mTitle,
|
|
&bufsize));
|
|
if (bufsize == 0)
|
|
XI_IF_FREE(mTitle);
|
|
|
|
return err;
|
|
|
|
BAIL:
|
|
return err;
|
|
}
|
|
|
|
int
|
|
nsWelcomeDlg::Show()
|
|
{
|
|
int err = OK;
|
|
if (!mShowDlg)
|
|
{
|
|
gCtx->ldlg->Show();
|
|
return err;
|
|
}
|
|
|
|
char *readmeContents = NULL;
|
|
|
|
XI_VERIFY(gCtx);
|
|
XI_VERIFY(gCtx->notebook);
|
|
|
|
if (mWidgetsInit == FALSE) // static widget init
|
|
{
|
|
// create a new table and add it as a page of the notebook
|
|
mTable = gtk_table_new(1, 3, FALSE);
|
|
gtk_notebook_append_page(GTK_NOTEBOOK(gCtx->notebook), mTable, NULL);
|
|
mPageNum = gtk_notebook_get_current_page(GTK_NOTEBOOK(gCtx->notebook));
|
|
// gtk_table_set_row_spacing(GTK_TABLE(mTable), 0, 0);
|
|
gtk_table_set_col_spacing(GTK_TABLE(mTable), 1, 0);
|
|
gtk_widget_show(mTable);
|
|
|
|
// read the readme file contents into memory
|
|
readmeContents = GetReadmeContents();
|
|
if (!readmeContents)
|
|
{
|
|
err = ErrorHandler(E_EMPTY_README);
|
|
goto BAIL;
|
|
}
|
|
|
|
// create a new scrollable textarea and add it to the table
|
|
#if defined(MOZ_WIDGET_GTK)
|
|
GtkWidget *text = gtk_text_new(NULL, NULL);
|
|
GdkFont *font = gdk_font_load( README_FONT );
|
|
gtk_text_set_editable(GTK_TEXT(text), FALSE);
|
|
gtk_table_attach(GTK_TABLE(mTable), text, 1, 2, 0, 1,
|
|
static_cast<GtkAttachOptions>(GTK_FILL | GTK_EXPAND),
|
|
static_cast<GtkAttachOptions>(GTK_FILL | GTK_EXPAND),
|
|
0, 0);
|
|
gtk_text_freeze(GTK_TEXT(text));
|
|
gtk_text_insert (GTK_TEXT(text), font, &text->style->black, NULL,
|
|
readmeContents, -1);
|
|
gtk_text_thaw(GTK_TEXT(text));
|
|
gtk_text_set_word_wrap(GTK_TEXT(text), TRUE);
|
|
gtk_widget_show(text);
|
|
|
|
// Add a vertical scrollbar to the GtkText widget
|
|
GtkWidget *vscrollbar = gtk_vscrollbar_new (GTK_TEXT (text)->vadj);
|
|
gtk_table_attach(GTK_TABLE(mTable), vscrollbar, 2, 3, 0, 1, GTK_FILL,
|
|
static_cast<GtkAttachOptions>(GTK_EXPAND | GTK_SHRINK | GTK_FILL),
|
|
0, 0);
|
|
gtk_widget_show(vscrollbar);
|
|
#elif defined(MOZ_WIDGET_GTK2)
|
|
GtkWidget *text = gtk_scrolled_window_new (NULL, NULL);
|
|
GtkWidget *textview = gtk_text_view_new();
|
|
GtkTextBuffer *textbuffer;
|
|
|
|
textbuffer = gtk_text_view_get_buffer(GTK_TEXT_VIEW(textview));
|
|
gtk_text_buffer_set_text (textbuffer, readmeContents, -1);
|
|
gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (text),
|
|
GTK_POLICY_AUTOMATIC,
|
|
GTK_POLICY_AUTOMATIC);
|
|
gtk_container_add (GTK_CONTAINER (text), textview);
|
|
gtk_text_view_set_editable(GTK_TEXT_VIEW(textview), FALSE);
|
|
gtk_text_view_set_cursor_visible (GTK_TEXT_VIEW(textview), FALSE);
|
|
gtk_text_view_set_wrap_mode(GTK_TEXT_VIEW(textview), GTK_WRAP_WORD);
|
|
gtk_table_attach_defaults(GTK_TABLE(mTable), text, 1, 2, 0, 1);
|
|
gtk_widget_show_all(text);
|
|
#endif
|
|
|
|
mWidgetsInit = TRUE;
|
|
}
|
|
else
|
|
{
|
|
gtk_notebook_set_page(GTK_NOTEBOOK(gCtx->notebook), mPageNum);
|
|
gtk_widget_show(mTable);
|
|
}
|
|
|
|
// signal connect the buttons
|
|
gCtx->nextID = gtk_signal_connect(GTK_OBJECT(gCtx->next), "clicked",
|
|
GTK_SIGNAL_FUNC(nsWelcomeDlg::Next), gCtx->wdlg);
|
|
|
|
GTK_WIDGET_SET_FLAGS(gCtx->next, GTK_CAN_DEFAULT);
|
|
gtk_widget_grab_default(gCtx->next);
|
|
gtk_widget_grab_focus(gCtx->next);
|
|
|
|
// show the Next button
|
|
gCtx->nextLabel = gtk_label_new(gCtx->Res("NEXT"));
|
|
gtk_container_add(GTK_CONTAINER(gCtx->next), gCtx->nextLabel);
|
|
gtk_widget_show(gCtx->nextLabel);
|
|
gtk_widget_show(gCtx->next);
|
|
|
|
BAIL:
|
|
XI_IF_FREE(readmeContents);
|
|
|
|
return err;
|
|
}
|
|
|
|
int
|
|
nsWelcomeDlg::Hide()
|
|
{
|
|
// hide all this dlg's widgets
|
|
gtk_widget_hide(mTable);
|
|
|
|
// disconnect and remove this dlg's nav btn
|
|
gtk_signal_disconnect(GTK_OBJECT(gCtx->next), gCtx->nextID);
|
|
gtk_container_remove(GTK_CONTAINER(gCtx->next), gCtx->nextLabel);
|
|
gtk_widget_hide(gCtx->next);
|
|
|
|
return OK;
|
|
}
|
|
|
|
int
|
|
nsWelcomeDlg::SetReadmeFile(char *aReadmeFile)
|
|
{
|
|
if (!aReadmeFile)
|
|
return E_PARAM;
|
|
|
|
mReadmeFile = aReadmeFile;
|
|
|
|
return OK;
|
|
}
|
|
|
|
char *
|
|
nsWelcomeDlg::GetReadmeFile()
|
|
{
|
|
if (mReadmeFile)
|
|
return mReadmeFile;
|
|
|
|
return NULL;
|
|
}
|
|
|
|
char *
|
|
nsWelcomeDlg::GetReadmeContents()
|
|
{
|
|
char *buf = NULL;
|
|
FILE *fd = NULL;
|
|
struct stat attr;
|
|
int buflen;
|
|
|
|
DUMP(mReadmeFile);
|
|
if (!mReadmeFile)
|
|
return NULL;
|
|
|
|
// open file
|
|
fd = fopen(mReadmeFile, "r");
|
|
if (!fd) return NULL;
|
|
DUMP("readme fopen");
|
|
|
|
// get file length
|
|
if (0 != stat(mReadmeFile, &attr)) return NULL;
|
|
if (attr.st_size == 0) return NULL;
|
|
DUMP("readme fstat");
|
|
|
|
// allocate buffer of file length
|
|
buflen = sizeof(char) * (attr.st_size + 1);
|
|
buf = (char *) malloc(buflen);
|
|
if (!buf) return NULL;
|
|
memset(buf, 0, buflen);
|
|
DUMP("readme buf malloc");
|
|
|
|
// read entire file into buffer
|
|
if (attr.st_size != ((int) fread(buf, sizeof(char), attr.st_size, fd)))
|
|
XI_IF_FREE(buf);
|
|
DUMP("readme fread");
|
|
|
|
// close file
|
|
fclose(fd);
|
|
DUMP("readme close");
|
|
|
|
return buf;
|
|
}
|