1 /* ar.c - Archive modify and extract.
2 Copyright 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000,
4 Free Software Foundation, Inc.
6 This file is part of GNU Binutils.
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
23 Bugs: should use getopt the way tar does (complete w/optional -) and
24 should have long options too. GNU ar used to check file against filesystem
25 in quick_update and replace operations (would check mtime). Doesn't warn
26 when name truncated. No way to specify pos_end. Error messages should be
30 #include "libiberty.h"
36 #include "filenames.h"
40 #define EXT_NAME_LEN 3 /* bufflen of addition to name if it's MS-DOS */
42 #define EXT_NAME_LEN 6 /* ditto for *NIX */
45 /* We need to open files in binary modes on system where that makes a
53 /* Kludge declaration from BFD! This is ugly! FIXME! XXX */
56 bfd_special_undocumented_glue
PARAMS ((bfd
* abfd
, const char *filename
));
58 /* Static declarations */
61 mri_emul
PARAMS ((void));
64 normalize
PARAMS ((const char *, bfd
*));
67 remove_output
PARAMS ((void));
70 map_over_members
PARAMS ((bfd
*, void (*)(bfd
*), char **, int));
73 print_contents
PARAMS ((bfd
* member
));
76 delete_members
PARAMS ((bfd
*, char **files_to_delete
));
80 do_quick_append
PARAMS ((const char *archive_filename
,
81 char **files_to_append
));
85 move_members
PARAMS ((bfd
*, char **files_to_move
));
88 replace_members
PARAMS ((bfd
*, char **files_to_replace
, boolean quick
));
91 print_descr
PARAMS ((bfd
* abfd
));
94 write_archive
PARAMS ((bfd
*));
97 ranlib_only
PARAMS ((const char *archname
));
100 ranlib_touch
PARAMS ((const char *archname
));
103 usage
PARAMS ((int));
105 /** Globals and flags */
109 /* This flag distinguishes between ar and ranlib:
110 1 means this is 'ranlib'; 0 means this is 'ar'.
111 -1 means if we should use argv[0] to decide. */
112 extern int is_ranlib
;
114 /* Nonzero means don't warn about creating the archive file if necessary. */
115 int silent_create
= 0;
117 /* Nonzero means describe each action performed. */
120 /* Nonzero means preserve dates of members when extracting them. */
121 int preserve_dates
= 0;
123 /* Nonzero means don't replace existing members whose dates are more recent
124 than the corresponding files. */
127 /* Controls the writing of an archive symbol table (in BSD: a __.SYMDEF
128 member). -1 means we've been explicitly asked to not write a symbol table;
129 +1 means we've been explictly asked to write it;
131 Traditionally, the default in BSD has been to not write the table.
132 However, for POSIX.2 compliance the default is now to write a symbol table
133 if any of the members are object files. */
136 /* Nonzero means it's the name of an existing member; position new or moved
137 files with respect to this one. */
138 char *posname
= NULL
;
140 /* Sez how to use `posname': pos_before means position before that member.
141 pos_after means position after that member. pos_end means always at end.
142 pos_default means default appropriately. For the latter two, `posname'
143 should also be zero. */
146 pos_default
, pos_before
, pos_after
, pos_end
147 } postype
= pos_default
;
150 get_pos_bfd
PARAMS ((bfd
**, enum pos
, const char *));
152 /* For extract/delete only. If COUNTED_NAME_MODE is true, we only
153 extract the COUNTED_NAME_COUNTER instance of that name. */
154 static boolean counted_name_mode
= 0;
155 static int counted_name_counter
= 0;
157 /* Whether to truncate names of files stored in the archive. */
158 static boolean ar_truncate
= false;
160 /* Whether to use a full file name match when searching an archive.
161 This is convenient for archives created by the Microsoft lib
163 static boolean full_pathname
= false;
170 interactive
= isatty (fileno (stdin
));
174 /* If COUNT is 0, then FUNCTION is called once on each entry. If nonzero,
175 COUNT is the length of the FILES chain; FUNCTION is called on each entry
176 whose name matches one in FILES. */
179 map_over_members (arch
, function
, files
, count
)
181 void (*function
) PARAMS ((bfd
*));
190 for (head
= arch
->next
; head
; head
= head
->next
)
198 /* This may appear to be a baroque way of accomplishing what we want.
199 However we have to iterate over the filenames in order to notice where
200 a filename is requested but does not exist in the archive. Ditto
201 mapping over each file each time -- we want to hack multiple
204 for (; count
> 0; files
++, count
--)
206 boolean found
= false;
209 for (head
= arch
->next
; head
; head
= head
->next
)
212 if (head
->filename
== NULL
)
214 /* Some archive formats don't get the filenames filled in
215 until the elements are opened. */
217 bfd_stat_arch_elt (head
, &buf
);
219 if ((head
->filename
!= NULL
) &&
220 (!FILENAME_CMP (normalize (*files
, arch
), head
->filename
)))
223 if (counted_name_mode
224 && match_count
!= counted_name_counter
)
226 /* Counting, and didn't match on count; go on to the
236 /* xgettext:c-format */
237 fprintf (stderr
, _("no entry %s in archive\n"), *files
);
241 boolean operation_alters_arch
= false;
249 s
= help
? stdout
: stderr
;
253 /* xgettext:c-format */
254 fprintf (s
, _("Usage: %s [-X32_64] [-]{dmpqrstx}[abcfilNoPsSuvV] [member-name] [count] archive-file file...\n"),
256 /* xgettext:c-format */
257 fprintf (s
, _(" %s -M [<mri-script]\n"), program_name
);
258 fprintf (s
, _(" commands:\n"));
259 fprintf (s
, _(" d - delete file(s) from the archive\n"));
260 fprintf (s
, _(" m[ab] - move file(s) in the archive\n"));
261 fprintf (s
, _(" p - print file(s) found in the archive\n"));
262 fprintf (s
, _(" q[f] - quick append file(s) to the archive\n"));
263 fprintf (s
, _(" r[ab][f][u] - replace existing or insert new file(s) into the archive\n"));
264 fprintf (s
, _(" t - display contents of archive\n"));
265 fprintf (s
, _(" x[o] - extract file(s) from the archive\n"));
266 fprintf (s
, _(" command specific modifiers:\n"));
267 fprintf (s
, _(" [a] - put file(s) after [member-name]\n"));
268 fprintf (s
, _(" [b] - put file(s) before [member-name] (same as [i])\n"));
269 fprintf (s
, _(" [N] - use instance [count] of name\n"));
270 fprintf (s
, _(" [f] - truncate inserted file names\n"));
271 fprintf (s
, _(" [P] - use full path names when matching\n"));
272 fprintf (s
, _(" [o] - preserve original dates\n"));
273 fprintf (s
, _(" [u] - only replace files that are newer than current archive contents\n"));
274 fprintf (s
, _(" generic modifiers:\n"));
275 fprintf (s
, _(" [c] - do not warn if the library had to be created\n"));
276 fprintf (s
, _(" [s] - create an archive index (cf. ranlib)\n"));
277 fprintf (s
, _(" [S] - do not build a symbol table\n"));
278 fprintf (s
, _(" [v] - be verbose\n"));
279 fprintf (s
, _(" [V] - display the version number\n"));
280 fprintf (s
, _(" [-X32_64] - (ignored)\n"));
283 /* xgettext:c-format */
284 fprintf (s
, _("Usage: %s [-vV] archive\n"), program_name
);
286 list_supported_targets (program_name
, stderr
);
289 fprintf (s
, _("Report bugs to %s\n"), REPORT_BUGS_TO
);
291 xexit (help
? 0 : 1);
294 /* Normalize a file name specified on the command line into a file
295 name which we will use in an archive. */
298 normalize (file
, abfd
)
302 const char *filename
;
307 filename
= strrchr (file
, '/');
308 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
310 /* We could have foo/bar\\baz, or foo\\bar, or d:bar. */
311 char *bslash
= strrchr (file
, '\\');
312 if (filename
== NULL
|| (bslash
!= NULL
&& bslash
> filename
))
314 if (filename
== NULL
&& file
[0] != '\0' && file
[1] == ':')
318 if (filename
!= (char *) NULL
)
325 && strlen (filename
) > abfd
->xvec
->ar_max_namelen
)
330 s
= (char *) xmalloc (abfd
->xvec
->ar_max_namelen
+ 1);
331 memcpy (s
, filename
, abfd
->xvec
->ar_max_namelen
);
332 s
[abfd
->xvec
->ar_max_namelen
] = '\0';
339 /* Remove any output file. This is only called via xatexit. */
341 static const char *output_filename
= NULL
;
342 static FILE *output_file
= NULL
;
343 static bfd
*output_bfd
= NULL
;
348 if (output_filename
!= NULL
)
350 if (output_bfd
!= NULL
&& output_bfd
->iostream
!= NULL
)
351 fclose ((FILE *) (output_bfd
->iostream
));
352 if (output_file
!= NULL
)
353 fclose (output_file
);
354 unlink (output_filename
);
358 /* The option parsing should be in its own function.
359 It will be when I have getopt working. */
361 int main
PARAMS ((int, char **));
372 none
= 0, delete, replace
, print_table
,
373 print_files
, extract
, move
, quick_append
378 char *inarch_filename
;
381 #if defined (HAVE_SETLOCALE) && defined (HAVE_LC_MESSAGES)
382 setlocale (LC_MESSAGES
, "");
384 #if defined (HAVE_SETLOCALE)
385 setlocale (LC_CTYPE
, "");
387 bindtextdomain (PACKAGE
, LOCALEDIR
);
388 textdomain (PACKAGE
);
390 program_name
= argv
[0];
391 xmalloc_set_program_name (program_name
);
397 temp
= strrchr (program_name
, '/');
398 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
400 /* We could have foo/bar\\baz, or foo\\bar, or d:bar. */
401 char *bslash
= strrchr (program_name
, '\\');
402 if (temp
== NULL
|| (bslash
!= NULL
&& bslash
> temp
))
404 if (temp
== NULL
&& program_name
[0] != '\0' && program_name
[1] == ':')
405 temp
= program_name
+ 1;
412 if (strlen (temp
) >= 6
413 && FILENAME_CMP (temp
+ strlen (temp
) - 6, "ranlib") == 0)
419 if (argc
> 1 && argv
[1][0] == '-')
421 if (strcmp (argv
[1], "--help") == 0)
423 else if (strcmp (argv
[1], "--version") == 0)
426 print_version ("ranlib");
428 print_version ("ar");
432 START_PROGRESS (program_name
, 0);
435 set_default_bfd_target ();
439 xatexit (remove_output
);
441 /* Ignored for (partial) AIX compatibility. On AIX,
442 the -X option can be used to ignore certain kinds
443 of object files in the archive (the 64-bit objects
444 or the 32-bit objects). GNU ar always looks at all
445 kinds of objects in an archive. */
446 while (argc
> 1 && strcmp (argv
[1], "-X32_64") == 0)
454 boolean touch
= false;
456 if (argc
< 2 || strcmp (argv
[1], "--help") == 0)
458 if (strcmp (argv
[1], "-V") == 0
459 || strcmp (argv
[1], "-v") == 0
460 || strncmp (argv
[1], "--v", 3) == 0)
461 print_version ("ranlib");
463 if (strcmp (argv
[1], "-t") == 0)
468 while (arg_index
< argc
)
471 ranlib_only (argv
[arg_index
]);
473 ranlib_touch (argv
[arg_index
]);
479 if (argc
== 2 && strcmp (argv
[1], "-M") == 0)
491 ++arg_ptr
; /* compatibility */
493 while ((c
= *arg_ptr
++) != '\0')
504 if (operation
!= none
)
505 fatal (_("two different operation options specified"));
510 operation_alters_arch
= true;
514 operation_alters_arch
= true;
517 operation
= print_files
;
520 operation
= quick_append
;
521 operation_alters_arch
= true;
525 operation_alters_arch
= true;
528 operation
= print_table
;
561 postype
= pos_before
;
564 postype
= pos_before
;
570 counted_name_mode
= true;
576 full_pathname
= true;
579 /* xgettext:c-format */
580 non_fatal (_("illegal option -- %c"), c
);
586 print_version ("ar");
599 /* We can't write an armap when using ar q, so just do ar r
601 if (operation
== quick_append
&& write_armap
)
604 if ((operation
== none
|| operation
== print_table
)
607 ranlib_only (argv
[2]);
611 if (operation
== none
)
612 fatal (_("no operation specified"));
614 if (newer_only
&& operation
!= replace
)
615 fatal (_("`u' is only meaningful with the `r' option."));
619 if (postype
!= pos_default
)
620 posname
= argv
[arg_index
++];
622 if (counted_name_mode
)
624 if (operation
!= extract
&& operation
!= delete)
625 fatal (_("`N' is only meaningful with the `x' and `d' options."));
626 counted_name_counter
= atoi (argv
[arg_index
++]);
627 if (counted_name_counter
<= 0)
628 fatal (_("Value for `N' must be positive."));
631 inarch_filename
= argv
[arg_index
++];
633 files
= arg_index
< argc
? argv
+ arg_index
: NULL
;
634 file_count
= argc
- arg_index
;
637 /* We don't use do_quick_append any more. Too many systems
638 expect ar to always rebuild the symbol table even when q is
641 /* We can't do a quick append if we need to construct an
642 extended name table, because do_quick_append won't be able to
643 rebuild the name table. Unfortunately, at this point we
644 don't actually know the maximum name length permitted by this
645 object file format. So, we guess. FIXME. */
646 if (operation
== quick_append
&& ! ar_truncate
)
650 for (chk
= files
; chk
!= NULL
&& *chk
!= '\0'; chk
++)
652 if (strlen (normalize (*chk
, (bfd
*) NULL
)) > 14)
660 if (operation
== quick_append
)
662 /* Note that quick appending to a non-existent archive creates it,
663 even if there are no files to append. */
664 do_quick_append (inarch_filename
, files
);
669 arch
= open_inarch (inarch_filename
,
670 files
== NULL
? (char *) NULL
: files
[0]);
675 map_over_members (arch
, print_descr
, files
, file_count
);
679 map_over_members (arch
, print_contents
, files
, file_count
);
683 map_over_members (arch
, extract_file
, files
, file_count
);
688 delete_members (arch
, files
);
690 output_filename
= NULL
;
695 move_members (arch
, files
);
697 output_filename
= NULL
;
702 if (files
!= NULL
|| write_armap
> 0)
703 replace_members (arch
, files
, operation
== quick_append
);
705 output_filename
= NULL
;
708 /* Shouldn't happen! */
710 /* xgettext:c-format */
711 fatal (_("internal error -- this option not implemented"));
715 END_PROGRESS (program_name
);
722 open_inarch (archive_filename
, file
)
723 const char *archive_filename
;
733 bfd_set_error (bfd_error_no_error
);
737 if (stat (archive_filename
, &sbuf
) != 0)
739 #if !defined(__GO32__) || defined(__DJGPP__)
741 /* FIXME: I don't understand why this fragment was ifndef'ed
742 away for __GO32__; perhaps it was in the days of DJGPP v1.x.
743 stat() works just fine in v2.x, so I think this should be
744 removed. For now, I enable it for DJGPP v2. -- EZ. */
746 /* KLUDGE ALERT! Temporary fix until I figger why
747 stat() is wrong ... think it's buried in GO32's IDT - Jax */
749 bfd_fatal (archive_filename
);
752 if (!operation_alters_arch
)
754 fprintf (stderr
, "%s: ", program_name
);
755 perror (archive_filename
);
760 /* Try to figure out the target to use for the archive from the
761 first object on the list. */
766 obj
= bfd_openr (file
, NULL
);
769 if (bfd_check_format (obj
, bfd_object
))
770 target
= bfd_get_target (obj
);
771 (void) bfd_close (obj
);
775 /* Create an empty archive. */
776 arch
= bfd_openw (archive_filename
, target
);
778 || ! bfd_set_format (arch
, bfd_archive
)
779 || ! bfd_close (arch
))
780 bfd_fatal (archive_filename
);
782 /* If we die creating a new archive, don't leave it around. */
783 output_filename
= archive_filename
;
786 arch
= bfd_openr (archive_filename
, target
);
790 bfd_fatal (archive_filename
);
793 if (! bfd_check_format_matches (arch
, bfd_archive
, &matching
))
795 bfd_nonfatal (archive_filename
);
796 if (bfd_get_error () == bfd_error_file_ambiguously_recognized
)
798 list_matching_formats (matching
);
804 last_one
= &(arch
->next
);
805 /* Read all the contents right away, regardless. */
806 for (next_one
= bfd_openr_next_archived_file (arch
, NULL
);
808 next_one
= bfd_openr_next_archived_file (arch
, next_one
))
811 *last_one
= next_one
;
812 last_one
= &next_one
->next
;
814 *last_one
= (bfd
*) NULL
;
815 if (bfd_get_error () != bfd_error_no_more_archived_files
)
821 print_contents (abfd
)
825 char *cbuf
= xmalloc (BUFSIZE
);
828 if (bfd_stat_arch_elt (abfd
, &buf
) != 0)
829 /* xgettext:c-format */
830 fatal (_("internal stat error on %s"), bfd_get_filename (abfd
));
833 /* xgettext:c-format */
834 printf (_("\n<member %s>\n\n"), bfd_get_filename (abfd
));
836 bfd_seek (abfd
, (file_ptr
) 0, SEEK_SET
);
839 while (ncopied
< size
)
843 int tocopy
= size
- ncopied
;
844 if (tocopy
> BUFSIZE
)
847 nread
= bfd_bread (cbuf
, (bfd_size_type
) tocopy
, abfd
);
849 /* xgettext:c-format */
850 fatal (_("%s is not a valid archive"),
851 bfd_get_filename (bfd_my_archive (abfd
)));
852 fwrite (cbuf
, 1, nread
, stdout
);
858 /* Extract a member of the archive into its own file.
860 We defer opening the new file until after we have read a BUFSIZ chunk of the
861 old one, since we know we have just read the archive header for the old
862 one. Since most members are shorter than BUFSIZ, this means we will read
863 the old header, read the old data, write a new inode for the new file, and
864 write the new data, and be done. This 'optimization' is what comes from
865 sitting next to a bare disk and hearing it every time it seeks. -- Gnu
873 char *cbuf
= xmalloc (BUFSIZE
);
879 if (bfd_stat_arch_elt (abfd
, &buf
) != 0)
880 /* xgettext:c-format */
881 fatal (_("internal stat error on %s"), bfd_get_filename (abfd
));
885 /* xgettext:c-format */
886 fatal (_("stat returns negative size for %s"), bfd_get_filename (abfd
));
889 printf ("x - %s\n", bfd_get_filename (abfd
));
891 bfd_seek (abfd
, (file_ptr
) 0, SEEK_SET
);
896 /* Seems like an abstraction violation, eh? Well it's OK! */
897 output_filename
= bfd_get_filename (abfd
);
899 ostream
= fopen (bfd_get_filename (abfd
), FOPEN_WB
);
902 perror (bfd_get_filename (abfd
));
906 output_file
= ostream
;
909 while (ncopied
< size
)
911 tocopy
= size
- ncopied
;
912 if (tocopy
> BUFSIZE
)
915 nread
= bfd_bread (cbuf
, (bfd_size_type
) tocopy
, abfd
);
917 /* xgettext:c-format */
918 fatal (_("%s is not a valid archive"),
919 bfd_get_filename (bfd_my_archive (abfd
)));
921 /* See comment above; this saves disk arm motion */
924 /* Seems like an abstraction violation, eh? Well it's OK! */
925 output_filename
= bfd_get_filename (abfd
);
927 ostream
= fopen (bfd_get_filename (abfd
), FOPEN_WB
);
930 perror (bfd_get_filename (abfd
));
934 output_file
= ostream
;
936 fwrite (cbuf
, 1, nread
, ostream
);
944 output_filename
= NULL
;
946 chmod (bfd_get_filename (abfd
), buf
.st_mode
);
949 set_times (bfd_get_filename (abfd
), &buf
);
956 /* We don't use this anymore. Too many systems expect ar to rebuild
957 the symbol table even when q is used. */
959 /* Just do it quickly; don't worry about dups, armap, or anything like that */
962 do_quick_append (archive_filename
, files_to_append
)
963 const char *archive_filename
;
964 char **files_to_append
;
967 char *buf
= xmalloc (BUFSIZE
);
968 long tocopy
, thistime
;
971 boolean newfile
= false;
972 bfd_set_error (bfd_error_no_error
);
974 if (stat (archive_filename
, &sbuf
) != 0)
977 #if !defined(__GO32__) || defined(__DJGPP__)
979 /* FIXME: I don't understand why this fragment was ifndef'ed
980 away for __GO32__; perhaps it was in the days of DJGPP v1.x.
981 stat() works just fine in v2.x, so I think this should be
982 removed. For now, I enable it for DJGPP v2.
984 (And yes, I know this is all unused, but somebody, someday,
985 might wish to resurrect this again... -- EZ. */
987 /* KLUDGE ALERT! Temporary fix until I figger why
988 stat() is wrong ... think it's buried in GO32's IDT - Jax */
991 bfd_fatal (archive_filename
);
997 ofile
= fopen (archive_filename
, FOPEN_AUB
);
1000 perror (program_name
);
1004 temp
= bfd_openr (archive_filename
, NULL
);
1007 bfd_fatal (archive_filename
);
1009 if (newfile
== false)
1011 if (bfd_check_format (temp
, bfd_archive
) != true)
1012 /* xgettext:c-format */
1013 fatal (_("%s is not an archive"), archive_filename
);
1017 fwrite (ARMAG
, 1, SARMAG
, ofile
);
1019 /* xgettext:c-format */
1020 non_fatal (_("creating %s"), archive_filename
);
1024 temp
->flags
|= BFD_TRADITIONAL_FORMAT
;
1026 /* assume it's an achive, go straight to the end, sans $200 */
1027 fseek (ofile
, 0, 2);
1029 for (; files_to_append
&& *files_to_append
; ++files_to_append
)
1031 struct ar_hdr
*hdr
= bfd_special_undocumented_glue (temp
, *files_to_append
);
1034 bfd_fatal (*files_to_append
);
1037 BFD_SEND (temp
, _bfd_truncate_arname
, (temp
, *files_to_append
, (char *) hdr
));
1039 ifile
= fopen (*files_to_append
, FOPEN_RB
);
1042 bfd_nonfatal (*files_to_append
);
1045 if (stat (*files_to_append
, &sbuf
) != 0)
1047 bfd_nonfatal (*files_to_append
);
1050 tocopy
= sbuf
.st_size
;
1052 /* XXX should do error-checking! */
1053 fwrite (hdr
, 1, sizeof (struct ar_hdr
), ofile
);
1058 if (thistime
> BUFSIZE
)
1060 fread (buf
, 1, thistime
, ifile
);
1061 fwrite (buf
, 1, thistime
, ofile
);
1065 if ((sbuf
.st_size
% 2) == 1)
1066 putc ('\012', ofile
);
1076 write_archive (iarch
)
1080 char *old_name
, *new_name
;
1081 bfd
*contents_head
= iarch
->next
;
1083 old_name
= xmalloc (strlen (bfd_get_filename (iarch
)) + 1);
1084 strcpy (old_name
, bfd_get_filename (iarch
));
1085 new_name
= make_tempname (old_name
);
1087 output_filename
= new_name
;
1089 obfd
= bfd_openw (new_name
, bfd_get_target (iarch
));
1092 bfd_fatal (old_name
);
1096 bfd_set_format (obfd
, bfd_archive
);
1098 /* Request writing the archive symbol table unless we've
1099 been explicitly requested not to. */
1100 obfd
->has_armap
= write_armap
>= 0;
1104 /* This should really use bfd_set_file_flags, but that rejects
1106 obfd
->flags
|= BFD_TRADITIONAL_FORMAT
;
1109 if (bfd_set_archive_head (obfd
, contents_head
) != true)
1110 bfd_fatal (old_name
);
1112 if (!bfd_close (obfd
))
1113 bfd_fatal (old_name
);
1116 output_filename
= NULL
;
1118 /* We don't care if this fails; we might be creating the archive. */
1121 if (smart_rename (new_name
, old_name
, 0) != 0)
1125 /* Return a pointer to the pointer to the entry which should be rplacd'd
1126 into when altering. DEFAULT_POS should be how to interpret pos_default,
1127 and should be a pos value. */
1130 get_pos_bfd (contents
, default_pos
, default_posname
)
1132 enum pos default_pos
;
1133 const char *default_posname
;
1135 bfd
**after_bfd
= contents
;
1137 const char *realposname
;
1139 if (postype
== pos_default
)
1141 realpos
= default_pos
;
1142 realposname
= default_posname
;
1147 realposname
= posname
;
1150 if (realpos
== pos_end
)
1153 after_bfd
= &((*after_bfd
)->next
);
1157 for (; *after_bfd
; after_bfd
= &(*after_bfd
)->next
)
1158 if (FILENAME_CMP ((*after_bfd
)->filename
, realposname
) == 0)
1160 if (realpos
== pos_after
)
1161 after_bfd
= &(*after_bfd
)->next
;
1169 delete_members (arch
, files_to_delete
)
1171 char **files_to_delete
;
1173 bfd
**current_ptr_ptr
;
1175 boolean something_changed
= false;
1178 for (; *files_to_delete
!= NULL
; ++files_to_delete
)
1180 /* In a.out systems, the armap is optional. It's also called
1181 __.SYMDEF. So if the user asked to delete it, we should remember
1182 that fact. This isn't quite right for COFF systems (where
1183 __.SYMDEF might be regular member), but it's very unlikely
1184 to be a problem. FIXME */
1186 if (!strcmp (*files_to_delete
, "__.SYMDEF"))
1188 arch
->has_armap
= false;
1195 current_ptr_ptr
= &(arch
->next
);
1196 while (*current_ptr_ptr
)
1198 if (FILENAME_CMP (normalize (*files_to_delete
, arch
),
1199 (*current_ptr_ptr
)->filename
) == 0)
1202 if (counted_name_mode
1203 && match_count
!= counted_name_counter
)
1205 /* Counting, and didn't match on count; go on to the
1211 something_changed
= true;
1215 *current_ptr_ptr
= ((*current_ptr_ptr
)->next
);
1220 current_ptr_ptr
= &((*current_ptr_ptr
)->next
);
1223 if (verbose
&& found
== false)
1225 /* xgettext:c-format */
1226 printf (_("No member named `%s'\n"), *files_to_delete
);
1232 if (something_changed
== true)
1233 write_archive (arch
);
1235 output_filename
= NULL
;
1239 /* Reposition existing members within an archive */
1242 move_members (arch
, files_to_move
)
1244 char **files_to_move
;
1246 bfd
**after_bfd
; /* New entries go after this one */
1247 bfd
**current_ptr_ptr
; /* cdr pointer into contents */
1249 for (; *files_to_move
; ++files_to_move
)
1251 current_ptr_ptr
= &(arch
->next
);
1252 while (*current_ptr_ptr
)
1254 bfd
*current_ptr
= *current_ptr_ptr
;
1255 if (FILENAME_CMP (normalize (*files_to_move
, arch
),
1256 current_ptr
->filename
) == 0)
1258 /* Move this file to the end of the list - first cut from
1261 *current_ptr_ptr
= current_ptr
->next
;
1263 /* Now glue to end */
1264 after_bfd
= get_pos_bfd (&arch
->next
, pos_end
, NULL
);
1266 *after_bfd
= current_ptr
;
1267 current_ptr
->next
= link
;
1270 printf ("m - %s\n", *files_to_move
);
1275 current_ptr_ptr
= &((*current_ptr_ptr
)->next
);
1277 /* xgettext:c-format */
1278 fatal (_("no entry %s in archive %s!"), *files_to_move
, arch
->filename
);
1283 write_archive (arch
);
1286 /* Ought to default to replacing in place, but this is existing practice! */
1289 replace_members (arch
, files_to_move
, quick
)
1291 char **files_to_move
;
1294 boolean changed
= false;
1295 bfd
**after_bfd
; /* New entries go after this one */
1300 while (files_to_move
&& *files_to_move
)
1304 current_ptr
= &arch
->next
;
1305 while (*current_ptr
)
1307 current
= *current_ptr
;
1309 /* For compatibility with existing ar programs, we
1310 permit the same file to be added multiple times. */
1311 if (FILENAME_CMP (normalize (*files_to_move
, arch
),
1312 normalize (current
->filename
, arch
)) == 0
1313 && current
->arelt_data
!= NULL
)
1317 struct stat fsbuf
, asbuf
;
1319 if (stat (*files_to_move
, &fsbuf
) != 0)
1321 if (errno
!= ENOENT
)
1322 bfd_fatal (*files_to_move
);
1325 if (bfd_stat_arch_elt (current
, &asbuf
) != 0)
1326 /* xgettext:c-format */
1327 fatal (_("internal stat error on %s"), current
->filename
);
1329 if (fsbuf
.st_mtime
<= asbuf
.st_mtime
)
1333 after_bfd
= get_pos_bfd (&arch
->next
, pos_after
,
1337 *after_bfd
= bfd_openr (*files_to_move
, NULL
);
1338 if (*after_bfd
== (bfd
*) NULL
)
1340 bfd_fatal (*files_to_move
);
1342 (*after_bfd
)->next
= temp
;
1344 /* snip out this entry from the chain */
1345 *current_ptr
= (*current_ptr
)->next
;
1349 printf ("r - %s\n", *files_to_move
);
1356 current_ptr
= &(current
->next
);
1360 /* Add to the end of the archive. */
1362 after_bfd
= get_pos_bfd (&arch
->next
, pos_end
, NULL
);
1364 *after_bfd
= bfd_openr (*files_to_move
, NULL
);
1365 if (*after_bfd
== (bfd
*) NULL
)
1367 bfd_fatal (*files_to_move
);
1371 printf ("a - %s\n", *files_to_move
);
1374 (*after_bfd
)->next
= temp
;
1384 write_archive (arch
);
1386 output_filename
= NULL
;
1390 ranlib_only (archname
)
1391 const char *archname
;
1396 arch
= open_inarch (archname
, (char *) NULL
);
1399 write_archive (arch
);
1402 /* Update the timestamp of the symbol map of an archive. */
1405 ranlib_touch (archname
)
1406 const char *archname
;
1409 /* I don't think updating works on go32. */
1410 ranlib_only (archname
);
1416 f
= open (archname
, O_RDWR
| O_BINARY
, 0);
1419 bfd_set_error (bfd_error_system_call
);
1420 bfd_fatal (archname
);
1423 arch
= bfd_fdopenr (archname
, (const char *) NULL
, f
);
1425 bfd_fatal (archname
);
1426 if (! bfd_check_format_matches (arch
, bfd_archive
, &matching
))
1428 bfd_nonfatal (archname
);
1429 if (bfd_get_error () == bfd_error_file_ambiguously_recognized
)
1431 list_matching_formats (matching
);
1437 if (! bfd_has_map (arch
))
1438 /* xgettext:c-format */
1439 fatal (_("%s: no archive map to update"), archname
);
1441 bfd_update_armap_timestamp (arch
);
1443 if (! bfd_close (arch
))
1444 bfd_fatal (archname
);
1448 /* Things which are interesting to map over all or some of the files: */
1454 print_arelt_descr (stdout
, abfd
, verbose
);