From e530fbfc5f47e5fb19107f442f3d752ed049817c Mon Sep 17 00:00:00 2001 From: Tom Willemse Date: Tue, 27 Aug 2019 23:53:06 -0700 Subject: Add snippets for ‘oni-php’ --- .gitlab-ci.yml | 14 ++++ GNUmakefile | 17 ++++- oni-php.el | 103 --------------------------- oni-php/Cask | 19 +++++ oni-php/oni-php.el | 126 +++++++++++++++++++++++++++++++++ oni-php/snippets/php-mode/function | 8 +++ oni-php/snippets/php-mode/wpheader.php | 13 ++++ 7 files changed, 196 insertions(+), 104 deletions(-) delete mode 100644 oni-php.el create mode 100644 oni-php/Cask create mode 100644 oni-php/oni-php.el create mode 100644 oni-php/snippets/php-mode/function create mode 100644 oni-php/snippets/php-mode/wpheader.php diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 359339f..c6fddd6 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -66,6 +66,16 @@ package-oni-nxml: paths: - oni-nxml/dist/ +package-oni-php: + stage: pre-package-multifile + before_script: + - rm -rf oni-elisp/dist + script: + - cask --path oni-php package + artifacts: + paths: + - oni-php/dist/ + test-oni-alert: stage: test script: make test-oni-alert @@ -105,6 +115,9 @@ test-oni-highlight-indent-guides: test-oni-php: stage: test + dependencies: + - package-oni-php + needs: [package-oni-php] script: make test-oni-php package: @@ -116,6 +129,7 @@ package: - package-oni-haml - package-oni-html - package-oni-nxml + - package-oni-php before_script: - rm -rf bin/ - mkdir bin/ diff --git a/GNUmakefile b/GNUmakefile index 246208b..36b22e8 100644 --- a/GNUmakefile +++ b/GNUmakefile @@ -3,7 +3,8 @@ FILES := $(wildcard *.el) PACKAGE_TARGETS := $(addprefix package-,$(FILES)) package: $(PACKAGE_TARGETS) package-oni-conf package-oni-css package-oni-elisp \ - package-oni-haml package-oni-html package-oni-nxml package-oni-org + package-oni-haml package-oni-html package-oni-nxml package-oni-org \ + package-oni-php package-%: % emacs --batch \ @@ -53,6 +54,12 @@ package-oni-org: --funcall package-initialize \ --eval "(package-upload-file (car (sort (file-expand-wildcards \"oni-org/dist/*.tar\") #'string>)))" +package-oni-php: + emacs --batch \ + --load oni-package.el \ + --funcall package-initialize \ + --eval "(package-upload-file (car (sort (file-expand-wildcards \"oni-php/dist/*.tar\") #'string>)))" + install-%: emacs --batch \ --load oni-package.el \ @@ -117,6 +124,14 @@ install-oni-org: $(foreach DEP,$(DEPS),--eval "(package-install-file \"$(DEP).el\")") \ --eval "(package-install-file (car (sort (file-expand-wildcards \"oni-org/dist/*.tar\") #'string>)))" +install-oni-php: + emacs --batch \ + --load oni-package.el \ + --fluncall package-initialize \ + --eval '(package-refresh-contents)' \ + $(foreach DEP,$(DEPS),--eval "(package-install-file \"$(DEP).el\")") \ + --eval "(package-install-file (car (sort (file-expand-wildcards \"oni-php/dist/*.tar\") #'string>)))" + test-%: install-% emacs --batch \ --load oni-package.el \ diff --git a/oni-php.el b/oni-php.el deleted file mode 100644 index 4b21c9c..0000000 --- a/oni-php.el +++ /dev/null @@ -1,103 +0,0 @@ -;;; oni-php.el --- PHP Configuration -*- lexical-binding: t; -*- - -;; Copyright (C) 2019 Tom Willemse - -;; Author: Tom Willemse -;; Keywords: local -;; Version: 20190505200117 -;; Package-Requires: (php-mode oni-flycheck oni-company oni-fci ggtags fic-mode hydra company-php phpcbf) - -;; This program is free software; you can redistribute it and/or modify -;; it under the terms of the GNU General Public License as published by -;; the Free Software Foundation, either version 3 of the License, or -;; (at your option) any later version. - -;; This program is distributed in the hope that it will be useful, -;; but WITHOUT ANY WARRANTY; without even the implied warranty of -;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -;; GNU General Public License for more details. - -;; You should have received a copy of the GNU General Public License -;; along with this program. If not, see . - -;;; Commentary: - -;; My PHP mode configuration. Includes rules for aligning variables according to -;; the WordPress coding standards. - -;;; Code: - -(require 'align) -(require 'company) -(require 'php-mode) -(require 'whitespace) - -(defun oni-php--set-require-final-newline () - "Set `require-final-newline' to t. -This is necessary because the PHP mode configuration sets this to -nil for some reason." - (setq require-final-newline t)) - -(defun oni-php--whitespace-mode () - "Enable whitespace mode with only tabs showing." - (setq-local whitespace-style '(face tabs)) - (whitespace-mode)) - -(defhydra php-mode-hydra (:color blue) - ("a" align-current "Align current selection")) - -(add-hook 'php-mode-hook #'oni-php--set-require-final-newline) -(add-hook 'php-mode-hook #'oni-php--whitespace-mode) -(add-hook 'php-mode-hook 'company-mode) -(add-hook 'php-mode-hook 'electric-indent-local-mode) -(add-hook 'php-mode-hook 'electric-pair-local-mode) -(add-hook 'php-mode-hook 'fci-mode) -(add-hook 'php-mode-hook 'fic-mode) -(add-hook 'php-mode-hook 'flycheck-mode) -(add-hook 'php-mode-hook 'ggtags-mode) -(add-hook 'php-mode-hook 'phpcbf-enable-on-save) - -(with-eval-after-load 'company - (add-to-list 'company-backends 'company-ac-php-backend)) - -(define-key php-mode-map (kbd "C-c m") #'php-mode-hydra/body) - -;; In PHP code it's nice to have any ~=>~ aligned. - -;; 'bar', -;; 'frob' => 'baz' -;; ); -;; ?> - -(add-to-list 'align-rules-list - `(php-array-arrow - (regexp . ,(rx any (group (zero-or-more whitespace)) "=>" any)) - (group . (1)) - (modes . '(php-mode web-mode)) - (repeat . t))) - -;; The WordPress coding standards specify that multiple assignments -;; should have their assignment operators aligned. - -;; +;; Keywords: local +;; Version: 20190827234741 +;; Package-Requires: (php-mode oni-yasnippet oni-flycheck oni-company oni-fci ggtags fic-mode hydra company-php phpcbf) + +;; This program is free software; you can redistribute it and/or modify +;; it under the terms of the GNU General Public License as published by +;; the Free Software Foundation, either version 3 of the License, or +;; (at your option) any later version. + +;; This program is distributed in the hope that it will be useful, +;; but WITHOUT ANY WARRANTY; without even the implied warranty of +;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +;; GNU General Public License for more details. + +;; You should have received a copy of the GNU General Public License +;; along with this program. If not, see . + +;;; Commentary: + +;; My PHP mode configuration. Includes rules for aligning variables according to +;; the WordPress coding standards. + +;;; Code: + +(require 'align) +(require 'company) +(require 'php-mode) +(require 'whitespace) +(require 'yasnippet) + +(defconst oni-php-root + (file-name-directory + (or load-file-name + (buffer-file-name))) + "The directory where ‘oni-php’ was loaded from.") + +(defconst oni-php-snippets-dir + (expand-file-name "snippets" oni-php-root) + "The directory where ‘oni-php’ stores its snippets.") + +;;;###autoload +(defun oni-php-snippets-initialize () + "Initialize the snippets for ‘oni-php’." + (when (boundp 'yas-snippet-dirs) + (add-to-list 'yas-snippet-dirs oni-php-snippets-dir)) + (yas-load-directory oni-php-snippets-dir)) + +(defun oni-php--set-require-final-newline () + "Set `require-final-newline' to t. +This is necessary because the PHP mode configuration sets this to +nil for some reason." + (setq require-final-newline t)) + +(defun oni-php--whitespace-mode () + "Enable whitespace mode with only tabs showing." + (setq-local whitespace-style '(face tabs)) + (whitespace-mode)) + +(defhydra php-mode-hydra (:color blue) + ("a" align-current "Align current selection")) + +(add-hook 'php-mode-hook #'oni-php--set-require-final-newline) +(add-hook 'php-mode-hook #'oni-php--whitespace-mode) +(add-hook 'php-mode-hook 'company-mode) +(add-hook 'php-mode-hook 'electric-indent-local-mode) +(add-hook 'php-mode-hook 'electric-pair-local-mode) +(add-hook 'php-mode-hook 'fci-mode) +(add-hook 'php-mode-hook 'fic-mode) +(add-hook 'php-mode-hook 'flycheck-mode) +(add-hook 'php-mode-hook 'ggtags-mode) +(add-hook 'php-mode-hook 'phpcbf-enable-on-save) + +(with-eval-after-load 'company + (add-to-list 'company-backends 'company-ac-php-backend)) + +(define-key php-mode-map (kbd "C-c m") #'php-mode-hydra/body) + +;; In PHP code it's nice to have any ~=>~ aligned. + +;; 'bar', +;; 'frob' => 'baz' +;; ); +;; ?> + +(add-to-list 'align-rules-list + `(php-array-arrow + (regexp . ,(rx any (group (zero-or-more whitespace)) "=>" any)) + (group . (1)) + (modes . '(php-mode web-mode)) + (repeat . t))) + +;; The WordPress coding standards specify that multiple assignments +;; should have their assignment operators aligned. + +;;