/[winpt]/trunk/Src/wptMDSumDlg.cpp
ViewVC logotype

Annotation of /trunk/Src/wptMDSumDlg.cpp

Parent Directory Parent Directory | Revision Log Revision Log


Revision 208 - (hide annotations)
Mon May 1 12:22:18 2006 UTC (18 years, 10 months ago) by twoaday
File size: 5039 byte(s)
See ChangeLog.


1 werner 36 /* wptMDSumDlg.cpp
2 twoaday 165 * Copyright (C) 2003, 2005, 2006 Timo Schulz
3 werner 36 *
4     * This file is part of WinPT.
5     *
6     * WinPT is free software; you can redistribute it and/or modify
7     * it under the terms of the GNU General Public License as published by
8     * the Free Software Foundation; either version 2 of the License, or
9     * (at your option) any later version.
10     *
11     * WinPT is distributed in the hope that it will be useful,
12     * but WITHOUT ANY WARRANTY; without even the implied warranty of
13     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14     * GNU General Public License for more details.
15     *
16     * You should have received a copy of the GNU General Public License
17     * along with WinPT; if not, write to the Free Software Foundation,
18     * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
19     */
20     #ifdef HAVE_CONFIG_H
21     #include <config.h>
22     #endif
23    
24     #include <windows.h>
25     #include <stdio.h>
26 twoaday 99
27 werner 47 #include "resource.h"
28 werner 36 #include "wptTypes.h"
29     #include "wptW32API.h"
30     #include "wptGPG.h"
31     #include "wptCommonCtl.h"
32     #include "wptContext.h"
33     #include "wptNLS.h"
34     #include "wptErrors.h"
35    
36 twoaday 130
37 werner 36 /* Return a printable digest of the buffer @mdbuf. */
38     static const char*
39     printable_digest (byte *mdbuf, size_t n)
40     {
41 twoaday 204 static char mdasc[128];
42 werner 36 size_t i;
43 twoaday 204
44 werner 36 for (i = 0; i < n; i++)
45     sprintf (mdasc+2*i, "%02X", mdbuf[i]);
46     return mdasc;
47     }
48    
49    
50 twoaday 130 static const char*
51 twoaday 204 id2algo (gpgme_hash_algo_t mdalgo)
52 twoaday 130 {
53 twoaday 204 switch (mdalgo) {
54 twoaday 130 case GPGME_MD_MD5: return "MD5";
55     case GPGME_MD_SHA1: return "SHA1";
56     case GPGME_MD_RMD160: return "RMD160";
57     case GPGME_MD_SHA256: return "SHA256";
58 twoaday 205 default: return "";
59 twoaday 130 }
60     return "";
61     }
62    
63    
64 twoaday 204 /* Hash the selected file from the FM listview control in @md.
65     Add the results to the listview @lv. */
66     static void
67     hash_selected_files (md_file_s *md, listview_ctrl_t lv)
68     {
69     BYTE mdbuf[32];
70     char fname[256+1];
71     int i;
72     size_t n;
73    
74     for (i = 0; i < listview_count_items( md->lv, 0 ); i++) {
75     if( listview_get_item_state (md->lv, i)) {
76     listview_get_item_text (md->lv, i, 1, fname, sizeof (fname)-1);
77     if (!gpg_md_hash_file (md->mdalgo, fname, mdbuf, &n)) {
78     listview_add_item (lv, "");
79     listview_add_sub_item (lv, 0, 0, printable_digest (mdbuf, n));
80     listview_add_sub_item (lv, 0, 1, fname);
81     }
82     }
83     }
84     }
85    
86    
87     static int
88     tool_avail (gpgme_hash_algo_t mdalgo)
89     {
90     if (mdalgo == GPGME_MD_SHA1 || mdalgo == GPGME_MD_MD5)
91     return 1;
92     return 0;
93     }
94    
95    
96 werner 36 /* Dialog box procedure to show and calculate file digests. */
97     BOOL CALLBACK
98     mdsum_dlg_proc (HWND dlg, UINT msg, WPARAM wparam, LPARAM lparam)
99     {
100     static listview_ctrl_t lv;
101 twoaday 204 static struct md_file_s *md;
102 werner 36 struct listview_column_s cols[] = {
103     {0, 264, (char *)_("Digest")},
104     {1, 128, (char *)_("Name")},
105     {0, 0, 0}
106     };
107     gpgme_data_t sumlist;
108 twoaday 204 const char *name, *algname;
109     char fname[300], mdasc[128];
110 werner 36 int i;
111    
112     switch( msg ) {
113     case WM_INITDIALOG:
114     md = (md_file_s *)lparam;
115 twoaday 204 if (!md)
116     BUG (NULL);
117 twoaday 208 listview_new (&lv, GetDlgItem (dlg, IDC_MDSUM_LIST));
118 twoaday 204 for (i = 0; i < cols[i].width; i++)
119     listview_add_column( lv, &cols[i]);
120     hash_selected_files (md, lv);
121 twoaday 99 SetDlgItemText (dlg, IDC_MDSUM_COPY, _("&Save..."));
122 twoaday 119 SetDlgItemText (dlg, IDOK, _("&Close"));
123 twoaday 167 SetDlgItemText (dlg, IDC_MDSUM_TOCLIP, _("Save to clipboard"));
124 twoaday 99 SetWindowText (dlg, _("Print Message Digest"));
125     SetForegroundWindow (dlg);
126 werner 36 break;
127    
128 twoaday 130 case WM_SYSCOMMAND:
129     if (wparam == SC_CLOSE)
130     EndDialog (dlg, TRUE);
131     return TRUE;
132    
133 werner 36 case WM_DESTROY:
134 twoaday 204 if (lv) {
135     listview_release (lv);
136 werner 36 lv = NULL;
137     }
138     break;
139    
140     case WM_COMMAND:
141     switch (LOWORD (wparam)) {
142     case IDOK:
143     EndDialog (dlg, TRUE);
144     break;
145    
146 twoaday 204 case IDCANCEL:
147     EndDialog (dlg, FALSE);
148     break;
149    
150 werner 36 case IDC_MDSUM_COPY:
151 twoaday 204 algname = id2algo ((gpgme_hash_algo_t)md->mdalgo);
152 werner 36 if (gpgme_data_new (&sumlist))
153     BUG(0);
154 twoaday 204 if (!tool_avail ((gpgme_hash_algo_t)md->mdalgo)) {
155     const char *s;
156    
157     s = "#warning '";
158 werner 36 gpgme_data_write (sumlist, s, strlen (s));
159 twoaday 204 gpgme_data_write (sumlist, algname, strlen (algname));
160     s = " ' sum is not yet available\r\n";
161     gpgme_data_write (sumlist, s, strlen (s));
162 werner 36 }
163     for (i = 0; i < listview_count_items (lv, 0); i++) {
164     listview_get_item_text (lv, i, 0, mdasc, DIM (mdasc)-1);
165     listview_get_item_text (lv, i, 1, fname, DIM (fname)-1);
166    
167     gpgme_data_write (sumlist, mdasc, strlen (mdasc));
168     gpgme_data_write (sumlist, " ", 1);
169     gpgme_data_write (sumlist, fname, strlen (fname));
170     gpgme_data_write (sumlist, "\r\n", 2);
171     }
172 twoaday 165 if (IsDlgButtonChecked (dlg, IDC_MDSUM_TOCLIP)) {
173     gpg_data_release_and_set_clipboard (sumlist, 0);
174     break;
175     }
176 twoaday 204 _snprintf (fname, sizeof (fname)-1, "%s_sums.txt", algname);
177 twoaday 130 name = get_filesave_dlg (dlg, _("Select file to save checksums"),
178     NULL, fname);
179 werner 36 if (name && *name) {
180     gpg_data_release_and_set_file (sumlist, name);
181 twoaday 130 log_box (_("File Manager"), MB_OK,
182     _("Checksums successfully saved in '%s'"), name);
183 werner 36 }
184     else
185     gpgme_data_release (sumlist);
186     break;
187     }
188     break;
189     }
190     return FALSE;
191     }

Properties

Name Value
svn:eol-style native

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26