2007-03-27 17:47:10 +00:00
|
|
|
/*
|
|
|
|
* CiderPress
|
|
|
|
* Copyright (C) 2007 by faddenSoft, LLC. All Rights Reserved.
|
|
|
|
* See the file LICENSE for distribution terms.
|
|
|
|
*/
|
|
|
|
/*
|
|
|
|
* Import BASIC programs from text files.
|
|
|
|
*
|
|
|
|
* THOUGHT: change the way the dialog works so that it doesn't scan until
|
|
|
|
* you say "go". Have some options for selecting language (BAS vs. INT),
|
|
|
|
* and whether to try to identify listings with line breaks (i.e. they
|
|
|
|
* neglected to "poke 33,33"). Have an optional "check syntax" box if we
|
|
|
|
* want to get really fancy.
|
|
|
|
*/
|
Large set of changes to restore CiderPress build.
CiderPress and MDC now compile, and execute far enough to open
their respective "about" boxes, but I doubt they'll do much
more than that.
* Switch from MBCS to UNICODE APIs
Microsoft switched to UTF-16 (by way of UCS-2) a long time ago,
and the support for MBCS seems to be getting phased out. So it's
time to switch to wide strings.
This is a bit awkward for CiderPress because it works with disk
and file archives with 8-bit filenames, and I want NufxLib and
DiskImgLib to continue to work on Linux (which has largely taken
the UTF-8 approach to Unicode). The libraries will continue to
work with 8-bit filenames, with CiderPress/MDC doing the
conversion at the appropriate point.
There were a couple of places where strings from a structure
handed back by one of the libraries were used directly in the UI,
or vice-versa, which is a problem because we have nowhere to
store the result of the conversion. These currently have fixed
place-holder "xyzzy" strings.
All UI strings are now wide.
Various format strings now use "%ls" and "%hs" to explicitly
specify wide and narrow. This doesn't play well with gcc, so
only the Windows-specific parts use those.
* Various updates to vcxproj files
The project-file conversion had some cruft that is now largely
gone. The build now has a common output directory for the EXEs
and libraries, avoiding the old post-build copy steps.
* Added zlib 1.2.8 and nufxlib 2.2.2 source snapshots
The old "prebuilts" directory is now gone. The libraries are now
built as part of building the apps.
I added a minimal set of files for zlib, and a full set for nufxlib.
The Linux-specific nufxlib goodies are included for the benefit of
the Linux utilities, which are currently broken (don't build).
* Replace symbols used for include guards
Symbols with a leading "__" are reserved.
2014-11-10 23:32:55 +00:00
|
|
|
#ifndef APP_BASICIMPORT_H
|
|
|
|
#define APP_BASICIMPORT_H
|
2007-03-27 17:47:10 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* This is a helper class to scan for a token in the list.
|
|
|
|
*
|
|
|
|
* Ideally we'd create a hash table to make it faster, but that's probably
|
|
|
|
* not necessary for the small data sets we're working with.
|
|
|
|
*/
|
|
|
|
class BASTokenLookup {
|
|
|
|
public:
|
2014-11-04 00:26:53 +00:00
|
|
|
BASTokenLookup(void)
|
2014-11-18 05:13:13 +00:00
|
|
|
: fTokenPtr(NULL), fTokenLen(NULL)
|
2014-11-04 00:26:53 +00:00
|
|
|
{}
|
|
|
|
~BASTokenLookup(void) {
|
|
|
|
delete[] fTokenPtr;
|
|
|
|
delete[] fTokenLen;
|
|
|
|
}
|
2007-03-27 17:47:10 +00:00
|
|
|
|
2014-11-21 21:18:20 +00:00
|
|
|
// Initialize the array. Pass in the info for the token blob.
|
2014-11-04 00:26:53 +00:00
|
|
|
void Init(const char* tokenList, int numTokens, int tokenLen);
|
2007-03-27 17:47:10 +00:00
|
|
|
|
2014-11-04 00:26:53 +00:00
|
|
|
// Return the index of the matching token, or -1 if none found.
|
|
|
|
int Lookup(const char* str, int len, int* pFoundLen);
|
2007-03-27 17:47:10 +00:00
|
|
|
|
2014-11-04 00:26:53 +00:00
|
|
|
// Return a printable string.
|
|
|
|
const char* GetToken(int idx) {
|
|
|
|
return fTokenPtr[idx];
|
|
|
|
}
|
2007-03-27 17:47:10 +00:00
|
|
|
|
|
|
|
private:
|
2014-11-04 00:26:53 +00:00
|
|
|
int fNumTokens;
|
|
|
|
const char** fTokenPtr;
|
|
|
|
int* fTokenLen;
|
2007-03-27 17:47:10 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Import a BASIC program.
|
|
|
|
*
|
|
|
|
* Currently works for Applesoft. Might work for Integer someday.
|
|
|
|
*/
|
|
|
|
class ImportBASDialog : public CDialog {
|
|
|
|
public:
|
2014-11-04 00:26:53 +00:00
|
|
|
ImportBASDialog(CWnd* pParentWnd = NULL) :
|
|
|
|
CDialog(IDD_IMPORT_BAS, pParentWnd), fDirty(false),
|
2014-11-18 05:13:13 +00:00
|
|
|
fOutput(NULL), fOutputLen(-1)
|
2014-11-04 00:26:53 +00:00
|
|
|
{}
|
|
|
|
virtual ~ImportBASDialog(void) {
|
|
|
|
delete[] fOutput;
|
|
|
|
}
|
2007-03-27 17:47:10 +00:00
|
|
|
|
2014-11-04 00:26:53 +00:00
|
|
|
// did we add something to the archive?
|
|
|
|
bool IsDirty(void) const { return fDirty; }
|
2007-03-27 17:47:10 +00:00
|
|
|
|
2014-11-21 21:18:20 +00:00
|
|
|
void SetFileName(const CString& fileName) { fFileName = fileName; }
|
|
|
|
|
2007-03-27 17:47:10 +00:00
|
|
|
private:
|
2014-11-21 21:18:20 +00:00
|
|
|
virtual BOOL OnInitDialog(void) override;
|
2014-11-04 00:26:53 +00:00
|
|
|
//virtual void DoDataExchange(CDataExchange* pDX);
|
2014-11-21 21:18:20 +00:00
|
|
|
virtual void OnOK(void) override;
|
2007-03-27 17:47:10 +00:00
|
|
|
|
2014-12-09 22:10:52 +00:00
|
|
|
afx_msg void OnHelp(void) {
|
|
|
|
MyApp::HandleHelp(this, HELP_TOPIC_IMPORT_BASIC);
|
|
|
|
}
|
2007-03-27 17:47:10 +00:00
|
|
|
|
2014-11-21 21:18:20 +00:00
|
|
|
/*
|
|
|
|
* Import an Applesoft BASIC program from the specified file.
|
|
|
|
*/
|
Large set of changes to restore CiderPress build.
CiderPress and MDC now compile, and execute far enough to open
their respective "about" boxes, but I doubt they'll do much
more than that.
* Switch from MBCS to UNICODE APIs
Microsoft switched to UTF-16 (by way of UCS-2) a long time ago,
and the support for MBCS seems to be getting phased out. So it's
time to switch to wide strings.
This is a bit awkward for CiderPress because it works with disk
and file archives with 8-bit filenames, and I want NufxLib and
DiskImgLib to continue to work on Linux (which has largely taken
the UTF-8 approach to Unicode). The libraries will continue to
work with 8-bit filenames, with CiderPress/MDC doing the
conversion at the appropriate point.
There were a couple of places where strings from a structure
handed back by one of the libraries were used directly in the UI,
or vice-versa, which is a problem because we have nowhere to
store the result of the conversion. These currently have fixed
place-holder "xyzzy" strings.
All UI strings are now wide.
Various format strings now use "%ls" and "%hs" to explicitly
specify wide and narrow. This doesn't play well with gcc, so
only the Windows-specific parts use those.
* Various updates to vcxproj files
The project-file conversion had some cruft that is now largely
gone. The build now has a common output directory for the EXEs
and libraries, avoiding the old post-build copy steps.
* Added zlib 1.2.8 and nufxlib 2.2.2 source snapshots
The old "prebuilts" directory is now gone. The libraries are now
built as part of building the apps.
I added a minimal set of files for zlib, and a full set for nufxlib.
The Linux-specific nufxlib goodies are included for the benefit of
the Linux utilities, which are currently broken (don't build).
* Replace symbols used for include guards
Symbols with a leading "__" are reserved.
2014-11-10 23:32:55 +00:00
|
|
|
bool ImportBAS(const WCHAR* fileName);
|
2014-11-21 21:18:20 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Do the actual conversion.
|
|
|
|
*/
|
2014-11-04 00:26:53 +00:00
|
|
|
bool ConvertTextToBAS(const char* buf, long fileLen,
|
|
|
|
char** pOutBuf, long* pOutLen, ExpandBuffer* pMsgs);
|
2014-11-21 21:18:20 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Process a line of Applesoft BASIC text.
|
|
|
|
*
|
|
|
|
* Writes output to "pOutput".
|
|
|
|
*
|
|
|
|
* On failure, writes an error message to "msg" and returns false.
|
|
|
|
*/
|
2014-11-04 00:26:53 +00:00
|
|
|
bool ProcessBASLine(const char* buf, int len,
|
|
|
|
ExpandBuffer* pOutput, CString& msg);
|
2007-03-27 17:47:10 +00:00
|
|
|
|
2014-11-21 21:18:20 +00:00
|
|
|
/*
|
|
|
|
* Fix up the line pointers. We left dummy nonzero values in them initially.
|
|
|
|
*/
|
|
|
|
bool FixBASLinePointers(char* buf, long len, uint16_t addr);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Look for the end of line.
|
|
|
|
*
|
|
|
|
* Returns a pointer to the first byte *past* the EOL marker, which will point
|
|
|
|
* at unallocated space for last line in the buffer.
|
|
|
|
*/
|
2014-11-04 00:26:53 +00:00
|
|
|
const char* FindEOL(const char* buf, long max);
|
2014-11-21 21:18:20 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Find the next non-whitespace character.
|
|
|
|
*
|
|
|
|
* Updates the buffer pointer and length.
|
|
|
|
*
|
|
|
|
* Returns "false" if we run off the end without finding another non-ws char.
|
|
|
|
*/
|
2014-11-04 00:26:53 +00:00
|
|
|
bool GetNextNWC(const char** pBuf, int* pLen, char* pCh);
|
2007-03-27 17:47:10 +00:00
|
|
|
|
2014-11-04 00:26:53 +00:00
|
|
|
void SetOutput(char* outBuf, long outLen) {
|
|
|
|
delete[] fOutput;
|
|
|
|
fOutput = outBuf;
|
|
|
|
fOutputLen = outLen;
|
|
|
|
}
|
2007-03-27 17:47:10 +00:00
|
|
|
|
2014-11-04 00:26:53 +00:00
|
|
|
BASTokenLookup fBASLookup;
|
|
|
|
bool fDirty;
|
2007-03-27 17:47:10 +00:00
|
|
|
|
2014-11-04 00:26:53 +00:00
|
|
|
char* fOutput;
|
|
|
|
long fOutputLen;
|
2007-03-27 17:47:10 +00:00
|
|
|
|
2014-11-21 21:18:20 +00:00
|
|
|
CString fFileName; // file to open
|
|
|
|
|
2014-11-04 00:26:53 +00:00
|
|
|
DECLARE_MESSAGE_MAP()
|
2007-03-27 17:47:10 +00:00
|
|
|
};
|
|
|
|
|
Large set of changes to restore CiderPress build.
CiderPress and MDC now compile, and execute far enough to open
their respective "about" boxes, but I doubt they'll do much
more than that.
* Switch from MBCS to UNICODE APIs
Microsoft switched to UTF-16 (by way of UCS-2) a long time ago,
and the support for MBCS seems to be getting phased out. So it's
time to switch to wide strings.
This is a bit awkward for CiderPress because it works with disk
and file archives with 8-bit filenames, and I want NufxLib and
DiskImgLib to continue to work on Linux (which has largely taken
the UTF-8 approach to Unicode). The libraries will continue to
work with 8-bit filenames, with CiderPress/MDC doing the
conversion at the appropriate point.
There were a couple of places where strings from a structure
handed back by one of the libraries were used directly in the UI,
or vice-versa, which is a problem because we have nowhere to
store the result of the conversion. These currently have fixed
place-holder "xyzzy" strings.
All UI strings are now wide.
Various format strings now use "%ls" and "%hs" to explicitly
specify wide and narrow. This doesn't play well with gcc, so
only the Windows-specific parts use those.
* Various updates to vcxproj files
The project-file conversion had some cruft that is now largely
gone. The build now has a common output directory for the EXEs
and libraries, avoiding the old post-build copy steps.
* Added zlib 1.2.8 and nufxlib 2.2.2 source snapshots
The old "prebuilts" directory is now gone. The libraries are now
built as part of building the apps.
I added a minimal set of files for zlib, and a full set for nufxlib.
The Linux-specific nufxlib goodies are included for the benefit of
the Linux utilities, which are currently broken (don't build).
* Replace symbols used for include guards
Symbols with a leading "__" are reserved.
2014-11-10 23:32:55 +00:00
|
|
|
#endif /*APP_BASICIMPORT_H*/
|