diff options
| author | Mattias Andrée <maandree@operamail.com> | 2014-01-26 09:55:39 +0100 | 
|---|---|---|
| committer | Mattias Andrée <maandree@operamail.com> | 2014-01-26 09:55:39 +0100 | 
| commit | 4ae7d9cd14b3c80b7e45e27d1d74f01497a0ec01 (patch) | |
| tree | 6e975a429be5dfb32271fb9e92cd4c1ec59c1b84 | |
| parent | some small code improvements + add --get (diff) | |
| download | adjbacklight-4ae7d9cd14b3c80b7e45e27d1d74f01497a0ec01.tar.gz adjbacklight-4ae7d9cd14b3c80b7e45e27d1d74f01497a0ec01.tar.bz2 adjbacklight-4ae7d9cd14b3c80b7e45e27d1d74f01497a0ec01.tar.xz | |
implement --set
Signed-off-by: Mattias Andrée <maandree@operamail.com>
Diffstat (limited to '')
| -rw-r--r-- | src/adjbacklight.c | 93 | 
1 files changed, 93 insertions, 0 deletions
| diff --git a/src/adjbacklight.c b/src/adjbacklight.c index 4bf50ac..289401c 100644 --- a/src/adjbacklight.c +++ b/src/adjbacklight.c @@ -100,6 +100,14 @@ static void adjust(int cols, const char* device);  static float getbrightness(const char* device);  /** + * Sets the current backlight setting on a device + *  + * @param  device      The device from which to get backlight + * @param  adjustment  The adjustment to make + */ +static void setbrightness(const char* device, const char* adjustment); + +/**   * Read a file   *    * @param   output  Buffer to store the file's content in @@ -395,6 +403,8 @@ int main(int argc, char** argv)  		      nbrightness++;  		    }  		} +	      else if (set) +		setbrightness(device, set);  	      else  		adjust(cols, device);  	    } @@ -422,6 +432,8 @@ int main(int argc, char** argv)  				nbrightness++;  			      }  			  } +			else if (set) +			  setbrightness(device, set);  			else  			  adjust(cols, device);  		      } @@ -598,6 +610,87 @@ static float getbrightness(const char* device)  /** + * Sets the current backlight setting on a device + *  + * @param  device      The device from which to get backlight + * @param  adjustment  The adjustment to make + */ +static void setbrightness(const char* device, const char* adjustment) +{ +  int min, max, cur, i, adj; +  size_t lendir; +  char* dir = alloca(PATH_MAX * sizeof(char)); +  char* buf = alloca(256); +  int act = 0, integer = 0, decimal = 0, p = 0, d = 0; +   +  *dir = 0; +  dir = strcat(dir, "/sys/class/backlight/"); +  dir = strcat(dir, device); +  dir = strcat(dir, "/"); +  lendir = strlen(dir); +   +  /* Get brightness parameters */ +  min = 0; +  if (readfile(buf, strcat(dir, "max_brightness"))) +    return; +  max = atoi(unnl(buf)); +  *(dir + lendir) = 0; +  if (readfile(buf, strcat(dir, "brightness"))) +    return; +  cur = atoi(unnl(buf)); +   +  if (max <= min) +    return; /* what the buck */ +   +  /* Read -/+/= head */ +  if (*adjustment == '-') +    act = -1; +  else if (*adjustment == '+') +    act = 1; +  else if (*adjustment != '=') +    adjustment--; +  adjustment++; +   +  /* Parse numerical part */ +  for (; *adjustment && (*adjustment != '%'); adjustment++) +    if (*adjustment == '.') +      d = 1; +    else if (d) +      { +	if ((d * 10 < 0) || (decimal * 10 + 9 < 0)) /* stop if the precision is too high */ +	  continue; +	d *= 10; +	decimal *= 10; +	decimal += (*adjustment) - '0'; +      } +    else +      { +	integer *= 10; +	integer -= (*adjustment) - '0'; +      } +   +  /* Count number of p:s */ +  while (*adjustment++) +    p++; +   +  /* Calculate value to send */ +  if (p == 0) +    adj = (int)((double)decimal / (double)d + 0.5d) - integer; +  else if (p == 1) +    adj = (int)(((double)decimal / (double)d - (double)integer) * (double)(max - min)); +  else +    adj = (int)(((double)decimal / (double)d - (double)integer) * (double)cur); +  adj = (act & 1) * cur + (act | 1) * adj; +  if (adj < min)  adj = min; +  if (adj > max)  adj = max; +   +  /* Send value */ +  writefile(buf, adj, dir); +} + + + +/**   * Read a file   *    * @param   output  Buffer to store the file's content in | 
