Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 1 | # Copyright (c) 2016 Cisco and/or its affiliates. |
| 2 | # Licensed under the Apache License, Version 2.0 (the "License"); |
| 3 | # you may not use this file except in compliance with the License. |
| 4 | # You may obtain a copy of the License at: |
| 5 | # |
| 6 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 7 | # |
| 8 | # Unless required by applicable law or agreed to in writing, software |
| 9 | # distributed under the License is distributed on an "AS IS" BASIS, |
| 10 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 11 | # See the License for the specific language governing permissions and |
| 12 | # limitations under the License. |
| 13 | |
| 14 | WS_ROOT=$(CURDIR) |
| 15 | BR=$(WS_ROOT)/build-root |
| 16 | CCACHE_DIR?=$(BR)/.ccache |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 17 | GDB?=gdb |
Damjan Marion | e6f9023 | 2016-03-16 22:49:05 +0100 | [diff] [blame] | 18 | PLATFORM?=vpp |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 19 | |
Damjan Marion | 7a2a378 | 2016-04-15 20:24:55 +0200 | [diff] [blame] | 20 | MINIMAL_STARTUP_CONF="unix { interactive }" |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 21 | |
Damjan Marion | eef4d99 | 2016-02-23 22:04:50 +0100 | [diff] [blame] | 22 | GDB_ARGS= -ex "handle SIGUSR1 noprint nostop" |
| 23 | |
Damjan Marion | c5e8681 | 2016-05-02 19:40:27 +0200 | [diff] [blame] | 24 | # |
| 25 | # OS Detection |
| 26 | # |
| 27 | OS_ID = $(shell grep '^ID=' /etc/os-release | cut -f2- -d= | sed -e 's/\"//g') |
| 28 | OS_VERSION_ID= $(shell grep '^VERSION_ID=' /etc/os-release | cut -f2- -d= | sed -e 's/\"//g') |
| 29 | |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 30 | DEB_DEPENDS = curl build-essential autoconf automake bison libssl-dev ccache |
Ed Warnicke | 027103e | 2016-05-05 18:03:27 -0500 | [diff] [blame] | 31 | DEB_DEPENDS += debhelper dkms git libtool libganglia1-dev libapr1-dev dh-systemd |
Damjan Marion | e6f9023 | 2016-03-16 22:49:05 +0100 | [diff] [blame] | 32 | DEB_DEPENDS += libconfuse-dev git-review exuberant-ctags cscope |
Chris Luke | 1d1644c | 2016-05-13 13:41:36 -0400 | [diff] [blame] | 33 | DEB_DEPENDS += doxygen graphviz |
Ed Warnicke | 027103e | 2016-05-05 18:03:27 -0500 | [diff] [blame] | 34 | ifeq ($(OS_VERSION_ID),14.04) |
| 35 | DEB_DEPENDS += openjdk-8-jdk-headless |
| 36 | else |
| 37 | DEB_DEPENDS += default-jdk-headless |
| 38 | endif |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 39 | |
Ed Warnicke | 84eda9d | 2016-03-22 16:09:29 -0500 | [diff] [blame] | 40 | RPM_DEPENDS_GROUPS = 'Development Tools' |
Thomas F Herbert | 473bf23 | 2016-04-27 16:19:03 -0400 | [diff] [blame] | 41 | RPM_DEPENDS = redhat-lsb glibc-static java-1.8.0-openjdk-devel yum-utils |
Ed Warnicke | 3c79e65 | 2016-03-28 14:53:19 -0500 | [diff] [blame] | 42 | RPM_DEPENDS += openssl-devel https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm apr-devel |
Chris Luke | 1d1644c | 2016-05-13 13:41:36 -0400 | [diff] [blame] | 43 | RPM_DEPENDS += doxygen graphviz |
Ed Warnicke | 84eda9d | 2016-03-22 16:09:29 -0500 | [diff] [blame] | 44 | EPEL_DEPENDS = libconfuse-devel ganglia-devel |
| 45 | |
Damjan Marion | 0df78dd | 2016-03-29 22:37:02 +0200 | [diff] [blame] | 46 | ifneq ($(wildcard $(STARTUP_DIR)/startup.conf),) |
Damjan Marion | eef4d99 | 2016-02-23 22:04:50 +0100 | [diff] [blame] | 47 | STARTUP_CONF ?= $(STARTUP_DIR)/startup.conf |
| 48 | endif |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 49 | |
Damjan Marion | c5e8681 | 2016-05-02 19:40:27 +0200 | [diff] [blame] | 50 | ifeq ($(findstring y,$(UNATTENDED)),y) |
| 51 | CONFIRM=-y |
| 52 | endif |
| 53 | |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 54 | .PHONY: help bootstrap wipe wipe-release build build-release rebuild rebuild-release |
| 55 | .PHONY: run run-release debug debug-release build-vat run-vat pkg-deb pkg-rpm |
Ole Troan | 3b3688f | 2016-06-15 14:29:08 +0200 | [diff] [blame] | 56 | .PHONY: ctags cscope doxygen wipe-doxygen plugins plugins-release |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 57 | |
| 58 | help: |
| 59 | @echo "Make Targets:" |
| 60 | @echo " bootstrap - prepare tree for build" |
Damjan Marion | ebb27fb | 2016-02-25 16:26:01 +0100 | [diff] [blame] | 61 | @echo " install-dep - install software dependencies" |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 62 | @echo " wipe - wipe all products of debug build " |
| 63 | @echo " wipe-release - wipe all products of release build " |
| 64 | @echo " build - build debug binaries" |
| 65 | @echo " build-release - build release binaries" |
| 66 | @echo " rebuild - wipe and build debug binares" |
| 67 | @echo " rebuild-release - wipe and build release binares" |
| 68 | @echo " run - run debug binary" |
| 69 | @echo " run-release - run release binary" |
| 70 | @echo " debug - run debug binary with debugger" |
| 71 | @echo " debug-release - run release binary with debugger" |
| 72 | @echo " build-vat - build vpp-api-test tool" |
| 73 | @echo " run-vat - run vpp-api-test tool" |
| 74 | @echo " pkg-deb - build DEB packages" |
| 75 | @echo " pkg-rpm - build RPM packages" |
Damjan Marion | e6f9023 | 2016-03-16 22:49:05 +0100 | [diff] [blame] | 76 | @echo " ctags - (re)generate ctags database" |
| 77 | @echo " cscope - (re)generate cscope database" |
Chris Luke | 1d1644c | 2016-05-13 13:41:36 -0400 | [diff] [blame] | 78 | @echo " doxygen - (re)generate documentation" |
| 79 | @echo " wipe-doxygen - wipe all generated documentation" |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 80 | @echo "" |
| 81 | @echo "Make Arguments:" |
| 82 | @echo " V=[0|1] - set build verbosity level" |
| 83 | @echo " STARTUP_CONF=<path> - startup configuration file" |
| 84 | @echo " (e.g. /etc/vpp/startup.conf)" |
Damjan Marion | eef4d99 | 2016-02-23 22:04:50 +0100 | [diff] [blame] | 85 | @echo " STARTUP_DIR=<path> - startup drectory (e.g. /etc/vpp)" |
| 86 | @echo " It also sets STARTUP_CONF if" |
| 87 | @echo " startup.conf file is present" |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 88 | @echo " GDB=<path> - gdb binary to use for debugging" |
Damjan Marion | e6f9023 | 2016-03-16 22:49:05 +0100 | [diff] [blame] | 89 | @echo " PLATFORM=<name> - target platform. default is vpp" |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 90 | @echo "" |
| 91 | @echo "Current Argumernt Values:" |
| 92 | @echo " V = $(V)" |
| 93 | @echo " STARTUP_CONF = $(STARTUP_CONF)" |
Damjan Marion | eef4d99 | 2016-02-23 22:04:50 +0100 | [diff] [blame] | 94 | @echo " STARTUP_DIR = $(STARTUP_DIR)" |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 95 | @echo " GDB = $(GDB)" |
Damjan Marion | e6f9023 | 2016-03-16 22:49:05 +0100 | [diff] [blame] | 96 | @echo " PLATFORM = $(PLATFORM)" |
Damjan Marion | 0df78dd | 2016-03-29 22:37:02 +0200 | [diff] [blame] | 97 | @echo " DPDK_VERSION = $(DPDK_VERSION)" |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 98 | |
| 99 | $(BR)/.bootstrap.ok: |
Damjan Marion | c5e8681 | 2016-05-02 19:40:27 +0200 | [diff] [blame] | 100 | ifeq ($(OS_ID),ubuntu) |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 101 | @MISSING=$$(apt-get install -y -qq -s $(DEB_DEPENDS) | grep "^Inst ") ; \ |
| 102 | if [ -n "$$MISSING" ] ; then \ |
| 103 | echo "\nPlease install missing packages: \n$$MISSING\n" ; \ |
Damjan Marion | ebb27fb | 2016-02-25 16:26:01 +0100 | [diff] [blame] | 104 | echo "by executing \"make install-dep\"\n" ; \ |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 105 | exit 1 ; \ |
| 106 | fi ; \ |
| 107 | exit 0 |
| 108 | endif |
Pierre Pfister | 3535222 | 2016-05-27 10:30:13 +0100 | [diff] [blame] | 109 | @echo "SOURCE_PATH = $(WS_ROOT) $(WS_ROOT)/plugins"> $(BR)/build-config.mk |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 110 | @echo "#!/bin/bash\n" > $(BR)/path_setup |
| 111 | @echo 'export PATH=$(BR)/tools/ccache-bin:$$PATH' >> $(BR)/path_setup |
| 112 | @echo 'export PATH=$(BR)/tools/bin:$$PATH' >> $(BR)/path_setup |
| 113 | @echo 'export CCACHE_DIR=$(CCACHE_DIR)' >> $(BR)/path_setup |
Ole Troan | 6855f6c | 2016-04-09 03:16:30 +0200 | [diff] [blame] | 114 | |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 115 | ifeq ("$(wildcard /usr/bin/ccache )","") |
| 116 | @echo "WARNING: Please install ccache AYEC and re-run this script" |
| 117 | else |
| 118 | @rm -rf $(BR)/tools/ccache-bin |
| 119 | @mkdir -p $(BR)/tools/ccache-bin |
| 120 | @ln -s /usr/bin/ccache $(BR)/tools/ccache-bin/gcc |
| 121 | @ln -s /usr/bin/ccache $(BR)/tools/ccache-bin/g++ |
| 122 | endif |
| 123 | @make -C $(BR) V=$(V) is_build_tool=yes vppapigen-install |
| 124 | @touch $@ |
| 125 | |
| 126 | bootstrap: $(BR)/.bootstrap.ok |
| 127 | |
Damjan Marion | ebb27fb | 2016-02-25 16:26:01 +0100 | [diff] [blame] | 128 | install-dep: |
Damjan Marion | c5e8681 | 2016-05-02 19:40:27 +0200 | [diff] [blame] | 129 | ifeq ($(OS_ID),ubuntu) |
| 130 | ifeq ($(OS_VERSION_ID),14.04) |
Dave Wallace | ed18a1c | 2016-05-13 19:00:29 -0400 | [diff] [blame] | 131 | @sudo -E apt-get $(CONFIRM) install software-properties-common |
| 132 | @sudo -E add-apt-repository $(CONFIRM) ppa:openjdk-r/ppa |
| 133 | @sudo -E apt-get update |
Damjan Marion | c5e8681 | 2016-05-02 19:40:27 +0200 | [diff] [blame] | 134 | endif |
Dave Wallace | ed18a1c | 2016-05-13 19:00:29 -0400 | [diff] [blame] | 135 | @sudo -E apt-get $(CONFIRM) install $(DEB_DEPENDS) |
Ed Warnicke | 84eda9d | 2016-03-22 16:09:29 -0500 | [diff] [blame] | 136 | else ifneq ("$(wildcard /etc/redhat-release)","") |
Damjan Marion | c5e8681 | 2016-05-02 19:40:27 +0200 | [diff] [blame] | 137 | @sudo yum groupinstall $(CONFIRM) $(RPM_DEPENDS_GROUPS) |
| 138 | @sudo yum install $(CONFIRM) $(RPM_DEPENDS) |
| 139 | @sudo yum install $(CONFIRM) --enablerepo=epel $(EPEL_DEPENDS) |
Ed Warnicke | d6a779c | 2016-05-03 16:47:50 -0500 | [diff] [blame] | 140 | @sudo debuginfo-install $(CONFIRM) glibc-2.17-106.el7_2.4.x86_64 openssl-libs-1.0.1e-51.el7_2.4.x86_64 zlib-1.2.7-15.el7.x86_64 |
Damjan Marion | ebb27fb | 2016-02-25 16:26:01 +0100 | [diff] [blame] | 141 | else |
Ed Warnicke | 84eda9d | 2016-03-22 16:09:29 -0500 | [diff] [blame] | 142 | $(error "This option currently works only on Ubuntu or Centos systems") |
Damjan Marion | ebb27fb | 2016-02-25 16:26:01 +0100 | [diff] [blame] | 143 | endif |
| 144 | |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 145 | define make |
Damjan Marion | 6b1d7c5 | 2016-04-26 18:19:47 +0200 | [diff] [blame] | 146 | @make -C $(BR) PLATFORM=$(PLATFORM) TAG=$(1) $(2) |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 147 | endef |
| 148 | |
| 149 | build: $(BR)/.bootstrap.ok |
Damjan Marion | e6f9023 | 2016-03-16 22:49:05 +0100 | [diff] [blame] | 150 | $(call make,$(PLATFORM)_debug,vpp-install) |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 151 | |
| 152 | wipe: $(BR)/.bootstrap.ok |
Damjan Marion | e6f9023 | 2016-03-16 22:49:05 +0100 | [diff] [blame] | 153 | $(call make,$(PLATFORM)_debug,vpp-wipe) |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 154 | |
| 155 | rebuild: wipe build |
| 156 | |
| 157 | build-release: $(BR)/.bootstrap.ok |
Damjan Marion | e6f9023 | 2016-03-16 22:49:05 +0100 | [diff] [blame] | 158 | $(call make,$(PLATFORM),vpp-install) |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 159 | |
| 160 | wipe-release: $(BR)/.bootstrap.ok |
Damjan Marion | e6f9023 | 2016-03-16 22:49:05 +0100 | [diff] [blame] | 161 | $(call make,$(PLATFORM),vpp-wipe) |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 162 | |
| 163 | rebuild-release: wipe-release build-release |
| 164 | |
Pierre Pfister | 3535222 | 2016-05-27 10:30:13 +0100 | [diff] [blame] | 165 | plugins: $(BR)/.bootstrap.ok |
Ole Troan | 3b3688f | 2016-06-15 14:29:08 +0200 | [diff] [blame] | 166 | $(call make,$(PLATFORM)_debug,plugins-install) |
Pierre Pfister | 3535222 | 2016-05-27 10:30:13 +0100 | [diff] [blame] | 167 | |
| 168 | plugins-release: $(BR)/.bootstrap.ok |
Ole Troan | 3b3688f | 2016-06-15 14:29:08 +0200 | [diff] [blame] | 169 | $(call make,$(PLATFORM),plugins-install) |
Pierre Pfister | 3535222 | 2016-05-27 10:30:13 +0100 | [diff] [blame] | 170 | |
Damjan Marion | eef4d99 | 2016-02-23 22:04:50 +0100 | [diff] [blame] | 171 | STARTUP_DIR ?= $(PWD) |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 172 | ifeq ("$(wildcard $(STARTUP_CONF))","") |
| 173 | define run |
| 174 | @echo "WARNING: STARTUP_CONF not defined or file doesn't exist." |
| 175 | @echo " Running with minimal startup config: $(MINIMAL_STARTUP_CONF)\n" |
Damjan Marion | 1aa310f | 2016-06-13 21:06:20 +0200 | [diff] [blame] | 176 | @sudo rm -f /dev/shm/vpe-api /dev/shm/db /dev/shm/global_vm |
Damjan Marion | eef4d99 | 2016-02-23 22:04:50 +0100 | [diff] [blame] | 177 | @cd $(STARTUP_DIR) && sudo $(1) $(MINIMAL_STARTUP_CONF) |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 178 | endef |
| 179 | else |
| 180 | define run |
Damjan Marion | 1aa310f | 2016-06-13 21:06:20 +0200 | [diff] [blame] | 181 | @sudo rm -f /dev/shm/vpe-api /dev/shm/db /dev/shm/global_vm |
Damjan Marion | eef4d99 | 2016-02-23 22:04:50 +0100 | [diff] [blame] | 182 | @cd $(STARTUP_DIR) && sudo $(1) -c $(STARTUP_CONF) |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 183 | endef |
| 184 | endif |
| 185 | |
Damjan Marion | e6f9023 | 2016-03-16 22:49:05 +0100 | [diff] [blame] | 186 | %.files: .FORCE |
| 187 | @find . \( -name '*\.[chyS]' -o -name '*\.java' -o -name '*\.lex' \) -and \ |
| 188 | \( -not -path './build-root*' -o -path \ |
| 189 | './build-root/build-vpp_debug-native/dpdk*' \) > $@ |
| 190 | |
| 191 | .FORCE: |
| 192 | |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 193 | run: |
Damjan Marion | e6f9023 | 2016-03-16 22:49:05 +0100 | [diff] [blame] | 194 | $(call run, $(BR)/install-$(PLATFORM)_debug-native/vpp/bin/vpp) |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 195 | |
| 196 | run-release: |
Damjan Marion | e6f9023 | 2016-03-16 22:49:05 +0100 | [diff] [blame] | 197 | $(call run, $(BR)/install-$(PLATFORM)-native/vpp/bin/vpp) |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 198 | |
| 199 | debug: |
Damjan Marion | e6f9023 | 2016-03-16 22:49:05 +0100 | [diff] [blame] | 200 | $(call run, $(GDB) $(GDB_ARGS) --args $(BR)/install-$(PLATFORM)_debug-native/vpp/bin/vpp) |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 201 | |
| 202 | debug-release: |
Damjan Marion | e6f9023 | 2016-03-16 22:49:05 +0100 | [diff] [blame] | 203 | $(call run, $(GDB) $(GDB_ARGS) --args $(BR)/install-$(PLATFORM)-native/vpp/bin/vpp) |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 204 | |
| 205 | build-vat: |
Damjan Marion | e6f9023 | 2016-03-16 22:49:05 +0100 | [diff] [blame] | 206 | $(call make,$(PLATFORM)_debug,vpp-api-test-install) |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 207 | |
| 208 | run-vat: |
Damjan Marion | e6f9023 | 2016-03-16 22:49:05 +0100 | [diff] [blame] | 209 | @sudo $(BR)/install-$(PLATFORM)_debug-native/vpp-api-test/bin/vpp_api_test |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 210 | |
| 211 | pkg-deb: |
Damjan Marion | e6f9023 | 2016-03-16 22:49:05 +0100 | [diff] [blame] | 212 | $(call make,$(PLATFORM),install-deb) |
Damjan Marion | e17fdb5 | 2016-02-10 00:36:06 +0100 | [diff] [blame] | 213 | |
| 214 | pkg-rpm: |
Damjan Marion | e6f9023 | 2016-03-16 22:49:05 +0100 | [diff] [blame] | 215 | $(call make,$(PLATFORM),install-rpm) |
| 216 | |
| 217 | ctags: ctags.files |
| 218 | @ctags --totals --tag-relative -L $< |
| 219 | @rm $< |
| 220 | |
| 221 | cscope: cscope.files |
| 222 | @cscope -b -q -v |
Marek Gradzki | 60c63c7 | 2016-04-26 08:01:31 +0200 | [diff] [blame] | 223 | |
Chris Luke | b585097 | 2016-05-03 16:34:59 -0400 | [diff] [blame] | 224 | |
Chris Luke | 1d1644c | 2016-05-13 13:41:36 -0400 | [diff] [blame] | 225 | # |
| 226 | # Build the documentation |
| 227 | # |
| 228 | |
Chris Luke | b585097 | 2016-05-03 16:34:59 -0400 | [diff] [blame] | 229 | DOXY_INPUT = \ |
| 230 | README.md \ |
| 231 | vppinfra \ |
| 232 | svm \ |
| 233 | vlib \ |
| 234 | vlib-api \ |
| 235 | vnet \ |
| 236 | vpp \ |
| 237 | vpp-api |
| 238 | |
Chris Luke | b585097 | 2016-05-03 16:34:59 -0400 | [diff] [blame] | 239 | doxygen: |
| 240 | @mkdir -p "$(BR)/docs" |
| 241 | ROOT="$(WS_ROOT)" \ |
| 242 | BUILD_ROOT="$(BR)" \ |
| 243 | INPUT="$(addprefix $(WS_ROOT)/,$(DOXY_INPUT))" \ |
| 244 | HTML=YES \ |
| 245 | VERSION="`git describe --tags --dirty`" \ |
| 246 | doxygen doxygen/doxygen.cfg |
| 247 | |
| 248 | wipe-doxygen: |
| 249 | rm -rf "$(BR)/docs" |