mirror of
				https://gitlab.freedesktop.org/pipewire/pipewire.git
				synced 2025-11-03 09:01:54 -05:00 
			
		
		
		
	Remove glib from config loading
This commit is contained in:
		
							parent
							
								
									1a48bccca0
								
							
						
					
					
						commit
						b9e2b1c0e3
					
				
					 5 changed files with 67 additions and 23 deletions
				
			
		| 
						 | 
				
			
			@ -48,6 +48,11 @@ typedef struct {
 | 
			
		|||
  size_t size;
 | 
			
		||||
} PinosTransportInfo;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * PinosTransportArea:
 | 
			
		||||
 *
 | 
			
		||||
 * Shared structure between client and server
 | 
			
		||||
 */
 | 
			
		||||
struct _PinosTransportArea {
 | 
			
		||||
  unsigned int       max_inputs;
 | 
			
		||||
  unsigned int       n_inputs;
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -81,3 +81,23 @@ pinos_free_strv (char **str)
 | 
			
		|||
    free (str[i]);
 | 
			
		||||
  free (str);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
char *
 | 
			
		||||
pinos_strip (char       *str,
 | 
			
		||||
             const char *whitespace)
 | 
			
		||||
{
 | 
			
		||||
  char *e, *l = NULL;
 | 
			
		||||
 | 
			
		||||
  str += strspn (str, whitespace);
 | 
			
		||||
 | 
			
		||||
  for (e = str; *e; e++)
 | 
			
		||||
     if (!strchr (whitespace, *e))
 | 
			
		||||
         l = e;
 | 
			
		||||
 | 
			
		||||
  if (l)
 | 
			
		||||
    *(l+1) = '\0';
 | 
			
		||||
  else
 | 
			
		||||
    *str = '\0';
 | 
			
		||||
 | 
			
		||||
  return str;
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -36,6 +36,9 @@ char **      pinos_split_strv   (const char *str,
 | 
			
		|||
                                 int        *n_tokens);
 | 
			
		||||
void         pinos_free_strv    (char **str);
 | 
			
		||||
 | 
			
		||||
char *       pinos_strip        (char       *str,
 | 
			
		||||
                                 const char *whitespace);
 | 
			
		||||
 | 
			
		||||
#ifdef __cplusplus
 | 
			
		||||
}  /* extern "C" */
 | 
			
		||||
#endif
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -23,6 +23,7 @@
 | 
			
		|||
#endif
 | 
			
		||||
 | 
			
		||||
#include <string.h>
 | 
			
		||||
#include <errno.h>
 | 
			
		||||
 | 
			
		||||
#include <pinos/client/pinos.h>
 | 
			
		||||
#include <pinos/server/command.h>
 | 
			
		||||
| 
						 | 
				
			
			@ -48,7 +49,7 @@ parse_line (PinosDaemonConfig  *config,
 | 
			
		|||
    *p = '\0';
 | 
			
		||||
 | 
			
		||||
  /* remove whitespaces */
 | 
			
		||||
  g_strstrip (line);
 | 
			
		||||
  pinos_strip (line, "\n\r \t");
 | 
			
		||||
 | 
			
		||||
  if (*line == '\0') /* empty line */
 | 
			
		||||
    return true;
 | 
			
		||||
| 
						 | 
				
			
			@ -112,29 +113,42 @@ pinos_daemon_config_load_file (PinosDaemonConfig *config,
 | 
			
		|||
                               const char        *filename,
 | 
			
		||||
                               char             **err)
 | 
			
		||||
{
 | 
			
		||||
  char *data;
 | 
			
		||||
  char **lines;
 | 
			
		||||
  bool ret = true;
 | 
			
		||||
  unsigned int i;
 | 
			
		||||
  int n_lines;
 | 
			
		||||
  unsigned int line;
 | 
			
		||||
  FILE *f;
 | 
			
		||||
  char buf[4096];
 | 
			
		||||
 | 
			
		||||
  pinos_log_debug ("deamon-config %p loading file %s", config, filename);
 | 
			
		||||
  pinos_log_debug ("deamon-config %p: loading configuration file '%s'", config, filename);
 | 
			
		||||
 | 
			
		||||
  if (!g_file_get_contents (filename, &data, NULL, NULL))
 | 
			
		||||
    return false;
 | 
			
		||||
  if ((f = fopen (filename, "r")) == NULL) {
 | 
			
		||||
    asprintf (err, "failed to open configuration file '%s': %s", filename, strerror (errno));
 | 
			
		||||
    goto open_error;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  lines = pinos_split_strv (data, "\n", 0, &n_lines);
 | 
			
		||||
  for (i = 0; lines[i] != NULL; i++) {
 | 
			
		||||
    if (!parse_line (config, filename, lines[i], i+1, err)) {
 | 
			
		||||
      ret = false;
 | 
			
		||||
  line = 0;
 | 
			
		||||
 | 
			
		||||
  while (!feof(f)) {
 | 
			
		||||
    if (!fgets(buf, sizeof (buf), f)) {
 | 
			
		||||
      if (feof(f))
 | 
			
		||||
        break;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
      asprintf (err, "failed to read configuration file '%s': %s", filename, strerror (errno));
 | 
			
		||||
      goto read_error;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  pinos_free_strv (lines);
 | 
			
		||||
  free (data);
 | 
			
		||||
    line++;
 | 
			
		||||
 | 
			
		||||
  return ret;
 | 
			
		||||
    if (!parse_line (config, filename, buf, line, err))
 | 
			
		||||
      goto parse_failed;
 | 
			
		||||
  }
 | 
			
		||||
  fclose (f);
 | 
			
		||||
 | 
			
		||||
  return true;
 | 
			
		||||
 | 
			
		||||
parse_failed:
 | 
			
		||||
read_error:
 | 
			
		||||
  fclose (f);
 | 
			
		||||
open_error:
 | 
			
		||||
  return false;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -21,9 +21,9 @@
 | 
			
		|||
#ifndef __PINOS_DAEMON_CONFIG_H__
 | 
			
		||||
#define __PINOS_DAEMON_CONFIG_H__
 | 
			
		||||
 | 
			
		||||
#include <glib-object.h>
 | 
			
		||||
 | 
			
		||||
G_BEGIN_DECLS
 | 
			
		||||
#ifdef __cplusplus
 | 
			
		||||
extern "C" {
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#include <pinos/server/daemon.h>
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -42,7 +42,9 @@ bool                pinos_daemon_config_load          (PinosDaemonConfig  *confi
 | 
			
		|||
                                                       char              **err);
 | 
			
		||||
bool                pinos_daemon_config_run_commands  (PinosDaemonConfig  *config,
 | 
			
		||||
                                                       PinosDaemon        *daemon);
 | 
			
		||||
#ifdef __cplusplus
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
G_END_DECLS
 | 
			
		||||
 | 
			
		||||
#endif /* __PINOS_DAEMON_CONFIG_H__ */
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue