mpw/toolbox/utility.cpp

127 lines
3.4 KiB
C++
Raw Normal View History

2013-07-30 05:06:19 +00:00
/*
* Copyright (c) 2013, Kelvin W Sherlock
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
2013-07-30 05:06:19 +00:00
*
* 1. Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
2013-07-30 05:06:19 +00:00
* 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.
2013-07-30 05:06:19 +00:00
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "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 COPYRIGHT OWNER OR CONTRIBUTORS 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.
*
*/
2013-03-27 03:29:08 +00:00
#include "utility.h"
#include "toolbox.h"
#include "mm.h"
2013-03-27 03:54:28 +00:00
#include "rm.h"
2013-03-27 03:29:08 +00:00
#include <cpu/defs.h>
#include <cpu/CpuModule.h>
#include <cpu/fmem.h>
#include "stackframe.h"
using ToolBox::Log;
namespace Utility {
2013-03-27 03:54:28 +00:00
// FUNCTION NewString (theString: Str255): StringHandle;
2013-03-27 03:29:08 +00:00
uint16_t NewString(uint16_t trap)
{
/*
* NewString allocates the specified string as a relocatable object
2013-03-27 03:29:08 +00:00
* in the heap and returns a handle to it.
*/
uint32_t theString;
uint32_t sp;
uint32_t length = 0;
std::string s;
sp = StackFrame<4>(theString);
s = ToolBox::ReadPString(theString);
Log("%04x NewString(%s)\n", trap, s.c_str());
length = s.length() + 1;
auto rv = MM::Native::NewHandle(s.length(), false);
if (!rv.error()) ToolBox::WritePString(rv.value().pointer, s);
2013-03-27 03:29:08 +00:00
ToolReturn<4>(sp, rv.value().handle);
return rv.error();
2013-03-27 03:29:08 +00:00
}
2013-03-27 03:54:28 +00:00
// FUNCTION GetString (stringID: Integer): StringHandle;
uint16_t GetString(uint16_t trap)
{
/*
* The GetString function loads a string from a string ('STR ')
* resource into memory. It returns a handle to the string with the
* specified resource ID, reading it from the resource file if
2013-03-27 03:54:28 +00:00
* necessary.
*/
uint16_t stringID;
uint32_t sp;
sp = StackFrame<2>(stringID);
Log("%04x GetString($%04x)\n", trap, stringID);
auto rv = RM::Native::GetResource(0x53545220, stringID);
2013-03-27 03:54:28 +00:00
ToolReturn<4>(sp, rv.value());
return rv.error();
2013-03-27 03:54:28 +00:00
}
2013-05-23 00:37:03 +00:00
// FUNCTION BitTst (bytePtr: Ptr; bitNum: LONGINT) : BOOLEAN;
uint16_t BitTst(uint16_t trap)
{
/*
* BitTst tests whether a given bit is set and returns TRUE if so or
* FALSE if not. The bit is specified by bitNum, an offset from the
2013-05-23 00:37:03 +00:00
* high-order bit of the byte pointed to by bytePtr.
*/
uint32_t bytePtr;
uint32_t bitNum;
uint16_t rv;
uint32_t sp;
sp = StackFrame<8>(bytePtr, bitNum);
Log("%04x BitTst($%08x, $%08x)\n", trap, bytePtr, bitNum);
uint32_t offset = bitNum >> 3;
int mask = 0x80 >> (bitNum & 0x07);
uint32_t value = memoryReadByte(bytePtr + offset);
rv = value & mask ? 1 : 0;
ToolReturn<2>(sp, rv);
return 0;
}
2013-03-27 03:29:08 +00:00
}