aboutsummaryrefslogtreecommitdiff
path: root/ch1/1-20_detab.c
diff options
context:
space:
mode:
Diffstat (limited to 'ch1/1-20_detab.c')
-rw-r--r--ch1/1-20_detab.c48
1 files changed, 48 insertions, 0 deletions
diff --git a/ch1/1-20_detab.c b/ch1/1-20_detab.c
new file mode 100644
index 0000000..dc8f5b5
--- /dev/null
+++ b/ch1/1-20_detab.c
@@ -0,0 +1,48 @@
+#include <stdio.h>
+
+/* The C Programming Language: 2nd Edition
+ * Exercise 1-20:
+ * "Write a program `detab` that replaces tabs in the input with the proper
+ * number of blanks to space to the next tabstop. Assume a fixed set of
+ * tabstops, say every 'n' columns. Should 'n' be a variable or a symbolic
+ * parameter?"
+ *
+ * Answer: 'n' should be a symbolic parameter. It's more apparent what's being
+ * worked with and it's not susceptible to scope. Though, in this simple
+ * program it really doesn't matter.
+ *
+ * The "correct" solution uses the isprint() stdlib function, but it's not
+ * covered by this point in the book, so I did not use it.
+ */
+
+#define TABWIDTH 8
+
+int main(void) {
+ int column, c;
+ column = 0;
+ while ((c = getchar()) != EOF) {
+ // Be sure that the character is a tab
+ if (c == '\t') {
+ /*
+ * Divide a line by TABWIDTH and you have your tabstops. If you
+ * modulo by TABWIDTH and it equals 0, you've reached a tabstop and
+ * don't need to output more spaces!
+ */
+ while (column % TABWIDTH != 0 && column != 0) {
+ putchar(' ');
+ ++column;
+ }
+ } else {
+ if (c == '\n') {
+ // Line-endings should reset the column counter after being output.
+ putchar(c);
+ column = 0;
+ } else {
+ // Now we can just output and increase column!
+ putchar(c);
+ ++column;
+ }
+ }
+ }
+ return 0;
+}
ash/commit/src/vgstash_cli.py?h=v0.3b6&id=ac3e84c9438ef964a08f2acf40ab58fe1c04675e&follow=1'>cli: add 'update' commandzlg3-20/+92 2018-10-06cli: Add "delete" commandzlg2-0/+19 2018-10-06Remove ID field from DBzlg3-38/+46 2018-10-06cli: change "Status" heading to "Progress"zlg2-36/+40 2018-09-29Bump to 0.3alpha5 for PyPIzlg1-1/+1 2018-09-29cli: Add pretty printing to 'list' commandzlg3-17/+107 2018-09-08setup.py: Bump to alpha4 for PyPIzlg1-1/+1 2018-09-08cli: add '--raw' option to list commandzlg2-9/+45 2018-09-08Add remaining filters to vgstash packagezlg1-2/+11 2018-09-04Update LICENSE to match setup.pyzlg1-80/+67 2018-09-03Branch off from master with pytest, tox, clickzlg16-778/+779 2018-03-18Flesh out filter types and ownership statuszlg3-82/+144 2018-03-18README.mdown: break line correctlyzlg1-1/+1 2018-03-18add 'playlog' list filterzlg2-2/+9 2018-03-13Update helpers a bitzlg1-2/+9 2018-03-13Make VGSTASH_DB_LOCATION point to a filezlg2-21/+20 2016-11-18Remove settings from helpers.shZe Libertine Gamer1-5/+0 2016-11-15Correct phrasing in README.Ze Libertine Gamer1-4/+4 2016-11-13DerpZe Libertine Gamer1-0/+1 2016-11-03Improve error handling in shell scriptsZe Libertine Gamer4-3/+23 2016-10-24Correct run_again, add recursionZe Libertine Gamer1-0/+4 2016-10-21Add quotes to correct behavior for arglistZe Libertine Gamer1-1/+1 2016-10-14updater.sh: add recursion, error handlingZe Libertine Gamer1-43/+101 2016-10-14Correct pipe-handling behaviorZe Libertine Gamer1-1/+9 2016-10-12Clarify a method to move between platformsZe Libertine Gamer1-2/+5