155 lines
4.3 KiB
C
155 lines
4.3 KiB
C
/*-
|
|
* Copyright (c) 2017-2019 Carsten Sonne Larsen <cs@innolan.net>
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*
|
|
*/
|
|
|
|
#include "config.h"
|
|
#include "state.h"
|
|
#include "time.h"
|
|
#include "mem.h"
|
|
|
|
#include <workbench/startup.h>
|
|
|
|
const char *vers = "\0$VER: " APP_ID;
|
|
static const char *template = KEYWORD_TEMPLATE;
|
|
|
|
static void LogStartMessage(void);
|
|
static void LogLocalTime(void);
|
|
static void GetCliSettings(void);
|
|
static void GetWbSettings(struct WBStartup *);
|
|
|
|
int main(int argc, char **argv)
|
|
{
|
|
InitState();
|
|
SetLogBuffer();
|
|
LogStartMessage();
|
|
LogLocalTime();
|
|
|
|
if (OpenLibraries() != 0)
|
|
return RETURN_ERROR;
|
|
|
|
LoadSettings();
|
|
|
|
if (argc != 0)
|
|
GetCliSettings();
|
|
else
|
|
GetWbSettings((struct WBStartup *)argv);
|
|
|
|
ApplySettings();
|
|
SanitizeSettings();
|
|
ShowSettings();
|
|
OpenLogFile();
|
|
FlushLogBuffer();
|
|
|
|
StartBroker();
|
|
|
|
LogLocalTime();
|
|
CloseSocketLibrary();
|
|
CloseLibraries();
|
|
CloseLogFile();
|
|
DestroyState();
|
|
FreeAllSafe();
|
|
|
|
return RETURN_OK;
|
|
}
|
|
|
|
static void GetCliSettings(void)
|
|
{
|
|
struct AppSettings *settings;
|
|
struct RDArgs *inArgs;
|
|
long args[KEYWORD_COUNT];
|
|
int i;
|
|
|
|
for (i = 0; i < KEYWORD_COUNT; i++)
|
|
args[i] = 0;
|
|
|
|
settings = CreateSettings(CliSettingType);
|
|
settings->Verbose = 1;
|
|
|
|
inArgs = ReadArgs((void *)template, (void *)&args, NULL);
|
|
if (inArgs)
|
|
{
|
|
// Keyword order in template needs to match order in settingFunctions
|
|
for (i = 0; i < KEYWORD_COUNT; i++)
|
|
{
|
|
if (args[i] != 0)
|
|
{
|
|
settingFunctions[i].Function(settings, (void *)args[i]);
|
|
}
|
|
}
|
|
FreeArgs(inArgs);
|
|
}
|
|
|
|
CacheSettings(settings);
|
|
}
|
|
|
|
static void GetWbSettings(struct WBStartup *wbs)
|
|
{
|
|
struct AppSettings *settings;
|
|
struct DiskObject *diskObject;
|
|
STRPTR filename, arg;
|
|
BPTR oldDir;
|
|
int argNo, i;
|
|
|
|
filename = (STRPTR)AllocMemSafe(MAXFILEPATHLEN);
|
|
settings = CreateSettings(WbSettingType);
|
|
|
|
for (argNo = 0; argNo < wbs->sm_NumArgs; ++argNo)
|
|
{
|
|
if (wbs->sm_ArgList[argNo].wa_Lock != NULL)
|
|
{
|
|
oldDir = CurrentDir(wbs->sm_ArgList[argNo].wa_Lock);
|
|
diskObject = GetDiskObjectNew((void *)wbs->sm_ArgList[argNo].wa_Name);
|
|
if (diskObject)
|
|
{
|
|
for (i = 0; i < KEYWORD_COUNT; i++)
|
|
{
|
|
arg = FindToolType(diskObject->do_ToolTypes, (STRPTR)settingFunctions[i].Name);
|
|
if (arg)
|
|
{
|
|
settingFunctions[i].Function(settings, (char *)arg);
|
|
}
|
|
}
|
|
FreeDiskObject(diskObject);
|
|
}
|
|
CurrentDir(oldDir);
|
|
}
|
|
}
|
|
|
|
CacheSettings(settings);
|
|
FreeMemSafe(filename);
|
|
}
|
|
|
|
static void LogStartMessage(void)
|
|
{
|
|
LogWarning("%s", APP_TITLE);
|
|
}
|
|
|
|
static void LogLocalTime(void)
|
|
{
|
|
char timeString[10], dateString[10], dayString[10];
|
|
SystemTimeString(timeString, dateString, dayString);
|
|
LogWarning("Local time is %s %s %s", dayString, dateString, timeString);
|
|
}
|