=================================================================== RCS file: /home/cvs/OpenXM_contrib2/windows/asir32gui/asir32guiview.cpp,v retrieving revision 1.24 retrieving revision 1.32 diff -u -p -r1.24 -r1.32 --- OpenXM_contrib2/windows/asir32gui/asir32guiview.cpp 2009/12/07 01:23:18 1.24 +++ OpenXM_contrib2/windows/asir32gui/asir32guiview.cpp 2019/03/28 14:34:35 1.32 @@ -33,7 +33,9 @@ void loadfile(char *); void put_line(char *); void send_intr(void); void insert_to_theView(char *); -void get_rootdir(char *,int,char *); +BOOL get_rootdir(char *,int,char *); +const char *get_locale_lang_iso639(); +const char *get_helpdir(); extern int bigfloat, prtime, prresult; extern char *asir_libdir; extern int asirgui_kind; @@ -82,6 +84,8 @@ BEGIN_MESSAGE_MAP(CAsir32guiView, CEditView) ON_COMMAND(ID_NOROMATRIX, OnNoromatrix) ON_COMMAND(ID_NOROMWL, OnNoromwl) ON_COMMAND(ID_NNNDBF, OnNnndbf) + ON_COMMAND(ID_NOROPD, OnNoropd) + ON_COMMAND(ID_NSTWLG, OnNstwistedlog) //}}AFX_MSG_MAP // 標準印刷コマンド // ON_COMMAND(ID_FILE_PRINT, CEditView::OnFilePrint) @@ -375,6 +379,7 @@ void CAsir32guiView::OnChar(UINT nChar, UINT nRepCnt, // TODO: この位置にメッセージ ハンドラ用のコードを追加するかまたはデフォルトの処理を呼び出してください char *exp_result; char tmp[BUFSIZ]; + int i; if ( asirgui_kind == ASIRGUI_MESSAGE ) { Beep(); return; @@ -438,6 +443,10 @@ void CAsir32guiView::OnChar(UINT nChar, UINT nRepCnt, tmp[0] = 0; put_line(tmp); return; + case CTRL('Y'): + Paste(); return; + case CTRL('I'): + return; default : if ( nChar >= 0x20 && nChar < 0x7f ) PutChar(nChar); @@ -494,14 +503,14 @@ void CAsir32guiView::OnFileOpen() } } } + void CAsir32guiView::viewHtmlHelp(char *help) { char *helpfile; - char fmt[] = "%s\\help\\%shelp.chm"; - char root[BUFSIZ],errmsg[BUFSIZ]; - get_rootdir(root,sizeof(root),errmsg); - helpfile = (char *)malloc(sizeof(fmt) + strlen(root) + strlen(help)); - sprintf(helpfile,fmt,root,help); + char fmt[] = "%s\\%shelp.chm"; + const char *dir = get_helpdir(); + helpfile = (char *)malloc(sizeof(fmt) + strlen(dir) + strlen(help)); + sprintf(helpfile,fmt,dir,help); #if _MSC_VER < 1300 /* Visual C++ 6.0 */ ::HtmlHelp(NULL, helpfile, HH_DISPLAY_TOPIC, 0); @@ -516,10 +525,25 @@ void CAsir32guiView::viewHtmlHelp(char *help) #endif } +void CAsir32guiView::viewWebHelp(char *key) +{ + char *base="http://www.math.kobe-u.ac.jp/OpenXM/Current/doc/"; + char *url = (char *)malloc(strlen(base)+strlen(key)+1); + sprintf(url,"%s%s",base,key); + ShellExecute(NULL,"open",url,NULL,NULL,SW_SHOWNORMAL); + free(url); +} + void CAsir32guiView::OnAsirhelp() { + const char *lang = get_locale_lang_iso639(); + if(strcmp(lang,"ja")==0) { + viewWebHelp("index-doc-ja.html"); + }else { + viewWebHelp("index-doc.html"); + } // TODO: この位置にコマンド ハンドラ用のコードを追加してください - viewHtmlHelp("asir"); +// viewHtmlHelp("asir"); } void CAsir32guiView::OnFileLog() @@ -575,7 +599,7 @@ void CAsir32guiView::UpdateMetrics() void CAsir32guiView::OnFont() { // TODO: この位置にコマンド ハンドラ用のコードを追加してください - int ret; + INT_PTR ret; LOGFONT lf; GetFont()->GetLogFont(&lf); @@ -701,33 +725,41 @@ void CAsir32guiView::OnNoromwl() viewHtmlHelp("noro_mwl"); } +void CAsir32guiView::OnNoropd() +{ + // TODO: この位置にコマンド ハンドラ用のコードを追加してください + viewHtmlHelp("noro_pd"); +} + void CAsir32guiView::OnNnndbf() { // TODO: この位置にコマンド ハンドラ用のコードを追加してください viewHtmlHelp("nn_ndbf"); } +void CAsir32guiView::OnNstwistedlog() +{ + // TODO: この位置にコマンド ハンドラ用のコードを追加してください + viewHtmlHelp("ns_twistedlog"); +} + BOOL CAsir32guiView::Create(LPCTSTR lpszClassName, LPCTSTR lpszWindowName, DWORD dwStyle, const RECT& rect, CWnd* pParentWnd, UINT nID, CCreateContext* pContext) { // TODO: この位置に固有の処理を追加するか、または基本クラスを呼び出してください BOOL ret = CWnd::Create(lpszClassName, lpszWindowName, dwStyle, rect, pParentWnd, nID, pContext); - FILE *fp = fopen("asirgui.hnd","w"); + FILE *fp = NULL; char *temp; + char hndname[_MAX_PATH]; - if ( fp ) { - fprintf(fp,"%d",(unsigned int)theView->m_hWnd); - fclose(fp); + if ( asirgui_kind == ASIRGUI_MAIN ) { if ( temp = getenv("TEMP") ) { - int len; - char *name; - - len = strlen(temp); - name = (char *)malloc(len+BUFSIZ); - sprintf(name,"%s\\asirgui.hnd",temp); - fopen(name,"w"); - fprintf(fp,"%d",(unsigned int)theView->m_hWnd); - fclose(fp); + sprintf(hndname,"%s\\asirgui.hnd", temp); + fp = fopen(hndname,"w"); + if ( fp ) { + fprintf(fp,"%d",(unsigned int)theView->m_hWnd); + fclose(fp); + } } } return ret;