/mandos/trunk

To get this branch, use:
bzr branch http://bzr.recompile.se/loggerhead/mandos/trunk

« back to all changes in this revision

Viewing changes to plugins.d/plymouth.c

  • Committer: Teddy Hogeborn
  • Date: 2010-10-11 18:17:25 UTC
  • mfrom: (237.4.12 mandos-release)
  • Revision ID: teddy@fukt.bsnet.se-20101011181725-ud266ctjhu3s730q
Merge from release branch.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
/*  -*- coding: utf-8 -*- */
2
2
/*
3
 
 * Plymouth - Read a password from Plymouth and output it
 
3
 * Usplash - Read a password from usplash and output it
4
4
 * 
5
5
 * Copyright © 2010 Teddy Hogeborn
6
6
 * Copyright © 2010 Björn Påhlsson
76
76
  char *prompt;
77
77
  const char *const cryptsource = getenv("cryptsource");
78
78
  const char *const crypttarget = getenv("crypttarget");
79
 
  const char prompt_start[] = "Unlocking the disk";
80
 
  const char prompt_end[] = "Enter passphrase";
 
79
  const char prompt_start[] = "Enter passphrase to unlock the disk";
81
80
  
82
81
  if(cryptsource == NULL){
83
82
    if(crypttarget == NULL){
84
 
      ret = asprintf(&prompt, "%s\n%s", prompt_start, prompt_end);
 
83
      ret = asprintf(&prompt, "%s: ", prompt_start);
85
84
    } else {
86
 
      ret = asprintf(&prompt, "%s (%s)\n%s", prompt_start,
87
 
                     crypttarget, prompt_end);
 
85
      ret = asprintf(&prompt, "%s (%s): ", prompt_start,
 
86
                     crypttarget);
88
87
    }
89
88
  } else {
90
89
    if(crypttarget == NULL){
91
 
      ret = asprintf(&prompt, "%s %s\n%s", prompt_start, cryptsource,
92
 
                     prompt_end);
 
90
      ret = asprintf(&prompt, "%s %s: ", prompt_start, cryptsource);
93
91
    } else {
94
 
      ret = asprintf(&prompt, "%s %s (%s)\n%s", prompt_start,
95
 
                     cryptsource, crypttarget, prompt_end);
 
92
      ret = asprintf(&prompt, "%s %s (%s): ", prompt_start,
 
93
                     cryptsource, crypttarget);
96
94
    }
97
95
  }
98
96
  if(ret == -1){
144
142
        _exit(EX_OSERR);
145
143
      }
146
144
    }
147
 
    
 
145
 
148
146
    char **new_argv = NULL;
149
 
    char **tmp;
 
147
    char *tmp;
150
148
    int i = 0;
151
 
    for (; argv[i]!=NULL; i++){
 
149
    for (; argv[i]!=(char *)NULL; i++){
152
150
      tmp = realloc(new_argv, sizeof(const char *) * ((size_t)i + 1));
153
151
      if (tmp == NULL){
154
152
        error(0, errno, "realloc");
155
153
        free(new_argv);
156
154
        _exit(EX_OSERR);
157
155
      }
158
 
      new_argv = tmp;
 
156
      new_argv = (char **)tmp;
159
157
      new_argv[i] = strdup(argv[i]);
160
158
    }
161
 
    new_argv[i] = NULL;
 
159
    new_argv[i] = (char *) NULL;
162
160
    
163
161
    execv(path, (char *const *)new_argv);
164
162
    error(0, errno, "execv");