summaryrefslogtreecommitdiff
path: root/ldmicro
diff options
context:
space:
mode:
Diffstat (limited to 'ldmicro')
-rw-r--r--ldmicro/includes/ldmicro.h5
-rw-r--r--ldmicro/ldmicro.cpp250
-rw-r--r--ldmicro/lib/linuxUI/linuxLD.h1
-rw-r--r--ldmicro/lib/linuxUI/linuxUI.cpp3
-rw-r--r--ldmicro/maincontrols.cpp208
5 files changed, 138 insertions, 329 deletions
diff --git a/ldmicro/includes/ldmicro.h b/ldmicro/includes/ldmicro.h
index e434b82..0f165bc 100644
--- a/ldmicro/includes/ldmicro.h
+++ b/ldmicro/includes/ldmicro.h
@@ -526,7 +526,7 @@ extern McuIoInfo SupportedMcus[NUM_SUPPORTED_MCUS];
// heap used for all the program storage is not yet corrupt, and oops() if
// it is
void CheckHeap(char *file, int line);
-#define ok() CheckHeap(__FILE__, __LINE__)
+#define ok() CheckHeap(__FILE__, __LINE__)*/
// maincontrols.cpp
void MakeMainWindowControls(void);
@@ -543,10 +543,11 @@ void UpdateMainWindowTitleBar(void);
extern int ScrollWidth;
extern int ScrollHeight;
extern BOOL NeedHoriz;
-extern HWND IoList;
+extern HLIST IoList;
extern int IoListTop;
extern int IoListHeight;
+/*
// draw.cpp
int ProgCountWidestRow(void);
int CountHeightOfElement(int which, void *elem);
diff --git a/ldmicro/ldmicro.cpp b/ldmicro/ldmicro.cpp
index 8add732..19f825c 100644
--- a/ldmicro/ldmicro.cpp
+++ b/ldmicro/ldmicro.cpp
@@ -1048,126 +1048,140 @@ static BOOL MakeWindowClass()
return RegisterClassEx(&wc);
}
-//-----------------------------------------------------------------------------
-// Entry point into the program.
-//-----------------------------------------------------------------------------
-int main(int argc, char** argv)
+int main (int argc, char *argv[])
{
- // Check if we're running in non-interactive mode; in that case we should
- // load the file, compile, and exit.
- if(argc >= 2) {
- RunningInBatchMode = TRUE;
+ GtkApplication *app;
+ int status;
+
+ app = gtk_application_new ("org.gtk.new", G_APPLICATION_FLAGS_NONE);
+ g_signal_connect (app, "activate", G_CALLBACK (Activate_App), NULL);
+ status = g_application_run (G_APPLICATION (app), argc, argv);
- char *err =
- "Bad command line arguments: run 'ldmicro /c src.ld dest.hex'";
+ g_object_unref (app);
- char *source = lpCmdLine + 2;
- while(isspace(*source)) {
- source++;
- }
- if(*source == '\0') { Error(err); exit(-1); }
- char *dest = source;
- while(!isspace(*dest) && *dest) {
- dest++;
- }
- if(*dest == '\0') { Error(err); exit(-1); }
- *dest = '\0'; dest++;
- while(isspace(*dest)) {
- dest++;
- }
- if(*dest == '\0') { Error(err); exit(-1); }
- if(!LoadProjectFromFile(source)) {
- Error("Couldn't open '%s', running non-interactively.", source);
- exit(-1);
- }
- strcpy(CurrentCompileFile, dest);
- GenerateIoList(-1);
- CompileProgram(FALSE); /// Requires an open dialog to get file name
- exit(0);
- }
+ return status;
+}
- Instance = hInstance;
-
- MainHeap = HeapCreate(0, 1024*64, 0);
-
- // MakeWindowClass();
- // MakeDialogBoxClass();
- // MakeAdvancedDialogClass();
- // MakeAdvancedWorkspaceClass();
- // MakeComponentListClass();
- // MakeSmplDialogClass();
- // MakeNamingListClass();
- HMENU top = MakeMainWindowMenus();
-
- /// Make main window
- // MainWindow = CreateWindowEx(0, "LDmicro", "",
- // WS_OVERLAPPED | WS_THICKFRAME | WS_CLIPCHILDREN | WS_MAXIMIZEBOX |
- // WS_MINIMIZEBOX | WS_SYSMENU | WS_SIZEBOX,
- // 10, 10, 800, 600, NULL, top, Instance, NULL);
- ThawWindowPos(MainWindow);
- IoListHeight = 100;
- ThawDWORD(IoListHeight);
-
- InitCommonControls();
- InitForDrawing();
-
- MakeMainWindowControls();
- MainWindowResized();
- NewProgram();
- strcpy(CurrentSaveFile, "");
-
- // We are running interactively, or we would already have exited. We
- // can therefore show the window now, and otherwise set up the GUI.
-
- ShowWindow(MainWindow, SW_SHOW);
- SetTimer(MainWindow, TIMER_BLINK_CURSOR, 800, BlinkCursor);
+//-----------------------------------------------------------------------------
+// Entry point into the program.
+//-----------------------------------------------------------------------------
+// int main(int argc, char** argv)
+// {
+// // Check if we're running in non-interactive mode; in that case we should
+// // load the file, compile, and exit.
+// if(argc >= 2) {
+// RunningInBatchMode = TRUE;
+
+// char *err =
+// "Bad command line arguments: run 'ldmicro /c src.ld dest.hex'";
+
+// char *source = lpCmdLine + 2;
+// while(isspace(*source)) {
+// source++;
+// }
+// if(*source == '\0') { Error(err); exit(-1); }
+// char *dest = source;
+// while(!isspace(*dest) && *dest) {
+// dest++;
+// }
+// if(*dest == '\0') { Error(err); exit(-1); }
+// *dest = '\0'; dest++;
+// while(isspace(*dest)) {
+// dest++;
+// }
+// if(*dest == '\0') { Error(err); exit(-1); }
+// if(!LoadProjectFromFile(source)) {
+// Error("Couldn't open '%s', running non-interactively.", source);
+// exit(-1);
+// }
+// strcpy(CurrentCompileFile, dest);
+// GenerateIoList(-1);
+// CompileProgram(FALSE); /// Requires an open dialog to get file name
+// exit(0);
+// }
+
+// Instance = hInstance;
+
+// MainHeap = HeapCreate(0, 1024*64, 0);
+
+// // MakeWindowClass();
+// // MakeDialogBoxClass();
+// // MakeAdvancedDialogClass();
+// // MakeAdvancedWorkspaceClass();
+// // MakeComponentListClass();
+// // MakeSmplDialogClass();
+// // MakeNamingListClass();
+// HMENU top = MakeMainWindowMenus();
+
+// /// Make main window
+// // MainWindow = CreateWindowEx(0, "LDmicro", "",
+// // WS_OVERLAPPED | WS_THICKFRAME | WS_CLIPCHILDREN | WS_MAXIMIZEBOX |
+// // WS_MINIMIZEBOX | WS_SYSMENU | WS_SIZEBOX,
+// // 10, 10, 800, 600, NULL, top, Instance, NULL);
+// ThawWindowPos(MainWindow);
+// IoListHeight = 100;
+// ThawDWORD(IoListHeight);
+
+// InitCommonControls();
+// InitForDrawing();
+
+// MakeMainWindowControls();
+// MainWindowResized();
+// NewProgram();
+// strcpy(CurrentSaveFile, "");
+
+// // We are running interactively, or we would already have exited. We
+// // can therefore show the window now, and otherwise set up the GUI.
+
+// ShowWindow(MainWindow, SW_SHOW);
+// SetTimer(MainWindow, TIMER_BLINK_CURSOR, 800, BlinkCursor);
- if(strlen(lpCmdLine) > 0) {
- char line[MAX_PATH];
- if(*lpCmdLine == '"') {
- strcpy(line, lpCmdLine+1);
- } else {
- strcpy(line, lpCmdLine);
- }
- if(strchr(line, '"')) *strchr(line, '"') = '\0';
-
- char *s;
- GetFullPathName(line, sizeof(CurrentSaveFile), CurrentSaveFile, &s);
- if(!LoadProjectFromFile(CurrentSaveFile)) {
- NewProgram();
- Error(_("Couldn't open '%s'."), CurrentSaveFile);
- CurrentSaveFile[0] = '\0';
- }
- UndoFlush();
- }
-
- GenerateIoListDontLoseSelection();
- RefreshScrollbars();
- UpdateMainWindowTitleBar();
-
- MSG msg;
- DWORD ret;
- while(ret = GetMessage(&msg, NULL, 0, 0)) {
- if(msg.hwnd == IoList && msg.message == WM_KEYDOWN) {
- if(msg.wParam == VK_TAB) {
- SetFocus(MainWindow);
- continue;
- }
- }
- if(msg.message == WM_KEYDOWN && msg.wParam != VK_UP &&
- msg.wParam != VK_DOWN && msg.wParam != VK_RETURN && msg.wParam
- != VK_SHIFT)
- {
- if(msg.hwnd == IoList) {
- msg.hwnd = MainWindow;
- SetFocus(MainWindow);
- }
- }
- TranslateMessage(&msg);
- DispatchMessage(&msg);
- }
- FreezeWindowPos(MainWindow);
- FreezeDWORD(IoListHeight);
-
- return 0;
-}
+// if(strlen(lpCmdLine) > 0) {
+// char line[MAX_PATH];
+// if(*lpCmdLine == '"') {
+// strcpy(line, lpCmdLine+1);
+// } else {
+// strcpy(line, lpCmdLine);
+// }
+// if(strchr(line, '"')) *strchr(line, '"') = '\0';
+
+// char *s;
+// GetFullPathName(line, sizeof(CurrentSaveFile), CurrentSaveFile, &s);
+// if(!LoadProjectFromFile(CurrentSaveFile)) {
+// NewProgram();
+// Error(_("Couldn't open '%s'."), CurrentSaveFile);
+// CurrentSaveFile[0] = '\0';
+// }
+// UndoFlush();
+// }
+
+// GenerateIoListDontLoseSelection();
+// RefreshScrollbars();
+// UpdateMainWindowTitleBar();
+
+// MSG msg;
+// DWORD ret;
+// while(ret = GetMessage(&msg, NULL, 0, 0)) {
+// if(msg.hwnd == IoList && msg.message == WM_KEYDOWN) {
+// if(msg.wParam == VK_TAB) {
+// SetFocus(MainWindow);
+// continue;
+// }
+// }
+// if(msg.message == WM_KEYDOWN && msg.wParam != VK_UP &&
+// msg.wParam != VK_DOWN && msg.wParam != VK_RETURN && msg.wParam
+// != VK_SHIFT)
+// {
+// if(msg.hwnd == IoList) {
+// msg.hwnd = MainWindow;
+// SetFocus(MainWindow);
+// }
+// }
+// TranslateMessage(&msg);
+// DispatchMessage(&msg);
+// }
+// FreezeWindowPos(MainWindow);
+// FreezeDWORD(IoListHeight);
+
+// return 0;
+// }
diff --git a/ldmicro/lib/linuxUI/linuxLD.h b/ldmicro/lib/linuxUI/linuxLD.h
index 0e4f682..c6079d5 100644
--- a/ldmicro/lib/linuxUI/linuxLD.h
+++ b/ldmicro/lib/linuxUI/linuxLD.h
@@ -45,6 +45,7 @@ typedef HANDLE HDC;
typedef GtkWidget* HWID;
typedef GtkWidget* HMENU;
typedef GtkWindow* HWND;
+typedef GtkListStore* HLIST;
typedef GtkApplication* HAPP;
/// Check if system is x64 or x86
diff --git a/ldmicro/lib/linuxUI/linuxUI.cpp b/ldmicro/lib/linuxUI/linuxUI.cpp
index fea10b5..1cf45f4 100644
--- a/ldmicro/lib/linuxUI/linuxUI.cpp
+++ b/ldmicro/lib/linuxUI/linuxUI.cpp
@@ -1,8 +1,5 @@
#include "linuxUI.h"
-/// Menu Variables
- HWID window;
-
/// EnableMenuItem Variables
const UINT MF_ENABLED = 0;
const UINT MF_GRAYED = 1;
diff --git a/ldmicro/maincontrols.cpp b/ldmicro/maincontrols.cpp
index 38c9b9f..b029322 100644
--- a/ldmicro/maincontrols.cpp
+++ b/ldmicro/maincontrols.cpp
@@ -30,7 +30,7 @@
#include "ldmicro.h"
// Menu IDs
- HMENU MNU_NEW;
+HMENU MNU_NEW;
HMENU MNU_OPEN;
HMENU MNU_SAVE;
HMENU MNU_SAVE_AS;
@@ -122,7 +122,7 @@ static HMENU TopMenu;
// listview used to maintain the list of I/O pins with symbolic names, plus
// the internal relay too
-HWND IoList;
+HLIST IoList;
static int IoListSelectionPoint;
static BOOL IoListOutOfSync;
int IoListHeight;
@@ -346,14 +346,7 @@ HMENU MakeMainWindowMenus(void)
HWID CompileLabel; // Compile menu label
HWID HelpLabel; // Help menu label
HWID SimulateLabel; // Simulate menu label
- // HMENU file_menu_items; // File menu item
- // HMENU edit_menu_items; // Edit menu item
- // HMENU instruction_menu_items; // Instruction menu item
- // HMENU settings_menu_items; // Settings menu item
HMENU ProcessorMenuItems; // Processor menu items
- // HMENU compile_menu_items; // Compile menu item
- // HMENU help_menu_items; // Help menu item
- // HMENU simulate_menu_items; // Simulate menu item
HMENU FileMenuSeparator; // File menu separator
HMENU EditMenuSeparator; // Edit menu separator
HMENU InstructionMenuSeparator; // Instruction menu separator
@@ -639,104 +632,6 @@ void RefreshScrollbars(void)
}
//-----------------------------------------------------------------------------
-// Respond to a WM_VSCROLL sent to the main window, presumably by the one and
-// only vertical scrollbar that it has as a child.
-//-----------------------------------------------------------------------------
-void VscrollProc(WPARAM wParam)
-{
- int prevY = ScrollYOffset;
- switch(LOWORD(wParam)) {
- case SB_LINEUP:
- case SB_PAGEUP:
- if(ScrollYOffset > 0) {
- ScrollYOffset--;
- }
- break;
-
- case SB_LINEDOWN:
- case SB_PAGEDOWN:
- if(ScrollYOffset < ScrollYOffsetMax) {
- ScrollYOffset++;
- }
- break;
-
- case SB_TOP:
- ScrollYOffset = 0;
- break;
-
- case SB_BOTTOM:
- ScrollYOffset = ScrollYOffsetMax;
- break;
-
- case SB_THUMBTRACK:
- case SB_THUMBPOSITION:
- ScrollYOffset = HIWORD(wParam);
- break;
- }
- if(prevY != ScrollYOffset) {
- SCROLLINFO si;
- si.cbSize = sizeof(si);
- si.fMask = SIF_POS;
- si.nPos = ScrollYOffset;
- SetScrollInfo(VertScrollBar, SB_CTL, &si, TRUE);
-
- InvalidateRect(MainWindow, NULL, FALSE);
- }
-}
-
-//-----------------------------------------------------------------------------
-// Respond to a WM_HSCROLL sent to the main window, presumably by the one and
-// only horizontal scrollbar that it has as a child.
-//-----------------------------------------------------------------------------
-void HscrollProc(WPARAM wParam)
-{
- int prevX = ScrollXOffset;
- switch(LOWORD(wParam)) {
- case SB_LINEUP:
- ScrollXOffset -= FONT_WIDTH;
- break;
-
- case SB_PAGEUP:
- ScrollXOffset -= POS_WIDTH*FONT_WIDTH;
- break;
-
- case SB_LINEDOWN:
- ScrollXOffset += FONT_WIDTH;
- break;
-
- case SB_PAGEDOWN:
- ScrollXOffset += POS_WIDTH*FONT_WIDTH;
- break;
-
- case SB_TOP:
- ScrollXOffset = 0;
- break;
-
- case SB_BOTTOM:
- ScrollXOffset = ScrollXOffsetMax;
- break;
-
- case SB_THUMBTRACK:
- case SB_THUMBPOSITION:
- ScrollXOffset = HIWORD(wParam);
- break;
- }
-
- if(ScrollXOffset > ScrollXOffsetMax) ScrollXOffset = ScrollXOffsetMax;
- if(ScrollXOffset < 0) ScrollXOffset = 0;
-
- if(prevX != ScrollXOffset) {
- SCROLLINFO si;
- si.cbSize = sizeof(si);
- si.fMask = SIF_POS;
- si.nPos = ScrollXOffset;
- SetScrollInfo(HorizScrollBar, SB_CTL, &si, TRUE);
-
- InvalidateRect(MainWindow, NULL, FALSE);
- }
-}
-
-//-----------------------------------------------------------------------------
// Cause the status bar and the list view to be in sync with the actual data
// structures describing the settings and the I/O configuration. Listview
// does callbacks to get the strings it displays, so it just needs to know
@@ -744,72 +639,7 @@ void HscrollProc(WPARAM wParam)
//-----------------------------------------------------------------------------
void RefreshControlsToSettings(void)
{
- int i;
-
- if(!IoListOutOfSync) {
- IoListSelectionPoint = -1;
- for(i = 0; i < Prog.io.count; i++) {
- if(ListView_GetItemState(IoList, i, LVIS_SELECTED)) {
- IoListSelectionPoint = i;
- break;
- }
- }
- }
-
- ListView_DeleteAllItems(IoList);
- for(i = 0; i < Prog.io.count; i++) {
- LVITEM lvi;
- lvi.mask = LVIF_TEXT | LVIF_PARAM | LVIF_STATE;
- lvi.state = lvi.stateMask = 0;
- lvi.iItem = i;
- lvi.iSubItem = 0;
- lvi.pszText = LPSTR_TEXTCALLBACK;
- lvi.lParam = i;
-
- if(ListView_InsertItem(IoList, &lvi) < 0) oops();
- }
- if(IoListSelectionPoint >= 0) {
- for(i = 0; i < Prog.io.count; i++) {
- ListView_SetItemState(IoList, i, 0, LVIS_SELECTED);
- }
- ListView_SetItemState(IoList, IoListSelectionPoint, LVIS_SELECTED,
- LVIS_SELECTED);
- ListView_EnsureVisible(IoList, IoListSelectionPoint, FALSE);
- }
- IoListOutOfSync = FALSE;
- if(Prog.mcu) {
- SendMessage(StatusBar, SB_SETTEXT, 0, (LPARAM)Prog.mcu->mcuName);
- } else {
- SendMessage(StatusBar, SB_SETTEXT, 0, (LPARAM)_("no MCU selected"));
- }
- char buf[256];
- sprintf(buf, _("cycle time %.2f ms"), (double)Prog.cycleTime/1000.0);
- SendMessage(StatusBar, SB_SETTEXT, 1, (LPARAM)buf);
-
- if(Prog.mcu && (Prog.mcu->whichIsa == ISA_ANSIC ||
- Prog.mcu->whichIsa == ISA_INTERPRETED))
- {
- strcpy(buf, "");
- } else {
- sprintf(buf, _("processor clock %.4f MHz"),
- (double)Prog.mcuClock/1000000.0);
- }
- SendMessage(StatusBar, SB_SETTEXT, 2, (LPARAM)buf);
-
- for(i = 0; i < NUM_SUPPORTED_MCUS; i++) {
- if(&SupportedMcus[i] == Prog.mcu) {
- CheckMenuItem(ProcessorMenu, MNU_PROCESSOR_0+i, MF_CHECKED);
- } else {
- CheckMenuItem(ProcessorMenu, MNU_PROCESSOR_0+i, MF_UNCHECKED);
- }
- }
- // `(no microcontroller)' setting
- if(!Prog.mcu) {
- CheckMenuItem(ProcessorMenu, MNU_PROCESSOR_0+i, MF_CHECKED);
- } else {
- CheckMenuItem(ProcessorMenu, MNU_PROCESSOR_0+i, MF_UNCHECKED);
- }
}
//-----------------------------------------------------------------------------
@@ -839,40 +669,6 @@ void GenerateIoListDontLoseSelection(void)
}
//-----------------------------------------------------------------------------
-// Called when the main window has been resized. Adjust the size of the
-// status bar and the listview to reflect the new window size.
-//-----------------------------------------------------------------------------
-void MainWindowResized(void)
-{
- RECT main;
- GetClientRect(MainWindow, &main);
-
- RECT status;
- GetWindowRect(StatusBar, &status);
- int statusHeight = status.bottom - status.top;
-
- MoveWindow(StatusBar, 0, main.bottom - statusHeight, main.right,
- statusHeight, TRUE);
-
- // Make sure that the I/O list can't disappear entirely.
- if(IoListHeight < 30) {
- IoListHeight = 30;
- }
- IoListTop = main.bottom - IoListHeight - statusHeight;
- // Make sure that we can't drag the top of the I/O list above the
- // bottom of the menu bar, because it then becomes inaccessible.
- if(IoListTop < 5) {
- IoListHeight = main.bottom - statusHeight - 5;
- IoListTop = main.bottom - IoListHeight - statusHeight;
- }
- MoveWindow(IoList, 0, IoListTop, main.right, IoListHeight, TRUE);
-
- RefreshScrollbars();
-
- InvalidateRect(MainWindow, NULL, FALSE);
-}
-
-//-----------------------------------------------------------------------------
// Toggle whether we are in simulation mode. A lot of options are only
// available in one mode or the other.
//-----------------------------------------------------------------------------