2005-04-16 15:20:36 -07:00
/*
* Copyright ( C ) 2002 - 2005 Roman Zippel < zippel @ linux - m68k . org >
* Copyright ( C ) 2002 - 2005 Sam Ravnborg < sam @ ravnborg . org >
*
* Released under the terms of the GNU GPL v2 .0 .
*/
2011-06-01 16:00:46 -04:00
# include <stdarg.h>
2011-06-01 16:08:14 -04:00
# include <stdlib.h>
2005-04-16 15:20:36 -07:00
# include <string.h>
# include "lkc.h"
/* file already present in list? If not add it */
struct file * file_lookup ( const char * name )
{
struct file * file ;
2018-02-09 01:19:08 +09:00
char * file_name = sym_expand_string_value ( name ) ;
2005-04-16 15:20:36 -07:00
for ( file = file_list ; file ; file = file - > next ) {
2010-09-04 16:11:26 -04:00
if ( ! strcmp ( name , file - > name ) ) {
2018-02-09 01:19:08 +09:00
free ( file_name ) ;
2005-04-16 15:20:36 -07:00
return file ;
2010-09-04 16:11:26 -04:00
}
2005-04-16 15:20:36 -07:00
}
2012-11-06 14:32:08 +00:00
file = xmalloc ( sizeof ( * file ) ) ;
2005-04-16 15:20:36 -07:00
memset ( file , 0 , sizeof ( * file ) ) ;
2010-09-04 16:11:26 -04:00
file - > name = file_name ;
2005-04-16 15:20:36 -07:00
file - > next = file_list ;
file_list = file ;
return file ;
}
/* write a dependency file as used by kbuild to track dependencies */
int file_write_dep ( const char * name )
{
2008-01-14 04:50:54 +01:00
struct symbol * sym , * env_sym ;
struct expr * e ;
2005-04-16 15:20:36 -07:00
struct file * file ;
FILE * out ;
if ( ! name )
2005-12-26 23:34:03 +01:00
name = " .kconfig.d " ;
2005-04-16 15:20:36 -07:00
out = fopen ( " ..config.tmp " , " w " ) ;
if ( ! out )
return 1 ;
fprintf ( out , " deps_config := \\ \n " ) ;
for ( file = file_list ; file ; file = file - > next ) {
if ( file - > next )
fprintf ( out , " \t %s \\ \n " , file - > name ) ;
else
fprintf ( out , " \t %s \n " , file - > name ) ;
}
2009-05-18 01:36:54 +02:00
fprintf ( out , " \n %s: \\ \n "
" \t $(deps_config) \n \n " , conf_get_autoconfig_name ( ) ) ;
2008-01-14 04:50:54 +01:00
expr_list_for_each_sym ( sym_env_list , e , sym ) {
struct property * prop ;
const char * value ;
prop = sym_get_env_prop ( sym ) ;
env_sym = prop_get_symbol ( prop ) ;
if ( ! env_sym )
continue ;
value = getenv ( env_sym - > name ) ;
if ( ! value )
value = " " ;
fprintf ( out , " ifneq \" $(%s) \" \" %s \" \n " , env_sym - > name , value ) ;
2009-05-18 01:36:54 +02:00
fprintf ( out , " %s: FORCE \n " , conf_get_autoconfig_name ( ) ) ;
2008-01-14 04:50:54 +01:00
fprintf ( out , " endif \n " ) ;
}
fprintf ( out , " \n $(deps_config): ; \n " ) ;
2005-04-16 15:20:36 -07:00
fclose ( out ) ;
rename ( " ..config.tmp " , name ) ;
return 0 ;
}
2010-02-19 12:43:44 +01:00
/* Allocate initial growable string */
2005-04-16 15:20:36 -07:00
struct gstr str_new ( void )
{
struct gstr gs ;
2012-11-06 14:32:08 +00:00
gs . s = xmalloc ( sizeof ( char ) * 64 ) ;
2008-05-18 23:10:24 +02:00
gs . len = 64 ;
2009-12-20 00:29:49 -08:00
gs . max_width = 0 ;
2005-04-16 15:20:36 -07:00
strcpy ( gs . s , " \0 " ) ;
return gs ;
}
/* Free storage for growable string */
void str_free ( struct gstr * gs )
{
if ( gs - > s )
free ( gs - > s ) ;
gs - > s = NULL ;
gs - > len = 0 ;
}
/* Append to growable string */
void str_append ( struct gstr * gs , const char * s )
{
2007-09-19 21:23:09 +02:00
size_t l ;
if ( s ) {
l = strlen ( gs - > s ) + strlen ( s ) + 1 ;
if ( l > gs - > len ) {
2018-02-09 01:19:07 +09:00
gs - > s = xrealloc ( gs - > s , l ) ;
2007-09-19 21:23:09 +02:00
gs - > len = l ;
}
strcat ( gs - > s , s ) ;
2005-04-16 15:20:36 -07:00
}
}
/* Append printf formatted string to growable string */
void str_printf ( struct gstr * gs , const char * fmt , . . . )
{
va_list ap ;
char s [ 10000 ] ; /* big enough... */
va_start ( ap , fmt ) ;
vsnprintf ( s , sizeof ( s ) , fmt , ap ) ;
str_append ( gs , s ) ;
va_end ( ap ) ;
}
2006-01-03 13:27:11 +01:00
/* Retrieve value of growable string */
2005-04-16 15:20:36 -07:00
const char * str_get ( struct gstr * gs )
{
return gs - > s ;
}
2012-11-06 14:32:08 +00:00
void * xmalloc ( size_t size )
{
void * p = malloc ( size ) ;
if ( p )
return p ;
fprintf ( stderr , " Out of memory. \n " ) ;
exit ( 1 ) ;
}
void * xcalloc ( size_t nmemb , size_t size )
{
void * p = calloc ( nmemb , size ) ;
if ( p )
return p ;
fprintf ( stderr , " Out of memory. \n " ) ;
exit ( 1 ) ;
}
2018-02-09 01:19:07 +09:00
void * xrealloc ( void * p , size_t size )
{
p = realloc ( p , size ) ;
if ( p )
return p ;
fprintf ( stderr , " Out of memory. \n " ) ;
exit ( 1 ) ;
}