⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 analyzedlg.cpp

📁 基于从C++开发的一个LL1文法分析器
💻 CPP
字号:
// AnalyzeDlg.cpp : implementation file
//

#include "stdafx.h"
#include "ll1forwin.h"
#include "AnalyzeDlg.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CAnalyzeDlg dialog


CAnalyzeDlg::CAnalyzeDlg(CWnd* pParent /*=NULL*/)
	: CResizingDialog(CAnalyzeDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CAnalyzeDlg)
	m_input = _T("");
	//}}AFX_DATA_INIT
	m_strTempFilename = "";
	m_pTree = new CTreeDlg;
	m_pTree->Create(IDD_DIALOG3, this);
	m_pTree->SetControlInfo(IDC_TREE1, RESIZE_BOTH);
	m_pTree->SetControlInfo(IDOK, ANCHORE_BOTTOM | ANCHORE_RIGHT);
}

CAnalyzeDlg::~CAnalyzeDlg()
{
	m_pTree->DestroyWindow();
	delete m_pTree;
}

void CAnalyzeDlg::DoDataExchange(CDataExchange* pDX)
{
	CResizingDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CAnalyzeDlg)
	DDX_Control(pDX, IDC_EDIT1, m_edit1);
	DDX_Text(pDX, IDC_EDIT1, m_input);
	DDX_Control(pDX, IDC_EXPLORER1, m_web);
	//}}AFX_DATA_MAP
}


BEGIN_MESSAGE_MAP(CAnalyzeDlg, CResizingDialog)
	//{{AFX_MSG_MAP(CAnalyzeDlg)
	ON_BN_CLICKED(IDC_BUTTON1, OnButton1)
	ON_BN_CLICKED(IDC_BUTTON2, OnButton2)
	ON_WM_ACTIVATE()
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CAnalyzeDlg message handlers

void CAnalyzeDlg::OnButton1() 
{
	// TODO: Add your control notification handler code here
	UpdateData(TRUE);
	m_pTree->m_tree.DeleteAllItems();
	for(int i = 0; i < m_input.GetLength(); i ++)
	{
		if (!m_g.IsInVt(m_input.GetAt(i)))
		{
			MessageBox("输入的句子不全部由终结符组成", "错误", MB_OK | MB_ICONSTOP);
			return;
		}
	}
	char szTempPath[MAX_PATH]; 
	char szTempName[MAX_PATH]; 
	if (m_strTempFilename != "")
		::DeleteFile(m_strTempFilename.c_str());
	::GetTempPath(100,szTempPath);
	::GetTempFileName(szTempPath,"LL1",0,szTempName);
	m_strTempFilename = szTempName;
	CStdioFile out;
	out.Open(szTempName, CFile::modeCreate | CFile::modeWrite);
	out.WriteString("<html>\n");
	out.WriteString("<head>\n");
	out.WriteString("<title>Untitled Document</title>\n");
	out.WriteString("<meta http-equiv=\"Content-Type\" content=\"text/html; charset=gb2312\">\n");
	out.WriteString("</head>\n");
	out.WriteString("<body bgcolor=\"#FFFFFF\" text=\"#000000\">\n");
	out.WriteString("<table border=\"1\"  cellpadding=\"0\" cellspacing=\"0\" style=\"border-collapse: collapse\" bordercolor=\"#111111\">\n");
    out.WriteString("<tr><td nowrap>&nbsp;步骤&nbsp;</td><td nowrap>&nbsp;符号栈&nbsp;</td><td nowrap>&nbsp;输入串&nbsp;</td><td nowrap >&nbsp;所用生成式&nbsp;</td></tr>");
	stack <char> input;
	input.push('#');
	for(i = m_input.GetLength() -1; i >= 0; i --)
		input.push(m_input.GetAt(i));
	stack <char> s;
	s.push('#');
	s.push(m_g.GetStart());
	Precept p;
	bool error = false;
	int iStep = 0;
	stack <HTREEITEM> st;
	HTREEITEM hRoot = m_pTree->m_tree.InsertItem(CString(m_g.GetStart()));
	st.push(hRoot);
	while(true)
	{
		out.WriteString(GetStepInfo(s, input, iStep++, p));
		p.Clear();
		if (s.top() == input.top())
		{
			if (input.top() == '#')
				break;
			else
			{
				s.pop();
				st.pop();
				input.pop();
			}
		}
		else
		{
			if (!m_g.IsInVn(s.top()))
			{
				error = true;
				break;
			}
			if ((p = m_g.GetToDo(s.top(),input.top())).GetLeft() != "")
			{
				s.pop();
				HTREEITEM t = st.top();
				st.pop();
				if (p.GetRight() != "@")
				{
					for(int i = (int) p.GetRight().length() -1; i >=0; i --)
					{
						s.push(p.GetRight()[i]);
						st.push(m_pTree->m_tree.InsertItem(CString(p.GetRight()[i]), t));
					}
				}
				else
				{
					m_pTree->m_tree.InsertItem("@", t);
				}
			}
			else
			{
				error = true;
				break;
			}
		}
	}
	out.WriteString("</table>");
	if (error)
	{
		out.WriteString("<p><font color=\"#FF3300\">分析失败,输入的字符串是不符合预定文法的!</font></p>\n");
		m_pTree->m_tree.DeleteAllItems();
	}
	else
	{
		out.WriteString("<p><font color=\"#009900\">分析完成,输入的字符串是预定文法的句子</font></p>\n");
		HTREEITEM h = m_pTree->m_tree.GetRootItem();
		ExpandTree(h);

	}

	out.WriteString("</body>\n</html>");
	out.Close();
	m_web.Navigate(szTempName,NULL,NULL,NULL,NULL);
	m_edit1.SetFocus();
	m_edit1.SetSel(0, -1);
}

