aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--meson.build12
-rw-r--r--meson_options.txt1
-rw-r--r--sway/ipc-server.c10
3 files changed, 14 insertions, 9 deletions
diff --git a/meson.build b/meson.build
index 766bf012..c50fab17 100644
--- a/meson.build
+++ b/meson.build
@@ -1,6 +1,7 @@
1project( 1project(
2 'sway', 2 'sway',
3 'c', 3 'c',
4 version: '1.0',
4 license: 'MIT', 5 license: 'MIT',
5 meson_version: '>=0.48.0', 6 meson_version: '>=0.48.0',
6 default_options: [ 7 default_options: [
@@ -127,17 +128,12 @@ endif
127 128
128add_project_arguments('-DSYSCONFDIR="/@0@"'.format(join_paths(prefix, sysconfdir)), language : 'c') 129add_project_arguments('-DSYSCONFDIR="/@0@"'.format(join_paths(prefix, sysconfdir)), language : 'c')
129 130
130version = get_option('sway-version') 131if git.found()
131if version != ''
132 version = '"@0@"'.format(version)
133else
134 if not git.found()
135 error('git is required to make the version string')
136 endif
137
138 git_commit_hash = run_command([git.path(), 'describe', '--always', '--tags']).stdout().strip() 132 git_commit_hash = run_command([git.path(), 'describe', '--always', '--tags']).stdout().strip()
139 git_branch = run_command([git.path(), 'rev-parse', '--abbrev-ref', 'HEAD']).stdout().strip() 133 git_branch = run_command([git.path(), 'rev-parse', '--abbrev-ref', 'HEAD']).stdout().strip()
140 version = '"@0@ (" __DATE__ ", branch \'@1@\')"'.format(git_commit_hash, git_branch) 134 version = '"@0@ (" __DATE__ ", branch \'@1@\')"'.format(git_commit_hash, git_branch)
135else
136 version = '"@0@"'.format(meson.project_version())
141endif 137endif
142add_project_arguments('-DSWAY_VERSION=@0@'.format(version), language: 'c') 138add_project_arguments('-DSWAY_VERSION=@0@'.format(version), language: 'c')
143 139
diff --git a/meson_options.txt b/meson_options.txt
index 04b29e17..d3667acf 100644
--- a/meson_options.txt
+++ b/meson_options.txt
@@ -1,4 +1,3 @@
1option('sway-version', type : 'string', description: 'The version string reported in `sway --version`.')
2option('default-wallpaper', type: 'boolean', value: true, description: 'Install the default wallpaper.') 1option('default-wallpaper', type: 'boolean', value: true, description: 'Install the default wallpaper.')
3option('zsh-completions', type: 'boolean', value: true, description: 'Install zsh shell completions.') 2option('zsh-completions', type: 'boolean', value: true, description: 'Install zsh shell completions.')
4option('bash-completions', type: 'boolean', value: true, description: 'Install bash shell completions.') 3option('bash-completions', type: 'boolean', value: true, description: 'Install bash shell completions.')
diff --git a/sway/ipc-server.c b/sway/ipc-server.c
index d1920cfd..eb6f159d 100644
--- a/sway/ipc-server.c
+++ b/sway/ipc-server.c
@@ -595,6 +595,16 @@ void ipc_client_handle_command(struct ipc_client *client) {
595 switch (client->current_command) { 595 switch (client->current_command) {
596 case IPC_COMMAND: 596 case IPC_COMMAND:
597 { 597 {
598 char *line = strtok(buf, "\n");
599 while (line) {
600 size_t line_length = strlen(line);
601 if (line + line_length >= buf + client->payload_length) {
602 break;
603 }
604 line[line_length] = ';';
605 line = strtok(NULL, "\n");
606 }
607
598 list_t *res_list = execute_command(buf, NULL, NULL); 608 list_t *res_list = execute_command(buf, NULL, NULL);
599 transaction_commit_dirty(); 609 transaction_commit_dirty();
600 char *json = cmd_results_to_json(res_list); 610 char *json = cmd_results_to_json(res_list);