Mercurial > hg > xemacs-beta
view netinstall/diskfull.cc @ 5206:39d74978fd32
Keep around file info for dumped functions and variables without docstrings.
src/ChangeLog addition:
2010-04-17 Aidan Kehoe <kehoea@parhasard.net>
* doc.c (Fdocumentation):
If we have a zero length doc string in DOC, as may happen for
undocumented compiled function objects which nonetheless have file
information stored, return nil.
(Fsnarf_documentation):
DOC info existing for compiled functions without docstrings is
perfectly legitimate, now the file is also used to store file names.
* bytecode.c (set_compiled_function_documentation):
Allow this function to set the documentation successfully for
compiled function objects that don't currently have documentation;
most relevant for functions without docstrings which have file
information stored in DOC.
lib-src/ChangeLog addition:
2010-04-17 Aidan Kehoe <kehoea@parhasard.net>
* make-docfile.c (scan_lisp_file):
Even if a function doesn't have a doc string, store its file name
in DOC.
lisp/ChangeLog addition:
2010-04-17 Aidan Kehoe <kehoea@parhasard.net>
* loadup.el (load-history): Be a bit more discriminate in the
entries we remove from load-history, only removing those where the
information is entirely available from DOC.
Fixes problems finding the files that dumped undocumented
variables were loaded from, reported by Didier Verna.
* loadhist.el (symbol-file): Correct a regexp here, I had
forgotten to double a backslash.
author | Aidan Kehoe <kehoea@parhasard.net> |
---|---|
date | Sat, 17 Apr 2010 10:40:03 +0100 |
parents | 3078fd1074e8 |
children |
line wrap: on
line source
/* * Copyright (c) 2000, Red Hat, Inc. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * A copy of the GNU General Public License can be found at * http://www.gnu.org/ * * Written by DJ Delorie <dj@cygnus.com> * */ /* The purpose of this file is to hide the mess needed just to figure out how full a given disk is. There is an old API that can't handle disks bigger than 2G, and a new API that isn't always available. */ #include "win32.h" #include "diskfull.h" typedef BOOL (WINAPI * GDFS)(LPCTSTR, PULARGE_INTEGER, PULARGE_INTEGER, PULARGE_INTEGER); int diskfull (char *path) { GDFS gdfs = 0; HINSTANCE k = LoadLibrary ("KERNEL32.DLL"); if (k) { gdfs = (GDFS) GetProcAddress (k, "GetDiskFreeSpaceExA"); if (gdfs) { ULARGE_INTEGER avail, total, free; if (gdfs (path, &avail, &total, &free)) { int perc = avail.QuadPart * 100 / total.QuadPart; return 100-perc; } } } char root[4]; if (path[1] != ':') return 0; root[0] = path[0]; root[1] = ':'; root[2] = '\\'; root[3] = 0; DWORD junk, free_clusters, total_clusters; if (GetDiskFreeSpace (root, &junk, &junk, &free_clusters, &total_clusters)) { int perc = free_clusters * 100 / total_clusters; return 100-perc; } return 0; }