CString CAnalyzeDlg::GetStepInfo(stack<char> s, stack<char> input, int iStep, Precept p)
{
	CString rtn;
	CString t;
	CString t2;
	rtn.Format("<tr><td nowrap>&nbsp;&nbsp;%d&nbsp;&nbsp;</td>\n",iStep);
	t2 = "";
	while(!s.empty())
	{
		t.Format("%c", s.top());
		if(m_g.IsInVn(s.top()))
			t2 = "<font color=\"#000099\">" + t + "</font>" + t2;
		else
			if (s.top() != '#')
				t2 = "<font color=\"#FF6600\">" + t + "</font>" + t2;
			else
				t2 = t + t2;
		s.pop();
	}
	rtn = rtn + "<td nowrap>&nbsp;&nbsp;" +  t2 + "&nbsp;&nbsp;</td>\n";
	t2 = "<td>&nbsp;&nbsp;";
	while(!input.empty())
	{
		t.Format("%c", input.top());
		if (input.top() != '#')
			t2 = t2 + "<font color=\"#FF6600\">" + t + "</font>";
		else
			t2 += t;
		
		input.pop();
	}
	rtn = rtn + t2 + "&nbsp;&nbsp;</td>\n";
	if (p.GetLeft() != "")
	{
		rtn = rtn + "<td nowrap>&nbsp;&nbsp;" + p.GetLeft().c_str() + "->" + p.GetRight().c_str() + "&nbsp;&nbsp;</td>\n";
		string strRight = p.GetRight();
	}
	else
		rtn = rtn + "<td>&nbsp;</td>\n";
	return rtn;
	
}

void CAnalyzeDlg::ExpandTree(HTREEITEM h)
{
	m_pTree->m_tree.Expand(h, TVE_EXPAND);
	HTREEITEM hChild = m_pTree->m_tree.GetChildItem(h);
	while (hChild != NULL)
	{
		if (m_pTree->m_tree.ItemHasChildren(hChild))
			ExpandTree(hChild);
		hChild = m_pTree->m_tree.GetNextItem(hChild, TVGN_NEXT);
	}
}

void CAnalyzeDlg::SetGrammar(const Grammar & g)
{
	m_g = g;
}

void CAnalyzeDlg::OnButton2() 
{
	// TODO: Add your control notification handler code here
	CRect rect;
	GetWindowRect(rect);
	//int iWidth = GetSystemMetrics(SM_CXSCREEN) - rect.right;
	//if (iWidth < 200)
	//	iWidth = 200;
	if(!m_pTree->IsWindowVisible())
		m_pTree->SetWindowPos(&wndTopMost,GetSystemMetrics(SM_CXSCREEN) - 280, 0, 250, 350, SWP_SHOWWINDOW);
	m_pTree->SetFocus();
	
}

BOOL CAnalyzeDlg::OnInitDialog() 
{
	CResizingDialog::OnInitDialog();
	SetIcon(LoadIcon(::AfxGetInstanceHandle(), MAKEINTRESOURCE(IDR_MAINFRAME)),FALSE);
	// TODO: Add extra initialization here
	m_web.Navigate("about:blank",NULL,NULL,NULL,NULL);
	return TRUE;  // return TRUE unless you set the focus to a control
	              // EXCEPTION: OCX Property Pages should return FALSE
}

void CAnalyzeDlg::OnOK() 
{
	// TODO: Add extra validation here
	//CResizingDialog::OnOK();
}



//DEL BOOL CAnalyzeDlg::OnNcActivate(BOOL bActive) 
//DEL {
//DEL 	// TODO: Add your message handler code here and/or call default
//DEL 	
//DEL 	return CResizingDialog::OnNcActivate(bActive);
//DEL }

void CAnalyzeDlg::OnActivate(UINT nState, CWnd* pWndOther, BOOL bMinimized) 
{
	CResizingDialog::OnActivate(nState, pWndOther, bMinimized);
	if (nState == WA_INACTIVE)
		m_pTree->SetWindowPos(&wndNoTopMost,0,0,0,0, SWP_NOMOVE | SWP_NOSIZE |SWP_NOACTIVATE );
	else
		m_pTree->SetWindowPos(&wndTopMost,0,0,0,0,SWP_NOSIZE | SWP_NOMOVE |SWP_NOACTIVATE );
	// TODO: Add your message handler code here
	
}

void CAnalyzeDlg::OnCancel() 
{
	// TODO: Add extra cleanup here
	if (m_strTempFilename != "")
		DeleteFile(m_strTempFilename.c_str());
	CResizingDialog::OnCancel();
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -