OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [gcc-4.2.2/] [gcc/] [c-ppoutput.c] - Diff between revs 154 and 816

Only display areas with differences | Details | Blame | View Log

Rev 154 Rev 816
/* Preprocess only, using cpplib.
/* Preprocess only, using cpplib.
   Copyright (C) 1995, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2007
   Copyright (C) 1995, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2007
   Free Software Foundation, Inc.
   Free Software Foundation, Inc.
   Written by Per Bothner, 1994-95.
   Written by Per Bothner, 1994-95.
 
 
   This program is free software; you can redistribute it and/or modify it
   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
   under the terms of the GNU General Public License as published by the
   Free Software Foundation; either version 3, or (at your option) any
   Free Software Foundation; either version 3, or (at your option) any
   later version.
   later version.
 
 
   This program is distributed in the hope that it will be useful,
   This program is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.
   GNU General Public License for more details.
 
 
   You should have received a copy of the GNU General Public License
   You should have received a copy of the GNU General Public License
   along with this program; see the file COPYING3.  If not see
   along with this program; see the file COPYING3.  If not see
   <http://www.gnu.org/licenses/>.  */
   <http://www.gnu.org/licenses/>.  */
 
 
#include "config.h"
#include "config.h"
#include "system.h"
#include "system.h"
#include "coretypes.h"
#include "coretypes.h"
#include "tm.h"
#include "tm.h"
#include "cpplib.h"
#include "cpplib.h"
#include "../libcpp/internal.h"
#include "../libcpp/internal.h"
#include "tree.h"
#include "tree.h"
#include "c-common.h"           /* For flags.  */
#include "c-common.h"           /* For flags.  */
#include "c-pragma.h"           /* For parse_in.  */
#include "c-pragma.h"           /* For parse_in.  */
 
 
/* Encapsulates state used to convert a stream of tokens into a text
/* Encapsulates state used to convert a stream of tokens into a text
   file.  */
   file.  */
static struct
static struct
{
{
  FILE *outf;                   /* Stream to write to.  */
  FILE *outf;                   /* Stream to write to.  */
  const cpp_token *prev;        /* Previous token.  */
  const cpp_token *prev;        /* Previous token.  */
  const cpp_token *source;      /* Source token for spacing.  */
  const cpp_token *source;      /* Source token for spacing.  */
  int src_line;                 /* Line number currently being written.  */
  int src_line;                 /* Line number currently being written.  */
  unsigned char printed;        /* Nonzero if something output at line.  */
  unsigned char printed;        /* Nonzero if something output at line.  */
  bool first_time;              /* pp_file_change hasn't been called yet.  */
  bool first_time;              /* pp_file_change hasn't been called yet.  */
} print;
} print;
 
 
/* General output routines.  */
/* General output routines.  */
static void scan_translation_unit (cpp_reader *);
static void scan_translation_unit (cpp_reader *);
static void scan_translation_unit_trad (cpp_reader *);
static void scan_translation_unit_trad (cpp_reader *);
static void account_for_newlines (const unsigned char *, size_t);
static void account_for_newlines (const unsigned char *, size_t);
static int dump_macro (cpp_reader *, cpp_hashnode *, void *);
static int dump_macro (cpp_reader *, cpp_hashnode *, void *);
 
 
static void print_line (source_location, const char *);
static void print_line (source_location, const char *);
static void maybe_print_line (source_location);
static void maybe_print_line (source_location);
 
 
/* Callback routines for the parser.   Most of these are active only
/* Callback routines for the parser.   Most of these are active only
   in specific modes.  */
   in specific modes.  */
static void cb_line_change (cpp_reader *, const cpp_token *, int);
static void cb_line_change (cpp_reader *, const cpp_token *, int);
static void cb_define (cpp_reader *, source_location, cpp_hashnode *);
static void cb_define (cpp_reader *, source_location, cpp_hashnode *);
static void cb_undef (cpp_reader *, source_location, cpp_hashnode *);
static void cb_undef (cpp_reader *, source_location, cpp_hashnode *);
static void cb_include (cpp_reader *, source_location, const unsigned char *,
static void cb_include (cpp_reader *, source_location, const unsigned char *,
                        const char *, int, const cpp_token **);
                        const char *, int, const cpp_token **);
static void cb_ident (cpp_reader *, source_location, const cpp_string *);
static void cb_ident (cpp_reader *, source_location, const cpp_string *);
static void cb_def_pragma (cpp_reader *, source_location);
static void cb_def_pragma (cpp_reader *, source_location);
static void cb_read_pch (cpp_reader *pfile, const char *name,
static void cb_read_pch (cpp_reader *pfile, const char *name,
                         int fd, const char *orig_name);
                         int fd, const char *orig_name);
 
 
/* Preprocess and output.  */
/* Preprocess and output.  */
void
void
preprocess_file (cpp_reader *pfile)
preprocess_file (cpp_reader *pfile)
{
{
  /* A successful cpp_read_main_file guarantees that we can call
  /* A successful cpp_read_main_file guarantees that we can call
     cpp_scan_nooutput or cpp_get_token next.  */
     cpp_scan_nooutput or cpp_get_token next.  */
  if (flag_no_output)
  if (flag_no_output)
    {
    {
      /* Scan -included buffers, then the main file.  */
      /* Scan -included buffers, then the main file.  */
      while (pfile->buffer->prev)
      while (pfile->buffer->prev)
        cpp_scan_nooutput (pfile);
        cpp_scan_nooutput (pfile);
      cpp_scan_nooutput (pfile);
      cpp_scan_nooutput (pfile);
    }
    }
  else if (cpp_get_options (pfile)->traditional)
  else if (cpp_get_options (pfile)->traditional)
    scan_translation_unit_trad (pfile);
    scan_translation_unit_trad (pfile);
  else
  else
    scan_translation_unit (pfile);
    scan_translation_unit (pfile);
 
 
  /* -dM command line option.  Should this be elsewhere?  */
  /* -dM command line option.  Should this be elsewhere?  */
  if (flag_dump_macros == 'M')
  if (flag_dump_macros == 'M')
    cpp_forall_identifiers (pfile, dump_macro, NULL);
    cpp_forall_identifiers (pfile, dump_macro, NULL);
 
 
  /* Flush any pending output.  */
  /* Flush any pending output.  */
  if (print.printed)
  if (print.printed)
    putc ('\n', print.outf);
    putc ('\n', print.outf);
}
}
 
 
/* Set up the callbacks as appropriate.  */
/* Set up the callbacks as appropriate.  */
void
void
init_pp_output (FILE *out_stream)
init_pp_output (FILE *out_stream)
{
{
  cpp_callbacks *cb = cpp_get_callbacks (parse_in);
  cpp_callbacks *cb = cpp_get_callbacks (parse_in);
 
 
  if (!flag_no_output)
  if (!flag_no_output)
    {
    {
      cb->line_change = cb_line_change;
      cb->line_change = cb_line_change;
      /* Don't emit #pragma or #ident directives if we are processing
      /* Don't emit #pragma or #ident directives if we are processing
         assembly language; the assembler may choke on them.  */
         assembly language; the assembler may choke on them.  */
      if (cpp_get_options (parse_in)->lang != CLK_ASM)
      if (cpp_get_options (parse_in)->lang != CLK_ASM)
        {
        {
          cb->ident      = cb_ident;
          cb->ident      = cb_ident;
          cb->def_pragma = cb_def_pragma;
          cb->def_pragma = cb_def_pragma;
        }
        }
    }
    }
 
 
  if (flag_dump_includes)
  if (flag_dump_includes)
    cb->include  = cb_include;
    cb->include  = cb_include;
 
 
  if (flag_pch_preprocess)
  if (flag_pch_preprocess)
    {
    {
      cb->valid_pch = c_common_valid_pch;
      cb->valid_pch = c_common_valid_pch;
      cb->read_pch = cb_read_pch;
      cb->read_pch = cb_read_pch;
    }
    }
 
 
  if (flag_dump_macros == 'N' || flag_dump_macros == 'D')
  if (flag_dump_macros == 'N' || flag_dump_macros == 'D')
    {
    {
      cb->define = cb_define;
      cb->define = cb_define;
      cb->undef  = cb_undef;
      cb->undef  = cb_undef;
    }
    }
 
 
  /* Initialize the print structure.  Setting print.src_line to -1 here is
  /* Initialize the print structure.  Setting print.src_line to -1 here is
     a trick to guarantee that the first token of the file will cause
     a trick to guarantee that the first token of the file will cause
     a linemarker to be output by maybe_print_line.  */
     a linemarker to be output by maybe_print_line.  */
  print.src_line = -1;
  print.src_line = -1;
  print.printed = 0;
  print.printed = 0;
  print.prev = 0;
  print.prev = 0;
  print.outf = out_stream;
  print.outf = out_stream;
  print.first_time = 1;
  print.first_time = 1;
}
}
 
 
/* Writes out the preprocessed file, handling spacing and paste
/* Writes out the preprocessed file, handling spacing and paste
   avoidance issues.  */
   avoidance issues.  */
static void
static void
scan_translation_unit (cpp_reader *pfile)
scan_translation_unit (cpp_reader *pfile)
{
{
  bool avoid_paste = false;
  bool avoid_paste = false;
 
 
  print.source = NULL;
  print.source = NULL;
  for (;;)
  for (;;)
    {
    {
      const cpp_token *token = cpp_get_token (pfile);
      const cpp_token *token = cpp_get_token (pfile);
 
 
      if (token->type == CPP_PADDING)
      if (token->type == CPP_PADDING)
        {
        {
          avoid_paste = true;
          avoid_paste = true;
          if (print.source == NULL
          if (print.source == NULL
              || (!(print.source->flags & PREV_WHITE)
              || (!(print.source->flags & PREV_WHITE)
                  && token->val.source == NULL))
                  && token->val.source == NULL))
            print.source = token->val.source;
            print.source = token->val.source;
          continue;
          continue;
        }
        }
 
 
      if (token->type == CPP_EOF)
      if (token->type == CPP_EOF)
        break;
        break;
 
 
      /* Subtle logic to output a space if and only if necessary.  */
      /* Subtle logic to output a space if and only if necessary.  */
      if (avoid_paste)
      if (avoid_paste)
        {
        {
          if (print.source == NULL)
          if (print.source == NULL)
            print.source = token;
            print.source = token;
          if (print.source->flags & PREV_WHITE
          if (print.source->flags & PREV_WHITE
              || (print.prev
              || (print.prev
                  && cpp_avoid_paste (pfile, print.prev, token))
                  && cpp_avoid_paste (pfile, print.prev, token))
              || (print.prev == NULL && token->type == CPP_HASH))
              || (print.prev == NULL && token->type == CPP_HASH))
            putc (' ', print.outf);
            putc (' ', print.outf);
        }
        }
      else if (token->flags & PREV_WHITE)
      else if (token->flags & PREV_WHITE)
        putc (' ', print.outf);
        putc (' ', print.outf);
 
 
      avoid_paste = false;
      avoid_paste = false;
      print.source = NULL;
      print.source = NULL;
      print.prev = token;
      print.prev = token;
      cpp_output_token (token, print.outf);
      cpp_output_token (token, print.outf);
 
 
      if (token->type == CPP_COMMENT)
      if (token->type == CPP_COMMENT)
        account_for_newlines (token->val.str.text, token->val.str.len);
        account_for_newlines (token->val.str.text, token->val.str.len);
    }
    }
}
}
 
 
/* Adjust print.src_line for newlines embedded in output.  */
/* Adjust print.src_line for newlines embedded in output.  */
static void
static void
account_for_newlines (const unsigned char *str, size_t len)
account_for_newlines (const unsigned char *str, size_t len)
{
{
  while (len--)
  while (len--)
    if (*str++ == '\n')
    if (*str++ == '\n')
      print.src_line++;
      print.src_line++;
}
}
 
 
/* Writes out a traditionally preprocessed file.  */
/* Writes out a traditionally preprocessed file.  */
static void
static void
scan_translation_unit_trad (cpp_reader *pfile)
scan_translation_unit_trad (cpp_reader *pfile)
{
{
  while (_cpp_read_logical_line_trad (pfile))
  while (_cpp_read_logical_line_trad (pfile))
    {
    {
      size_t len = pfile->out.cur - pfile->out.base;
      size_t len = pfile->out.cur - pfile->out.base;
      maybe_print_line (pfile->out.first_line);
      maybe_print_line (pfile->out.first_line);
      fwrite (pfile->out.base, 1, len, print.outf);
      fwrite (pfile->out.base, 1, len, print.outf);
      print.printed = 1;
      print.printed = 1;
      if (!CPP_OPTION (pfile, discard_comments))
      if (!CPP_OPTION (pfile, discard_comments))
        account_for_newlines (pfile->out.base, len);
        account_for_newlines (pfile->out.base, len);
    }
    }
}
}
 
 
/* If the token read on logical line LINE needs to be output on a
/* If the token read on logical line LINE needs to be output on a
   different line to the current one, output the required newlines or
   different line to the current one, output the required newlines or
   a line marker, and return 1.  Otherwise return 0.  */
   a line marker, and return 1.  Otherwise return 0.  */
static void
static void
maybe_print_line (source_location src_loc)
maybe_print_line (source_location src_loc)
{
{
  const struct line_map *map = linemap_lookup (&line_table, src_loc);
  const struct line_map *map = linemap_lookup (&line_table, src_loc);
  int src_line = SOURCE_LINE (map, src_loc);
  int src_line = SOURCE_LINE (map, src_loc);
  /* End the previous line of text.  */
  /* End the previous line of text.  */
  if (print.printed)
  if (print.printed)
    {
    {
      putc ('\n', print.outf);
      putc ('\n', print.outf);
      print.src_line++;
      print.src_line++;
      print.printed = 0;
      print.printed = 0;
    }
    }
 
 
  if (src_line >= print.src_line && src_line < print.src_line + 8)
  if (src_line >= print.src_line && src_line < print.src_line + 8)
    {
    {
      while (src_line > print.src_line)
      while (src_line > print.src_line)
        {
        {
          putc ('\n', print.outf);
          putc ('\n', print.outf);
          print.src_line++;
          print.src_line++;
        }
        }
    }
    }
  else
  else
    print_line (src_loc, "");
    print_line (src_loc, "");
}
}
 
 
/* Output a line marker for logical line LINE.  Special flags are "1"
/* Output a line marker for logical line LINE.  Special flags are "1"
   or "2" indicating entering or leaving a file.  */
   or "2" indicating entering or leaving a file.  */
static void
static void
print_line (source_location src_loc, const char *special_flags)
print_line (source_location src_loc, const char *special_flags)
{
{
  /* End any previous line of text.  */
  /* End any previous line of text.  */
  if (print.printed)
  if (print.printed)
    putc ('\n', print.outf);
    putc ('\n', print.outf);
  print.printed = 0;
  print.printed = 0;
 
 
  if (!flag_no_line_commands)
  if (!flag_no_line_commands)
    {
    {
      const struct line_map *map = linemap_lookup (&line_table, src_loc);
      const struct line_map *map = linemap_lookup (&line_table, src_loc);
 
 
      size_t to_file_len = strlen (map->to_file);
      size_t to_file_len = strlen (map->to_file);
      unsigned char *to_file_quoted =
      unsigned char *to_file_quoted =
         (unsigned char *) alloca (to_file_len * 4 + 1);
         (unsigned char *) alloca (to_file_len * 4 + 1);
      unsigned char *p;
      unsigned char *p;
 
 
      print.src_line = SOURCE_LINE (map, src_loc);
      print.src_line = SOURCE_LINE (map, src_loc);
 
 
      /* cpp_quote_string does not nul-terminate, so we have to do it
      /* cpp_quote_string does not nul-terminate, so we have to do it
         ourselves.  */
         ourselves.  */
      p = cpp_quote_string (to_file_quoted,
      p = cpp_quote_string (to_file_quoted,
                            (unsigned char *) map->to_file, to_file_len);
                            (unsigned char *) map->to_file, to_file_len);
      *p = '\0';
      *p = '\0';
      fprintf (print.outf, "# %u \"%s\"%s",
      fprintf (print.outf, "# %u \"%s\"%s",
               print.src_line == 0 ? 1 : print.src_line,
               print.src_line == 0 ? 1 : print.src_line,
               to_file_quoted, special_flags);
               to_file_quoted, special_flags);
 
 
      if (map->sysp == 2)
      if (map->sysp == 2)
        fputs (" 3 4", print.outf);
        fputs (" 3 4", print.outf);
      else if (map->sysp == 1)
      else if (map->sysp == 1)
        fputs (" 3", print.outf);
        fputs (" 3", print.outf);
 
 
      putc ('\n', print.outf);
      putc ('\n', print.outf);
    }
    }
}
}
 
 
/* Called when a line of output is started.  TOKEN is the first token
/* Called when a line of output is started.  TOKEN is the first token
   of the line, and at end of file will be CPP_EOF.  */
   of the line, and at end of file will be CPP_EOF.  */
static void
static void
cb_line_change (cpp_reader *pfile, const cpp_token *token,
cb_line_change (cpp_reader *pfile, const cpp_token *token,
                int parsing_args)
                int parsing_args)
{
{
  source_location src_loc = token->src_loc;
  source_location src_loc = token->src_loc;
 
 
  if (token->type == CPP_EOF || parsing_args)
  if (token->type == CPP_EOF || parsing_args)
    return;
    return;
 
 
  maybe_print_line (src_loc);
  maybe_print_line (src_loc);
  print.prev = 0;
  print.prev = 0;
  print.source = 0;
  print.source = 0;
 
 
  /* Supply enough spaces to put this token in its original column,
  /* Supply enough spaces to put this token in its original column,
     one space per column greater than 2, since scan_translation_unit
     one space per column greater than 2, since scan_translation_unit
     will provide a space if PREV_WHITE.  Don't bother trying to
     will provide a space if PREV_WHITE.  Don't bother trying to
     reconstruct tabs; we can't get it right in general, and nothing
     reconstruct tabs; we can't get it right in general, and nothing
     ought to care.  Some things do care; the fault lies with them.  */
     ought to care.  Some things do care; the fault lies with them.  */
  if (!CPP_OPTION (pfile, traditional))
  if (!CPP_OPTION (pfile, traditional))
    {
    {
      const struct line_map *map = linemap_lookup (&line_table, src_loc);
      const struct line_map *map = linemap_lookup (&line_table, src_loc);
      int spaces = SOURCE_COLUMN (map, src_loc) - 2;
      int spaces = SOURCE_COLUMN (map, src_loc) - 2;
      print.printed = 1;
      print.printed = 1;
 
 
      while (-- spaces >= 0)
      while (-- spaces >= 0)
        putc (' ', print.outf);
        putc (' ', print.outf);
    }
    }
}
}
 
 
static void
static void
cb_ident (cpp_reader *pfile ATTRIBUTE_UNUSED, source_location line,
cb_ident (cpp_reader *pfile ATTRIBUTE_UNUSED, source_location line,
          const cpp_string *str)
          const cpp_string *str)
{
{
  maybe_print_line (line);
  maybe_print_line (line);
  fprintf (print.outf, "#ident %s\n", str->text);
  fprintf (print.outf, "#ident %s\n", str->text);
  print.src_line++;
  print.src_line++;
}
}
 
 
static void
static void
cb_define (cpp_reader *pfile, source_location line, cpp_hashnode *node)
cb_define (cpp_reader *pfile, source_location line, cpp_hashnode *node)
{
{
  maybe_print_line (line);
  maybe_print_line (line);
  fputs ("#define ", print.outf);
  fputs ("#define ", print.outf);
 
 
  /* 'D' is whole definition; 'N' is name only.  */
  /* 'D' is whole definition; 'N' is name only.  */
  if (flag_dump_macros == 'D')
  if (flag_dump_macros == 'D')
    fputs ((const char *) cpp_macro_definition (pfile, node),
    fputs ((const char *) cpp_macro_definition (pfile, node),
           print.outf);
           print.outf);
  else
  else
    fputs ((const char *) NODE_NAME (node), print.outf);
    fputs ((const char *) NODE_NAME (node), print.outf);
 
 
  putc ('\n', print.outf);
  putc ('\n', print.outf);
  if (linemap_lookup (&line_table, line)->to_line != 0)
  if (linemap_lookup (&line_table, line)->to_line != 0)
    print.src_line++;
    print.src_line++;
}
}
 
 
static void
static void
cb_undef (cpp_reader *pfile ATTRIBUTE_UNUSED, source_location line,
cb_undef (cpp_reader *pfile ATTRIBUTE_UNUSED, source_location line,
          cpp_hashnode *node)
          cpp_hashnode *node)
{
{
  maybe_print_line (line);
  maybe_print_line (line);
  fprintf (print.outf, "#undef %s\n", NODE_NAME (node));
  fprintf (print.outf, "#undef %s\n", NODE_NAME (node));
  print.src_line++;
  print.src_line++;
}
}
 
 
static void
static void
cb_include (cpp_reader *pfile ATTRIBUTE_UNUSED, source_location line,
cb_include (cpp_reader *pfile ATTRIBUTE_UNUSED, source_location line,
            const unsigned char *dir, const char *header, int angle_brackets,
            const unsigned char *dir, const char *header, int angle_brackets,
            const cpp_token **comments)
            const cpp_token **comments)
{
{
  maybe_print_line (line);
  maybe_print_line (line);
  if (angle_brackets)
  if (angle_brackets)
    fprintf (print.outf, "#%s <%s>", dir, header);
    fprintf (print.outf, "#%s <%s>", dir, header);
  else
  else
    fprintf (print.outf, "#%s \"%s\"", dir, header);
    fprintf (print.outf, "#%s \"%s\"", dir, header);
 
 
  if (comments != NULL)
  if (comments != NULL)
    {
    {
      while (*comments != NULL)
      while (*comments != NULL)
        {
        {
          if ((*comments)->flags & PREV_WHITE)
          if ((*comments)->flags & PREV_WHITE)
            putc (' ', print.outf);
            putc (' ', print.outf);
          cpp_output_token (*comments, print.outf);
          cpp_output_token (*comments, print.outf);
          ++comments;
          ++comments;
        }
        }
    }
    }
 
 
  putc ('\n', print.outf);
  putc ('\n', print.outf);
  print.src_line++;
  print.src_line++;
}
}
 
 
/* Callback called when -fworking-director and -E to emit working
/* Callback called when -fworking-director and -E to emit working
   directory in cpp output file.  */
   directory in cpp output file.  */
 
 
void
void
pp_dir_change (cpp_reader *pfile ATTRIBUTE_UNUSED, const char *dir)
pp_dir_change (cpp_reader *pfile ATTRIBUTE_UNUSED, const char *dir)
{
{
  size_t to_file_len = strlen (dir);
  size_t to_file_len = strlen (dir);
  unsigned char *to_file_quoted =
  unsigned char *to_file_quoted =
     (unsigned char *) alloca (to_file_len * 4 + 1);
     (unsigned char *) alloca (to_file_len * 4 + 1);
  unsigned char *p;
  unsigned char *p;
 
 
  /* cpp_quote_string does not nul-terminate, so we have to do it ourselves.  */
  /* cpp_quote_string does not nul-terminate, so we have to do it ourselves.  */
  p = cpp_quote_string (to_file_quoted, (unsigned char *) dir, to_file_len);
  p = cpp_quote_string (to_file_quoted, (unsigned char *) dir, to_file_len);
  *p = '\0';
  *p = '\0';
  fprintf (print.outf, "# 1 \"%s//\"\n", to_file_quoted);
  fprintf (print.outf, "# 1 \"%s//\"\n", to_file_quoted);
}
}
 
 
/* The file name, line number or system header flags have changed, as
/* The file name, line number or system header flags have changed, as
   described in MAP.  */
   described in MAP.  */
 
 
void
void
pp_file_change (const struct line_map *map)
pp_file_change (const struct line_map *map)
{
{
  const char *flags = "";
  const char *flags = "";
 
 
  if (flag_no_line_commands)
  if (flag_no_line_commands)
    return;
    return;
 
 
  if (map != NULL)
  if (map != NULL)
    {
    {
      if (print.first_time)
      if (print.first_time)
        {
        {
          /* Avoid printing foo.i when the main file is foo.c.  */
          /* Avoid printing foo.i when the main file is foo.c.  */
          if (!cpp_get_options (parse_in)->preprocessed)
          if (!cpp_get_options (parse_in)->preprocessed)
            print_line (map->start_location, flags);
            print_line (map->start_location, flags);
          print.first_time = 0;
          print.first_time = 0;
        }
        }
      else
      else
        {
        {
          /* Bring current file to correct line when entering a new file.  */
          /* Bring current file to correct line when entering a new file.  */
          if (map->reason == LC_ENTER)
          if (map->reason == LC_ENTER)
            {
            {
              const struct line_map *from = INCLUDED_FROM (&line_table, map);
              const struct line_map *from = INCLUDED_FROM (&line_table, map);
              maybe_print_line (LAST_SOURCE_LINE_LOCATION (from));
              maybe_print_line (LAST_SOURCE_LINE_LOCATION (from));
            }
            }
          if (map->reason == LC_ENTER)
          if (map->reason == LC_ENTER)
            flags = " 1";
            flags = " 1";
          else if (map->reason == LC_LEAVE)
          else if (map->reason == LC_LEAVE)
            flags = " 2";
            flags = " 2";
          print_line (map->start_location, flags);
          print_line (map->start_location, flags);
        }
        }
    }
    }
}
}
 
 
/* Copy a #pragma directive to the preprocessed output.  */
/* Copy a #pragma directive to the preprocessed output.  */
static void
static void
cb_def_pragma (cpp_reader *pfile, source_location line)
cb_def_pragma (cpp_reader *pfile, source_location line)
{
{
  maybe_print_line (line);
  maybe_print_line (line);
  fputs ("#pragma ", print.outf);
  fputs ("#pragma ", print.outf);
  cpp_output_line (pfile, print.outf);
  cpp_output_line (pfile, print.outf);
  print.src_line++;
  print.src_line++;
}
}
 
 
/* Dump out the hash table.  */
/* Dump out the hash table.  */
static int
static int
dump_macro (cpp_reader *pfile, cpp_hashnode *node, void *v ATTRIBUTE_UNUSED)
dump_macro (cpp_reader *pfile, cpp_hashnode *node, void *v ATTRIBUTE_UNUSED)
{
{
  if (node->type == NT_MACRO && !(node->flags & NODE_BUILTIN))
  if (node->type == NT_MACRO && !(node->flags & NODE_BUILTIN))
    {
    {
      fputs ("#define ", print.outf);
      fputs ("#define ", print.outf);
      fputs ((const char *) cpp_macro_definition (pfile, node),
      fputs ((const char *) cpp_macro_definition (pfile, node),
             print.outf);
             print.outf);
      putc ('\n', print.outf);
      putc ('\n', print.outf);
      print.src_line++;
      print.src_line++;
    }
    }
 
 
  return 1;
  return 1;
}
}
 
 
/* Load in the PCH file NAME, open on FD.  It was originally searched for
/* Load in the PCH file NAME, open on FD.  It was originally searched for
   by ORIG_NAME.  Also, print out a #include command so that the PCH
   by ORIG_NAME.  Also, print out a #include command so that the PCH
   file can be loaded when the preprocessed output is compiled.  */
   file can be loaded when the preprocessed output is compiled.  */
 
 
static void
static void
cb_read_pch (cpp_reader *pfile, const char *name,
cb_read_pch (cpp_reader *pfile, const char *name,
             int fd, const char *orig_name ATTRIBUTE_UNUSED)
             int fd, const char *orig_name ATTRIBUTE_UNUSED)
{
{
  c_common_read_pch (pfile, name, fd, orig_name);
  c_common_read_pch (pfile, name, fd, orig_name);
 
 
  fprintf (print.outf, "#pragma GCC pch_preprocess \"%s\"\n", name);
  fprintf (print.outf, "#pragma GCC pch_preprocess \"%s\"\n", name);
  print.src_line++;
  print.src_line++;
}
}
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.