Browse Source

NSM_Proxy: save options upon 'start'.

tags/non-daw-v1.2.0
Jonathan Moore Liles 12 years ago
parent
commit
3b8991c54c
1 changed files with 21 additions and 18 deletions
  1. +21
    -18
      session-manager/src/nsm-proxy.C

+ 21
- 18
session-manager/src/nsm-proxy.C View File

@@ -51,6 +51,7 @@ static char *nsm_display_name;

#define CONFIG_FILE_NAME "nsm-proxy.config"


class NSM_Proxy {

char *_label;
@@ -97,10 +98,18 @@ public:

bool start ( void )
{
dump( project_file );

if ( _pid )
/* already running */
return true;

if ( !_executable )
{
WARNING( "Executable is null." );
return false;
}

int pid;
if ( ! (pid = fork()) )
{
@@ -121,7 +130,6 @@ public:
setenv( "NSM_SESSION_NAME", nsm_display_name, 1 );
unsetenv( "NSM_URL" );

if ( -1 == execvp( "/bin/sh", args ) )
{
WARNING( "Error starting process: %s", strerror( errno ) );
@@ -159,9 +167,14 @@ public:


bool dump ( const char *path )
{
FILE *fp = fopen( path, "w" );
{
char *fname;
asprintf( &fname, "%s/%s", path, CONFIG_FILE_NAME );
FILE *fp = fopen( fname, "w" );

free( fname );
if ( !fp )
{
WARNING( "Error opening file for saving: %s", strerror( errno ) );
@@ -246,6 +259,11 @@ public:

NSM_Proxy *nsm_proxy;

bool
snapshot ( const char *file )
{
return nsm_proxy->dump(file);
}
void
announce ( const char *nsm_url, const char *client_name, const char *process_name )
{
@@ -266,21 +284,6 @@ announce ( const char *nsm_url, const char *client_name, const char *process_nam
lo_address_free( to );
}

bool
snapshot ( const char *file )
{
/* mkdir( file, 0777 ); */
char *path;
asprintf( &path, "%s/%s", file, CONFIG_FILE_NAME );

bool r = nsm_proxy->dump( path );

free( path );

return r;
}

bool
open ( const char *file )
{


Loading…
Cancel
Save