source: mainline/uspace/app/bdsh/cmds/modules/printf/printf.c@ a35b458

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since a35b458 was a35b458, checked in by Jiří Zárevúcky <zarevucky.jiri@…>, 7 years ago

style: Remove trailing whitespace on _all_ lines, including empty ones, for particular file types.

Command used: tools/srepl '\s\+$' '' -- *.c *.h *.py *.sh *.s *.S *.ag

Currently, whitespace on empty lines is very inconsistent.
There are two basic choices: Either remove the whitespace, or keep empty lines
indented to the level of surrounding code. The former is AFAICT more common,
and also much easier to do automatically.

Alternatively, we could write script for automatic indentation, and use that
instead. However, if such a script exists, it's possible to use the indented
style locally, by having the editor apply relevant conversions on load/save,
without affecting remote repository. IMO, it makes more sense to adopt
the simpler rule.

  • Property mode set to 100644
File size: 4.1 KB
Line 
1/*
2 * Copyright (c) 2012 Alexander Prutkov
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29#include <stdio.h>
30#include <stdlib.h>
31#include <stddef.h>
32#include "config.h"
33#include "util.h"
34#include "errors.h"
35#include "entry.h"
36#include "printf.h"
37#include "cmds.h"
38#include "str.h"
39
40static const char *cmdname = "printf";
41
42/* Dispays help for printf in various levels */
43void help_cmd_printf(unsigned int level)
44{
45 if (level == HELP_SHORT) {
46 printf("`%s' prints formatted data.\n", cmdname);
47 } else {
48 help_cmd_printf(HELP_SHORT);
49 printf(
50 "Usage: %s FORMAT [ARGS ...] \n"
51 "Prints ARGS according to FORMAT. Number of expected arguments in\n"
52 "FORMAT must be equals to the number of ARGS. Currently supported\n"
53 "format flags are:\n",
54 cmdname);
55 }
56
57
58 return;
59}
60
61/** Print a formatted data with lib printf.
62 *
63 * Currently available format flags are:
64 * '%d' - integer.
65 * '%u' - unsigned integer.
66 * '%s' - null-terminated string.
67 *****
68 * @param ch formatted flag.
69 * @param arg string with data to print.
70 */
71static int print_arg(wchar_t ch, const char* arg)
72{
73 switch(ch) {
74 case 'd':
75 printf("%d", (int)(strtol(arg, NULL, 10)));
76 break;
77 case 'u':
78 printf("%u", (unsigned int)(strtoul(arg, NULL, 10)));
79 break;
80 case 's':
81 printf("%s", arg);
82 break;
83 default:
84 return CMD_FAILURE;
85 }
86 return CMD_SUCCESS;
87}
88
89/** Process a control character.
90 *
91 * Currently available characters are:
92 * '\n' - new line.
93 *****
94 * @param ch Control character.
95 */
96static int process_ctl(wchar_t ch)
97{
98 switch(ch) {
99 case 'n':
100 printf("\n");
101 break;
102 default:
103 return CMD_FAILURE;
104 }
105 return CMD_SUCCESS;
106}
107
108
109/** Prints formatted data.
110 *
111 * Accepted format flags:
112 * %d - print an integer
113 * %u - print an unsigned integer
114 * %s - print a null terminated string
115 *****
116 * Accepted output controls:
117 * \n - new line
118 */
119int cmd_printf(char **argv)
120{
121 unsigned int argc;
122 char* fmt;
123 size_t pos, fmt_sz;
124 wchar_t ch;
125 bool esc_flag = false;
126 unsigned int carg; // Current argument
127
128 /* Count the arguments */
129 for (argc = 0; argv[argc] != NULL; argc ++);
130
131 if (argc < 2) {
132 printf("Usage: %s FORMAT [ARGS ...] \n", cmdname);
133 return CMD_SUCCESS;
134 }
135
136 fmt = argv[1];
137 fmt_sz = str_size(fmt);
138 pos = 0;
139 carg = 2;
140
141 while ((ch = str_decode(fmt, &pos, fmt_sz))) {
142 switch(ch) {
143
144 case '\\':
145 if (esc_flag)
146 goto emit;
147 esc_flag = true;
148 break;
149
150 case '%':
151 if (esc_flag)
152 goto emit;
153 ch = str_decode(fmt, &pos, fmt_sz);
154 if (!ch) {
155 putchar('%');
156 break;
157 }
158 if (carg == argc) {
159 printf("\nBad parameter number. Aborted.\n");
160 return CMD_FAILURE;
161 }
162 print_arg(ch, argv[carg]);
163 ++carg;
164 break;
165
166 default:
167 if (esc_flag) {
168 process_ctl(ch);
169 esc_flag = false;
170 break;
171 }
172 putchar(ch);
173 break;
174
175 emit:
176 putchar(ch);
177 esc_flag = false;
178 }
179 }
180
181 return CMD_SUCCESS;
182}
Note: See TracBrowser for help on using the repository browser.