view lib-src/make-path.c @ 27142:f742c86fcc15

(Fgarbage_collect): Return number of live and free strings. (mark_buffer): Remove code in #if 0. (gc_sweep): Ditto. (UNMARK_BALANCE_INTERVALS): Give the macro statement form. (strings_consed): New variable. (allocate_string): Set it. (syms_of_alloc): Add DEFVAR_INT for strings_consed. (Fmemory_use_counts): Return strings_consed. Use Flist. General cleanup in comments etc. Remove conditional compilation for `standalone'. (MARK_STRING, UNMARK_STRING, STRING_MARKED_P): (GC_STRING_BYTES, GC_STRING_CHARS): New macros. (DONT_COPY_FLAG): Removed. (SBLOCK_SIZE, LARGE_STRING_BYTES): New macros. (struct sdata, struct sblock): New (struct string_block): Rewritten. (STRINGS_IN_STRING_BLOCK): New macro. (oldest_sblock, current_sblock, total_strings, total_free_strings) (large_sblocks, string_blocks, string_free_list): New variables. (NEXT_FREE_LISP_STRING, SDATA_OF_STRING, SDATA_SIZE): New macros. (init_strings): Rewritten. (allocate_string, allocate_string_data, compact_small_strings) (free_large_strings, sweep_strings): New functions. (STRING_BLOCK_SIZE, STRING_BLOCK_OUTSIZE) (struct string_block_head, current_string_block) (first_string_block, large_string_blocks, STRING_FULLSIZE) (STRING_PAD): Removed. (make_uninit_multibyte_string, make_pure_string): Rewritten. (Fgarbage_collect): Don't set mark bit in large strings. (mark_object): Mark strings differently. Mark symbol names differently. (survives_gc_p): Test marked strings differently. (gc_sweep): Sweep strings differently, unmark strings in symbol names. (compact_strings): Removed.
author Gerd Moellmann <gerd@gnu.org>
date Tue, 04 Jan 2000 12:22:13 +0000
parents 953e5ea2b8ea
children
line wrap: on
line source

/* Make all the directories along a path.
   Copyright (C) 1992 Free Software Foundation, Inc.

This file is part of GNU Emacs.

GNU Emacs 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, or (at your option)
any later version.

GNU Emacs is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with GNU Emacs; see the file COPYING.  If not, write to
the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */

/* This program works like mkdir, except that it generates
   intermediate directories if they don't exist.  This is just like
   the `mkdir -p' command on most systems; unfortunately, the mkdir
   command on some of the purer BSD systems (like Mt. Xinu) don't have
   that option. */

#include <sys/types.h>
#include <sys/stat.h>
#include <stdio.h>
#include <errno.h>

extern int errno;

char *prog_name;

/* Create directory DIRNAME if it does not exist already.
   Then give permission for everyone to read and search it.
   Return 0 if successful, 1 if not.  */

int
touchy_mkdir (dirname)
     char *dirname;
{
  struct stat buf;

  /* If DIRNAME already exists and is a directory, don't create.  */
  if (! (stat (dirname, &buf) >= 0
	 && (buf.st_mode & S_IFMT) == S_IFDIR))
    {
      /* Otherwise, try to make it.  If DIRNAME exists but isn't a directory,
	 this will signal an error.  */
      if (mkdir (dirname, 0777) < 0)
	{
	  fprintf (stderr, "%s: ", prog_name);
	  perror (dirname);
	  return 1;
	}
    }

  /* Make sure everyone can look at this directory.  */
  if (stat (dirname, &buf) < 0)
    {
      fprintf (stderr, "%s: ", prog_name);
      perror (dirname);
      return 1;
    }
  if (chmod (dirname, 0555 | (buf.st_mode & 0777)) < 0)
    {
      fprintf (stderr, "%s: ", prog_name);
      perror (dirname);
    }

  return 0;
}

int
main (argc, argv)
     int argc;
     char **argv;
{
  prog_name = *argv;

  for (argc--, argv++; argc > 0; argc--, argv++)
    {
      char *dirname = *argv;
      int i;

      /* Stop at each slash in dirname and try to create the directory.
	 Skip any initial slash.  */
      for (i = (dirname[0] == '/') ? 1 : 0; dirname[i]; i++)
	if (dirname[i] == '/')
	  {
	    dirname[i] = '\0';
	    if (touchy_mkdir (dirname) < 0)
	      goto next_dirname;
	    dirname[i] = '/';
	  }

      touchy_mkdir (dirname);

    next_dirname:
      ;
    }

  return 0;
}