Mercurial > hg > xemacs-beta
annotate netinstall/log.cc @ 1365:02909207294a
[xemacs-hg @ 2003-03-20 13:19:56 by youngs]
2003-03-20 Steve Youngs <youngs@xemacs.org>
* menubar-items.el (default-menubar): Add a "Pre-Release Download
Sites" submenu to "Tools -> Packages" menu.
Filter the package download sites menus through
`menu-split-long-menu'.
* obsolete.el (pui-add-install-directory): New.
(package-get-download-menu): New.
* package-admin.el: (package-admin-add-single-file-package):
Removed.
(package-admin-get-install-dir): Don't rely on an installed
xemacs-base package to guess where a package needs to be installed
to.
(package-admin-get-manifest-file): Whitespace clean up.
(package-admin-check-manifest): Use `directory-sep-char' to
compute regexp.
Only search 'lisp' and 'man' directories to determine package
name.
Don't error is xemacs-base package isn't installed, just don't
sort the MANIFEST file and issue a warning.
(package-admin-add-binary-package): Whitespace clean up.
(package-admin-get-lispdir): Ditto.
(package-admin-delete-binary-package): Use `with-temp-buffer'
instead of creating a temporary buffer manually.
* package-get.el: (package-get-remote): Change custom type so that
only either a single directory or remote host:directory can be
selected.
(package-get-download-sites): Put the sites into alphabetical
order of country.
Make the description element be "Country (site)" instead of the
other way around.
(package-get-pre-release-download-sites): New.
(package-get-require-signed-base-updates): Default to t.
(package-get-download-menu): Removed.
(package-get-locate-file): Change to reflect new format of
'package-get-remote'.
(package-get-update-base-from-buffer): Whitespace clean up and
remove an unneccessary 'when'.
(package-get-interactive-package-query): Whitespace clean up.
(package-get-update-all): Ditto.
(package-get-all): Ditto.
(package-get-init-package): Ditto.
(package-get-info): New.
(package-get): Bring into line with new format of
'package-get-remote'.
Error if non-Mule XEmacsen try to install Mule packages.
Don't rely on a Mule package having 'mule-base' in its
"REQUIRES" to determine if it is a Mule package or not,
instead we test "CATEGORY".
Better handling of the situation where a partial package tarball
exists on the local hard drive from a previous interupted
download.
Clean up after a failed package install.
(package-get-set-version-prop): Removed.
(package-get-installedp): Whitespace clean up.
* package-ui.el: Whitespace clean up.
(pui-info-buffer): Make it a defcustom.
(pui-directory-exists): Removed.
(pui-package-dir-list): Removed.
(pui-add-install-directory): Removed.
(package-ui-download-menu): New.
(package-ui-pre-release-download-menu): New.
(pui-set-local-package-get-directory): New.
(pui-package-symbol-char): Whitespace clean up.
(pui-update-package-display): Ditto.
(pui-toggle-package): Ditto.
(pui-toggle-package-key): Ditto.
(pui-toggle-package-delete): Ditto.
(pui-toggle-package-delete-key): Ditto.
(pui-toggle-package-event): Ditto.
(pui-toggle-verbosity-redisplay): Ditto.
(pui-install-selected-packages): Ditto.
(pui-help-echo): Ditto.
(pui-display-info): Ditto.
(pui-list-packages): Ditto.
* packages.el: Whitespace clean up.
author | youngs |
---|---|
date | Thu, 20 Mar 2003 13:19:59 +0000 |
parents | 685b588e92d8 |
children |
rev | line source |
---|---|
448 | 1 /* |
2 * Copyright (c) 2000, Red Hat, Inc. | |
3 * | |
4 * This program is free software; you can redistribute it and/or modify | |
5 * it under the terms of the GNU General Public License as published by | |
6 * the Free Software Foundation; either version 2 of the License, or | |
7 * (at your option) any later version. | |
8 * | |
9 * A copy of the GNU General Public License can be found at | |
10 * http://www.gnu.org/ | |
11 * | |
12 * Written by DJ Delorie <dj@redhat.com> | |
13 * | |
14 */ | |
15 | |
16 /* The purpose of this file is to centralize all the logging functions. */ | |
17 | |
18 #include "win32.h" | |
19 #include <stdio.h> | |
20 #include <stdarg.h> | |
21 #include <stdlib.h> | |
22 #include <time.h> | |
23 | |
24 #include "resource.h" | |
25 #include "msg.h" | |
26 #include "log.h" | |
27 #include "dialog.h" | |
28 #include "state.h" | |
29 #include "concat.h" | |
30 #include "mkdir.h" | |
31 | |
32 struct LogEnt { | |
33 LogEnt *next; | |
34 int flags; | |
35 time_t when; | |
36 char msg[1]; | |
37 }; | |
38 | |
39 static LogEnt *first_logent = 0; | |
40 static LogEnt **next_logent = &first_logent; | |
41 | |
42 void | |
43 log (int flags, char *fmt, ...) | |
44 { | |
45 char buf[1000]; | |
46 va_list args; | |
47 va_start (args, fmt); | |
48 vsprintf (buf, fmt, args); | |
49 | |
50 LogEnt *l = (LogEnt *) malloc (sizeof (LogEnt) + strlen (buf) + 20); | |
51 l->next = 0; | |
52 l->flags = flags; | |
53 time (&(l->when)); | |
54 *next_logent = l; | |
55 next_logent = &(l->next); | |
56 | |
57 char *b = l->msg; | |
58 if (flags & LOG_TIMESTAMP) | |
59 { | |
60 struct tm *tm = localtime (&(l->when)); | |
61 strftime (b, 1000, "%Y/%m/%d %H:%M:%S ", tm); | |
62 b += strlen (b); | |
63 } | |
64 | |
65 strcpy (b, buf); | |
66 msg ("LOG: %d %s", l->flags, l->msg); | |
67 } | |
68 | |
69 void | |
70 log_save (int babble, char *filename, int append) | |
71 { | |
72 static int been_here = 0; | |
73 if (been_here) | |
74 return; | |
75 been_here = 1; | |
76 | |
77 mkdir_p (0, filename); | |
78 | |
79 FILE *f = fopen (filename, append ? "at" : "wt"); | |
80 if (!f) | |
81 { | |
82 fatal (IDS_NOLOGFILE, filename); | |
83 return; | |
84 } | |
85 | |
86 LogEnt *l; | |
87 | |
88 for (l=first_logent; l; l=l->next) | |
89 { | |
90 if (babble || !(l->flags & LOG_BABBLE)) | |
91 { | |
92 fputs (l->msg, f); | |
93 if (l->msg[strlen(l->msg)-1] != '\n') | |
94 fputc ('\n', f); | |
95 } | |
96 } | |
97 | |
98 fclose (f); | |
99 been_here = 0; | |
100 } | |
101 | |
102 void | |
103 exit_setup (int exit_code) | |
104 { | |
105 static int been_here = 0; | |
106 if (been_here) | |
107 ExitProcess (1); | |
108 been_here = 1; | |
109 | |
110 if (exit_msg) | |
111 note (exit_msg); | |
112 | |
673 | 113 log (LOG_TIMESTAMP, "Ending XEmacs install"); |
448 | 114 |
115 if (source == IDC_SOURCE_DOWNLOAD || !root_dir) | |
116 { | |
117 log_save (LOG_BABBLE, "setup.log.full", 0); | |
118 log_save (0, "setup.log", 1); | |
119 } | |
120 else | |
121 { | |
122 log_save (LOG_BABBLE, concat (root_dir, "/setup.log.full", 0), 0); | |
123 log_save (0, concat (root_dir, "/setup.log", 0), 1); | |
124 } | |
125 | |
126 ExitProcess (exit_code); | |
127 } |