stump-cli 0.1.0 → 0.1.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1310) hide show
  1. checksums.yaml +8 -8
  2. data/.gitignore +18 -0
  3. data/Gemfile +4 -0
  4. data/LICENSE.txt +22 -0
  5. data/README.md +3 -16
  6. data/Rakefile +2 -0
  7. data/bin/stump-cli +58 -0
  8. data/lib/stump-cli/version.rb +3 -0
  9. data/lib/stump.rb +5 -0
  10. data/lib/wp/Movefile-example +62 -0
  11. data/lib/wp/README.md +25 -0
  12. data/lib/wp/index.php +17 -0
  13. data/lib/wp/license.txt +385 -0
  14. data/lib/wp/readme.html +96 -0
  15. data/lib/wp/wp-activate.php +131 -0
  16. data/lib/wp/wp-admin/about.php +193 -0
  17. data/lib/wp/wp-admin/admin-ajax.php +98 -0
  18. data/lib/wp/wp-admin/admin-footer.php +99 -0
  19. data/lib/wp/wp-admin/admin-functions.php +15 -0
  20. data/lib/wp/wp-admin/admin-header.php +243 -0
  21. data/lib/wp/wp-admin/admin-post.php +71 -0
  22. data/lib/wp/wp-admin/admin.php +347 -0
  23. data/lib/wp/wp-admin/async-upload.php +114 -0
  24. data/lib/wp/wp-admin/comment.php +299 -0
  25. data/lib/wp/wp-admin/credits.php +192 -0
  26. data/lib/wp/wp-admin/css/about-rtl.css +446 -0
  27. data/lib/wp/wp-admin/css/about.css +446 -0
  28. data/lib/wp/wp-admin/css/admin-menu-rtl.css +917 -0
  29. data/lib/wp/wp-admin/css/admin-menu.css +917 -0
  30. data/lib/wp/wp-admin/css/color-picker-rtl.css +127 -0
  31. data/lib/wp/wp-admin/css/color-picker-rtl.min.css +1 -0
  32. data/lib/wp/wp-admin/css/color-picker.css +127 -0
  33. data/lib/wp/wp-admin/css/color-picker.min.css +1 -0
  34. data/lib/wp/wp-admin/css/colors/_admin.scss +525 -0
  35. data/lib/wp/wp-admin/css/colors/_mixins.scss +43 -0
  36. data/lib/wp/wp-admin/css/colors/_variables.scss +58 -0
  37. data/lib/wp/wp-admin/css/colors/blue/colors-rtl.css +341 -0
  38. data/lib/wp/wp-admin/css/colors/blue/colors-rtl.min.css +1 -0
  39. data/lib/wp/wp-admin/css/colors/blue/colors.css +341 -0
  40. data/lib/wp/wp-admin/css/colors/blue/colors.min.css +1 -0
  41. data/lib/wp/wp-admin/css/colors/blue/colors.scss +11 -0
  42. data/lib/wp/wp-admin/css/colors/coffee/colors-rtl.css +341 -0
  43. data/lib/wp/wp-admin/css/colors/coffee/colors-rtl.min.css +1 -0
  44. data/lib/wp/wp-admin/css/colors/coffee/colors.css +341 -0
  45. data/lib/wp/wp-admin/css/colors/coffee/colors.min.css +1 -0
  46. data/lib/wp/wp-admin/css/colors/coffee/colors.scss +7 -0
  47. data/lib/wp/wp-admin/css/colors/ectoplasm/colors-rtl.css +341 -0
  48. data/lib/wp/wp-admin/css/colors/ectoplasm/colors-rtl.min.css +1 -0
  49. data/lib/wp/wp-admin/css/colors/ectoplasm/colors.css +341 -0
  50. data/lib/wp/wp-admin/css/colors/ectoplasm/colors.min.css +1 -0
  51. data/lib/wp/wp-admin/css/colors/ectoplasm/colors.scss +8 -0
  52. data/lib/wp/wp-admin/css/colors/light/colors-rtl.css +349 -0
  53. data/lib/wp/wp-admin/css/colors/light/colors-rtl.min.css +1 -0
  54. data/lib/wp/wp-admin/css/colors/light/colors.css +349 -0
  55. data/lib/wp/wp-admin/css/colors/light/colors.min.css +1 -0
  56. data/lib/wp/wp-admin/css/colors/light/colors.scss +38 -0
  57. data/lib/wp/wp-admin/css/colors/midnight/colors-rtl.css +341 -0
  58. data/lib/wp/wp-admin/css/colors/midnight/colors-rtl.min.css +1 -0
  59. data/lib/wp/wp-admin/css/colors/midnight/colors.css +341 -0
  60. data/lib/wp/wp-admin/css/colors/midnight/colors.min.css +1 -0
  61. data/lib/wp/wp-admin/css/colors/midnight/colors.scss +5 -0
  62. data/lib/wp/wp-admin/css/colors/ocean/colors-rtl.css +341 -0
  63. data/lib/wp/wp-admin/css/colors/ocean/colors-rtl.min.css +1 -0
  64. data/lib/wp/wp-admin/css/colors/ocean/colors.css +341 -0
  65. data/lib/wp/wp-admin/css/colors/ocean/colors.min.css +1 -0
  66. data/lib/wp/wp-admin/css/colors/ocean/colors.scss +8 -0
  67. data/lib/wp/wp-admin/css/colors/sunrise/colors-rtl.css +341 -0
  68. data/lib/wp/wp-admin/css/colors/sunrise/colors-rtl.min.css +1 -0
  69. data/lib/wp/wp-admin/css/colors/sunrise/colors.css +341 -0
  70. data/lib/wp/wp-admin/css/colors/sunrise/colors.min.css +1 -0
  71. data/lib/wp/wp-admin/css/colors/sunrise/colors.scss +6 -0
  72. data/lib/wp/wp-admin/css/common-rtl.css +3212 -0
  73. data/lib/wp/wp-admin/css/common.css +3212 -0
  74. data/lib/wp/wp-admin/css/customize-controls-rtl.css +889 -0
  75. data/lib/wp/wp-admin/css/customize-controls-rtl.min.css +1 -0
  76. data/lib/wp/wp-admin/css/customize-controls.css +889 -0
  77. data/lib/wp/wp-admin/css/customize-controls.min.css +1 -0
  78. data/lib/wp/wp-admin/css/customize-widgets-rtl.css +603 -0
  79. data/lib/wp/wp-admin/css/customize-widgets-rtl.min.css +1 -0
  80. data/lib/wp/wp-admin/css/customize-widgets.css +603 -0
  81. data/lib/wp/wp-admin/css/customize-widgets.min.css +1 -0
  82. data/lib/wp/wp-admin/css/dashboard-rtl.css +1116 -0
  83. data/lib/wp/wp-admin/css/dashboard.css +1116 -0
  84. data/lib/wp/wp-admin/css/deprecated-media-rtl.css +371 -0
  85. data/lib/wp/wp-admin/css/deprecated-media-rtl.min.css +1 -0
  86. data/lib/wp/wp-admin/css/deprecated-media.css +371 -0
  87. data/lib/wp/wp-admin/css/deprecated-media.min.css +1 -0
  88. data/lib/wp/wp-admin/css/edit-rtl.css +1501 -0
  89. data/lib/wp/wp-admin/css/edit.css +1501 -0
  90. data/lib/wp/wp-admin/css/farbtastic-rtl.css +41 -0
  91. data/lib/wp/wp-admin/css/farbtastic.css +41 -0
  92. data/lib/wp/wp-admin/css/forms-rtl.css +992 -0
  93. data/lib/wp/wp-admin/css/forms.css +992 -0
  94. data/lib/wp/wp-admin/css/ie-rtl.css +785 -0
  95. data/lib/wp/wp-admin/css/ie-rtl.min.css +1 -0
  96. data/lib/wp/wp-admin/css/ie.css +785 -0
  97. data/lib/wp/wp-admin/css/ie.min.css +1 -0
  98. data/lib/wp/wp-admin/css/install-rtl.css +389 -0
  99. data/lib/wp/wp-admin/css/install-rtl.min.css +1 -0
  100. data/lib/wp/wp-admin/css/install.css +389 -0
  101. data/lib/wp/wp-admin/css/install.min.css +1 -0
  102. data/lib/wp/wp-admin/css/l10n-rtl.css +101 -0
  103. data/lib/wp/wp-admin/css/l10n.css +101 -0
  104. data/lib/wp/wp-admin/css/list-tables-rtl.css +1875 -0
  105. data/lib/wp/wp-admin/css/list-tables.css +1875 -0
  106. data/lib/wp/wp-admin/css/login-rtl.css +269 -0
  107. data/lib/wp/wp-admin/css/login-rtl.min.css +1 -0
  108. data/lib/wp/wp-admin/css/login.css +269 -0
  109. data/lib/wp/wp-admin/css/login.min.css +1 -0
  110. data/lib/wp/wp-admin/css/media-rtl.css +1196 -0
  111. data/lib/wp/wp-admin/css/media.css +1196 -0
  112. data/lib/wp/wp-admin/css/nav-menus-rtl.css +857 -0
  113. data/lib/wp/wp-admin/css/nav-menus.css +857 -0
  114. data/lib/wp/wp-admin/css/press-this-rtl.css +458 -0
  115. data/lib/wp/wp-admin/css/press-this.css +458 -0
  116. data/lib/wp/wp-admin/css/revisions-rtl.css +574 -0
  117. data/lib/wp/wp-admin/css/revisions.css +574 -0
  118. data/lib/wp/wp-admin/css/themes-rtl.css +1732 -0
  119. data/lib/wp/wp-admin/css/themes.css +1732 -0
  120. data/lib/wp/wp-admin/css/widgets-rtl.css +577 -0
  121. data/lib/wp/wp-admin/css/widgets.css +577 -0
  122. data/lib/wp/wp-admin/css/wp-admin-rtl.css +14 -0
  123. data/lib/wp/wp-admin/css/wp-admin-rtl.min.css +1 -0
  124. data/lib/wp/wp-admin/css/wp-admin.css +14 -0
  125. data/lib/wp/wp-admin/css/wp-admin.min.css +1 -0
  126. data/lib/wp/wp-admin/custom-background.php +482 -0
  127. data/lib/wp/wp-admin/custom-header.php +1366 -0
  128. data/lib/wp/wp-admin/customize.php +278 -0
  129. data/lib/wp/wp-admin/edit-comments.php +254 -0
  130. data/lib/wp/wp-admin/edit-form-advanced.php +636 -0
  131. data/lib/wp/wp-admin/edit-form-comment.php +160 -0
  132. data/lib/wp/wp-admin/edit-link-form.php +150 -0
  133. data/lib/wp/wp-admin/edit-tag-form.php +204 -0
  134. data/lib/wp/wp-admin/edit-tags.php +591 -0
  135. data/lib/wp/wp-admin/edit.php +330 -0
  136. data/lib/wp/wp-admin/export.php +243 -0
  137. data/lib/wp/wp-admin/freedoms.php +57 -0
  138. data/lib/wp/wp-admin/images/align-center-2x.png +0 -0
  139. data/lib/wp/wp-admin/images/align-center.png +0 -0
  140. data/lib/wp/wp-admin/images/align-left-2x.png +0 -0
  141. data/lib/wp/wp-admin/images/align-left.png +0 -0
  142. data/lib/wp/wp-admin/images/align-none-2x.png +0 -0
  143. data/lib/wp/wp-admin/images/align-none.png +0 -0
  144. data/lib/wp/wp-admin/images/align-right-2x.png +0 -0
  145. data/lib/wp/wp-admin/images/align-right.png +0 -0
  146. data/lib/wp/wp-admin/images/arrows-2x.png +0 -0
  147. data/lib/wp/wp-admin/images/arrows.png +0 -0
  148. data/lib/wp/wp-admin/images/bubble_bg-2x.gif +0 -0
  149. data/lib/wp/wp-admin/images/bubble_bg.gif +0 -0
  150. data/lib/wp/wp-admin/images/comment-grey-bubble-2x.png +0 -0
  151. data/lib/wp/wp-admin/images/comment-grey-bubble.png +0 -0
  152. data/lib/wp/wp-admin/images/date-button-2x.gif +0 -0
  153. data/lib/wp/wp-admin/images/date-button.gif +0 -0
  154. data/lib/wp/wp-admin/images/generic.png +0 -0
  155. data/lib/wp/wp-admin/images/icons32-2x.png +0 -0
  156. data/lib/wp/wp-admin/images/icons32-vs-2x.png +0 -0
  157. data/lib/wp/wp-admin/images/icons32-vs.png +0 -0
  158. data/lib/wp/wp-admin/images/icons32.png +0 -0
  159. data/lib/wp/wp-admin/images/imgedit-icons-2x.png +0 -0
  160. data/lib/wp/wp-admin/images/imgedit-icons.png +0 -0
  161. data/lib/wp/wp-admin/images/list-2x.png +0 -0
  162. data/lib/wp/wp-admin/images/list.png +0 -0
  163. data/lib/wp/wp-admin/images/loading.gif +0 -0
  164. data/lib/wp/wp-admin/images/marker.png +0 -0
  165. data/lib/wp/wp-admin/images/mask.png +0 -0
  166. data/lib/wp/wp-admin/images/media-button-2x.png +0 -0
  167. data/lib/wp/wp-admin/images/media-button-image.gif +0 -0
  168. data/lib/wp/wp-admin/images/media-button-music.gif +0 -0
  169. data/lib/wp/wp-admin/images/media-button-other.gif +0 -0
  170. data/lib/wp/wp-admin/images/media-button-video.gif +0 -0
  171. data/lib/wp/wp-admin/images/media-button.png +0 -0
  172. data/lib/wp/wp-admin/images/menu-2x.png +0 -0
  173. data/lib/wp/wp-admin/images/menu-vs-2x.png +0 -0
  174. data/lib/wp/wp-admin/images/menu-vs.png +0 -0
  175. data/lib/wp/wp-admin/images/menu.png +0 -0
  176. data/lib/wp/wp-admin/images/no.png +0 -0
  177. data/lib/wp/wp-admin/images/post-formats-vs.png +0 -0
  178. data/lib/wp/wp-admin/images/post-formats.png +0 -0
  179. data/lib/wp/wp-admin/images/post-formats32-vs.png +0 -0
  180. data/lib/wp/wp-admin/images/post-formats32.png +0 -0
  181. data/lib/wp/wp-admin/images/resize-2x.gif +0 -0
  182. data/lib/wp/wp-admin/images/resize-rtl-2x.gif +0 -0
  183. data/lib/wp/wp-admin/images/resize-rtl.gif +0 -0
  184. data/lib/wp/wp-admin/images/resize.gif +0 -0
  185. data/lib/wp/wp-admin/images/se.png +0 -0
  186. data/lib/wp/wp-admin/images/sort-2x.gif +0 -0
  187. data/lib/wp/wp-admin/images/sort.gif +0 -0
  188. data/lib/wp/wp-admin/images/spinner-2x.gif +0 -0
  189. data/lib/wp/wp-admin/images/spinner.gif +0 -0
  190. data/lib/wp/wp-admin/images/stars-2x.png +0 -0
  191. data/lib/wp/wp-admin/images/stars.png +0 -0
  192. data/lib/wp/wp-admin/images/w-logo-blue.png +0 -0
  193. data/lib/wp/wp-admin/images/w-logo-white.png +0 -0
  194. data/lib/wp/wp-admin/images/wheel.png +0 -0
  195. data/lib/wp/wp-admin/images/wordpress-logo-white.svg +1 -0
  196. data/lib/wp/wp-admin/images/wordpress-logo.png +0 -0
  197. data/lib/wp/wp-admin/images/wordpress-logo.svg +1 -0
  198. data/lib/wp/wp-admin/images/wpspin_light-2x.gif +0 -0
  199. data/lib/wp/wp-admin/images/wpspin_light.gif +0 -0
  200. data/lib/wp/wp-admin/images/xit-2x.gif +0 -0
  201. data/lib/wp/wp-admin/images/xit.gif +0 -0
  202. data/lib/wp/wp-admin/images/yes.png +0 -0
  203. data/lib/wp/wp-admin/import.php +132 -0
  204. data/lib/wp/wp-admin/includes/admin.php +74 -0
  205. data/lib/wp/wp-admin/includes/ajax-actions.php +2762 -0
  206. data/lib/wp/wp-admin/includes/bookmark.php +305 -0
  207. data/lib/wp/wp-admin/includes/class-ftp-pure.php +190 -0
  208. data/lib/wp/wp-admin/includes/class-ftp-sockets.php +250 -0
  209. data/lib/wp/wp-admin/includes/class-ftp.php +907 -0
  210. data/lib/wp/wp-admin/includes/class-pclzip.php +5687 -0
  211. data/lib/wp/wp-admin/includes/class-wp-comments-list-table.php +637 -0
  212. data/lib/wp/wp-admin/includes/class-wp-filesystem-base.php +815 -0
  213. data/lib/wp/wp-admin/includes/class-wp-filesystem-direct.php +384 -0
  214. data/lib/wp/wp-admin/includes/class-wp-filesystem-ftpext.php +415 -0
  215. data/lib/wp/wp-admin/includes/class-wp-filesystem-ftpsockets.php +352 -0
  216. data/lib/wp/wp-admin/includes/class-wp-filesystem-ssh2.php +392 -0
  217. data/lib/wp/wp-admin/includes/class-wp-importer.php +302 -0
  218. data/lib/wp/wp-admin/includes/class-wp-links-list-table.php +207 -0
  219. data/lib/wp/wp-admin/includes/class-wp-list-table.php +1080 -0
  220. data/lib/wp/wp-admin/includes/class-wp-media-list-table.php +574 -0
  221. data/lib/wp/wp-admin/includes/class-wp-ms-sites-list-table.php +402 -0
  222. data/lib/wp/wp-admin/includes/class-wp-ms-themes-list-table.php +459 -0
  223. data/lib/wp/wp-admin/includes/class-wp-ms-users-list-table.php +303 -0
  224. data/lib/wp/wp-admin/includes/class-wp-plugin-install-list-table.php +490 -0
  225. data/lib/wp/wp-admin/includes/class-wp-plugins-list-table.php +605 -0
  226. data/lib/wp/wp-admin/includes/class-wp-posts-list-table.php +1306 -0
  227. data/lib/wp/wp-admin/includes/class-wp-terms-list-table.php +466 -0
  228. data/lib/wp/wp-admin/includes/class-wp-theme-install-list-table.php +431 -0
  229. data/lib/wp/wp-admin/includes/class-wp-themes-list-table.php +279 -0
  230. data/lib/wp/wp-admin/includes/class-wp-upgrader-skins.php +767 -0
  231. data/lib/wp/wp-admin/includes/class-wp-upgrader.php +2676 -0
  232. data/lib/wp/wp-admin/includes/class-wp-users-list-table.php +459 -0
  233. data/lib/wp/wp-admin/includes/comment.php +171 -0
  234. data/lib/wp/wp-admin/includes/continents-cities.php +493 -0
  235. data/lib/wp/wp-admin/includes/dashboard.php +1333 -0
  236. data/lib/wp/wp-admin/includes/deprecated.php +1190 -0
  237. data/lib/wp/wp-admin/includes/export.php +508 -0
  238. data/lib/wp/wp-admin/includes/file.php +1152 -0
  239. data/lib/wp/wp-admin/includes/image-edit.php +828 -0
  240. data/lib/wp/wp-admin/includes/image.php +598 -0
  241. data/lib/wp/wp-admin/includes/import.php +206 -0
  242. data/lib/wp/wp-admin/includes/list-table.php +113 -0
  243. data/lib/wp/wp-admin/includes/media.php +3012 -0
  244. data/lib/wp/wp-admin/includes/menu.php +322 -0
  245. data/lib/wp/wp-admin/includes/meta-boxes.php +1119 -0
  246. data/lib/wp/wp-admin/includes/misc.php +845 -0
  247. data/lib/wp/wp-admin/includes/ms-deprecated.php +78 -0
  248. data/lib/wp/wp-admin/includes/ms.php +814 -0
  249. data/lib/wp/wp-admin/includes/nav-menu.php +1328 -0
  250. data/lib/wp/wp-admin/includes/plugin-install.php +550 -0
  251. data/lib/wp/wp-admin/includes/plugin.php +1899 -0
  252. data/lib/wp/wp-admin/includes/post.php +1661 -0
  253. data/lib/wp/wp-admin/includes/revision.php +228 -0
  254. data/lib/wp/wp-admin/includes/schema.php +1038 -0
  255. data/lib/wp/wp-admin/includes/screen.php +1179 -0
  256. data/lib/wp/wp-admin/includes/taxonomy.php +284 -0
  257. data/lib/wp/wp-admin/includes/template.php +2157 -0
  258. data/lib/wp/wp-admin/includes/theme-install.php +205 -0
  259. data/lib/wp/wp-admin/includes/theme.php +474 -0
  260. data/lib/wp/wp-admin/includes/translation-install.php +240 -0
  261. data/lib/wp/wp-admin/includes/update-core.php +1186 -0
  262. data/lib/wp/wp-admin/includes/update.php +432 -0
  263. data/lib/wp/wp-admin/includes/upgrade.php +2218 -0
  264. data/lib/wp/wp-admin/includes/user.php +442 -0
  265. data/lib/wp/wp-admin/includes/widgets.php +245 -0
  266. data/lib/wp/wp-admin/index.php +131 -0
  267. data/lib/wp/wp-admin/install-helper.php +199 -0
  268. data/lib/wp/wp-admin/install.php +305 -0
  269. data/lib/wp/wp-admin/js/accordion.js +143 -0
  270. data/lib/wp/wp-admin/js/accordion.min.js +1 -0
  271. data/lib/wp/wp-admin/js/color-picker.js +155 -0
  272. data/lib/wp/wp-admin/js/color-picker.min.js +1 -0
  273. data/lib/wp/wp-admin/js/comment.js +50 -0
  274. data/lib/wp/wp-admin/js/comment.min.js +1 -0
  275. data/lib/wp/wp-admin/js/common.js +804 -0
  276. data/lib/wp/wp-admin/js/common.min.js +1 -0
  277. data/lib/wp/wp-admin/js/custom-background.js +75 -0
  278. data/lib/wp/wp-admin/js/custom-background.min.js +1 -0
  279. data/lib/wp/wp-admin/js/custom-header.js +61 -0
  280. data/lib/wp/wp-admin/js/customize-controls.js +1305 -0
  281. data/lib/wp/wp-admin/js/customize-controls.min.js +1 -0
  282. data/lib/wp/wp-admin/js/customize-widgets.js +1882 -0
  283. data/lib/wp/wp-admin/js/customize-widgets.min.js +1 -0
  284. data/lib/wp/wp-admin/js/dashboard.js +190 -0
  285. data/lib/wp/wp-admin/js/dashboard.min.js +1 -0
  286. data/lib/wp/wp-admin/js/edit-comments.js +625 -0
  287. data/lib/wp/wp-admin/js/edit-comments.min.js +1 -0
  288. data/lib/wp/wp-admin/js/editor-expand.js +705 -0
  289. data/lib/wp/wp-admin/js/editor-expand.min.js +1 -0
  290. data/lib/wp/wp-admin/js/editor.js +324 -0
  291. data/lib/wp/wp-admin/js/editor.min.js +1 -0
  292. data/lib/wp/wp-admin/js/farbtastic.js +276 -0
  293. data/lib/wp/wp-admin/js/gallery.js +237 -0
  294. data/lib/wp/wp-admin/js/gallery.min.js +1 -0
  295. data/lib/wp/wp-admin/js/image-edit.js +633 -0
  296. data/lib/wp/wp-admin/js/image-edit.min.js +1 -0
  297. data/lib/wp/wp-admin/js/inline-edit-post.js +359 -0
  298. data/lib/wp/wp-admin/js/inline-edit-post.min.js +1 -0
  299. data/lib/wp/wp-admin/js/inline-edit-tax.js +142 -0
  300. data/lib/wp/wp-admin/js/inline-edit-tax.min.js +1 -0
  301. data/lib/wp/wp-admin/js/iris.min.js +4 -0
  302. data/lib/wp/wp-admin/js/language-chooser.js +26 -0
  303. data/lib/wp/wp-admin/js/language-chooser.min.js +1 -0
  304. data/lib/wp/wp-admin/js/link.js +69 -0
  305. data/lib/wp/wp-admin/js/link.min.js +1 -0
  306. data/lib/wp/wp-admin/js/media-gallery.js +26 -0
  307. data/lib/wp/wp-admin/js/media-gallery.min.js +1 -0
  308. data/lib/wp/wp-admin/js/media-upload.js +69 -0
  309. data/lib/wp/wp-admin/js/media-upload.min.js +1 -0
  310. data/lib/wp/wp-admin/js/media.js +111 -0
  311. data/lib/wp/wp-admin/js/media.min.js +1 -0
  312. data/lib/wp/wp-admin/js/nav-menu.js +1205 -0
  313. data/lib/wp/wp-admin/js/nav-menu.min.js +1 -0
  314. data/lib/wp/wp-admin/js/password-strength-meter.js +75 -0
  315. data/lib/wp/wp-admin/js/password-strength-meter.min.js +1 -0
  316. data/lib/wp/wp-admin/js/plugin-install.js +76 -0
  317. data/lib/wp/wp-admin/js/plugin-install.min.js +1 -0
  318. data/lib/wp/wp-admin/js/post.js +1094 -0
  319. data/lib/wp/wp-admin/js/post.min.js +1 -0
  320. data/lib/wp/wp-admin/js/postbox.js +199 -0
  321. data/lib/wp/wp-admin/js/postbox.min.js +1 -0
  322. data/lib/wp/wp-admin/js/revisions.js +1110 -0
  323. data/lib/wp/wp-admin/js/revisions.min.js +1 -0
  324. data/lib/wp/wp-admin/js/set-post-thumbnail.js +24 -0
  325. data/lib/wp/wp-admin/js/set-post-thumbnail.min.js +1 -0
  326. data/lib/wp/wp-admin/js/svg-painter.js +240 -0
  327. data/lib/wp/wp-admin/js/svg-painter.min.js +1 -0
  328. data/lib/wp/wp-admin/js/tags.js +72 -0
  329. data/lib/wp/wp-admin/js/tags.min.js +1 -0
  330. data/lib/wp/wp-admin/js/theme.js +1691 -0
  331. data/lib/wp/wp-admin/js/theme.min.js +1 -0
  332. data/lib/wp/wp-admin/js/updates.js +65 -0
  333. data/lib/wp/wp-admin/js/updates.min.js +1 -0
  334. data/lib/wp/wp-admin/js/user-profile.js +127 -0
  335. data/lib/wp/wp-admin/js/user-profile.min.js +1 -0
  336. data/lib/wp/wp-admin/js/user-suggest.js +30 -0
  337. data/lib/wp/wp-admin/js/user-suggest.min.js +1 -0
  338. data/lib/wp/wp-admin/js/widgets.js +494 -0
  339. data/lib/wp/wp-admin/js/widgets.min.js +1 -0
  340. data/lib/wp/wp-admin/js/word-count.js +44 -0
  341. data/lib/wp/wp-admin/js/word-count.min.js +1 -0
  342. data/lib/wp/wp-admin/js/wp-fullscreen.js +704 -0
  343. data/lib/wp/wp-admin/js/wp-fullscreen.min.js +1 -0
  344. data/lib/wp/wp-admin/js/xfn.js +17 -0
  345. data/lib/wp/wp-admin/js/xfn.min.js +1 -0
  346. data/lib/wp/wp-admin/link-add.php +29 -0
  347. data/lib/wp/wp-admin/link-manager.php +99 -0
  348. data/lib/wp/wp-admin/link-parse-opml.php +84 -0
  349. data/lib/wp/wp-admin/link.php +117 -0
  350. data/lib/wp/wp-admin/load-scripts.php +162 -0
  351. data/lib/wp/wp-admin/load-styles.php +153 -0
  352. data/lib/wp/wp-admin/maint/repair.php +124 -0
  353. data/lib/wp/wp-admin/media-new.php +84 -0
  354. data/lib/wp/wp-admin/media-upload.php +100 -0
  355. data/lib/wp/wp-admin/media.php +146 -0
  356. data/lib/wp/wp-admin/menu-header.php +227 -0
  357. data/lib/wp/wp-admin/menu.php +255 -0
  358. data/lib/wp/wp-admin/moderation.php +12 -0
  359. data/lib/wp/wp-admin/ms-admin.php +13 -0
  360. data/lib/wp/wp-admin/ms-delete-site.php +91 -0
  361. data/lib/wp/wp-admin/ms-edit.php +13 -0
  362. data/lib/wp/wp-admin/ms-options.php +12 -0
  363. data/lib/wp/wp-admin/ms-sites.php +13 -0
  364. data/lib/wp/wp-admin/ms-themes.php +13 -0
  365. data/lib/wp/wp-admin/ms-upgrade-network.php +13 -0
  366. data/lib/wp/wp-admin/ms-users.php +13 -0
  367. data/lib/wp/wp-admin/my-sites.php +145 -0
  368. data/lib/wp/wp-admin/nav-menus.php +798 -0
  369. data/lib/wp/wp-admin/network.php +561 -0
  370. data/lib/wp/wp-admin/network/about.php +16 -0
  371. data/lib/wp/wp-admin/network/admin.php +32 -0
  372. data/lib/wp/wp-admin/network/credits.php +16 -0
  373. data/lib/wp/wp-admin/network/edit.php +42 -0
  374. data/lib/wp/wp-admin/network/freedoms.php +16 -0
  375. data/lib/wp/wp-admin/network/index.php +79 -0
  376. data/lib/wp/wp-admin/network/menu.php +63 -0
  377. data/lib/wp/wp-admin/network/plugin-editor.php +16 -0
  378. data/lib/wp/wp-admin/network/plugin-install.php +19 -0
  379. data/lib/wp/wp-admin/network/plugins.php +16 -0
  380. data/lib/wp/wp-admin/network/profile.php +16 -0
  381. data/lib/wp/wp-admin/network/settings.php +347 -0
  382. data/lib/wp/wp-admin/network/setup.php +16 -0
  383. data/lib/wp/wp-admin/network/site-info.php +178 -0
  384. data/lib/wp/wp-admin/network/site-new.php +153 -0
  385. data/lib/wp/wp-admin/network/site-settings.php +173 -0
  386. data/lib/wp/wp-admin/network/site-themes.php +185 -0
  387. data/lib/wp/wp-admin/network/site-users.php +319 -0
  388. data/lib/wp/wp-admin/network/sites.php +275 -0
  389. data/lib/wp/wp-admin/network/theme-editor.php +16 -0
  390. data/lib/wp/wp-admin/network/theme-install.php +19 -0
  391. data/lib/wp/wp-admin/network/themes.php +291 -0
  392. data/lib/wp/wp-admin/network/update-core.php +16 -0
  393. data/lib/wp/wp-admin/network/update.php +19 -0
  394. data/lib/wp/wp-admin/network/upgrade.php +120 -0
  395. data/lib/wp/wp-admin/network/user-edit.php +16 -0
  396. data/lib/wp/wp-admin/network/user-new.php +106 -0
  397. data/lib/wp/wp-admin/network/users.php +296 -0
  398. data/lib/wp/wp-admin/options-discussion.php +273 -0
  399. data/lib/wp/wp-admin/options-general.php +355 -0
  400. data/lib/wp/wp-admin/options-head.php +18 -0
  401. data/lib/wp/wp-admin/options-media.php +136 -0
  402. data/lib/wp/wp-admin/options-permalink.php +289 -0
  403. data/lib/wp/wp-admin/options-reading.php +184 -0
  404. data/lib/wp/wp-admin/options-writing.php +194 -0
  405. data/lib/wp/wp-admin/options.php +265 -0
  406. data/lib/wp/wp-admin/plugin-editor.php +279 -0
  407. data/lib/wp/wp-admin/plugin-install.php +134 -0
  408. data/lib/wp/wp-admin/plugins.php +474 -0
  409. data/lib/wp/wp-admin/post-new.php +74 -0
  410. data/lib/wp/wp-admin/post.php +318 -0
  411. data/lib/wp/wp-admin/press-this.php +691 -0
  412. data/lib/wp/wp-admin/profile.php +18 -0
  413. data/lib/wp/wp-admin/revision.php +221 -0
  414. data/lib/wp/wp-admin/setup-config.php +345 -0
  415. data/lib/wp/wp-admin/theme-editor.php +243 -0
  416. data/lib/wp/wp-admin/theme-install.php +278 -0
  417. data/lib/wp/wp-admin/themes.php +374 -0
  418. data/lib/wp/wp-admin/tools.php +75 -0
  419. data/lib/wp/wp-admin/update-core.php +653 -0
  420. data/lib/wp/wp-admin/update.php +272 -0
  421. data/lib/wp/wp-admin/upgrade-functions.php +12 -0
  422. data/lib/wp/wp-admin/upgrade.php +116 -0
  423. data/lib/wp/wp-admin/upload.php +292 -0
  424. data/lib/wp/wp-admin/user-edit.php +557 -0
  425. data/lib/wp/wp-admin/user-new.php +439 -0
  426. data/lib/wp/wp-admin/user/about.php +13 -0
  427. data/lib/wp/wp-admin/user/admin.php +32 -0
  428. data/lib/wp/wp-admin/user/credits.php +13 -0
  429. data/lib/wp/wp-admin/user/freedoms.php +13 -0
  430. data/lib/wp/wp-admin/user/index.php +12 -0
  431. data/lib/wp/wp-admin/user/menu.php +22 -0
  432. data/lib/wp/wp-admin/user/profile.php +12 -0
  433. data/lib/wp/wp-admin/user/user-edit.php +12 -0
  434. data/lib/wp/wp-admin/users.php +460 -0
  435. data/lib/wp/wp-admin/widgets.php +442 -0
  436. data/lib/wp/wp-blog-header.php +18 -0
  437. data/lib/wp/wp-comments-post.php +164 -0
  438. data/lib/wp/wp-config-sample.php +80 -0
  439. data/lib/wp/wp-content/index.php +2 -0
  440. data/lib/wp/wp-content/plugins/hello.php +82 -0
  441. data/lib/wp/wp-content/plugins/index.php +2 -0
  442. data/lib/wp/wp-content/themes/index.php +2 -0
  443. data/lib/wp/wp-content/themes/stump/.editorconfig +11 -0
  444. data/lib/wp/wp-content/themes/stump/.jshintrc +16 -0
  445. data/lib/wp/wp-content/themes/stump/404.php +13 -0
  446. data/lib/wp/wp-content/themes/stump/CHANGELOG.md +333 -0
  447. data/lib/wp/wp-content/themes/stump/CONTRIBUTING.md +121 -0
  448. data/lib/wp/wp-content/themes/stump/Gruntfile.js +151 -0
  449. data/lib/wp/wp-content/themes/stump/LICENSE.md +19 -0
  450. data/lib/wp/wp-content/themes/stump/assets/coffee/build/.gitkeep +0 -0
  451. data/lib/wp/wp-content/themes/stump/assets/coffee/build/site.js +6 -0
  452. data/lib/wp/wp-content/themes/stump/assets/css/editor-style.css +548 -0
  453. data/lib/wp/wp-content/themes/stump/assets/css/main.min.css +4 -0
  454. data/lib/wp/wp-content/themes/stump/assets/css/main.min.css.map +7 -0
  455. data/lib/wp/wp-content/themes/stump/assets/fonts/glyphicons-halflings-regular.eot +0 -0
  456. data/lib/wp/wp-content/themes/stump/assets/fonts/glyphicons-halflings-regular.svg +229 -0
  457. data/lib/wp/wp-content/themes/stump/assets/fonts/glyphicons-halflings-regular.ttf +0 -0
  458. data/lib/wp/wp-content/themes/stump/assets/fonts/glyphicons-halflings-regular.woff +0 -0
  459. data/lib/wp/wp-content/themes/stump/assets/img/.gitignore +0 -0
  460. data/lib/wp/wp-content/themes/stump/assets/js/_main.js +63 -0
  461. data/lib/wp/wp-content/themes/stump/assets/js/plugins/bootstrap/affix.js +137 -0
  462. data/lib/wp/wp-content/themes/stump/assets/js/plugins/bootstrap/alert.js +88 -0
  463. data/lib/wp/wp-content/themes/stump/assets/js/plugins/bootstrap/button.js +107 -0
  464. data/lib/wp/wp-content/themes/stump/assets/js/plugins/bootstrap/carousel.js +205 -0
  465. data/lib/wp/wp-content/themes/stump/assets/js/plugins/bootstrap/collapse.js +170 -0
  466. data/lib/wp/wp-content/themes/stump/assets/js/plugins/bootstrap/dropdown.js +147 -0
  467. data/lib/wp/wp-content/themes/stump/assets/js/plugins/bootstrap/modal.js +243 -0
  468. data/lib/wp/wp-content/themes/stump/assets/js/plugins/bootstrap/popover.js +110 -0
  469. data/lib/wp/wp-content/themes/stump/assets/js/plugins/bootstrap/scrollspy.js +153 -0
  470. data/lib/wp/wp-content/themes/stump/assets/js/plugins/bootstrap/tab.js +125 -0
  471. data/lib/wp/wp-content/themes/stump/assets/js/plugins/bootstrap/tooltip.js +399 -0
  472. data/lib/wp/wp-content/themes/stump/assets/js/plugins/bootstrap/transition.js +48 -0
  473. data/lib/wp/wp-content/themes/stump/assets/js/scripts.min.js +1 -0
  474. data/lib/wp/wp-content/themes/stump/assets/js/vendor/jquery-1.11.0.min.js +4 -0
  475. data/lib/wp/wp-content/themes/stump/assets/js/vendor/modernizr-2.7.0.min.js +4 -0
  476. data/lib/wp/wp-content/themes/stump/assets/sass/app.scss +9 -0
  477. data/lib/wp/wp-content/themes/stump/assets/sass/core/_variables.scss +1 -0
  478. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_alerts.scss +67 -0
  479. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_badges.scss +55 -0
  480. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_bootstrap.scss +49 -0
  481. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_breadcrumbs.scss +26 -0
  482. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_button-groups.scss +226 -0
  483. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_buttons.scss +159 -0
  484. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_carousel.scss +232 -0
  485. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_close.scss +35 -0
  486. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_code.scss +63 -0
  487. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_component-animations.scss +29 -0
  488. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_dropdowns.scss +213 -0
  489. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_forms.scss +436 -0
  490. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_glyphicons.scss +233 -0
  491. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_grid.scss +84 -0
  492. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_input-groups.scss +162 -0
  493. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_jumbotron.scss +44 -0
  494. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_labels.scss +64 -0
  495. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_list-group.scss +110 -0
  496. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_media.scss +56 -0
  497. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_mixins.scss +947 -0
  498. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_modals.scss +139 -0
  499. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_navbar.scss +620 -0
  500. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_navs.scss +242 -0
  501. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_normalize.scss +423 -0
  502. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_pager.scss +55 -0
  503. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_pagination.scss +88 -0
  504. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_panels.scss +241 -0
  505. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_popovers.scss +133 -0
  506. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_print.scss +101 -0
  507. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_progress-bars.scss +80 -0
  508. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_responsive-utilities.scss +74 -0
  509. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_scaffolding.scss +134 -0
  510. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_tables.scss +233 -0
  511. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_theme.scss +247 -0
  512. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_thumbnails.scss +38 -0
  513. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_tooltip.scss +95 -0
  514. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_type.scss +284 -0
  515. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_utilities.scss +56 -0
  516. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_variables.scss +833 -0
  517. data/lib/wp/wp-content/themes/stump/assets/vendor/bootstrap/_wells.scss +29 -0
  518. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/_bourbon-deprecated-upcoming.scss +13 -0
  519. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/_bourbon.scss +59 -0
  520. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/addons/_button.scss +273 -0
  521. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/addons/_clearfix.scss +29 -0
  522. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/addons/_font-family.scss +5 -0
  523. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/addons/_hide-text.scss +5 -0
  524. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/addons/_html5-input-types.scss +56 -0
  525. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/addons/_position.scss +42 -0
  526. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/addons/_prefixer.scss +49 -0
  527. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/addons/_retina-image.scss +32 -0
  528. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/addons/_size.scss +44 -0
  529. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/addons/_timing-functions.scss +32 -0
  530. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/addons/_triangle.scss +45 -0
  531. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_animation.scss +52 -0
  532. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_appearance.scss +3 -0
  533. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_backface-visibility.scss +6 -0
  534. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_background-image.scss +48 -0
  535. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_background.scss +103 -0
  536. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_border-image.scss +55 -0
  537. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_border-radius.scss +22 -0
  538. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_box-sizing.scss +4 -0
  539. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_columns.scss +47 -0
  540. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_flex-box.scss +52 -0
  541. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_font-face.scss +23 -0
  542. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_hidpi-media-query.scss +10 -0
  543. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_image-rendering.scss +13 -0
  544. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_inline-block.scss +8 -0
  545. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_keyframes.scss +43 -0
  546. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_linear-gradient.scss +41 -0
  547. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_perspective.scss +8 -0
  548. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_placeholder.scss +29 -0
  549. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_radial-gradient.scss +44 -0
  550. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_transform.scss +15 -0
  551. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_transition.scss +34 -0
  552. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/css3/_user-select.scss +3 -0
  553. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/functions/_compact.scss +11 -0
  554. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/functions/_flex-grid.scss +39 -0
  555. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/functions/_grid-width.scss +13 -0
  556. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/functions/_linear-gradient.scss +13 -0
  557. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/functions/_modular-scale.scss +40 -0
  558. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/functions/_px-to-em.scss +8 -0
  559. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/functions/_radial-gradient.scss +23 -0
  560. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/functions/_tint-shade.scss +9 -0
  561. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/functions/_transition-property-name.scss +22 -0
  562. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/helpers/_deprecated-webkit-gradient.scss +39 -0
  563. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/helpers/_gradient-positions-parser.scss +13 -0
  564. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/helpers/_linear-positions-parser.scss +61 -0
  565. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/helpers/_radial-arg-parser.scss +69 -0
  566. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/helpers/_radial-positions-parser.scss +18 -0
  567. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/helpers/_render-gradients.scss +26 -0
  568. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/bourbon/helpers/_shape-size-stripper.scss +10 -0
  569. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/manhattan.sass +11 -0
  570. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/manhattan/_grid.sass +161 -0
  571. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/manhattan/_mixins.sass +63 -0
  572. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/manhattan/_utilities.sass +24 -0
  573. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/manhattan/_variables.sass +42 -0
  574. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/_neat-helpers.scss +8 -0
  575. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/_neat.scss +21 -0
  576. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/functions/_new-breakpoint.scss +16 -0
  577. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/functions/_private.scss +107 -0
  578. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/functions/_px-to-em.scss +3 -0
  579. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/grid/_fill-parent.scss +7 -0
  580. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/grid/_grid.scss +5 -0
  581. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/grid/_media.scss +51 -0
  582. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/grid/_omega.scss +79 -0
  583. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/grid/_outer-container.scss +8 -0
  584. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/grid/_pad.scss +8 -0
  585. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/grid/_private.scss +50 -0
  586. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/grid/_reset.scss +12 -0
  587. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/grid/_row.scss +17 -0
  588. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/grid/_shift.scss +9 -0
  589. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/grid/_span-columns.scss +38 -0
  590. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/grid/_to-deprecate.scss +57 -0
  591. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/grid/_visual-grid.scss +41 -0
  592. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/settings/_grid.scss +7 -0
  593. data/lib/wp/wp-content/themes/stump/assets/vendor/manhattan/neat/settings/_visual-grid.scss +5 -0
  594. data/lib/wp/wp-content/themes/stump/base.php +36 -0
  595. data/lib/wp/wp-content/themes/stump/functions.php +19 -0
  596. data/lib/wp/wp-content/themes/stump/index.php +21 -0
  597. data/lib/wp/wp-content/themes/stump/lang/ar.mo +0 -0
  598. data/lib/wp/wp-content/themes/stump/lang/ar.po +270 -0
  599. data/lib/wp/wp-content/themes/stump/lang/bg_BG.mo +0 -0
  600. data/lib/wp/wp-content/themes/stump/lang/bg_BG.po +338 -0
  601. data/lib/wp/wp-content/themes/stump/lang/ca.mo +0 -0
  602. data/lib/wp/wp-content/themes/stump/lang/ca.po +517 -0
  603. data/lib/wp/wp-content/themes/stump/lang/da_DK.mo +0 -0
  604. data/lib/wp/wp-content/themes/stump/lang/da_DK.po +305 -0
  605. data/lib/wp/wp-content/themes/stump/lang/de_DE.mo +0 -0
  606. data/lib/wp/wp-content/themes/stump/lang/de_DE.po +271 -0
  607. data/lib/wp/wp-content/themes/stump/lang/el.mo +0 -0
  608. data/lib/wp/wp-content/themes/stump/lang/el.po +319 -0
  609. data/lib/wp/wp-content/themes/stump/lang/es_ES.mo +0 -0
  610. data/lib/wp/wp-content/themes/stump/lang/es_ES.po +270 -0
  611. data/lib/wp/wp-content/themes/stump/lang/et.mo +0 -0
  612. data/lib/wp/wp-content/themes/stump/lang/et.po +262 -0
  613. data/lib/wp/wp-content/themes/stump/lang/fa_IR.mo +0 -0
  614. data/lib/wp/wp-content/themes/stump/lang/fa_IR.po +273 -0
  615. data/lib/wp/wp-content/themes/stump/lang/fi_FI.mo +0 -0
  616. data/lib/wp/wp-content/themes/stump/lang/fi_FI.po +367 -0
  617. data/lib/wp/wp-content/themes/stump/lang/fr_FR.mo +0 -0
  618. data/lib/wp/wp-content/themes/stump/lang/fr_FR.po +336 -0
  619. data/lib/wp/wp-content/themes/stump/lang/he_IL.mo +0 -0
  620. data/lib/wp/wp-content/themes/stump/lang/he_IL.po +336 -0
  621. data/lib/wp/wp-content/themes/stump/lang/hu_HU.mo +0 -0
  622. data/lib/wp/wp-content/themes/stump/lang/hu_HU.po +271 -0
  623. data/lib/wp/wp-content/themes/stump/lang/id_ID.mo +0 -0
  624. data/lib/wp/wp-content/themes/stump/lang/id_ID.po +278 -0
  625. data/lib/wp/wp-content/themes/stump/lang/it_IT.mo +0 -0
  626. data/lib/wp/wp-content/themes/stump/lang/it_IT.po +269 -0
  627. data/lib/wp/wp-content/themes/stump/lang/ja.mo +0 -0
  628. data/lib/wp/wp-content/themes/stump/lang/ja.po +267 -0
  629. data/lib/wp/wp-content/themes/stump/lang/ko_KR.mo +0 -0
  630. data/lib/wp/wp-content/themes/stump/lang/ko_KR.po +282 -0
  631. data/lib/wp/wp-content/themes/stump/lang/mk_MK.mo +0 -0
  632. data/lib/wp/wp-content/themes/stump/lang/mk_MK.po +297 -0
  633. data/lib/wp/wp-content/themes/stump/lang/ms_MY.mo +0 -0
  634. data/lib/wp/wp-content/themes/stump/lang/ms_MY.po +342 -0
  635. data/lib/wp/wp-content/themes/stump/lang/nb_NO.mo +0 -0
  636. data/lib/wp/wp-content/themes/stump/lang/nb_NO.po +517 -0
  637. data/lib/wp/wp-content/themes/stump/lang/nl_NL.mo +0 -0
  638. data/lib/wp/wp-content/themes/stump/lang/nl_NL.po +261 -0
  639. data/lib/wp/wp-content/themes/stump/lang/nn_NO.mo +0 -0
  640. data/lib/wp/wp-content/themes/stump/lang/nn_NO.po +517 -0
  641. data/lib/wp/wp-content/themes/stump/lang/pl_PL.mo +0 -0
  642. data/lib/wp/wp-content/themes/stump/lang/pl_PL.po +283 -0
  643. data/lib/wp/wp-content/themes/stump/lang/pt_BR.mo +0 -0
  644. data/lib/wp/wp-content/themes/stump/lang/pt_BR.po +394 -0
  645. data/lib/wp/wp-content/themes/stump/lang/ro_RO.mo +0 -0
  646. data/lib/wp/wp-content/themes/stump/lang/ro_RO.po +271 -0
  647. data/lib/wp/wp-content/themes/stump/lang/roots.pot +244 -0
  648. data/lib/wp/wp-content/themes/stump/lang/ru_RU.mo +0 -0
  649. data/lib/wp/wp-content/themes/stump/lang/ru_RU.po +255 -0
  650. data/lib/wp/wp-content/themes/stump/lang/sk_SK.mo +0 -0
  651. data/lib/wp/wp-content/themes/stump/lang/sk_SK.po +267 -0
  652. data/lib/wp/wp-content/themes/stump/lang/sr_RS.mo +0 -0
  653. data/lib/wp/wp-content/themes/stump/lang/sr_RS.pot +261 -0
  654. data/lib/wp/wp-content/themes/stump/lang/sv_SE.mo +0 -0
  655. data/lib/wp/wp-content/themes/stump/lang/sv_SE.po +323 -0
  656. data/lib/wp/wp-content/themes/stump/lang/tr_TR.mo +0 -0
  657. data/lib/wp/wp-content/themes/stump/lang/tr_TR.po +405 -0
  658. data/lib/wp/wp-content/themes/stump/lang/vi_VN.mo +0 -0
  659. data/lib/wp/wp-content/themes/stump/lang/vi_VN.po +516 -0
  660. data/lib/wp/wp-content/themes/stump/lang/zh_CN.mo +0 -0
  661. data/lib/wp/wp-content/themes/stump/lang/zh_CN.po +329 -0
  662. data/lib/wp/wp-content/themes/stump/lang/zh_TW.mo +0 -0
  663. data/lib/wp/wp-content/themes/stump/lang/zh_TW.po +261 -0
  664. data/lib/wp/wp-content/themes/stump/lib/activation.php +215 -0
  665. data/lib/wp/wp-content/themes/stump/lib/cleanup.php +261 -0
  666. data/lib/wp/wp-content/themes/stump/lib/comments.php +52 -0
  667. data/lib/wp/wp-content/themes/stump/lib/config.php +79 -0
  668. data/lib/wp/wp-content/themes/stump/lib/custom.php +4 -0
  669. data/lib/wp/wp-content/themes/stump/lib/gallery.php +130 -0
  670. data/lib/wp/wp-content/themes/stump/lib/init.php +25 -0
  671. data/lib/wp/wp-content/themes/stump/lib/nav.php +93 -0
  672. data/lib/wp/wp-content/themes/stump/lib/relative-urls.php +50 -0
  673. data/lib/wp/wp-content/themes/stump/lib/scripts.php +67 -0
  674. data/lib/wp/wp-content/themes/stump/lib/sidebar.php +43 -0
  675. data/lib/wp/wp-content/themes/stump/lib/titles.php +37 -0
  676. data/lib/wp/wp-content/themes/stump/lib/utils.php +14 -0
  677. data/lib/wp/wp-content/themes/stump/lib/widgets.php +133 -0
  678. data/lib/wp/wp-content/themes/stump/lib/wrapper.php +49 -0
  679. data/lib/wp/wp-content/themes/stump/package.json +32 -0
  680. data/lib/wp/wp-content/themes/stump/page.php +2 -0
  681. data/lib/wp/wp-content/themes/stump/screenshot.png +0 -0
  682. data/lib/wp/wp-content/themes/stump/single.php +1 -0
  683. data/lib/wp/wp-content/themes/stump/style.css +11 -0
  684. data/lib/wp/wp-content/themes/stump/template-custom.php +8 -0
  685. data/lib/wp/wp-content/themes/stump/templates/comment.php +14 -0
  686. data/lib/wp/wp-content/themes/stump/templates/comments.php +80 -0
  687. data/lib/wp/wp-content/themes/stump/templates/content-page.php +4 -0
  688. data/lib/wp/wp-content/themes/stump/templates/content-single.php +15 -0
  689. data/lib/wp/wp-content/themes/stump/templates/content.php +9 -0
  690. data/lib/wp/wp-content/themes/stump/templates/entry-meta.php +2 -0
  691. data/lib/wp/wp-content/themes/stump/templates/footer.php +8 -0
  692. data/lib/wp/wp-content/themes/stump/templates/head.php +12 -0
  693. data/lib/wp/wp-content/themes/stump/templates/header-top-navbar.php +21 -0
  694. data/lib/wp/wp-content/themes/stump/templates/header.php +14 -0
  695. data/lib/wp/wp-content/themes/stump/templates/page-header.php +5 -0
  696. data/lib/wp/wp-content/themes/stump/templates/searchform.php +9 -0
  697. data/lib/wp/wp-content/themes/stump/templates/sidebar.php +1 -0
  698. data/lib/wp/wp-content/themes/twentyfourteen/404.php +32 -0
  699. data/lib/wp/wp-content/themes/twentyfourteen/archive.php +74 -0
  700. data/lib/wp/wp-content/themes/twentyfourteen/author.php +74 -0
  701. data/lib/wp/wp-content/themes/twentyfourteen/category.php +58 -0
  702. data/lib/wp/wp-content/themes/twentyfourteen/comments.php +66 -0
  703. data/lib/wp/wp-content/themes/twentyfourteen/content-aside.php +57 -0
  704. data/lib/wp/wp-content/themes/twentyfourteen/content-audio.php +57 -0
  705. data/lib/wp/wp-content/themes/twentyfourteen/content-featured-post.php +34 -0
  706. data/lib/wp/wp-content/themes/twentyfourteen/content-gallery.php +57 -0
  707. data/lib/wp/wp-content/themes/twentyfourteen/content-image.php +57 -0
  708. data/lib/wp/wp-content/themes/twentyfourteen/content-link.php +57 -0
  709. data/lib/wp/wp-content/themes/twentyfourteen/content-none.php +31 -0
  710. data/lib/wp/wp-content/themes/twentyfourteen/content-page.php +31 -0
  711. data/lib/wp/wp-content/themes/twentyfourteen/content-quote.php +57 -0
  712. data/lib/wp/wp-content/themes/twentyfourteen/content-video.php +57 -0
  713. data/lib/wp/wp-content/themes/twentyfourteen/content.php +66 -0
  714. data/lib/wp/wp-content/themes/twentyfourteen/css/editor-style.css +717 -0
  715. data/lib/wp/wp-content/themes/twentyfourteen/css/ie.css +1335 -0
  716. data/lib/wp/wp-content/themes/twentyfourteen/featured-content.php +39 -0
  717. data/lib/wp/wp-content/themes/twentyfourteen/footer.php +28 -0
  718. data/lib/wp/wp-content/themes/twentyfourteen/functions.php +519 -0
  719. data/lib/wp/wp-content/themes/twentyfourteen/genericons/COPYING.txt +9 -0
  720. data/lib/wp/wp-content/themes/twentyfourteen/genericons/Genericons-Regular.otf +0 -0
  721. data/lib/wp/wp-content/themes/twentyfourteen/genericons/LICENSE.txt +339 -0
  722. data/lib/wp/wp-content/themes/twentyfourteen/genericons/README.txt +123 -0
  723. data/lib/wp/wp-content/themes/twentyfourteen/genericons/example.html +464 -0
  724. data/lib/wp/wp-content/themes/twentyfourteen/genericons/font/genericons-regular-webfont.eot +0 -0
  725. data/lib/wp/wp-content/themes/twentyfourteen/genericons/font/genericons-regular-webfont.svg +135 -0
  726. data/lib/wp/wp-content/themes/twentyfourteen/genericons/font/genericons-regular-webfont.ttf +0 -0
  727. data/lib/wp/wp-content/themes/twentyfourteen/genericons/font/genericons-regular-webfont.woff +0 -0
  728. data/lib/wp/wp-content/themes/twentyfourteen/genericons/genericons.css +197 -0
  729. data/lib/wp/wp-content/themes/twentyfourteen/header.php +65 -0
  730. data/lib/wp/wp-content/themes/twentyfourteen/image.php +79 -0
  731. data/lib/wp/wp-content/themes/twentyfourteen/images/pattern-dark.svg +16 -0
  732. data/lib/wp/wp-content/themes/twentyfourteen/images/pattern-light.svg +6 -0
  733. data/lib/wp/wp-content/themes/twentyfourteen/inc/back-compat.php +63 -0
  734. data/lib/wp/wp-content/themes/twentyfourteen/inc/custom-header.php +147 -0
  735. data/lib/wp/wp-content/themes/twentyfourteen/inc/customizer.php +114 -0
  736. data/lib/wp/wp-content/themes/twentyfourteen/inc/featured-content.php +531 -0
  737. data/lib/wp/wp-content/themes/twentyfourteen/inc/template-tags.php +203 -0
  738. data/lib/wp/wp-content/themes/twentyfourteen/inc/widgets.php +269 -0
  739. data/lib/wp/wp-content/themes/twentyfourteen/index.php +61 -0
  740. data/lib/wp/wp-content/themes/twentyfourteen/js/customizer.js +38 -0
  741. data/lib/wp/wp-content/themes/twentyfourteen/js/featured-content-admin.js +9 -0
  742. data/lib/wp/wp-content/themes/twentyfourteen/js/functions.js +134 -0
  743. data/lib/wp/wp-content/themes/twentyfourteen/js/html5.js +8 -0
  744. data/lib/wp/wp-content/themes/twentyfourteen/js/keyboard-image-navigation.js +21 -0
  745. data/lib/wp/wp-content/themes/twentyfourteen/js/slider.js +598 -0
  746. data/lib/wp/wp-content/themes/twentyfourteen/languages/twentyfourteen.pot +467 -0
  747. data/lib/wp/wp-content/themes/twentyfourteen/page-templates/contributors.php +52 -0
  748. data/lib/wp/wp-content/themes/twentyfourteen/page-templates/full-width.php +42 -0
  749. data/lib/wp/wp-content/themes/twentyfourteen/page.php +48 -0
  750. data/lib/wp/wp-content/themes/twentyfourteen/rtl.css +854 -0
  751. data/lib/wp/wp-content/themes/twentyfourteen/screenshot.png +0 -0
  752. data/lib/wp/wp-content/themes/twentyfourteen/search.php +49 -0
  753. data/lib/wp/wp-content/themes/twentyfourteen/sidebar-content.php +16 -0
  754. data/lib/wp/wp-content/themes/twentyfourteen/sidebar-footer.php +19 -0
  755. data/lib/wp/wp-content/themes/twentyfourteen/sidebar.php +29 -0
  756. data/lib/wp/wp-content/themes/twentyfourteen/single.php +40 -0
  757. data/lib/wp/wp-content/themes/twentyfourteen/style.css +4321 -0
  758. data/lib/wp/wp-content/themes/twentyfourteen/tag.php +60 -0
  759. data/lib/wp/wp-content/themes/twentyfourteen/taxonomy-post_format.php +85 -0
  760. data/lib/wp/wp-cron.php +115 -0
  761. data/lib/wp/wp-includes/ID3/getid3.lib.php +1376 -0
  762. data/lib/wp/wp-includes/ID3/getid3.php +1796 -0
  763. data/lib/wp/wp-includes/ID3/license.commercial.txt +27 -0
  764. data/lib/wp/wp-includes/ID3/license.txt +29 -0
  765. data/lib/wp/wp-includes/ID3/module.audio-video.asf.php +2013 -0
  766. data/lib/wp/wp-includes/ID3/module.audio-video.flv.php +745 -0
  767. data/lib/wp/wp-includes/ID3/module.audio-video.matroska.php +1751 -0
  768. data/lib/wp/wp-includes/ID3/module.audio-video.quicktime.php +2246 -0
  769. data/lib/wp/wp-includes/ID3/module.audio-video.riff.php +2586 -0
  770. data/lib/wp/wp-includes/ID3/module.audio.ac3.php +474 -0
  771. data/lib/wp/wp-includes/ID3/module.audio.dts.php +291 -0
  772. data/lib/wp/wp-includes/ID3/module.audio.flac.php +443 -0
  773. data/lib/wp/wp-includes/ID3/module.audio.mp3.php +2012 -0
  774. data/lib/wp/wp-includes/ID3/module.audio.ogg.php +756 -0
  775. data/lib/wp/wp-includes/ID3/module.tag.apetag.php +371 -0
  776. data/lib/wp/wp-includes/ID3/module.tag.id3v1.php +360 -0
  777. data/lib/wp/wp-includes/ID3/module.tag.id3v2.php +3424 -0
  778. data/lib/wp/wp-includes/ID3/module.tag.lyrics3.php +294 -0
  779. data/lib/wp/wp-includes/ID3/readme.txt +604 -0
  780. data/lib/wp/wp-includes/SimplePie/Author.php +157 -0
  781. data/lib/wp/wp-includes/SimplePie/Cache.php +133 -0
  782. data/lib/wp/wp-includes/SimplePie/Cache/Base.php +114 -0
  783. data/lib/wp/wp-includes/SimplePie/Cache/DB.php +137 -0
  784. data/lib/wp/wp-includes/SimplePie/Cache/File.php +173 -0
  785. data/lib/wp/wp-includes/SimplePie/Cache/Memcache.php +183 -0
  786. data/lib/wp/wp-includes/SimplePie/Cache/MySQL.php +438 -0
  787. data/lib/wp/wp-includes/SimplePie/Caption.php +210 -0
  788. data/lib/wp/wp-includes/SimplePie/Category.php +157 -0
  789. data/lib/wp/wp-includes/SimplePie/Content/Type/Sniffer.php +332 -0
  790. data/lib/wp/wp-includes/SimplePie/Copyright.php +130 -0
  791. data/lib/wp/wp-includes/SimplePie/Core.php +57 -0
  792. data/lib/wp/wp-includes/SimplePie/Credit.php +156 -0
  793. data/lib/wp/wp-includes/SimplePie/Decode/HTML/Entities.php +617 -0
  794. data/lib/wp/wp-includes/SimplePie/Enclosure.php +1380 -0
  795. data/lib/wp/wp-includes/SimplePie/Exception.php +52 -0
  796. data/lib/wp/wp-includes/SimplePie/File.php +292 -0
  797. data/lib/wp/wp-includes/SimplePie/HTTP/Parser.php +500 -0
  798. data/lib/wp/wp-includes/SimplePie/IRI.php +1238 -0
  799. data/lib/wp/wp-includes/SimplePie/Item.php +2964 -0
  800. data/lib/wp/wp-includes/SimplePie/Locator.php +372 -0
  801. data/lib/wp/wp-includes/SimplePie/Misc.php +2247 -0
  802. data/lib/wp/wp-includes/SimplePie/Net/IPv6.php +276 -0
  803. data/lib/wp/wp-includes/SimplePie/Parse/Date.php +983 -0
  804. data/lib/wp/wp-includes/SimplePie/Parser.php +407 -0
  805. data/lib/wp/wp-includes/SimplePie/Rating.php +129 -0
  806. data/lib/wp/wp-includes/SimplePie/Registry.php +225 -0
  807. data/lib/wp/wp-includes/SimplePie/Restriction.php +155 -0
  808. data/lib/wp/wp-includes/SimplePie/Sanitize.php +554 -0
  809. data/lib/wp/wp-includes/SimplePie/Source.php +611 -0
  810. data/lib/wp/wp-includes/SimplePie/XML/Declaration/Parser.php +362 -0
  811. data/lib/wp/wp-includes/SimplePie/gzdecode.php +371 -0
  812. data/lib/wp/wp-includes/Text/Diff.php +450 -0
  813. data/lib/wp/wp-includes/Text/Diff/Engine/native.php +436 -0
  814. data/lib/wp/wp-includes/Text/Diff/Engine/shell.php +162 -0
  815. data/lib/wp/wp-includes/Text/Diff/Engine/string.php +248 -0
  816. data/lib/wp/wp-includes/Text/Diff/Engine/xdiff.php +64 -0
  817. data/lib/wp/wp-includes/Text/Diff/Renderer.php +235 -0
  818. data/lib/wp/wp-includes/Text/Diff/Renderer/inline.php +206 -0
  819. data/lib/wp/wp-includes/admin-bar.php +870 -0
  820. data/lib/wp/wp-includes/atomlib.php +352 -0
  821. data/lib/wp/wp-includes/author-template.php +471 -0
  822. data/lib/wp/wp-includes/bookmark-template.php +298 -0
  823. data/lib/wp/wp-includes/bookmark.php +416 -0
  824. data/lib/wp/wp-includes/cache.php +704 -0
  825. data/lib/wp/wp-includes/canonical.php +586 -0
  826. data/lib/wp/wp-includes/capabilities.php +1539 -0
  827. data/lib/wp/wp-includes/category-template.php +1407 -0
  828. data/lib/wp/wp-includes/category.php +343 -0
  829. data/lib/wp/wp-includes/certificates/ca-bundle.crt +3785 -0
  830. data/lib/wp/wp-includes/class-IXR.php +1100 -0
  831. data/lib/wp/wp-includes/class-feed.php +140 -0
  832. data/lib/wp/wp-includes/class-http.php +2245 -0
  833. data/lib/wp/wp-includes/class-json.php +936 -0
  834. data/lib/wp/wp-includes/class-oembed.php +579 -0
  835. data/lib/wp/wp-includes/class-phpass.php +260 -0
  836. data/lib/wp/wp-includes/class-phpmailer.php +3265 -0
  837. data/lib/wp/wp-includes/class-pop3.php +652 -0
  838. data/lib/wp/wp-includes/class-simplepie.php +3119 -0
  839. data/lib/wp/wp-includes/class-smtp.php +943 -0
  840. data/lib/wp/wp-includes/class-snoopy.php +1256 -0
  841. data/lib/wp/wp-includes/class-wp-admin-bar.php +517 -0
  842. data/lib/wp/wp-includes/class-wp-ajax-response.php +199 -0
  843. data/lib/wp/wp-includes/class-wp-customize-control.php +1124 -0
  844. data/lib/wp/wp-includes/class-wp-customize-manager.php +1272 -0
  845. data/lib/wp/wp-includes/class-wp-customize-panel.php +200 -0
  846. data/lib/wp/wp-includes/class-wp-customize-section.php +196 -0
  847. data/lib/wp/wp-includes/class-wp-customize-setting.php +554 -0
  848. data/lib/wp/wp-includes/class-wp-customize-widgets.php +1556 -0
  849. data/lib/wp/wp-includes/class-wp-editor.php +1435 -0
  850. data/lib/wp/wp-includes/class-wp-embed.php +373 -0
  851. data/lib/wp/wp-includes/class-wp-error.php +276 -0
  852. data/lib/wp/wp-includes/class-wp-http-ixr-client.php +97 -0
  853. data/lib/wp/wp-includes/class-wp-image-editor-gd.php +459 -0
  854. data/lib/wp/wp-includes/class-wp-image-editor-imagick.php +512 -0
  855. data/lib/wp/wp-includes/class-wp-image-editor.php +475 -0
  856. data/lib/wp/wp-includes/class-wp-theme.php +1235 -0
  857. data/lib/wp/wp-includes/class-wp-walker.php +471 -0
  858. data/lib/wp/wp-includes/class-wp-xmlrpc-server.php +5984 -0
  859. data/lib/wp/wp-includes/class-wp.php +782 -0
  860. data/lib/wp/wp-includes/class.wp-dependencies.php +509 -0
  861. data/lib/wp/wp-includes/class.wp-scripts.php +247 -0
  862. data/lib/wp/wp-includes/class.wp-styles.php +210 -0
  863. data/lib/wp/wp-includes/comment-template.php +2286 -0
  864. data/lib/wp/wp-includes/comment.php +2606 -0
  865. data/lib/wp/wp-includes/compat.php +125 -0
  866. data/lib/wp/wp-includes/cron.php +469 -0
  867. data/lib/wp/wp-includes/css/admin-bar-rtl.css +1099 -0
  868. data/lib/wp/wp-includes/css/admin-bar-rtl.min.css +1 -0
  869. data/lib/wp/wp-includes/css/admin-bar.css +1099 -0
  870. data/lib/wp/wp-includes/css/admin-bar.min.css +1 -0
  871. data/lib/wp/wp-includes/css/buttons-rtl.css +364 -0
  872. data/lib/wp/wp-includes/css/buttons-rtl.min.css +1 -0
  873. data/lib/wp/wp-includes/css/buttons.css +364 -0
  874. data/lib/wp/wp-includes/css/buttons.min.css +1 -0
  875. data/lib/wp/wp-includes/css/dashicons.css +893 -0
  876. data/lib/wp/wp-includes/css/dashicons.min.css +1 -0
  877. data/lib/wp/wp-includes/css/editor-rtl.css +1993 -0
  878. data/lib/wp/wp-includes/css/editor-rtl.min.css +1 -0
  879. data/lib/wp/wp-includes/css/editor.css +1993 -0
  880. data/lib/wp/wp-includes/css/editor.min.css +1 -0
  881. data/lib/wp/wp-includes/css/jquery-ui-dialog-rtl.css +343 -0
  882. data/lib/wp/wp-includes/css/jquery-ui-dialog-rtl.min.css +19 -0
  883. data/lib/wp/wp-includes/css/jquery-ui-dialog.css +343 -0
  884. data/lib/wp/wp-includes/css/jquery-ui-dialog.min.css +19 -0
  885. data/lib/wp/wp-includes/css/media-views-rtl.css +2568 -0
  886. data/lib/wp/wp-includes/css/media-views-rtl.min.css +1 -0
  887. data/lib/wp/wp-includes/css/media-views.css +2568 -0
  888. data/lib/wp/wp-includes/css/media-views.min.css +1 -0
  889. data/lib/wp/wp-includes/css/wp-auth-check-rtl.css +100 -0
  890. data/lib/wp/wp-includes/css/wp-auth-check-rtl.min.css +1 -0
  891. data/lib/wp/wp-includes/css/wp-auth-check.css +100 -0
  892. data/lib/wp/wp-includes/css/wp-auth-check.min.css +1 -0
  893. data/lib/wp/wp-includes/css/wp-pointer-rtl.css +212 -0
  894. data/lib/wp/wp-includes/css/wp-pointer-rtl.min.css +1 -0
  895. data/lib/wp/wp-includes/css/wp-pointer.css +212 -0
  896. data/lib/wp/wp-includes/css/wp-pointer.min.css +1 -0
  897. data/lib/wp/wp-includes/date.php +475 -0
  898. data/lib/wp/wp-includes/default-constants.php +323 -0
  899. data/lib/wp/wp-includes/default-filters.php +307 -0
  900. data/lib/wp/wp-includes/default-widgets.php +1423 -0
  901. data/lib/wp/wp-includes/deprecated.php +3501 -0
  902. data/lib/wp/wp-includes/feed-atom-comments.php +115 -0
  903. data/lib/wp/wp-includes/feed-atom.php +87 -0
  904. data/lib/wp/wp-includes/feed-rdf.php +81 -0
  905. data/lib/wp/wp-includes/feed-rss.php +46 -0
  906. data/lib/wp/wp-includes/feed-rss2-comments.php +97 -0
  907. data/lib/wp/wp-includes/feed-rss2.php +115 -0
  908. data/lib/wp/wp-includes/feed.php +659 -0
  909. data/lib/wp/wp-includes/fonts/dashicons.eot +0 -0
  910. data/lib/wp/wp-includes/fonts/dashicons.svg +250 -0
  911. data/lib/wp/wp-includes/fonts/dashicons.ttf +0 -0
  912. data/lib/wp/wp-includes/fonts/dashicons.woff +0 -0
  913. data/lib/wp/wp-includes/formatting.php +4006 -0
  914. data/lib/wp/wp-includes/functions.php +4631 -0
  915. data/lib/wp/wp-includes/functions.wp-scripts.php +258 -0
  916. data/lib/wp/wp-includes/functions.wp-styles.php +245 -0
  917. data/lib/wp/wp-includes/general-template.php +2982 -0
  918. data/lib/wp/wp-includes/http.php +551 -0
  919. data/lib/wp/wp-includes/images/admin-bar-sprite-2x.png +0 -0
  920. data/lib/wp/wp-includes/images/admin-bar-sprite.png +0 -0
  921. data/lib/wp/wp-includes/images/arrow-pointer-blue-2x.png +0 -0
  922. data/lib/wp/wp-includes/images/arrow-pointer-blue.png +0 -0
  923. data/lib/wp/wp-includes/images/blank.gif +0 -0
  924. data/lib/wp/wp-includes/images/crystal/archive.png +0 -0
  925. data/lib/wp/wp-includes/images/crystal/audio.png +0 -0
  926. data/lib/wp/wp-includes/images/crystal/code.png +0 -0
  927. data/lib/wp/wp-includes/images/crystal/default.png +0 -0
  928. data/lib/wp/wp-includes/images/crystal/document.png +0 -0
  929. data/lib/wp/wp-includes/images/crystal/interactive.png +0 -0
  930. data/lib/wp/wp-includes/images/crystal/license.txt +9 -0
  931. data/lib/wp/wp-includes/images/crystal/spreadsheet.png +0 -0
  932. data/lib/wp/wp-includes/images/crystal/text.png +0 -0
  933. data/lib/wp/wp-includes/images/crystal/video.png +0 -0
  934. data/lib/wp/wp-includes/images/down_arrow-2x.gif +0 -0
  935. data/lib/wp/wp-includes/images/down_arrow.gif +0 -0
  936. data/lib/wp/wp-includes/images/icon-pointer-flag-2x.png +0 -0
  937. data/lib/wp/wp-includes/images/icon-pointer-flag.png +0 -0
  938. data/lib/wp/wp-includes/images/media/archive.png +0 -0
  939. data/lib/wp/wp-includes/images/media/audio.png +0 -0
  940. data/lib/wp/wp-includes/images/media/code.png +0 -0
  941. data/lib/wp/wp-includes/images/media/default.png +0 -0
  942. data/lib/wp/wp-includes/images/media/document.png +0 -0
  943. data/lib/wp/wp-includes/images/media/interactive.png +0 -0
  944. data/lib/wp/wp-includes/images/media/spreadsheet.png +0 -0
  945. data/lib/wp/wp-includes/images/media/text.png +0 -0
  946. data/lib/wp/wp-includes/images/media/video.png +0 -0
  947. data/lib/wp/wp-includes/images/rss-2x.png +0 -0
  948. data/lib/wp/wp-includes/images/rss.png +0 -0
  949. data/lib/wp/wp-includes/images/smilies/icon_arrow.gif +0 -0
  950. data/lib/wp/wp-includes/images/smilies/icon_biggrin.gif +0 -0
  951. data/lib/wp/wp-includes/images/smilies/icon_confused.gif +0 -0
  952. data/lib/wp/wp-includes/images/smilies/icon_cool.gif +0 -0
  953. data/lib/wp/wp-includes/images/smilies/icon_cry.gif +0 -0
  954. data/lib/wp/wp-includes/images/smilies/icon_eek.gif +0 -0
  955. data/lib/wp/wp-includes/images/smilies/icon_evil.gif +0 -0
  956. data/lib/wp/wp-includes/images/smilies/icon_exclaim.gif +0 -0
  957. data/lib/wp/wp-includes/images/smilies/icon_idea.gif +0 -0
  958. data/lib/wp/wp-includes/images/smilies/icon_lol.gif +0 -0
  959. data/lib/wp/wp-includes/images/smilies/icon_mad.gif +0 -0
  960. data/lib/wp/wp-includes/images/smilies/icon_mrgreen.gif +0 -0
  961. data/lib/wp/wp-includes/images/smilies/icon_neutral.gif +0 -0
  962. data/lib/wp/wp-includes/images/smilies/icon_question.gif +0 -0
  963. data/lib/wp/wp-includes/images/smilies/icon_razz.gif +0 -0
  964. data/lib/wp/wp-includes/images/smilies/icon_redface.gif +0 -0
  965. data/lib/wp/wp-includes/images/smilies/icon_rolleyes.gif +0 -0
  966. data/lib/wp/wp-includes/images/smilies/icon_sad.gif +0 -0
  967. data/lib/wp/wp-includes/images/smilies/icon_smile.gif +0 -0
  968. data/lib/wp/wp-includes/images/smilies/icon_surprised.gif +0 -0
  969. data/lib/wp/wp-includes/images/smilies/icon_twisted.gif +0 -0
  970. data/lib/wp/wp-includes/images/smilies/icon_wink.gif +0 -0
  971. data/lib/wp/wp-includes/images/spinner-2x.gif +0 -0
  972. data/lib/wp/wp-includes/images/spinner.gif +0 -0
  973. data/lib/wp/wp-includes/images/toggle-arrow-2x.png +0 -0
  974. data/lib/wp/wp-includes/images/toggle-arrow.png +0 -0
  975. data/lib/wp/wp-includes/images/uploader-icons-2x.png +0 -0
  976. data/lib/wp/wp-includes/images/uploader-icons.png +0 -0
  977. data/lib/wp/wp-includes/images/wlw/wp-comments.png +0 -0
  978. data/lib/wp/wp-includes/images/wlw/wp-icon.png +0 -0
  979. data/lib/wp/wp-includes/images/wlw/wp-watermark.png +0 -0
  980. data/lib/wp/wp-includes/images/wpicons-2x.png +0 -0
  981. data/lib/wp/wp-includes/images/wpicons.png +0 -0
  982. data/lib/wp/wp-includes/images/wpspin-2x.gif +0 -0
  983. data/lib/wp/wp-includes/images/wpspin.gif +0 -0
  984. data/lib/wp/wp-includes/images/xit-2x.gif +0 -0
  985. data/lib/wp/wp-includes/images/xit.gif +0 -0
  986. data/lib/wp/wp-includes/js/admin-bar.js +365 -0
  987. data/lib/wp/wp-includes/js/admin-bar.min.js +1 -0
  988. data/lib/wp/wp-includes/js/autosave.js +589 -0
  989. data/lib/wp/wp-includes/js/autosave.min.js +1 -0
  990. data/lib/wp/wp-includes/js/backbone.min.js +1 -0
  991. data/lib/wp/wp-includes/js/colorpicker.js +707 -0
  992. data/lib/wp/wp-includes/js/colorpicker.min.js +1 -0
  993. data/lib/wp/wp-includes/js/comment-reply.js +47 -0
  994. data/lib/wp/wp-includes/js/comment-reply.min.js +1 -0
  995. data/lib/wp/wp-includes/js/crop/cropper.css +165 -0
  996. data/lib/wp/wp-includes/js/crop/cropper.js +516 -0
  997. data/lib/wp/wp-includes/js/crop/marqueeHoriz.gif +0 -0
  998. data/lib/wp/wp-includes/js/crop/marqueeVert.gif +0 -0
  999. data/lib/wp/wp-includes/js/customize-base.js +617 -0
  1000. data/lib/wp/wp-includes/js/customize-base.min.js +1 -0
  1001. data/lib/wp/wp-includes/js/customize-loader.js +246 -0
  1002. data/lib/wp/wp-includes/js/customize-loader.min.js +1 -0
  1003. data/lib/wp/wp-includes/js/customize-models.js +247 -0
  1004. data/lib/wp/wp-includes/js/customize-models.min.js +1 -0
  1005. data/lib/wp/wp-includes/js/customize-preview-widgets.js +129 -0
  1006. data/lib/wp/wp-includes/js/customize-preview-widgets.min.js +1 -0
  1007. data/lib/wp/wp-includes/js/customize-preview.js +154 -0
  1008. data/lib/wp/wp-includes/js/customize-preview.min.js +1 -0
  1009. data/lib/wp/wp-includes/js/customize-views.js +231 -0
  1010. data/lib/wp/wp-includes/js/customize-views.min.js +1 -0
  1011. data/lib/wp/wp-includes/js/heartbeat.js +738 -0
  1012. data/lib/wp/wp-includes/js/heartbeat.min.js +1 -0
  1013. data/lib/wp/wp-includes/js/hoverIntent.js +115 -0
  1014. data/lib/wp/wp-includes/js/hoverIntent.min.js +1 -0
  1015. data/lib/wp/wp-includes/js/imgareaselect/border-anim-h.gif +0 -0
  1016. data/lib/wp/wp-includes/js/imgareaselect/border-anim-v.gif +0 -0
  1017. data/lib/wp/wp-includes/js/imgareaselect/imgareaselect.css +41 -0
  1018. data/lib/wp/wp-includes/js/imgareaselect/jquery.imgareaselect.js +1205 -0
  1019. data/lib/wp/wp-includes/js/imgareaselect/jquery.imgareaselect.min.js +1 -0
  1020. data/lib/wp/wp-includes/js/jcrop/Jcrop.gif +0 -0
  1021. data/lib/wp/wp-includes/js/jcrop/jquery.Jcrop.min.css +29 -0
  1022. data/lib/wp/wp-includes/js/jcrop/jquery.Jcrop.min.js +22 -0
  1023. data/lib/wp/wp-includes/js/jquery/jquery-migrate.js +521 -0
  1024. data/lib/wp/wp-includes/js/jquery/jquery-migrate.min.js +2 -0
  1025. data/lib/wp/wp-includes/js/jquery/jquery.color.min.js +2 -0
  1026. data/lib/wp/wp-includes/js/jquery/jquery.form.js +1193 -0
  1027. data/lib/wp/wp-includes/js/jquery/jquery.form.min.js +11 -0
  1028. data/lib/wp/wp-includes/js/jquery/jquery.hotkeys.js +134 -0
  1029. data/lib/wp/wp-includes/js/jquery/jquery.hotkeys.min.js +1 -0
  1030. data/lib/wp/wp-includes/js/jquery/jquery.js +5 -0
  1031. data/lib/wp/wp-includes/js/jquery/jquery.masonry.min.js +11 -0
  1032. data/lib/wp/wp-includes/js/jquery/jquery.query.js +11 -0
  1033. data/lib/wp/wp-includes/js/jquery/jquery.schedule.js +36 -0
  1034. data/lib/wp/wp-includes/js/jquery/jquery.serialize-object.js +31 -0
  1035. data/lib/wp/wp-includes/js/jquery/jquery.table-hotkeys.js +99 -0
  1036. data/lib/wp/wp-includes/js/jquery/jquery.table-hotkeys.min.js +1 -0
  1037. data/lib/wp/wp-includes/js/jquery/jquery.ui.touch-punch.js +11 -0
  1038. data/lib/wp/wp-includes/js/jquery/suggest.js +316 -0
  1039. data/lib/wp/wp-includes/js/jquery/suggest.min.js +1 -0
  1040. data/lib/wp/wp-includes/js/jquery/ui/accordion.min.js +11 -0
  1041. data/lib/wp/wp-includes/js/jquery/ui/autocomplete.min.js +11 -0
  1042. data/lib/wp/wp-includes/js/jquery/ui/button.min.js +11 -0
  1043. data/lib/wp/wp-includes/js/jquery/ui/core.min.js +11 -0
  1044. data/lib/wp/wp-includes/js/jquery/ui/datepicker.min.js +12 -0
  1045. data/lib/wp/wp-includes/js/jquery/ui/dialog.min.js +11 -0
  1046. data/lib/wp/wp-includes/js/jquery/ui/draggable.min.js +11 -0
  1047. data/lib/wp/wp-includes/js/jquery/ui/droppable.min.js +11 -0
  1048. data/lib/wp/wp-includes/js/jquery/ui/effect-blind.min.js +11 -0
  1049. data/lib/wp/wp-includes/js/jquery/ui/effect-bounce.min.js +11 -0
  1050. data/lib/wp/wp-includes/js/jquery/ui/effect-clip.min.js +11 -0
  1051. data/lib/wp/wp-includes/js/jquery/ui/effect-drop.min.js +11 -0
  1052. data/lib/wp/wp-includes/js/jquery/ui/effect-explode.min.js +11 -0
  1053. data/lib/wp/wp-includes/js/jquery/ui/effect-fade.min.js +11 -0
  1054. data/lib/wp/wp-includes/js/jquery/ui/effect-fold.min.js +11 -0
  1055. data/lib/wp/wp-includes/js/jquery/ui/effect-highlight.min.js +11 -0
  1056. data/lib/wp/wp-includes/js/jquery/ui/effect-puff.min.js +11 -0
  1057. data/lib/wp/wp-includes/js/jquery/ui/effect-pulsate.min.js +11 -0
  1058. data/lib/wp/wp-includes/js/jquery/ui/effect-scale.min.js +11 -0
  1059. data/lib/wp/wp-includes/js/jquery/ui/effect-shake.min.js +11 -0
  1060. data/lib/wp/wp-includes/js/jquery/ui/effect-size.min.js +11 -0
  1061. data/lib/wp/wp-includes/js/jquery/ui/effect-slide.min.js +11 -0
  1062. data/lib/wp/wp-includes/js/jquery/ui/effect-transfer.min.js +11 -0
  1063. data/lib/wp/wp-includes/js/jquery/ui/effect.min.js +21 -0
  1064. data/lib/wp/wp-includes/js/jquery/ui/menu.min.js +11 -0
  1065. data/lib/wp/wp-includes/js/jquery/ui/mouse.min.js +11 -0
  1066. data/lib/wp/wp-includes/js/jquery/ui/position.min.js +11 -0
  1067. data/lib/wp/wp-includes/js/jquery/ui/progressbar.min.js +11 -0
  1068. data/lib/wp/wp-includes/js/jquery/ui/resizable.min.js +11 -0
  1069. data/lib/wp/wp-includes/js/jquery/ui/selectable.min.js +11 -0
  1070. data/lib/wp/wp-includes/js/jquery/ui/selectmenu.min.js +11 -0
  1071. data/lib/wp/wp-includes/js/jquery/ui/slider.min.js +11 -0
  1072. data/lib/wp/wp-includes/js/jquery/ui/sortable.min.js +11 -0
  1073. data/lib/wp/wp-includes/js/jquery/ui/spinner.min.js +11 -0
  1074. data/lib/wp/wp-includes/js/jquery/ui/tabs.min.js +11 -0
  1075. data/lib/wp/wp-includes/js/jquery/ui/tooltip.min.js +11 -0
  1076. data/lib/wp/wp-includes/js/jquery/ui/widget.min.js +11 -0
  1077. data/lib/wp/wp-includes/js/json2.js +480 -0
  1078. data/lib/wp/wp-includes/js/json2.min.js +1 -0
  1079. data/lib/wp/wp-includes/js/masonry.min.js +1 -0
  1080. data/lib/wp/wp-includes/js/mce-view.js +829 -0
  1081. data/lib/wp/wp-includes/js/mce-view.min.js +1 -0
  1082. data/lib/wp/wp-includes/js/media-audiovideo.js +831 -0
  1083. data/lib/wp/wp-includes/js/media-audiovideo.min.js +1 -0
  1084. data/lib/wp/wp-includes/js/media-editor.js +1114 -0
  1085. data/lib/wp/wp-includes/js/media-editor.min.js +1 -0
  1086. data/lib/wp/wp-includes/js/media-grid.js +732 -0
  1087. data/lib/wp/wp-includes/js/media-grid.min.js +1 -0
  1088. data/lib/wp/wp-includes/js/media-models.js +1362 -0
  1089. data/lib/wp/wp-includes/js/media-models.min.js +1 -0
  1090. data/lib/wp/wp-includes/js/media-views.js +7484 -0
  1091. data/lib/wp/wp-includes/js/media-views.min.js +3 -0
  1092. data/lib/wp/wp-includes/js/mediaelement/background.png +0 -0
  1093. data/lib/wp/wp-includes/js/mediaelement/bigplay.png +0 -0
  1094. data/lib/wp/wp-includes/js/mediaelement/bigplay.svg +1 -0
  1095. data/lib/wp/wp-includes/js/mediaelement/controls.png +0 -0
  1096. data/lib/wp/wp-includes/js/mediaelement/controls.svg +1 -0
  1097. data/lib/wp/wp-includes/js/mediaelement/flashmediaelement.swf +0 -0
  1098. data/lib/wp/wp-includes/js/mediaelement/loading.gif +0 -0
  1099. data/lib/wp/wp-includes/js/mediaelement/mediaelement-and-player.min.js +181 -0
  1100. data/lib/wp/wp-includes/js/mediaelement/mediaelementplayer.min.css +1 -0
  1101. data/lib/wp/wp-includes/js/mediaelement/silverlightmediaelement.xap +0 -0
  1102. data/lib/wp/wp-includes/js/mediaelement/wp-mediaelement.css +274 -0
  1103. data/lib/wp/wp-includes/js/mediaelement/wp-mediaelement.js +34 -0
  1104. data/lib/wp/wp-includes/js/mediaelement/wp-playlist.js +175 -0
  1105. data/lib/wp/wp-includes/js/plupload/handlers.js +488 -0
  1106. data/lib/wp/wp-includes/js/plupload/handlers.min.js +1 -0
  1107. data/lib/wp/wp-includes/js/plupload/license.txt +339 -0
  1108. data/lib/wp/wp-includes/js/plupload/plupload.flash.swf +0 -0
  1109. data/lib/wp/wp-includes/js/plupload/plupload.full.min.js +28 -0
  1110. data/lib/wp/wp-includes/js/plupload/plupload.silverlight.xap +0 -0
  1111. data/lib/wp/wp-includes/js/plupload/wp-plupload.js +376 -0
  1112. data/lib/wp/wp-includes/js/plupload/wp-plupload.min.js +1 -0
  1113. data/lib/wp/wp-includes/js/quicktags.js +652 -0
  1114. data/lib/wp/wp-includes/js/quicktags.min.js +1 -0
  1115. data/lib/wp/wp-includes/js/shortcode.js +356 -0
  1116. data/lib/wp/wp-includes/js/shortcode.min.js +1 -0
  1117. data/lib/wp/wp-includes/js/swfobject.js +4 -0
  1118. data/lib/wp/wp-includes/js/swfupload/handlers.js +376 -0
  1119. data/lib/wp/wp-includes/js/swfupload/handlers.min.js +1 -0
  1120. data/lib/wp/wp-includes/js/swfupload/license.txt +32 -0
  1121. data/lib/wp/wp-includes/js/swfupload/plugins/swfupload.cookies.js +53 -0
  1122. data/lib/wp/wp-includes/js/swfupload/plugins/swfupload.queue.js +98 -0
  1123. data/lib/wp/wp-includes/js/swfupload/plugins/swfupload.speed.js +342 -0
  1124. data/lib/wp/wp-includes/js/swfupload/plugins/swfupload.swfobject.js +105 -0
  1125. data/lib/wp/wp-includes/js/swfupload/swfupload.js +980 -0
  1126. data/lib/wp/wp-includes/js/swfupload/swfupload.swf +0 -0
  1127. data/lib/wp/wp-includes/js/thickbox/loadingAnimation.gif +0 -0
  1128. data/lib/wp/wp-includes/js/thickbox/macFFBgHack.png +0 -0
  1129. data/lib/wp/wp-includes/js/thickbox/thickbox.css +138 -0
  1130. data/lib/wp/wp-includes/js/thickbox/thickbox.js +314 -0
  1131. data/lib/wp/wp-includes/js/tinymce/langs/wp-langs-en.js +519 -0
  1132. data/lib/wp/wp-includes/js/tinymce/license.txt +504 -0
  1133. data/lib/wp/wp-includes/js/tinymce/plugins/charmap/plugin.js +370 -0
  1134. data/lib/wp/wp-includes/js/tinymce/plugins/charmap/plugin.min.js +1 -0
  1135. data/lib/wp/wp-includes/js/tinymce/plugins/colorpicker/plugin.js +112 -0
  1136. data/lib/wp/wp-includes/js/tinymce/plugins/colorpicker/plugin.min.js +1 -0
  1137. data/lib/wp/wp-includes/js/tinymce/plugins/compat3x/css/dialog.css +212 -0
  1138. data/lib/wp/wp-includes/js/tinymce/plugins/compat3x/plugin.js +304 -0
  1139. data/lib/wp/wp-includes/js/tinymce/plugins/compat3x/plugin.min.js +1 -0
  1140. data/lib/wp/wp-includes/js/tinymce/plugins/directionality/plugin.js +64 -0
  1141. data/lib/wp/wp-includes/js/tinymce/plugins/directionality/plugin.min.js +1 -0
  1142. data/lib/wp/wp-includes/js/tinymce/plugins/fullscreen/plugin.js +136 -0
  1143. data/lib/wp/wp-includes/js/tinymce/plugins/fullscreen/plugin.min.js +1 -0
  1144. data/lib/wp/wp-includes/js/tinymce/plugins/hr/plugin.js +30 -0
  1145. data/lib/wp/wp-includes/js/tinymce/plugins/hr/plugin.min.js +1 -0
  1146. data/lib/wp/wp-includes/js/tinymce/plugins/image/plugin.js +450 -0
  1147. data/lib/wp/wp-includes/js/tinymce/plugins/image/plugin.min.js +1 -0
  1148. data/lib/wp/wp-includes/js/tinymce/plugins/lists/plugin.js +786 -0
  1149. data/lib/wp/wp-includes/js/tinymce/plugins/lists/plugin.min.js +1 -0
  1150. data/lib/wp/wp-includes/js/tinymce/plugins/media/moxieplayer.swf +0 -0
  1151. data/lib/wp/wp-includes/js/tinymce/plugins/media/plugin.js +774 -0
  1152. data/lib/wp/wp-includes/js/tinymce/plugins/media/plugin.min.js +1 -0
  1153. data/lib/wp/wp-includes/js/tinymce/plugins/paste/plugin.js +1553 -0
  1154. data/lib/wp/wp-includes/js/tinymce/plugins/paste/plugin.min.js +1 -0
  1155. data/lib/wp/wp-includes/js/tinymce/plugins/tabfocus/plugin.js +125 -0
  1156. data/lib/wp/wp-includes/js/tinymce/plugins/tabfocus/plugin.min.js +1 -0
  1157. data/lib/wp/wp-includes/js/tinymce/plugins/textcolor/plugin.js +272 -0
  1158. data/lib/wp/wp-includes/js/tinymce/plugins/textcolor/plugin.min.js +1 -0
  1159. data/lib/wp/wp-includes/js/tinymce/plugins/wordpress/plugin.js +513 -0
  1160. data/lib/wp/wp-includes/js/tinymce/plugins/wordpress/plugin.min.js +1 -0
  1161. data/lib/wp/wp-includes/js/tinymce/plugins/wpautoresize/plugin.js +207 -0
  1162. data/lib/wp/wp-includes/js/tinymce/plugins/wpautoresize/plugin.min.js +1 -0
  1163. data/lib/wp/wp-includes/js/tinymce/plugins/wpdialogs/plugin.js +92 -0
  1164. data/lib/wp/wp-includes/js/tinymce/plugins/wpdialogs/plugin.min.js +1 -0
  1165. data/lib/wp/wp-includes/js/tinymce/plugins/wpeditimage/plugin.js +1035 -0
  1166. data/lib/wp/wp-includes/js/tinymce/plugins/wpeditimage/plugin.min.js +1 -0
  1167. data/lib/wp/wp-includes/js/tinymce/plugins/wpfullscreen/plugin.js +78 -0
  1168. data/lib/wp/wp-includes/js/tinymce/plugins/wpfullscreen/plugin.min.js +1 -0
  1169. data/lib/wp/wp-includes/js/tinymce/plugins/wpgallery/plugin.js +130 -0
  1170. data/lib/wp/wp-includes/js/tinymce/plugins/wpgallery/plugin.min.js +1 -0
  1171. data/lib/wp/wp-includes/js/tinymce/plugins/wplink/plugin.js +63 -0
  1172. data/lib/wp/wp-includes/js/tinymce/plugins/wplink/plugin.min.js +1 -0
  1173. data/lib/wp/wp-includes/js/tinymce/plugins/wpview/plugin.js +694 -0
  1174. data/lib/wp/wp-includes/js/tinymce/plugins/wpview/plugin.min.js +1 -0
  1175. data/lib/wp/wp-includes/js/tinymce/skins/lightgray/content.inline.min.css +1 -0
  1176. data/lib/wp/wp-includes/js/tinymce/skins/lightgray/content.min.css +1 -0
  1177. data/lib/wp/wp-includes/js/tinymce/skins/lightgray/fonts/readme.md +1 -0
  1178. data/lib/wp/wp-includes/js/tinymce/skins/lightgray/fonts/tinymce-small.eot +0 -0
  1179. data/lib/wp/wp-includes/js/tinymce/skins/lightgray/fonts/tinymce-small.svg +62 -0
  1180. data/lib/wp/wp-includes/js/tinymce/skins/lightgray/fonts/tinymce-small.ttf +0 -0
  1181. data/lib/wp/wp-includes/js/tinymce/skins/lightgray/fonts/tinymce-small.woff +0 -0
  1182. data/lib/wp/wp-includes/js/tinymce/skins/lightgray/fonts/tinymce.eot +0 -0
  1183. data/lib/wp/wp-includes/js/tinymce/skins/lightgray/fonts/tinymce.svg +63 -0
  1184. data/lib/wp/wp-includes/js/tinymce/skins/lightgray/fonts/tinymce.ttf +0 -0
  1185. data/lib/wp/wp-includes/js/tinymce/skins/lightgray/fonts/tinymce.woff +0 -0
  1186. data/lib/wp/wp-includes/js/tinymce/skins/lightgray/img/anchor.gif +0 -0
  1187. data/lib/wp/wp-includes/js/tinymce/skins/lightgray/img/loader.gif +0 -0
  1188. data/lib/wp/wp-includes/js/tinymce/skins/lightgray/img/object.gif +0 -0
  1189. data/lib/wp/wp-includes/js/tinymce/skins/lightgray/img/trans.gif +0 -0
  1190. data/lib/wp/wp-includes/js/tinymce/skins/lightgray/skin.ie7.min.css +1 -0
  1191. data/lib/wp/wp-includes/js/tinymce/skins/lightgray/skin.min.css +1 -0
  1192. data/lib/wp/wp-includes/js/tinymce/skins/wordpress/images/audio.png +0 -0
  1193. data/lib/wp/wp-includes/js/tinymce/skins/wordpress/images/dashicon-edit.png +0 -0
  1194. data/lib/wp/wp-includes/js/tinymce/skins/wordpress/images/dashicon-no-alt.png +0 -0
  1195. data/lib/wp/wp-includes/js/tinymce/skins/wordpress/images/embedded.png +0 -0
  1196. data/lib/wp/wp-includes/js/tinymce/skins/wordpress/images/gallery-2x.png +0 -0
  1197. data/lib/wp/wp-includes/js/tinymce/skins/wordpress/images/gallery.png +0 -0
  1198. data/lib/wp/wp-includes/js/tinymce/skins/wordpress/images/more-2x.png +0 -0
  1199. data/lib/wp/wp-includes/js/tinymce/skins/wordpress/images/more.png +0 -0
  1200. data/lib/wp/wp-includes/js/tinymce/skins/wordpress/images/pagebreak-2x.png +0 -0
  1201. data/lib/wp/wp-includes/js/tinymce/skins/wordpress/images/pagebreak.png +0 -0
  1202. data/lib/wp/wp-includes/js/tinymce/skins/wordpress/images/playlist-audio.png +0 -0
  1203. data/lib/wp/wp-includes/js/tinymce/skins/wordpress/images/playlist-video.png +0 -0
  1204. data/lib/wp/wp-includes/js/tinymce/skins/wordpress/images/video.png +0 -0
  1205. data/lib/wp/wp-includes/js/tinymce/skins/wordpress/wp-content.css +618 -0
  1206. data/lib/wp/wp-includes/js/tinymce/themes/modern/theme.js +617 -0
  1207. data/lib/wp/wp-includes/js/tinymce/themes/modern/theme.min.js +1 -0
  1208. data/lib/wp/wp-includes/js/tinymce/tiny_mce_popup.js +539 -0
  1209. data/lib/wp/wp-includes/js/tinymce/tinymce.min.js +11 -0
  1210. data/lib/wp/wp-includes/js/tinymce/utils/editable_selects.js +70 -0
  1211. data/lib/wp/wp-includes/js/tinymce/utils/form_utils.js +210 -0
  1212. data/lib/wp/wp-includes/js/tinymce/utils/mctabs.js +164 -0
  1213. data/lib/wp/wp-includes/js/tinymce/utils/validate.js +252 -0
  1214. data/lib/wp/wp-includes/js/tinymce/wp-mce-help.php +145 -0
  1215. data/lib/wp/wp-includes/js/tinymce/wp-tinymce.js.gz +0 -0
  1216. data/lib/wp/wp-includes/js/tinymce/wp-tinymce.php +39 -0
  1217. data/lib/wp/wp-includes/js/tw-sack.js +193 -0
  1218. data/lib/wp/wp-includes/js/tw-sack.min.js +1 -0
  1219. data/lib/wp/wp-includes/js/underscore.min.js +1 -0
  1220. data/lib/wp/wp-includes/js/utils.js +197 -0
  1221. data/lib/wp/wp-includes/js/utils.min.js +1 -0
  1222. data/lib/wp/wp-includes/js/wp-ajax-response.js +64 -0
  1223. data/lib/wp/wp-includes/js/wp-ajax-response.min.js +1 -0
  1224. data/lib/wp/wp-includes/js/wp-auth-check.js +112 -0
  1225. data/lib/wp/wp-includes/js/wp-auth-check.min.js +1 -0
  1226. data/lib/wp/wp-includes/js/wp-backbone.js +386 -0
  1227. data/lib/wp/wp-includes/js/wp-backbone.min.js +1 -0
  1228. data/lib/wp/wp-includes/js/wp-list-revisions.js +24 -0
  1229. data/lib/wp/wp-includes/js/wp-list-revisions.min.js +1 -0
  1230. data/lib/wp/wp-includes/js/wp-lists.js +469 -0
  1231. data/lib/wp/wp-includes/js/wp-lists.min.js +1 -0
  1232. data/lib/wp/wp-includes/js/wp-pointer.js +282 -0
  1233. data/lib/wp/wp-includes/js/wp-pointer.min.js +1 -0
  1234. data/lib/wp/wp-includes/js/wp-util.js +106 -0
  1235. data/lib/wp/wp-includes/js/wp-util.min.js +1 -0
  1236. data/lib/wp/wp-includes/js/wpdialog.js +19 -0
  1237. data/lib/wp/wp-includes/js/wpdialog.min.js +1 -0
  1238. data/lib/wp/wp-includes/js/wplink.js +615 -0
  1239. data/lib/wp/wp-includes/js/wplink.min.js +1 -0
  1240. data/lib/wp/wp-includes/js/zxcvbn-async.js +18 -0
  1241. data/lib/wp/wp-includes/js/zxcvbn-async.min.js +1 -0
  1242. data/lib/wp/wp-includes/js/zxcvbn.min.js +47 -0
  1243. data/lib/wp/wp-includes/kses.php +1526 -0
  1244. data/lib/wp/wp-includes/l10n.php +908 -0
  1245. data/lib/wp/wp-includes/link-template.php +3141 -0
  1246. data/lib/wp/wp-includes/load.php +828 -0
  1247. data/lib/wp/wp-includes/locale.php +368 -0
  1248. data/lib/wp/wp-includes/media-template.php +1235 -0
  1249. data/lib/wp/wp-includes/media.php +3329 -0
  1250. data/lib/wp/wp-includes/meta.php +1221 -0
  1251. data/lib/wp/wp-includes/ms-blogs.php +939 -0
  1252. data/lib/wp/wp-includes/ms-default-constants.php +153 -0
  1253. data/lib/wp/wp-includes/ms-default-filters.php +82 -0
  1254. data/lib/wp/wp-includes/ms-deprecated.php +347 -0
  1255. data/lib/wp/wp-includes/ms-files.php +82 -0
  1256. data/lib/wp/wp-includes/ms-functions.php +2476 -0
  1257. data/lib/wp/wp-includes/ms-load.php +458 -0
  1258. data/lib/wp/wp-includes/ms-settings.php +213 -0
  1259. data/lib/wp/wp-includes/nav-menu-template.php +678 -0
  1260. data/lib/wp/wp-includes/nav-menu.php +895 -0
  1261. data/lib/wp/wp-includes/option.php +1440 -0
  1262. data/lib/wp/wp-includes/pluggable-deprecated.php +192 -0
  1263. data/lib/wp/wp-includes/pluggable.php +2283 -0
  1264. data/lib/wp/wp-includes/plugin.php +920 -0
  1265. data/lib/wp/wp-includes/pomo/entry.php +78 -0
  1266. data/lib/wp/wp-includes/pomo/mo.php +262 -0
  1267. data/lib/wp/wp-includes/pomo/po.php +384 -0
  1268. data/lib/wp/wp-includes/pomo/streams.php +209 -0
  1269. data/lib/wp/wp-includes/pomo/translations.php +275 -0
  1270. data/lib/wp/wp-includes/post-formats.php +243 -0
  1271. data/lib/wp/wp-includes/post-template.php +1766 -0
  1272. data/lib/wp/wp-includes/post-thumbnail-template.php +142 -0
  1273. data/lib/wp/wp-includes/post.php +5842 -0
  1274. data/lib/wp/wp-includes/query.php +4666 -0
  1275. data/lib/wp/wp-includes/registration-functions.php +7 -0
  1276. data/lib/wp/wp-includes/registration.php +7 -0
  1277. data/lib/wp/wp-includes/revision.php +657 -0
  1278. data/lib/wp/wp-includes/rewrite.php +2180 -0
  1279. data/lib/wp/wp-includes/rss-functions.php +9 -0
  1280. data/lib/wp/wp-includes/rss.php +936 -0
  1281. data/lib/wp/wp-includes/script-loader.php +1045 -0
  1282. data/lib/wp/wp-includes/session.php +430 -0
  1283. data/lib/wp/wp-includes/shortcodes.php +410 -0
  1284. data/lib/wp/wp-includes/taxonomy.php +4006 -0
  1285. data/lib/wp/wp-includes/template-loader.php +76 -0
  1286. data/lib/wp/wp-includes/template.php +505 -0
  1287. data/lib/wp/wp-includes/theme-compat/comments-popup.php +128 -0
  1288. data/lib/wp/wp-includes/theme-compat/comments.php +101 -0
  1289. data/lib/wp/wp-includes/theme-compat/footer.php +30 -0
  1290. data/lib/wp/wp-includes/theme-compat/header.php +49 -0
  1291. data/lib/wp/wp-includes/theme-compat/sidebar.php +83 -0
  1292. data/lib/wp/wp-includes/theme.php +2014 -0
  1293. data/lib/wp/wp-includes/update.php +674 -0
  1294. data/lib/wp/wp-includes/user.php +2292 -0
  1295. data/lib/wp/wp-includes/vars.php +144 -0
  1296. data/lib/wp/wp-includes/version.php +35 -0
  1297. data/lib/wp/wp-includes/widgets.php +1514 -0
  1298. data/lib/wp/wp-includes/wlwmanifest.xml +43 -0
  1299. data/lib/wp/wp-includes/wp-db.php +2190 -0
  1300. data/lib/wp/wp-includes/wp-diff.php +523 -0
  1301. data/lib/wp/wp-links-opml.php +80 -0
  1302. data/lib/wp/wp-load.php +73 -0
  1303. data/lib/wp/wp-login.php +952 -0
  1304. data/lib/wp/wp-mail.php +260 -0
  1305. data/lib/wp/wp-settings.php +374 -0
  1306. data/lib/wp/wp-signup.php +749 -0
  1307. data/lib/wp/wp-trackback.php +127 -0
  1308. data/lib/wp/xmlrpc.php +101 -0
  1309. data/stump-cli.gemspec +26 -0
  1310. metadata +1332 -4
@@ -0,0 +1,3141 @@
1
+ <?php
2
+ /**
3
+ * WordPress Link Template Functions
4
+ *
5
+ * @package WordPress
6
+ * @subpackage Template
7
+ */
8
+
9
+ /**
10
+ * Display the permalink for the current post.
11
+ *
12
+ * @since 1.2.0
13
+ */
14
+ function the_permalink() {
15
+ /**
16
+ * Filter the display of the permalink for the current post.
17
+ *
18
+ * @since 1.5.0
19
+ *
20
+ * @param string $permalink The permalink for the current post.
21
+ */
22
+ echo esc_url( apply_filters( 'the_permalink', get_permalink() ) );
23
+ }
24
+
25
+ /**
26
+ * Retrieve trailing slash string, if blog set for adding trailing slashes.
27
+ *
28
+ * Conditionally adds a trailing slash if the permalink structure has a trailing
29
+ * slash, strips the trailing slash if not. The string is passed through the
30
+ * 'user_trailingslashit' filter. Will remove trailing slash from string, if
31
+ * blog is not set to have them.
32
+ *
33
+ * @since 2.2.0
34
+ * @uses $wp_rewrite
35
+ *
36
+ * @param string $string URL with or without a trailing slash.
37
+ * @param string $type_of_url The type of URL being considered (e.g. single, category, etc) for use in the filter.
38
+ * @return string
39
+ */
40
+ function user_trailingslashit($string, $type_of_url = '') {
41
+ global $wp_rewrite;
42
+ if ( $wp_rewrite->use_trailing_slashes )
43
+ $string = trailingslashit($string);
44
+ else
45
+ $string = untrailingslashit($string);
46
+
47
+ /**
48
+ * Filter the trailing slashed string, depending on whether the site is set
49
+ * to use training slashes.
50
+ *
51
+ * @since 2.2.0
52
+ *
53
+ * @param string $string URL with or without a trailing slash.
54
+ * @param string $type_of_url The type of URL being considered. Accepts 'single', 'single_trackback',
55
+ * 'single_feed', 'single_paged', 'feed', 'category', 'page', 'year',
56
+ * 'month', 'day', 'paged', 'post_type_archive'.
57
+ */
58
+ $string = apply_filters( 'user_trailingslashit', $string, $type_of_url );
59
+ return $string;
60
+ }
61
+
62
+ /**
63
+ * Display permalink anchor for current post.
64
+ *
65
+ * The permalink mode title will use the post title for the 'a' element 'id'
66
+ * attribute. The id mode uses 'post-' with the post ID for the 'id' attribute.
67
+ *
68
+ * @since 0.71
69
+ *
70
+ * @param string $mode Permalink mode can be either 'title', 'id', or default, which is 'id'.
71
+ */
72
+ function permalink_anchor( $mode = 'id' ) {
73
+ $post = get_post();
74
+ switch ( strtolower( $mode ) ) {
75
+ case 'title':
76
+ $title = sanitize_title( $post->post_title ) . '-' . $post->ID;
77
+ echo '<a id="'.$title.'"></a>';
78
+ break;
79
+ case 'id':
80
+ default:
81
+ echo '<a id="post-' . $post->ID . '"></a>';
82
+ break;
83
+ }
84
+ }
85
+
86
+ /**
87
+ * Retrieve full permalink for current post or post ID.
88
+ *
89
+ * This function is an alias for get_permalink().
90
+ *
91
+ * @since 3.9.0
92
+ *
93
+ * @see get_permalink()
94
+ *
95
+ * @param int|WP_Post $id Optional. Post ID or post object. Default is the current post.
96
+ * @param bool $leavename Optional. Whether to keep post name or page name. Default false.
97
+ * @return string|bool The permalink URL or false if post does not exist.
98
+ */
99
+ function get_the_permalink( $id = 0, $leavename = false ) {
100
+ return get_permalink( $id, $leavename );
101
+ }
102
+
103
+ /**
104
+ * Retrieve full permalink for current post or post ID.
105
+ *
106
+ * @since 1.0.0
107
+ *
108
+ * @param int|WP_Post $id Optional. Post ID or post object. Default current post.
109
+ * @param bool $leavename Optional. Whether to keep post name or page name. Default false.
110
+ * @return string|bool The permalink URL or false if post does not exist.
111
+ */
112
+ function get_permalink( $id = 0, $leavename = false ) {
113
+ $rewritecode = array(
114
+ '%year%',
115
+ '%monthnum%',
116
+ '%day%',
117
+ '%hour%',
118
+ '%minute%',
119
+ '%second%',
120
+ $leavename? '' : '%postname%',
121
+ '%post_id%',
122
+ '%category%',
123
+ '%author%',
124
+ $leavename? '' : '%pagename%',
125
+ );
126
+
127
+ if ( is_object($id) && isset($id->filter) && 'sample' == $id->filter ) {
128
+ $post = $id;
129
+ $sample = true;
130
+ } else {
131
+ $post = get_post($id);
132
+ $sample = false;
133
+ }
134
+
135
+ if ( empty($post->ID) )
136
+ return false;
137
+
138
+ if ( $post->post_type == 'page' )
139
+ return get_page_link($post, $leavename, $sample);
140
+ elseif ( $post->post_type == 'attachment' )
141
+ return get_attachment_link( $post, $leavename );
142
+ elseif ( in_array($post->post_type, get_post_types( array('_builtin' => false) ) ) )
143
+ return get_post_permalink($post, $leavename, $sample);
144
+
145
+ $permalink = get_option('permalink_structure');
146
+
147
+ /**
148
+ * Filter the permalink structure for a post before token replacement occurs.
149
+ *
150
+ * Only applies to posts with post_type of 'post'.
151
+ *
152
+ * @since 3.0.0
153
+ *
154
+ * @param string $permalink The site's permalink structure.
155
+ * @param WP_Post $post The post in question.
156
+ * @param bool $leavename Whether to keep the post name.
157
+ */
158
+ $permalink = apply_filters( 'pre_post_link', $permalink, $post, $leavename );
159
+
160
+ if ( '' != $permalink && !in_array($post->post_status, array('draft', 'pending', 'auto-draft')) ) {
161
+ $unixtime = strtotime($post->post_date);
162
+
163
+ $category = '';
164
+ if ( strpos($permalink, '%category%') !== false ) {
165
+ $cats = get_the_category($post->ID);
166
+ if ( $cats ) {
167
+ usort($cats, '_usort_terms_by_ID'); // order by ID
168
+
169
+ /**
170
+ * Filter the category that gets used in the %category% permalink token.
171
+ *
172
+ * @since 3.5.0
173
+ *
174
+ * @param stdClass $cat The category to use in the permalink.
175
+ * @param array $cats Array of all categories associated with the post.
176
+ * @param WP_Post $post The post in question.
177
+ */
178
+ $category_object = apply_filters( 'post_link_category', $cats[0], $cats, $post );
179
+
180
+ $category_object = get_term( $category_object, 'category' );
181
+ $category = $category_object->slug;
182
+ if ( $parent = $category_object->parent )
183
+ $category = get_category_parents($parent, false, '/', true) . $category;
184
+ }
185
+ // show default category in permalinks, without
186
+ // having to assign it explicitly
187
+ if ( empty($category) ) {
188
+ $default_category = get_term( get_option( 'default_category' ), 'category' );
189
+ $category = is_wp_error( $default_category ) ? '' : $default_category->slug;
190
+ }
191
+ }
192
+
193
+ $author = '';
194
+ if ( strpos($permalink, '%author%') !== false ) {
195
+ $authordata = get_userdata($post->post_author);
196
+ $author = $authordata->user_nicename;
197
+ }
198
+
199
+ $date = explode(" ",date('Y m d H i s', $unixtime));
200
+ $rewritereplace =
201
+ array(
202
+ $date[0],
203
+ $date[1],
204
+ $date[2],
205
+ $date[3],
206
+ $date[4],
207
+ $date[5],
208
+ $post->post_name,
209
+ $post->ID,
210
+ $category,
211
+ $author,
212
+ $post->post_name,
213
+ );
214
+ $permalink = home_url( str_replace($rewritecode, $rewritereplace, $permalink) );
215
+ $permalink = user_trailingslashit($permalink, 'single');
216
+ } else { // if they're not using the fancy permalink option
217
+ $permalink = home_url('?p=' . $post->ID);
218
+ }
219
+
220
+ /**
221
+ * Filter the permalink for a post.
222
+ *
223
+ * Only applies to posts with post_type of 'post'.
224
+ *
225
+ * @since 1.5.0
226
+ *
227
+ * @param string $permalink The post's permalink.
228
+ * @param WP_Post $post The post in question.
229
+ * @param bool $leavename Whether to keep the post name.
230
+ */
231
+ return apply_filters( 'post_link', $permalink, $post, $leavename );
232
+ }
233
+
234
+ /**
235
+ * Retrieve the permalink for a post with a custom post type.
236
+ *
237
+ * @since 3.0.0
238
+ *
239
+ * @param int $id Optional. Post ID.
240
+ * @param bool $leavename Optional, defaults to false. Whether to keep post name.
241
+ * @param bool $sample Optional, defaults to false. Is it a sample permalink.
242
+ * @return string
243
+ */
244
+ function get_post_permalink( $id = 0, $leavename = false, $sample = false ) {
245
+ global $wp_rewrite;
246
+
247
+ $post = get_post($id);
248
+
249
+ if ( is_wp_error( $post ) )
250
+ return $post;
251
+
252
+ $post_link = $wp_rewrite->get_extra_permastruct($post->post_type);
253
+
254
+ $slug = $post->post_name;
255
+
256
+ $draft_or_pending = isset($post->post_status) && in_array( $post->post_status, array( 'draft', 'pending', 'auto-draft' ) );
257
+
258
+ $post_type = get_post_type_object($post->post_type);
259
+
260
+ if ( $post_type->hierarchical ) {
261
+ $slug = get_page_uri( $id );
262
+ }
263
+
264
+ if ( !empty($post_link) && ( !$draft_or_pending || $sample ) ) {
265
+ if ( ! $leavename ) {
266
+ $post_link = str_replace("%$post->post_type%", $slug, $post_link);
267
+ }
268
+ $post_link = home_url( user_trailingslashit($post_link) );
269
+ } else {
270
+ if ( $post_type->query_var && ( isset($post->post_status) && !$draft_or_pending ) )
271
+ $post_link = add_query_arg($post_type->query_var, $slug, '');
272
+ else
273
+ $post_link = add_query_arg(array('post_type' => $post->post_type, 'p' => $post->ID), '');
274
+ $post_link = home_url($post_link);
275
+ }
276
+
277
+ /**
278
+ * Filter the permalink for a post with a custom post type.
279
+ *
280
+ * @since 3.0.0
281
+ *
282
+ * @param string $post_link The post's permalink.
283
+ * @param WP_Post $post The post in question.
284
+ * @param bool $leavename Whether to keep the post name.
285
+ * @param bool $sample Is it a sample permalink.
286
+ */
287
+ return apply_filters( 'post_type_link', $post_link, $post, $leavename, $sample );
288
+ }
289
+
290
+ /**
291
+ * Retrieve permalink from post ID.
292
+ *
293
+ * @since 1.0.0
294
+ *
295
+ * @param int|WP_Post $post_id Optional. Post ID or WP_Post object. Default is global $post.
296
+ * @param mixed $deprecated Not used.
297
+ * @return string
298
+ */
299
+ function post_permalink( $post_id = 0, $deprecated = '' ) {
300
+ if ( !empty( $deprecated ) )
301
+ _deprecated_argument( __FUNCTION__, '1.3' );
302
+
303
+ return get_permalink($post_id);
304
+ }
305
+
306
+ /**
307
+ * Retrieve the permalink for current page or page ID.
308
+ *
309
+ * Respects page_on_front. Use this one.
310
+ *
311
+ * @since 1.5.0
312
+ *
313
+ * @param int|object $post Optional. Post ID or object.
314
+ * @param bool $leavename Optional, defaults to false. Whether to keep page name.
315
+ * @param bool $sample Optional, defaults to false. Is it a sample permalink.
316
+ * @return string
317
+ */
318
+ function get_page_link( $post = false, $leavename = false, $sample = false ) {
319
+ $post = get_post( $post );
320
+
321
+ if ( 'page' == get_option( 'show_on_front' ) && $post->ID == get_option( 'page_on_front' ) )
322
+ $link = home_url('/');
323
+ else
324
+ $link = _get_page_link( $post, $leavename, $sample );
325
+
326
+ /**
327
+ * Filter the permalink for a page.
328
+ *
329
+ * @since 1.5.0
330
+ *
331
+ * @param string $link The page's permalink.
332
+ * @param int $post_id The ID of the page.
333
+ * @param bool $sample Is it a sample permalink.
334
+ */
335
+ return apply_filters( 'page_link', $link, $post->ID, $sample );
336
+ }
337
+
338
+ /**
339
+ * Retrieve the page permalink.
340
+ *
341
+ * Ignores page_on_front. Internal use only.
342
+ *
343
+ * @since 2.1.0
344
+ * @access private
345
+ *
346
+ * @param int|object $post Optional. Post ID or object.
347
+ * @param bool $leavename Optional. Leave name.
348
+ * @param bool $sample Optional. Sample permalink.
349
+ * @return string
350
+ */
351
+ function _get_page_link( $post = false, $leavename = false, $sample = false ) {
352
+ global $wp_rewrite;
353
+
354
+ $post = get_post( $post );
355
+
356
+ $draft_or_pending = in_array( $post->post_status, array( 'draft', 'pending', 'auto-draft' ) );
357
+
358
+ $link = $wp_rewrite->get_page_permastruct();
359
+
360
+ if ( !empty($link) && ( ( isset($post->post_status) && !$draft_or_pending ) || $sample ) ) {
361
+ if ( ! $leavename ) {
362
+ $link = str_replace('%pagename%', get_page_uri( $post ), $link);
363
+ }
364
+
365
+ $link = home_url($link);
366
+ $link = user_trailingslashit($link, 'page');
367
+ } else {
368
+ $link = home_url( '?page_id=' . $post->ID );
369
+ }
370
+
371
+ /**
372
+ * Filter the permalink for a non-page_on_front page.
373
+ *
374
+ * @since 2.1.0
375
+ *
376
+ * @param string $link The page's permalink.
377
+ * @param int $post_id The ID of the page.
378
+ */
379
+ return apply_filters( '_get_page_link', $link, $post->ID );
380
+ }
381
+
382
+ /**
383
+ * Retrieve permalink for attachment.
384
+ *
385
+ * This can be used in the WordPress Loop or outside of it.
386
+ *
387
+ * @since 2.0.0
388
+ *
389
+ * @param int|object $post Optional. Post ID or object.
390
+ * @param bool $leavename Optional. Leave name.
391
+ * @return string
392
+ */
393
+ function get_attachment_link( $post = null, $leavename = false ) {
394
+ global $wp_rewrite;
395
+
396
+ $link = false;
397
+
398
+ $post = get_post( $post );
399
+ $parent = ( $post->post_parent > 0 && $post->post_parent != $post->ID ) ? get_post( $post->post_parent ) : false;
400
+
401
+ if ( $wp_rewrite->using_permalinks() && $parent ) {
402
+ if ( 'page' == $parent->post_type )
403
+ $parentlink = _get_page_link( $post->post_parent ); // Ignores page_on_front
404
+ else
405
+ $parentlink = get_permalink( $post->post_parent );
406
+
407
+ if ( is_numeric($post->post_name) || false !== strpos(get_option('permalink_structure'), '%category%') )
408
+ $name = 'attachment/' . $post->post_name; // <permalink>/<int>/ is paged so we use the explicit attachment marker
409
+ else
410
+ $name = $post->post_name;
411
+
412
+ if ( strpos($parentlink, '?') === false )
413
+ $link = user_trailingslashit( trailingslashit($parentlink) . '%postname%' );
414
+
415
+ if ( ! $leavename )
416
+ $link = str_replace( '%postname%', $name, $link );
417
+ }
418
+
419
+ if ( ! $link )
420
+ $link = home_url( '/?attachment_id=' . $post->ID );
421
+
422
+ /**
423
+ * Filter the permalink for an attachment.
424
+ *
425
+ * @since 2.0.0
426
+ *
427
+ * @param string $link The attachment's permalink.
428
+ * @param int $post_id Attachment ID.
429
+ */
430
+ return apply_filters( 'attachment_link', $link, $post->ID );
431
+ }
432
+
433
+ /**
434
+ * Retrieve the permalink for the year archives.
435
+ *
436
+ * @since 1.5.0
437
+ *
438
+ * @param int|bool $year False for current year or year for permalink.
439
+ * @return string
440
+ */
441
+ function get_year_link($year) {
442
+ global $wp_rewrite;
443
+ if ( !$year )
444
+ $year = gmdate('Y', current_time('timestamp'));
445
+ $yearlink = $wp_rewrite->get_year_permastruct();
446
+ if ( !empty($yearlink) ) {
447
+ $yearlink = str_replace('%year%', $year, $yearlink);
448
+ $yearlink = home_url( user_trailingslashit( $yearlink, 'year' ) );
449
+ } else {
450
+ $yearlink = home_url( '?m=' . $year );
451
+ }
452
+
453
+ /**
454
+ * Filter the year archive permalink.
455
+ *
456
+ * @since 1.5.0
457
+ *
458
+ * @param string $yearlink Permalink for the year archive.
459
+ * @param int $year Year for the archive.
460
+ */
461
+ return apply_filters( 'year_link', $yearlink, $year );
462
+ }
463
+
464
+ /**
465
+ * Retrieve the permalink for the month archives with year.
466
+ *
467
+ * @since 1.0.0
468
+ *
469
+ * @param bool|int $year False for current year. Integer of year.
470
+ * @param bool|int $month False for current month. Integer of month.
471
+ * @return string
472
+ */
473
+ function get_month_link($year, $month) {
474
+ global $wp_rewrite;
475
+ if ( !$year )
476
+ $year = gmdate('Y', current_time('timestamp'));
477
+ if ( !$month )
478
+ $month = gmdate('m', current_time('timestamp'));
479
+ $monthlink = $wp_rewrite->get_month_permastruct();
480
+ if ( !empty($monthlink) ) {
481
+ $monthlink = str_replace('%year%', $year, $monthlink);
482
+ $monthlink = str_replace('%monthnum%', zeroise(intval($month), 2), $monthlink);
483
+ $monthlink = home_url( user_trailingslashit( $monthlink, 'month' ) );
484
+ } else {
485
+ $monthlink = home_url( '?m=' . $year . zeroise( $month, 2 ) );
486
+ }
487
+
488
+ /**
489
+ * Filter the month archive permalink.
490
+ *
491
+ * @since 1.5.0
492
+ *
493
+ * @param string $monthlink Permalink for the month archive.
494
+ * @param int $year Year for the archive.
495
+ * @param int $month The month for the archive.
496
+ */
497
+ return apply_filters( 'month_link', $monthlink, $year, $month );
498
+ }
499
+
500
+ /**
501
+ * Retrieve the permalink for the day archives with year and month.
502
+ *
503
+ * @since 1.0.0
504
+ *
505
+ * @param bool|int $year False for current year. Integer of year.
506
+ * @param bool|int $month False for current month. Integer of month.
507
+ * @param bool|int $day False for current day. Integer of day.
508
+ * @return string
509
+ */
510
+ function get_day_link($year, $month, $day) {
511
+ global $wp_rewrite;
512
+ if ( !$year )
513
+ $year = gmdate('Y', current_time('timestamp'));
514
+ if ( !$month )
515
+ $month = gmdate('m', current_time('timestamp'));
516
+ if ( !$day )
517
+ $day = gmdate('j', current_time('timestamp'));
518
+
519
+ $daylink = $wp_rewrite->get_day_permastruct();
520
+ if ( !empty($daylink) ) {
521
+ $daylink = str_replace('%year%', $year, $daylink);
522
+ $daylink = str_replace('%monthnum%', zeroise(intval($month), 2), $daylink);
523
+ $daylink = str_replace('%day%', zeroise(intval($day), 2), $daylink);
524
+ $daylink = home_url( user_trailingslashit( $daylink, 'day' ) );
525
+ } else {
526
+ $daylink = home_url( '?m=' . $year . zeroise( $month, 2 ) . zeroise( $day, 2 ) );
527
+ }
528
+
529
+ /**
530
+ * Filter the day archive permalink.
531
+ *
532
+ * @since 1.5.0
533
+ *
534
+ * @param string $daylink Permalink for the day archive.
535
+ * @param int $year Year for the archive.
536
+ * @param int $month Month for the archive.
537
+ * @param int $day The day for the archive.
538
+ */
539
+ return apply_filters( 'day_link', $daylink, $year, $month, $day );
540
+ }
541
+
542
+ /**
543
+ * Display the permalink for the feed type.
544
+ *
545
+ * @since 3.0.0
546
+ *
547
+ * @param string $anchor The link's anchor text.
548
+ * @param string $feed Optional, defaults to default feed. Feed type.
549
+ */
550
+ function the_feed_link( $anchor, $feed = '' ) {
551
+ $link = '<a href="' . esc_url( get_feed_link( $feed ) ) . '">' . $anchor . '</a>';
552
+
553
+ /**
554
+ * Filter the feed link anchor tag.
555
+ *
556
+ * @since 3.0.0
557
+ *
558
+ * @param string $link The complete anchor tag for a feed link.
559
+ * @param string $feed The feed type, or an empty string for the
560
+ * default feed type.
561
+ */
562
+ echo apply_filters( 'the_feed_link', $link, $feed );
563
+ }
564
+
565
+ /**
566
+ * Retrieve the permalink for the feed type.
567
+ *
568
+ * @since 1.5.0
569
+ *
570
+ * @param string $feed Optional, defaults to default feed. Feed type.
571
+ * @return string
572
+ */
573
+ function get_feed_link($feed = '') {
574
+ global $wp_rewrite;
575
+
576
+ $permalink = $wp_rewrite->get_feed_permastruct();
577
+ if ( '' != $permalink ) {
578
+ if ( false !== strpos($feed, 'comments_') ) {
579
+ $feed = str_replace('comments_', '', $feed);
580
+ $permalink = $wp_rewrite->get_comment_feed_permastruct();
581
+ }
582
+
583
+ if ( get_default_feed() == $feed )
584
+ $feed = '';
585
+
586
+ $permalink = str_replace('%feed%', $feed, $permalink);
587
+ $permalink = preg_replace('#/+#', '/', "/$permalink");
588
+ $output = home_url( user_trailingslashit($permalink, 'feed') );
589
+ } else {
590
+ if ( empty($feed) )
591
+ $feed = get_default_feed();
592
+
593
+ if ( false !== strpos($feed, 'comments_') )
594
+ $feed = str_replace('comments_', 'comments-', $feed);
595
+
596
+ $output = home_url("?feed={$feed}");
597
+ }
598
+
599
+ /**
600
+ * Filter the feed type permalink.
601
+ *
602
+ * @since 1.5.0
603
+ *
604
+ * @param string $output The feed permalink.
605
+ * @param string $feed Feed type.
606
+ */
607
+ return apply_filters( 'feed_link', $output, $feed );
608
+ }
609
+
610
+ /**
611
+ * Retrieve the permalink for the post comments feed.
612
+ *
613
+ * @since 2.2.0
614
+ *
615
+ * @param int $post_id Optional. Post ID.
616
+ * @param string $feed Optional. Feed type.
617
+ * @return string
618
+ */
619
+ function get_post_comments_feed_link($post_id = 0, $feed = '') {
620
+ $post_id = absint( $post_id );
621
+
622
+ if ( ! $post_id )
623
+ $post_id = get_the_ID();
624
+
625
+ if ( empty( $feed ) )
626
+ $feed = get_default_feed();
627
+
628
+ if ( '' != get_option('permalink_structure') ) {
629
+ if ( 'page' == get_option('show_on_front') && $post_id == get_option('page_on_front') )
630
+ $url = _get_page_link( $post_id );
631
+ else
632
+ $url = get_permalink($post_id);
633
+
634
+ $url = trailingslashit($url) . 'feed';
635
+ if ( $feed != get_default_feed() )
636
+ $url .= "/$feed";
637
+ $url = user_trailingslashit($url, 'single_feed');
638
+ } else {
639
+ $type = get_post_field('post_type', $post_id);
640
+ if ( 'page' == $type )
641
+ $url = add_query_arg( array( 'feed' => $feed, 'page_id' => $post_id ), home_url( '/' ) );
642
+ else
643
+ $url = add_query_arg( array( 'feed' => $feed, 'p' => $post_id ), home_url( '/' ) );
644
+ }
645
+
646
+ /**
647
+ * Filter the post comments feed permalink.
648
+ *
649
+ * @since 1.5.1
650
+ *
651
+ * @param string $url Post comments feed permalink.
652
+ */
653
+ return apply_filters( 'post_comments_feed_link', $url );
654
+ }
655
+
656
+ /**
657
+ * Display the comment feed link for a post.
658
+ *
659
+ * Prints out the comment feed link for a post. Link text is placed in the
660
+ * anchor. If no link text is specified, default text is used. If no post ID is
661
+ * specified, the current post is used.
662
+ *
663
+ * @since 2.5.0
664
+ *
665
+ * @param string $link_text Descriptive text.
666
+ * @param int $post_id Optional post ID. Default to current post.
667
+ * @param string $feed Optional. Feed format.
668
+ * @return string Link to the comment feed for the current post.
669
+ */
670
+ function post_comments_feed_link( $link_text = '', $post_id = '', $feed = '' ) {
671
+ $url = esc_url( get_post_comments_feed_link( $post_id, $feed ) );
672
+ if ( empty($link_text) )
673
+ $link_text = __('Comments Feed');
674
+
675
+ /**
676
+ * Filter the post comment feed link anchor tag.
677
+ *
678
+ * @since 2.8.0
679
+ *
680
+ * @param string $link The complete anchor tag for the comment feed link.
681
+ * @param int $post_id Post ID.
682
+ * @param string $feed The feed type, or an empty string for the default feed type.
683
+ */
684
+ echo apply_filters( 'post_comments_feed_link_html', "<a href='$url'>$link_text</a>", $post_id, $feed );
685
+ }
686
+
687
+ /**
688
+ * Retrieve the feed link for a given author.
689
+ *
690
+ * Returns a link to the feed for all posts by a given author. A specific feed
691
+ * can be requested or left blank to get the default feed.
692
+ *
693
+ * @since 2.5.0
694
+ *
695
+ * @param int $author_id ID of an author.
696
+ * @param string $feed Optional. Feed type.
697
+ * @return string Link to the feed for the author specified by $author_id.
698
+ */
699
+ function get_author_feed_link( $author_id, $feed = '' ) {
700
+ $author_id = (int) $author_id;
701
+ $permalink_structure = get_option('permalink_structure');
702
+
703
+ if ( empty($feed) )
704
+ $feed = get_default_feed();
705
+
706
+ if ( '' == $permalink_structure ) {
707
+ $link = home_url("?feed=$feed&amp;author=" . $author_id);
708
+ } else {
709
+ $link = get_author_posts_url($author_id);
710
+ if ( $feed == get_default_feed() )
711
+ $feed_link = 'feed';
712
+ else
713
+ $feed_link = "feed/$feed";
714
+
715
+ $link = trailingslashit($link) . user_trailingslashit($feed_link, 'feed');
716
+ }
717
+
718
+ /**
719
+ * Filter the feed link for a given author.
720
+ *
721
+ * @since 1.5.1
722
+ *
723
+ * @param string $link The author feed link.
724
+ * @param string $feed Feed type.
725
+ */
726
+ $link = apply_filters( 'author_feed_link', $link, $feed );
727
+
728
+ return $link;
729
+ }
730
+
731
+ /**
732
+ * Retrieve the feed link for a category.
733
+ *
734
+ * Returns a link to the feed for all posts in a given category. A specific feed
735
+ * can be requested or left blank to get the default feed.
736
+ *
737
+ * @since 2.5.0
738
+ *
739
+ * @param int $cat_id ID of a category.
740
+ * @param string $feed Optional. Feed type.
741
+ * @return string Link to the feed for the category specified by $cat_id.
742
+ */
743
+ function get_category_feed_link($cat_id, $feed = '') {
744
+ return get_term_feed_link($cat_id, 'category', $feed);
745
+ }
746
+
747
+ /**
748
+ * Retrieve the feed link for a term.
749
+ *
750
+ * Returns a link to the feed for all posts in a given term. A specific feed
751
+ * can be requested or left blank to get the default feed.
752
+ *
753
+ * @since 3.0.0
754
+ *
755
+ * @param int $term_id ID of a category.
756
+ * @param string $taxonomy Optional. Taxonomy of $term_id
757
+ * @param string $feed Optional. Feed type.
758
+ * @return string Link to the feed for the term specified by $term_id and $taxonomy.
759
+ */
760
+ function get_term_feed_link( $term_id, $taxonomy = 'category', $feed = '' ) {
761
+ $term_id = ( int ) $term_id;
762
+
763
+ $term = get_term( $term_id, $taxonomy );
764
+
765
+ if ( empty( $term ) || is_wp_error( $term ) )
766
+ return false;
767
+
768
+ if ( empty( $feed ) )
769
+ $feed = get_default_feed();
770
+
771
+ $permalink_structure = get_option( 'permalink_structure' );
772
+
773
+ if ( '' == $permalink_structure ) {
774
+ if ( 'category' == $taxonomy ) {
775
+ $link = home_url("?feed=$feed&amp;cat=$term_id");
776
+ }
777
+ elseif ( 'post_tag' == $taxonomy ) {
778
+ $link = home_url("?feed=$feed&amp;tag=$term->slug");
779
+ } else {
780
+ $t = get_taxonomy( $taxonomy );
781
+ $link = home_url("?feed=$feed&amp;$t->query_var=$term->slug");
782
+ }
783
+ } else {
784
+ $link = get_term_link( $term_id, $term->taxonomy );
785
+ if ( $feed == get_default_feed() )
786
+ $feed_link = 'feed';
787
+ else
788
+ $feed_link = "feed/$feed";
789
+
790
+ $link = trailingslashit( $link ) . user_trailingslashit( $feed_link, 'feed' );
791
+ }
792
+
793
+ if ( 'category' == $taxonomy ) {
794
+ /**
795
+ * Filter the category feed link.
796
+ *
797
+ * @since 1.5.1
798
+ *
799
+ * @param string $link The category feed link.
800
+ * @param string $feed Feed type.
801
+ */
802
+ $link = apply_filters( 'category_feed_link', $link, $feed );
803
+ } elseif ( 'post_tag' == $taxonomy ) {
804
+ /**
805
+ * Filter the post tag feed link.
806
+ *
807
+ * @since 2.3.0
808
+ *
809
+ * @param string $link The tag feed link.
810
+ * @param string $feed Feed type.
811
+ */
812
+ $link = apply_filters( 'tag_feed_link', $link, $feed );
813
+ } else {
814
+ /**
815
+ * Filter the feed link for a taxonomy other than 'category' or 'post_tag'.
816
+ *
817
+ * @since 3.0.0
818
+ *
819
+ * @param string $link The taxonomy feed link.
820
+ * @param string $feed Feed type.
821
+ * @param string $feed The taxonomy name.
822
+ */
823
+ $link = apply_filters( 'taxonomy_feed_link', $link, $feed, $taxonomy );
824
+ }
825
+
826
+ return $link;
827
+ }
828
+
829
+ /**
830
+ * Retrieve permalink for feed of tag.
831
+ *
832
+ * @since 2.3.0
833
+ *
834
+ * @param int $tag_id Tag ID.
835
+ * @param string $feed Optional. Feed type.
836
+ * @return string
837
+ */
838
+ function get_tag_feed_link($tag_id, $feed = '') {
839
+ return get_term_feed_link($tag_id, 'post_tag', $feed);
840
+ }
841
+
842
+ /**
843
+ * Retrieve edit tag link.
844
+ *
845
+ * @since 2.7.0
846
+ *
847
+ * @param int $tag_id Tag ID
848
+ * @param string $taxonomy Taxonomy
849
+ * @return string
850
+ */
851
+ function get_edit_tag_link( $tag_id, $taxonomy = 'post_tag' ) {
852
+ /**
853
+ * Filter the edit link for a tag (or term in another taxonomy).
854
+ *
855
+ * @since 2.7.0
856
+ *
857
+ * @param string $link The term edit link.
858
+ */
859
+ return apply_filters( 'get_edit_tag_link', get_edit_term_link( $tag_id, $taxonomy ) );
860
+ }
861
+
862
+ /**
863
+ * Display or retrieve edit tag link with formatting.
864
+ *
865
+ * @since 2.7.0
866
+ *
867
+ * @param string $link Optional. Anchor text.
868
+ * @param string $before Optional. Display before edit link.
869
+ * @param string $after Optional. Display after edit link.
870
+ * @param object $tag Tag object.
871
+ * @return string HTML content.
872
+ */
873
+ function edit_tag_link( $link = '', $before = '', $after = '', $tag = null ) {
874
+ $link = edit_term_link( $link, '', '', $tag, false );
875
+
876
+ /**
877
+ * Filter the anchor tag for the edit link for a tag (or term in another taxonomy).
878
+ *
879
+ * @since 2.7.0
880
+ *
881
+ * @param string $link The anchor tag for the edit link.
882
+ */
883
+ echo $before . apply_filters( 'edit_tag_link', $link ) . $after;
884
+ }
885
+
886
+ /**
887
+ * Retrieve edit term url.
888
+ *
889
+ * @since 3.1.0
890
+ *
891
+ * @param int $term_id Term ID
892
+ * @param string $taxonomy Taxonomy
893
+ * @param string $object_type The object type
894
+ * @return string
895
+ */
896
+ function get_edit_term_link( $term_id, $taxonomy, $object_type = '' ) {
897
+ $tax = get_taxonomy( $taxonomy );
898
+ if ( !current_user_can( $tax->cap->edit_terms ) )
899
+ return;
900
+
901
+ $term = get_term( $term_id, $taxonomy );
902
+
903
+ $args = array(
904
+ 'action' => 'edit',
905
+ 'taxonomy' => $taxonomy,
906
+ 'tag_ID' => $term->term_id,
907
+ );
908
+
909
+ if ( $object_type )
910
+ $args['post_type'] = $object_type;
911
+
912
+ $location = add_query_arg( $args, admin_url( 'edit-tags.php' ) );
913
+
914
+ /**
915
+ * Filter the edit link for a term.
916
+ *
917
+ * @since 3.1.0
918
+ *
919
+ * @param string $location The edit link.
920
+ * @param int $term_id Term ID.
921
+ * @param string $taxonomy Taxonomy name.
922
+ * @param string $object_type The object type (eg. the post type).
923
+ */
924
+ return apply_filters( 'get_edit_term_link', $location, $term_id, $taxonomy, $object_type );
925
+ }
926
+
927
+ /**
928
+ * Display or retrieve edit term link with formatting.
929
+ *
930
+ * @since 3.1.0
931
+ *
932
+ * @param string $link Optional. Anchor text.
933
+ * @param string $before Optional. Display before edit link.
934
+ * @param string $after Optional. Display after edit link.
935
+ * @param object $term Term object.
936
+ * @return string HTML content.
937
+ */
938
+ function edit_term_link( $link = '', $before = '', $after = '', $term = null, $echo = true ) {
939
+ if ( is_null( $term ) )
940
+ $term = get_queried_object();
941
+
942
+ if ( ! $term )
943
+ return;
944
+
945
+ $tax = get_taxonomy( $term->taxonomy );
946
+ if ( ! current_user_can( $tax->cap->edit_terms ) )
947
+ return;
948
+
949
+ if ( empty( $link ) )
950
+ $link = __('Edit This');
951
+
952
+ $link = '<a href="' . get_edit_term_link( $term->term_id, $term->taxonomy ) . '">' . $link . '</a>';
953
+
954
+ /**
955
+ * Filter the anchor tag for the edit link of a term.
956
+ *
957
+ * @since 3.1.0
958
+ *
959
+ * @param string $link The anchor tag for the edit link.
960
+ * @param int $term_id Term ID.
961
+ */
962
+ $link = $before . apply_filters( 'edit_term_link', $link, $term->term_id ) . $after;
963
+
964
+ if ( $echo )
965
+ echo $link;
966
+ else
967
+ return $link;
968
+ }
969
+
970
+ /**
971
+ * Retrieve permalink for search.
972
+ *
973
+ * @since 3.0.0
974
+ *
975
+ * @param string $query Optional. The query string to use. If empty the current query is used.
976
+ * @return string
977
+ */
978
+ function get_search_link( $query = '' ) {
979
+ global $wp_rewrite;
980
+
981
+ if ( empty($query) )
982
+ $search = get_search_query( false );
983
+ else
984
+ $search = stripslashes($query);
985
+
986
+ $permastruct = $wp_rewrite->get_search_permastruct();
987
+
988
+ if ( empty( $permastruct ) ) {
989
+ $link = home_url('?s=' . urlencode($search) );
990
+ } else {
991
+ $search = urlencode($search);
992
+ $search = str_replace('%2F', '/', $search); // %2F(/) is not valid within a URL, send it unencoded.
993
+ $link = str_replace( '%search%', $search, $permastruct );
994
+ $link = home_url( user_trailingslashit( $link, 'search' ) );
995
+ }
996
+
997
+ /**
998
+ * Filter the search permalink.
999
+ *
1000
+ * @since 3.0.0
1001
+ *
1002
+ * @param string $link Search permalink.
1003
+ * @param string $search The URL-encoded search term.
1004
+ */
1005
+ return apply_filters( 'search_link', $link, $search );
1006
+ }
1007
+
1008
+ /**
1009
+ * Retrieve the permalink for the feed of the search results.
1010
+ *
1011
+ * @since 2.5.0
1012
+ *
1013
+ * @param string $search_query Optional. Search query.
1014
+ * @param string $feed Optional. Feed type.
1015
+ * @return string
1016
+ */
1017
+ function get_search_feed_link($search_query = '', $feed = '') {
1018
+ global $wp_rewrite;
1019
+ $link = get_search_link($search_query);
1020
+
1021
+ if ( empty($feed) )
1022
+ $feed = get_default_feed();
1023
+
1024
+ $permastruct = $wp_rewrite->get_search_permastruct();
1025
+
1026
+ if ( empty($permastruct) ) {
1027
+ $link = add_query_arg('feed', $feed, $link);
1028
+ } else {
1029
+ $link = trailingslashit($link);
1030
+ $link .= "feed/$feed/";
1031
+ }
1032
+
1033
+ /**
1034
+ * Filter the search feed link.
1035
+ *
1036
+ * @since 2.5.0
1037
+ *
1038
+ * @param string $link Search feed link.
1039
+ * @param string $feed Feed type.
1040
+ * @param string $type The search type. One of 'posts' or 'comments'.
1041
+ */
1042
+ $link = apply_filters( 'search_feed_link', $link, $feed, 'posts' );
1043
+
1044
+ return $link;
1045
+ }
1046
+
1047
+ /**
1048
+ * Retrieve the permalink for the comments feed of the search results.
1049
+ *
1050
+ * @since 2.5.0
1051
+ *
1052
+ * @param string $search_query Optional. Search query.
1053
+ * @param string $feed Optional. Feed type.
1054
+ * @return string
1055
+ */
1056
+ function get_search_comments_feed_link($search_query = '', $feed = '') {
1057
+ global $wp_rewrite;
1058
+
1059
+ if ( empty($feed) )
1060
+ $feed = get_default_feed();
1061
+
1062
+ $link = get_search_feed_link($search_query, $feed);
1063
+
1064
+ $permastruct = $wp_rewrite->get_search_permastruct();
1065
+
1066
+ if ( empty($permastruct) )
1067
+ $link = add_query_arg('feed', 'comments-' . $feed, $link);
1068
+ else
1069
+ $link = add_query_arg('withcomments', 1, $link);
1070
+
1071
+ /** This filter is documented in wp-includes/link-template.php */
1072
+ $link = apply_filters('search_feed_link', $link, $feed, 'comments');
1073
+
1074
+ return $link;
1075
+ }
1076
+
1077
+ /**
1078
+ * Retrieve the permalink for a post type archive.
1079
+ *
1080
+ * @since 3.1.0
1081
+ *
1082
+ * @param string $post_type Post type
1083
+ * @return string
1084
+ */
1085
+ function get_post_type_archive_link( $post_type ) {
1086
+ global $wp_rewrite;
1087
+ if ( ! $post_type_obj = get_post_type_object( $post_type ) )
1088
+ return false;
1089
+
1090
+ if ( ! $post_type_obj->has_archive )
1091
+ return false;
1092
+
1093
+ if ( get_option( 'permalink_structure' ) && is_array( $post_type_obj->rewrite ) ) {
1094
+ $struct = ( true === $post_type_obj->has_archive ) ? $post_type_obj->rewrite['slug'] : $post_type_obj->has_archive;
1095
+ if ( $post_type_obj->rewrite['with_front'] )
1096
+ $struct = $wp_rewrite->front . $struct;
1097
+ else
1098
+ $struct = $wp_rewrite->root . $struct;
1099
+ $link = home_url( user_trailingslashit( $struct, 'post_type_archive' ) );
1100
+ } else {
1101
+ $link = home_url( '?post_type=' . $post_type );
1102
+ }
1103
+
1104
+ /**
1105
+ * Filter the post type archive permalink.
1106
+ *
1107
+ * @since 3.1.0
1108
+ *
1109
+ * @param string $link The post type archive permalink.
1110
+ * @param string $post_type Post type name.
1111
+ */
1112
+ return apply_filters( 'post_type_archive_link', $link, $post_type );
1113
+ }
1114
+
1115
+ /**
1116
+ * Retrieve the permalink for a post type archive feed.
1117
+ *
1118
+ * @since 3.1.0
1119
+ *
1120
+ * @param string $post_type Post type
1121
+ * @param string $feed Optional. Feed type
1122
+ * @return string
1123
+ */
1124
+ function get_post_type_archive_feed_link( $post_type, $feed = '' ) {
1125
+ $default_feed = get_default_feed();
1126
+ if ( empty( $feed ) )
1127
+ $feed = $default_feed;
1128
+
1129
+ if ( ! $link = get_post_type_archive_link( $post_type ) )
1130
+ return false;
1131
+
1132
+ $post_type_obj = get_post_type_object( $post_type );
1133
+ if ( get_option( 'permalink_structure' ) && is_array( $post_type_obj->rewrite ) && $post_type_obj->rewrite['feeds'] ) {
1134
+ $link = trailingslashit( $link );
1135
+ $link .= 'feed/';
1136
+ if ( $feed != $default_feed )
1137
+ $link .= "$feed/";
1138
+ } else {
1139
+ $link = add_query_arg( 'feed', $feed, $link );
1140
+ }
1141
+
1142
+ /**
1143
+ * Filter the post type archive feed link.
1144
+ *
1145
+ * @since 3.1.0
1146
+ *
1147
+ * @param string $link The post type archive feed link.
1148
+ * @param string $feed Feed type.
1149
+ */
1150
+ return apply_filters( 'post_type_archive_feed_link', $link, $feed );
1151
+ }
1152
+
1153
+ /**
1154
+ * Retrieve edit posts link for post.
1155
+ *
1156
+ * Can be used within the WordPress loop or outside of it. Can be used with
1157
+ * pages, posts, attachments, and revisions.
1158
+ *
1159
+ * @since 2.3.0
1160
+ *
1161
+ * @param int $id Optional. Post ID.
1162
+ * @param string $context Optional, defaults to display. How to write the '&', defaults to '&amp;'.
1163
+ * @return string
1164
+ */
1165
+ function get_edit_post_link( $id = 0, $context = 'display' ) {
1166
+ if ( ! $post = get_post( $id ) )
1167
+ return;
1168
+
1169
+ if ( 'revision' === $post->post_type )
1170
+ $action = '';
1171
+ elseif ( 'display' == $context )
1172
+ $action = '&amp;action=edit';
1173
+ else
1174
+ $action = '&action=edit';
1175
+
1176
+ $post_type_object = get_post_type_object( $post->post_type );
1177
+ if ( !$post_type_object )
1178
+ return;
1179
+
1180
+ if ( !current_user_can( 'edit_post', $post->ID ) )
1181
+ return;
1182
+
1183
+ /**
1184
+ * Filter the post edit link.
1185
+ *
1186
+ * @since 2.3.0
1187
+ *
1188
+ * @param string $link The edit link.
1189
+ * @param int $post_id Post ID.
1190
+ * @param string $context The link context. If set to 'display' then ampersands
1191
+ * are encoded.
1192
+ */
1193
+ return apply_filters( 'get_edit_post_link', admin_url( sprintf( $post_type_object->_edit_link . $action, $post->ID ) ), $post->ID, $context );
1194
+ }
1195
+
1196
+ /**
1197
+ * Display edit post link for post.
1198
+ *
1199
+ * @since 1.0.0
1200
+ *
1201
+ * @param string $text Optional. Anchor text.
1202
+ * @param string $before Optional. Display before edit link.
1203
+ * @param string $after Optional. Display after edit link.
1204
+ * @param int $id Optional. Post ID.
1205
+ */
1206
+ function edit_post_link( $text = null, $before = '', $after = '', $id = 0 ) {
1207
+ if ( ! $post = get_post( $id ) ) {
1208
+ return;
1209
+ }
1210
+
1211
+ if ( ! $url = get_edit_post_link( $post->ID ) ) {
1212
+ return;
1213
+ }
1214
+
1215
+ if ( null === $text ) {
1216
+ $text = __( 'Edit This' );
1217
+ }
1218
+
1219
+ $link = '<a class="post-edit-link" href="' . $url . '">' . $text . '</a>';
1220
+
1221
+ /**
1222
+ * Filter the post edit link anchor tag.
1223
+ *
1224
+ * @since 2.3.0
1225
+ *
1226
+ * @param string $link Anchor tag for the edit link.
1227
+ * @param int $post_id Post ID.
1228
+ * @param string $text Anchor text.
1229
+ */
1230
+ echo $before . apply_filters( 'edit_post_link', $link, $post->ID, $text ) . $after;
1231
+ }
1232
+
1233
+ /**
1234
+ * Retrieve delete posts link for post.
1235
+ *
1236
+ * Can be used within the WordPress loop or outside of it, with any post type.
1237
+ *
1238
+ * @since 2.9.0
1239
+ *
1240
+ * @param int $id Optional. Post ID.
1241
+ * @param string $deprecated Not used.
1242
+ * @param bool $force_delete Whether to bypass trash and force deletion. Default is false.
1243
+ * @return string
1244
+ */
1245
+ function get_delete_post_link( $id = 0, $deprecated = '', $force_delete = false ) {
1246
+ if ( ! empty( $deprecated ) )
1247
+ _deprecated_argument( __FUNCTION__, '3.0' );
1248
+
1249
+ if ( !$post = get_post( $id ) )
1250
+ return;
1251
+
1252
+ $post_type_object = get_post_type_object( $post->post_type );
1253
+ if ( !$post_type_object )
1254
+ return;
1255
+
1256
+ if ( !current_user_can( 'delete_post', $post->ID ) )
1257
+ return;
1258
+
1259
+ $action = ( $force_delete || !EMPTY_TRASH_DAYS ) ? 'delete' : 'trash';
1260
+
1261
+ $delete_link = add_query_arg( 'action', $action, admin_url( sprintf( $post_type_object->_edit_link, $post->ID ) ) );
1262
+
1263
+ /**
1264
+ * Filter the post delete link.
1265
+ *
1266
+ * @since 2.9.0
1267
+ *
1268
+ * @param string $link The delete link.
1269
+ * @param int $post_id Post ID.
1270
+ * @param bool $force_delete Whether to bypass the trash and force deletion. Default false.
1271
+ */
1272
+ return apply_filters( 'get_delete_post_link', wp_nonce_url( $delete_link, "$action-post_{$post->ID}" ), $post->ID, $force_delete );
1273
+ }
1274
+
1275
+ /**
1276
+ * Retrieve edit comment link.
1277
+ *
1278
+ * @since 2.3.0
1279
+ *
1280
+ * @param int $comment_id Optional. Comment ID.
1281
+ * @return string
1282
+ */
1283
+ function get_edit_comment_link( $comment_id = 0 ) {
1284
+ $comment = get_comment( $comment_id );
1285
+
1286
+ if ( !current_user_can( 'edit_comment', $comment->comment_ID ) )
1287
+ return;
1288
+
1289
+ $location = admin_url('comment.php?action=editcomment&amp;c=') . $comment->comment_ID;
1290
+
1291
+ /**
1292
+ * Filter the comment edit link.
1293
+ *
1294
+ * @since 2.3.0
1295
+ *
1296
+ * @param string $location The edit link.
1297
+ */
1298
+ return apply_filters( 'get_edit_comment_link', $location );
1299
+ }
1300
+
1301
+ /**
1302
+ * Display edit comment link with formatting.
1303
+ *
1304
+ * @since 1.0.0
1305
+ *
1306
+ * @param string $text Optional. Anchor text.
1307
+ * @param string $before Optional. Display before edit link.
1308
+ * @param string $after Optional. Display after edit link.
1309
+ */
1310
+ function edit_comment_link( $text = null, $before = '', $after = '' ) {
1311
+ global $comment;
1312
+
1313
+ if ( ! current_user_can( 'edit_comment', $comment->comment_ID ) ) {
1314
+ return;
1315
+ }
1316
+
1317
+ if ( null === $text ) {
1318
+ $text = __( 'Edit This' );
1319
+ }
1320
+
1321
+ $link = '<a class="comment-edit-link" href="' . get_edit_comment_link( $comment->comment_ID ) . '">' . $text . '</a>';
1322
+
1323
+ /**
1324
+ * Filter the comment edit link anchor tag.
1325
+ *
1326
+ * @since 2.3.0
1327
+ *
1328
+ * @param string $link Anchor tag for the edit link.
1329
+ * @param int $comment_id Comment ID.
1330
+ * @param string $text Anchor text.
1331
+ */
1332
+ echo $before . apply_filters( 'edit_comment_link', $link, $comment->comment_ID, $text ) . $after;
1333
+ }
1334
+
1335
+ /**
1336
+ * Display edit bookmark (literally a URL external to blog) link.
1337
+ *
1338
+ * @since 2.7.0
1339
+ *
1340
+ * @param int $link Optional. Bookmark ID.
1341
+ * @return string
1342
+ */
1343
+ function get_edit_bookmark_link( $link = 0 ) {
1344
+ $link = get_bookmark( $link );
1345
+
1346
+ if ( !current_user_can('manage_links') )
1347
+ return;
1348
+
1349
+ $location = admin_url('link.php?action=edit&amp;link_id=') . $link->link_id;
1350
+
1351
+ /**
1352
+ * Filter the bookmark (link) edit link.
1353
+ *
1354
+ * @since 2.7.0
1355
+ *
1356
+ * @param string $location The edit link.
1357
+ * @param int $link_id Bookmark ID.
1358
+ */
1359
+ return apply_filters( 'get_edit_bookmark_link', $location, $link->link_id );
1360
+ }
1361
+
1362
+ /**
1363
+ * Display edit bookmark (literally a URL external to blog) link anchor content.
1364
+ *
1365
+ * @since 2.7.0
1366
+ *
1367
+ * @param string $link Optional. Anchor text.
1368
+ * @param string $before Optional. Display before edit link.
1369
+ * @param string $after Optional. Display after edit link.
1370
+ * @param int $bookmark Optional. Bookmark ID.
1371
+ */
1372
+ function edit_bookmark_link( $link = '', $before = '', $after = '', $bookmark = null ) {
1373
+ $bookmark = get_bookmark($bookmark);
1374
+
1375
+ if ( !current_user_can('manage_links') )
1376
+ return;
1377
+
1378
+ if ( empty($link) )
1379
+ $link = __('Edit This');
1380
+
1381
+ $link = '<a href="' . get_edit_bookmark_link( $bookmark ) . '">' . $link . '</a>';
1382
+
1383
+ /**
1384
+ * Filter the bookmark edit link anchor tag.
1385
+ *
1386
+ * @since 2.7.0
1387
+ *
1388
+ * @param string $link Anchor tag for the edit link.
1389
+ * @param int $link_id Bookmark ID.
1390
+ */
1391
+ echo $before . apply_filters( 'edit_bookmark_link', $link, $bookmark->link_id ) . $after;
1392
+ }
1393
+
1394
+ /**
1395
+ * Retrieve edit user link
1396
+ *
1397
+ * @since 3.5.0
1398
+ *
1399
+ * @param int $user_id Optional. User ID. Defaults to the current user.
1400
+ * @return string URL to edit user page or empty string.
1401
+ */
1402
+ function get_edit_user_link( $user_id = null ) {
1403
+ if ( ! $user_id )
1404
+ $user_id = get_current_user_id();
1405
+
1406
+ if ( empty( $user_id ) || ! current_user_can( 'edit_user', $user_id ) )
1407
+ return '';
1408
+
1409
+ $user = get_userdata( $user_id );
1410
+
1411
+ if ( ! $user )
1412
+ return '';
1413
+
1414
+ if ( get_current_user_id() == $user->ID )
1415
+ $link = get_edit_profile_url( $user->ID );
1416
+ else
1417
+ $link = add_query_arg( 'user_id', $user->ID, self_admin_url( 'user-edit.php' ) );
1418
+
1419
+ /**
1420
+ * Filter the user edit link.
1421
+ *
1422
+ * @since 3.5.0
1423
+ *
1424
+ * @param string $link The edit link.
1425
+ * @param int $user_id User ID.
1426
+ */
1427
+ return apply_filters( 'get_edit_user_link', $link, $user->ID );
1428
+ }
1429
+
1430
+ // Navigation links
1431
+
1432
+ /**
1433
+ * Retrieve previous post that is adjacent to current post.
1434
+ *
1435
+ * @since 1.5.0
1436
+ *
1437
+ * @param bool $in_same_term Optional. Whether post should be in a same taxonomy term.
1438
+ * @param array|string $excluded_terms Optional. Array or comma-separated list of excluded term IDs.
1439
+ * @param string $taxonomy Optional. Taxonomy, if $in_same_term is true. Default 'category'.
1440
+ * @return mixed Post object if successful. Null if global $post is not set. Empty string if no corresponding post exists.
1441
+ */
1442
+ function get_previous_post( $in_same_term = false, $excluded_terms = '', $taxonomy = 'category' ) {
1443
+ return get_adjacent_post( $in_same_term, $excluded_terms, true, $taxonomy );
1444
+ }
1445
+
1446
+ /**
1447
+ * Retrieve next post that is adjacent to current post.
1448
+ *
1449
+ * @since 1.5.0
1450
+ *
1451
+ * @param bool $in_same_term Optional. Whether post should be in a same taxonomy term.
1452
+ * @param array|string $excluded_terms Optional. Array or comma-separated list of excluded term IDs.
1453
+ * @param string $taxonomy Optional. Taxonomy, if $in_same_term is true. Default 'category'.
1454
+ * @return mixed Post object if successful. Null if global $post is not set. Empty string if no corresponding post exists.
1455
+ */
1456
+ function get_next_post( $in_same_term = false, $excluded_terms = '', $taxonomy = 'category' ) {
1457
+ return get_adjacent_post( $in_same_term, $excluded_terms, false, $taxonomy );
1458
+ }
1459
+
1460
+ /**
1461
+ * Retrieve adjacent post.
1462
+ *
1463
+ * Can either be next or previous post.
1464
+ *
1465
+ * @since 2.5.0
1466
+ *
1467
+ * @param bool $in_same_term Optional. Whether post should be in a same taxonomy term.
1468
+ * @param array|string $excluded_terms Optional. Array or comma-separated list of excluded term IDs.
1469
+ * @param bool $previous Optional. Whether to retrieve previous post.
1470
+ * @param string $taxonomy Optional. Taxonomy, if $in_same_term is true. Default 'category'.
1471
+ * @return mixed Post object if successful. Null if global $post is not set. Empty string if no corresponding post exists.
1472
+ */
1473
+ function get_adjacent_post( $in_same_term = false, $excluded_terms = '', $previous = true, $taxonomy = 'category' ) {
1474
+ global $wpdb;
1475
+
1476
+ if ( ( ! $post = get_post() ) || ! taxonomy_exists( $taxonomy ) )
1477
+ return null;
1478
+
1479
+ $current_post_date = $post->post_date;
1480
+
1481
+ $join = '';
1482
+ $where = '';
1483
+
1484
+ if ( $in_same_term || ! empty( $excluded_terms ) ) {
1485
+ $join = " INNER JOIN $wpdb->term_relationships AS tr ON p.ID = tr.object_id INNER JOIN $wpdb->term_taxonomy tt ON tr.term_taxonomy_id = tt.term_taxonomy_id";
1486
+ $where = $wpdb->prepare( "AND tt.taxonomy = %s", $taxonomy );
1487
+
1488
+ if ( ! empty( $excluded_terms ) && ! is_array( $excluded_terms ) ) {
1489
+ // back-compat, $excluded_terms used to be $excluded_terms with IDs separated by " and "
1490
+ if ( false !== strpos( $excluded_terms, ' and ' ) ) {
1491
+ _deprecated_argument( __FUNCTION__, '3.3', sprintf( __( 'Use commas instead of %s to separate excluded terms.' ), "'and'" ) );
1492
+ $excluded_terms = explode( ' and ', $excluded_terms );
1493
+ } else {
1494
+ $excluded_terms = explode( ',', $excluded_terms );
1495
+ }
1496
+
1497
+ $excluded_terms = array_map( 'intval', $excluded_terms );
1498
+ }
1499
+
1500
+ if ( $in_same_term ) {
1501
+ if ( ! is_object_in_taxonomy( $post->post_type, $taxonomy ) )
1502
+ return '';
1503
+ $term_array = wp_get_object_terms( $post->ID, $taxonomy, array( 'fields' => 'ids' ) );
1504
+
1505
+ // Remove any exclusions from the term array to include.
1506
+ $term_array = array_diff( $term_array, (array) $excluded_terms );
1507
+ $term_array = array_map( 'intval', $term_array );
1508
+
1509
+ if ( ! $term_array || is_wp_error( $term_array ) )
1510
+ return '';
1511
+
1512
+ $where .= " AND tt.term_id IN (" . implode( ',', $term_array ) . ")";
1513
+ }
1514
+
1515
+ if ( ! empty( $excluded_terms ) ) {
1516
+ $where .= " AND p.ID NOT IN ( SELECT object_id FROM $wpdb->term_relationships WHERE term_taxonomy_id IN (" . implode( $excluded_terms, ',' ) . ') )';
1517
+ }
1518
+ }
1519
+
1520
+ $adjacent = $previous ? 'previous' : 'next';
1521
+ $op = $previous ? '<' : '>';
1522
+ $order = $previous ? 'DESC' : 'ASC';
1523
+
1524
+ /**
1525
+ * Filter the JOIN clause in the SQL for an adjacent post query.
1526
+ *
1527
+ * The dynamic portion of the hook name, $adjacent, refers to the type
1528
+ * of adjacency, 'next' or 'previous'.
1529
+ *
1530
+ * @since 2.5.0
1531
+ *
1532
+ * @param string $join The JOIN clause in the SQL.
1533
+ * @param bool $in_same_term Whether post should be in a same taxonomy term.
1534
+ * @param array $excluded_terms Array of excluded term IDs.
1535
+ */
1536
+ $join = apply_filters( "get_{$adjacent}_post_join", $join, $in_same_term, $excluded_terms );
1537
+
1538
+ /**
1539
+ * Filter the WHERE clause in the SQL for an adjacent post query.
1540
+ *
1541
+ * The dynamic portion of the hook name, $adjacent, refers to the type
1542
+ * of adjacency, 'next' or 'previous'.
1543
+ *
1544
+ * @since 2.5.0
1545
+ *
1546
+ * @param string $where The WHERE clause in the SQL.
1547
+ * @param bool $in_same_term Whether post should be in a same taxonomy term.
1548
+ * @param array $excluded_terms Array of excluded term IDs.
1549
+ */
1550
+ $where = apply_filters( "get_{$adjacent}_post_where", $wpdb->prepare( "WHERE p.post_date $op %s AND p.post_type = %s AND p.post_status = 'publish' $where", $current_post_date, $post->post_type ), $in_same_term, $excluded_terms );
1551
+
1552
+ /**
1553
+ * Filter the ORDER BY clause in the SQL for an adjacent post query.
1554
+ *
1555
+ * The dynamic portion of the hook name, $adjacent, refers to the type
1556
+ * of adjacency, 'next' or 'previous'.
1557
+ *
1558
+ * @since 2.5.0
1559
+ *
1560
+ * @param string $order_by The ORDER BY clause in the SQL.
1561
+ */
1562
+ $sort = apply_filters( "get_{$adjacent}_post_sort", "ORDER BY p.post_date $order LIMIT 1" );
1563
+
1564
+ $query = "SELECT p.ID FROM $wpdb->posts AS p $join $where $sort";
1565
+ $query_key = 'adjacent_post_' . md5( $query );
1566
+ $result = wp_cache_get( $query_key, 'counts' );
1567
+ if ( false !== $result ) {
1568
+ if ( $result )
1569
+ $result = get_post( $result );
1570
+ return $result;
1571
+ }
1572
+
1573
+ $result = $wpdb->get_var( $query );
1574
+ if ( null === $result )
1575
+ $result = '';
1576
+
1577
+ wp_cache_set( $query_key, $result, 'counts' );
1578
+
1579
+ if ( $result )
1580
+ $result = get_post( $result );
1581
+
1582
+ return $result;
1583
+ }
1584
+
1585
+ /**
1586
+ * Get adjacent post relational link.
1587
+ *
1588
+ * Can either be next or previous post relational link.
1589
+ *
1590
+ * @since 2.8.0
1591
+ *
1592
+ * @param string $title Optional. Link title format.
1593
+ * @param bool $in_same_term Optional. Whether link should be in a same taxonomy term.
1594
+ * @param array|string $excluded_terms Optional. Array or comma-separated list of excluded term IDs.
1595
+ * @param bool $previous Optional. Whether to display link to previous or next post. Default true.
1596
+ * @param string $taxonomy Optional. Taxonomy, if $in_same_term is true. Default 'category'.
1597
+ * @return string
1598
+ */
1599
+ function get_adjacent_post_rel_link( $title = '%title', $in_same_term = false, $excluded_terms = '', $previous = true, $taxonomy = 'category' ) {
1600
+ if ( $previous && is_attachment() && $post = get_post() )
1601
+ $post = get_post( $post->post_parent );
1602
+ else
1603
+ $post = get_adjacent_post( $in_same_term, $excluded_terms, $previous, $taxonomy );
1604
+
1605
+ if ( empty( $post ) )
1606
+ return;
1607
+
1608
+ $post_title = the_title_attribute( array( 'echo' => false, 'post' => $post ) );
1609
+
1610
+ if ( empty( $post_title ) )
1611
+ $post_title = $previous ? __( 'Previous Post' ) : __( 'Next Post' );
1612
+
1613
+ $date = mysql2date( get_option( 'date_format' ), $post->post_date );
1614
+
1615
+ $title = str_replace( '%title', $post_title, $title );
1616
+ $title = str_replace( '%date', $date, $title );
1617
+
1618
+ $link = $previous ? "<link rel='prev' title='" : "<link rel='next' title='";
1619
+ $link .= esc_attr( $title );
1620
+ $link .= "' href='" . get_permalink( $post ) . "' />\n";
1621
+
1622
+ $adjacent = $previous ? 'previous' : 'next';
1623
+
1624
+ /**
1625
+ * Filter the adjacent post relational link.
1626
+ *
1627
+ * The dynamic portion of the hook name, $adjacent, refers to the type
1628
+ * of adjacency, 'next' or 'previous'.
1629
+ *
1630
+ * @since 2.8.0
1631
+ *
1632
+ * @param string $link The relational link.
1633
+ */
1634
+ return apply_filters( "{$adjacent}_post_rel_link", $link );
1635
+ }
1636
+
1637
+ /**
1638
+ * Display relational links for the posts adjacent to the current post.
1639
+ *
1640
+ * @since 2.8.0
1641
+ *
1642
+ * @param string $title Optional. Link title format.
1643
+ * @param bool $in_same_term Optional. Whether link should be in a same taxonomy term.
1644
+ * @param array|string $excluded_terms Optional. Array or comma-separated list of excluded term IDs.
1645
+ * @param string $taxonomy Optional. Taxonomy, if $in_same_term is true. Default 'category'.
1646
+ */
1647
+ function adjacent_posts_rel_link( $title = '%title', $in_same_term = false, $excluded_terms = '', $taxonomy = 'category' ) {
1648
+ echo get_adjacent_post_rel_link( $title, $in_same_term, $excluded_terms, true, $taxonomy );
1649
+ echo get_adjacent_post_rel_link( $title, $in_same_term, $excluded_terms, false, $taxonomy );
1650
+ }
1651
+
1652
+ /**
1653
+ * Display relational links for the posts adjacent to the current post for single post pages.
1654
+ *
1655
+ * This is meant to be attached to actions like 'wp_head'. Do not call this directly in plugins or theme templates.
1656
+ * @since 3.0.0
1657
+ *
1658
+ */
1659
+ function adjacent_posts_rel_link_wp_head() {
1660
+ if ( ! is_single() || is_attachment() ) {
1661
+ return;
1662
+ }
1663
+ adjacent_posts_rel_link();
1664
+ }
1665
+
1666
+ /**
1667
+ * Display relational link for the next post adjacent to the current post.
1668
+ *
1669
+ * @since 2.8.0
1670
+ *
1671
+ * @param string $title Optional. Link title format.
1672
+ * @param bool $in_same_term Optional. Whether link should be in a same taxonomy term.
1673
+ * @param array|string $excluded_terms Optional. Array or comma-separated list of excluded term IDs.
1674
+ * @param string $taxonomy Optional. Taxonomy, if $in_same_term is true. Default 'category'.
1675
+ */
1676
+ function next_post_rel_link( $title = '%title', $in_same_term = false, $excluded_terms = '', $taxonomy = 'category' ) {
1677
+ echo get_adjacent_post_rel_link( $title, $in_same_term, $excluded_terms, false, $taxonomy );
1678
+ }
1679
+
1680
+ /**
1681
+ * Display relational link for the previous post adjacent to the current post.
1682
+ *
1683
+ * @since 2.8.0
1684
+ *
1685
+ * @param string $title Optional. Link title format.
1686
+ * @param bool $in_same_term Optional. Whether link should be in a same taxonomy term.
1687
+ * @param array|string $excluded_terms Optional. Array or comma-separated list of excluded term IDs. Default true.
1688
+ * @param string $taxonomy Optional. Taxonomy, if $in_same_term is true. Default 'category'.
1689
+ */
1690
+ function prev_post_rel_link( $title = '%title', $in_same_term = false, $excluded_terms = '', $taxonomy = 'category' ) {
1691
+ echo get_adjacent_post_rel_link( $title, $in_same_term, $excluded_terms, true, $taxonomy );
1692
+ }
1693
+
1694
+ /**
1695
+ * Retrieve boundary post.
1696
+ *
1697
+ * Boundary being either the first or last post by publish date within the constraints specified
1698
+ * by $in_same_term or $excluded_terms.
1699
+ *
1700
+ * @since 2.8.0
1701
+ *
1702
+ * @param bool $in_same_term Optional. Whether returned post should be in a same taxonomy term.
1703
+ * @param array|string $excluded_terms Optional. Array or comma-separated list of excluded term IDs.
1704
+ * @param bool $start Optional. Whether to retrieve first or last post.
1705
+ * @param string $taxonomy Optional. Taxonomy, if $in_same_term is true. Default 'category'.
1706
+ * @return mixed Array containing the boundary post object if successful, null otherwise.
1707
+ */
1708
+ function get_boundary_post( $in_same_term = false, $excluded_terms = '', $start = true, $taxonomy = 'category' ) {
1709
+ $post = get_post();
1710
+ if ( ! $post || ! is_single() || is_attachment() || ! taxonomy_exists( $taxonomy ) )
1711
+ return null;
1712
+
1713
+ $query_args = array(
1714
+ 'posts_per_page' => 1,
1715
+ 'order' => $start ? 'ASC' : 'DESC',
1716
+ 'update_post_term_cache' => false,
1717
+ 'update_post_meta_cache' => false
1718
+ );
1719
+
1720
+ $term_array = array();
1721
+
1722
+ if ( ! is_array( $excluded_terms ) ) {
1723
+ if ( ! empty( $excluded_terms ) )
1724
+ $excluded_terms = explode( ',', $excluded_terms );
1725
+ else
1726
+ $excluded_terms = array();
1727
+ }
1728
+
1729
+ if ( $in_same_term || ! empty( $excluded_terms ) ) {
1730
+ if ( $in_same_term )
1731
+ $term_array = wp_get_object_terms( $post->ID, $taxonomy, array( 'fields' => 'ids' ) );
1732
+
1733
+ if ( ! empty( $excluded_terms ) ) {
1734
+ $excluded_terms = array_map( 'intval', $excluded_terms );
1735
+ $excluded_terms = array_diff( $excluded_terms, $term_array );
1736
+
1737
+ $inverse_terms = array();
1738
+ foreach ( $excluded_terms as $excluded_term )
1739
+ $inverse_terms[] = $excluded_term * -1;
1740
+ $excluded_terms = $inverse_terms;
1741
+ }
1742
+
1743
+ $query_args[ 'tax_query' ] = array( array(
1744
+ 'taxonomy' => $taxonomy,
1745
+ 'terms' => array_merge( $term_array, $excluded_terms )
1746
+ ) );
1747
+ }
1748
+
1749
+ return get_posts( $query_args );
1750
+ }
1751
+
1752
+ /*
1753
+ * Get previous post link that is adjacent to the current post.
1754
+ *
1755
+ * @since 3.7.0
1756
+ *
1757
+ * @param string $format Optional. Link anchor format.
1758
+ * @param string $link Optional. Link permalink format.
1759
+ * @param bool $in_same_term Optional. Whether link should be in a same taxonomy term.
1760
+ * @param array|string $excluded_terms Optional. Array or comma-separated list of excluded term IDs.
1761
+ * @param string $taxonomy Optional. Taxonomy, if $in_same_term is true. Default 'category'.
1762
+ * @return string
1763
+ */
1764
+ function get_previous_post_link( $format = '&laquo; %link', $link = '%title', $in_same_term = false, $excluded_terms = '', $taxonomy = 'category' ) {
1765
+ return get_adjacent_post_link( $format, $link, $in_same_term, $excluded_terms, true, $taxonomy );
1766
+ }
1767
+
1768
+ /**
1769
+ * Display previous post link that is adjacent to the current post.
1770
+ *
1771
+ * @since 1.5.0
1772
+ * @see get_previous_post_link()
1773
+ *
1774
+ * @param string $format Optional. Link anchor format.
1775
+ * @param string $link Optional. Link permalink format.
1776
+ * @param bool $in_same_term Optional. Whether link should be in a same taxonomy term.
1777
+ * @param array|string $excluded_terms Optional. Array or comma-separated list of excluded term IDs.
1778
+ * @param string $taxonomy Optional. Taxonomy, if $in_same_term is true. Default 'category'.
1779
+ */
1780
+ function previous_post_link( $format = '&laquo; %link', $link = '%title', $in_same_term = false, $excluded_terms = '', $taxonomy = 'category' ) {
1781
+ echo get_previous_post_link( $format, $link, $in_same_term, $excluded_terms, $taxonomy );
1782
+ }
1783
+
1784
+ /**
1785
+ * Get next post link that is adjacent to the current post.
1786
+ *
1787
+ * @since 3.7.0
1788
+ *
1789
+ * @param string $format Optional. Link anchor format.
1790
+ * @param string $link Optional. Link permalink format.
1791
+ * @param bool $in_same_term Optional. Whether link should be in a same taxonomy term.
1792
+ * @param array|string $excluded_terms Optional. Array or comma-separated list of excluded term IDs.
1793
+ * @param string $taxonomy Optional. Taxonomy, if $in_same_term is true. Default 'category'.
1794
+ * @return string
1795
+ */
1796
+ function get_next_post_link( $format = '%link &raquo;', $link = '%title', $in_same_term = false, $excluded_terms = '', $taxonomy = 'category' ) {
1797
+ return get_adjacent_post_link( $format, $link, $in_same_term, $excluded_terms, false, $taxonomy );
1798
+ }
1799
+
1800
+ /**
1801
+ * Display next post link that is adjacent to the current post.
1802
+ *
1803
+ * @since 1.5.0
1804
+ * @see get_next_post_link()
1805
+ *
1806
+ * @param string $format Optional. Link anchor format.
1807
+ * @param string $link Optional. Link permalink format.
1808
+ * @param bool $in_same_term Optional. Whether link should be in a same taxonomy term.
1809
+ * @param array|string $excluded_terms Optional. Array or comma-separated list of excluded term IDs.
1810
+ * @param string $taxonomy Optional. Taxonomy, if $in_same_term is true. Default 'category'.
1811
+ */
1812
+ function next_post_link( $format = '%link &raquo;', $link = '%title', $in_same_term = false, $excluded_terms = '', $taxonomy = 'category' ) {
1813
+ echo get_next_post_link( $format, $link, $in_same_term, $excluded_terms, $taxonomy );
1814
+ }
1815
+
1816
+ /**
1817
+ * Get adjacent post link.
1818
+ *
1819
+ * Can be either next post link or previous.
1820
+ *
1821
+ * @since 3.7.0
1822
+ *
1823
+ * @param string $format Link anchor format.
1824
+ * @param string $link Link permalink format.
1825
+ * @param bool $in_same_term Optional. Whether link should be in a same taxonomy term.
1826
+ * @param array|string $excluded_terms Optional. Array or comma-separated list of excluded terms IDs.
1827
+ * @param bool $previous Optional. Whether to display link to previous or next post. Default true.
1828
+ * @param string $taxonomy Optional. Taxonomy, if $in_same_term is true. Default 'category'.
1829
+ * @return string
1830
+ */
1831
+ function get_adjacent_post_link( $format, $link, $in_same_term = false, $excluded_terms = '', $previous = true, $taxonomy = 'category' ) {
1832
+ if ( $previous && is_attachment() )
1833
+ $post = get_post( get_post()->post_parent );
1834
+ else
1835
+ $post = get_adjacent_post( $in_same_term, $excluded_terms, $previous, $taxonomy );
1836
+
1837
+ if ( ! $post ) {
1838
+ $output = '';
1839
+ } else {
1840
+ $title = $post->post_title;
1841
+
1842
+ if ( empty( $post->post_title ) )
1843
+ $title = $previous ? __( 'Previous Post' ) : __( 'Next Post' );
1844
+
1845
+ /** This filter is documented in wp-includes/post-template.php */
1846
+ $title = apply_filters( 'the_title', $title, $post->ID );
1847
+
1848
+ $date = mysql2date( get_option( 'date_format' ), $post->post_date );
1849
+ $rel = $previous ? 'prev' : 'next';
1850
+
1851
+ $string = '<a href="' . get_permalink( $post ) . '" rel="'.$rel.'">';
1852
+ $inlink = str_replace( '%title', $title, $link );
1853
+ $inlink = str_replace( '%date', $date, $inlink );
1854
+ $inlink = $string . $inlink . '</a>';
1855
+
1856
+ $output = str_replace( '%link', $inlink, $format );
1857
+ }
1858
+
1859
+ $adjacent = $previous ? 'previous' : 'next';
1860
+
1861
+ /**
1862
+ * Filter the adjacent post link.
1863
+ *
1864
+ * The dynamic portion of the hook name, $adjacent, refers to the type
1865
+ * of adjacency, 'next' or 'previous'.
1866
+ *
1867
+ * @since 2.6.0
1868
+ *
1869
+ * @param string $output The adjacent post link.
1870
+ * @param string $format Link anchor format.
1871
+ * @param string $link Link permalink format.
1872
+ * @param WP_Post $post The adjacent post.
1873
+ */
1874
+ return apply_filters( "{$adjacent}_post_link", $output, $format, $link, $post );
1875
+ }
1876
+
1877
+ /**
1878
+ * Display adjacent post link.
1879
+ *
1880
+ * Can be either next post link or previous.
1881
+ *
1882
+ * @since 2.5.0
1883
+ * @uses get_adjacent_post_link()
1884
+ *
1885
+ * @param string $format Link anchor format.
1886
+ * @param string $link Link permalink format.
1887
+ * @param bool $in_same_term Optional. Whether link should be in a same taxonomy term.
1888
+ * @param array|string $excluded_terms Optional. Array or comma-separated list of excluded category IDs.
1889
+ * @param bool $previous Optional. Whether to display link to previous or next post. Default true.
1890
+ * @param string $taxonomy Optional. Taxonomy, if $in_same_term is true. Default 'category'.
1891
+ * @return string
1892
+ */
1893
+ function adjacent_post_link( $format, $link, $in_same_term = false, $excluded_terms = '', $previous = true, $taxonomy = 'category' ) {
1894
+ echo get_adjacent_post_link( $format, $link, $in_same_term, $excluded_terms, $previous, $taxonomy );
1895
+ }
1896
+
1897
+ /**
1898
+ * Retrieve links for page numbers.
1899
+ *
1900
+ * @since 1.5.0
1901
+ *
1902
+ * @param int $pagenum Optional. Page ID.
1903
+ * @param bool $escape Optional. Whether to escape the URL for display, with esc_url(). Defaults to true.
1904
+ * Otherwise, prepares the URL with esc_url_raw().
1905
+ * @return string
1906
+ */
1907
+ function get_pagenum_link($pagenum = 1, $escape = true ) {
1908
+ global $wp_rewrite;
1909
+
1910
+ $pagenum = (int) $pagenum;
1911
+
1912
+ $request = remove_query_arg( 'paged' );
1913
+
1914
+ $home_root = parse_url(home_url());
1915
+ $home_root = ( isset($home_root['path']) ) ? $home_root['path'] : '';
1916
+ $home_root = preg_quote( $home_root, '|' );
1917
+
1918
+ $request = preg_replace('|^'. $home_root . '|i', '', $request);
1919
+ $request = preg_replace('|^/+|', '', $request);
1920
+
1921
+ if ( !$wp_rewrite->using_permalinks() || is_admin() ) {
1922
+ $base = trailingslashit( get_bloginfo( 'url' ) );
1923
+
1924
+ if ( $pagenum > 1 ) {
1925
+ $result = add_query_arg( 'paged', $pagenum, $base . $request );
1926
+ } else {
1927
+ $result = $base . $request;
1928
+ }
1929
+ } else {
1930
+ $qs_regex = '|\?.*?$|';
1931
+ preg_match( $qs_regex, $request, $qs_match );
1932
+
1933
+ if ( !empty( $qs_match[0] ) ) {
1934
+ $query_string = $qs_match[0];
1935
+ $request = preg_replace( $qs_regex, '', $request );
1936
+ } else {
1937
+ $query_string = '';
1938
+ }
1939
+
1940
+ $request = preg_replace( "|$wp_rewrite->pagination_base/\d+/?$|", '', $request);
1941
+ $request = preg_replace( '|^' . preg_quote( $wp_rewrite->index, '|' ) . '|i', '', $request);
1942
+ $request = ltrim($request, '/');
1943
+
1944
+ $base = trailingslashit( get_bloginfo( 'url' ) );
1945
+
1946
+ if ( $wp_rewrite->using_index_permalinks() && ( $pagenum > 1 || '' != $request ) )
1947
+ $base .= $wp_rewrite->index . '/';
1948
+
1949
+ if ( $pagenum > 1 ) {
1950
+ $request = ( ( !empty( $request ) ) ? trailingslashit( $request ) : $request ) . user_trailingslashit( $wp_rewrite->pagination_base . "/" . $pagenum, 'paged' );
1951
+ }
1952
+
1953
+ $result = $base . $request . $query_string;
1954
+ }
1955
+
1956
+ /**
1957
+ * Filter the page number link for the current request.
1958
+ *
1959
+ * @since 2.5.0
1960
+ *
1961
+ * @param string $result The page number link.
1962
+ */
1963
+ $result = apply_filters( 'get_pagenum_link', $result );
1964
+
1965
+ if ( $escape )
1966
+ return esc_url( $result );
1967
+ else
1968
+ return esc_url_raw( $result );
1969
+ }
1970
+
1971
+ /**
1972
+ * Retrieve next posts page link.
1973
+ *
1974
+ * Backported from 2.1.3 to 2.0.10.
1975
+ *
1976
+ * @since 2.0.10
1977
+ *
1978
+ * @param int $max_page Optional. Max pages.
1979
+ * @return string
1980
+ */
1981
+ function get_next_posts_page_link($max_page = 0) {
1982
+ global $paged;
1983
+
1984
+ if ( !is_single() ) {
1985
+ if ( !$paged )
1986
+ $paged = 1;
1987
+ $nextpage = intval($paged) + 1;
1988
+ if ( !$max_page || $max_page >= $nextpage )
1989
+ return get_pagenum_link($nextpage);
1990
+ }
1991
+ }
1992
+
1993
+ /**
1994
+ * Display or return the next posts page link.
1995
+ *
1996
+ * @since 0.71
1997
+ *
1998
+ * @param int $max_page Optional. Max pages.
1999
+ * @param boolean $echo Optional. Echo or return;
2000
+ */
2001
+ function next_posts( $max_page = 0, $echo = true ) {
2002
+ $output = esc_url( get_next_posts_page_link( $max_page ) );
2003
+
2004
+ if ( $echo )
2005
+ echo $output;
2006
+ else
2007
+ return $output;
2008
+ }
2009
+
2010
+ /**
2011
+ * Return the next posts page link.
2012
+ *
2013
+ * @since 2.7.0
2014
+ *
2015
+ * @param string $label Content for link text.
2016
+ * @param int $max_page Optional. Max pages.
2017
+ * @return string|null
2018
+ */
2019
+ function get_next_posts_link( $label = null, $max_page = 0 ) {
2020
+ global $paged, $wp_query;
2021
+
2022
+ if ( !$max_page )
2023
+ $max_page = $wp_query->max_num_pages;
2024
+
2025
+ if ( !$paged )
2026
+ $paged = 1;
2027
+
2028
+ $nextpage = intval($paged) + 1;
2029
+
2030
+ if ( null === $label )
2031
+ $label = __( 'Next Page &raquo;' );
2032
+
2033
+ if ( !is_single() && ( $nextpage <= $max_page ) ) {
2034
+ /**
2035
+ * Filter the anchor tag attributes for the next posts page link.
2036
+ *
2037
+ * @since 2.7.0
2038
+ *
2039
+ * @param string $attributes Attributes for the anchor tag.
2040
+ */
2041
+ $attr = apply_filters( 'next_posts_link_attributes', '' );
2042
+
2043
+ return '<a href="' . next_posts( $max_page, false ) . "\" $attr>" . preg_replace('/&([^#])(?![a-z]{1,8};)/i', '&#038;$1', $label) . '</a>';
2044
+ }
2045
+ }
2046
+
2047
+ /**
2048
+ * Display the next posts page link.
2049
+ *
2050
+ * @since 0.71
2051
+ * @uses get_next_posts_link()
2052
+ *
2053
+ * @param string $label Content for link text.
2054
+ * @param int $max_page Optional. Max pages.
2055
+ */
2056
+ function next_posts_link( $label = null, $max_page = 0 ) {
2057
+ echo get_next_posts_link( $label, $max_page );
2058
+ }
2059
+
2060
+ /**
2061
+ * Retrieve previous posts page link.
2062
+ *
2063
+ * Will only return string, if not on a single page or post.
2064
+ *
2065
+ * Backported to 2.0.10 from 2.1.3.
2066
+ *
2067
+ * @since 2.0.10
2068
+ *
2069
+ * @return string|null
2070
+ */
2071
+ function get_previous_posts_page_link() {
2072
+ global $paged;
2073
+
2074
+ if ( !is_single() ) {
2075
+ $nextpage = intval($paged) - 1;
2076
+ if ( $nextpage < 1 )
2077
+ $nextpage = 1;
2078
+ return get_pagenum_link($nextpage);
2079
+ }
2080
+ }
2081
+
2082
+ /**
2083
+ * Display or return the previous posts page link.
2084
+ *
2085
+ * @since 0.71
2086
+ *
2087
+ * @param boolean $echo Optional. Echo or return;
2088
+ */
2089
+ function previous_posts( $echo = true ) {
2090
+ $output = esc_url( get_previous_posts_page_link() );
2091
+
2092
+ if ( $echo )
2093
+ echo $output;
2094
+ else
2095
+ return $output;
2096
+ }
2097
+
2098
+ /**
2099
+ * Return the previous posts page link.
2100
+ *
2101
+ * @since 2.7.0
2102
+ *
2103
+ * @param string $label Optional. Previous page link text.
2104
+ * @return string|null
2105
+ */
2106
+ function get_previous_posts_link( $label = null ) {
2107
+ global $paged;
2108
+
2109
+ if ( null === $label )
2110
+ $label = __( '&laquo; Previous Page' );
2111
+
2112
+ if ( !is_single() && $paged > 1 ) {
2113
+ /**
2114
+ * Filter the anchor tag attributes for the previous posts page link.
2115
+ *
2116
+ * @since 2.7.0
2117
+ *
2118
+ * @param string $attributes Attributes for the anchor tag.
2119
+ */
2120
+ $attr = apply_filters( 'previous_posts_link_attributes', '' );
2121
+ return '<a href="' . previous_posts( false ) . "\" $attr>". preg_replace( '/&([^#])(?![a-z]{1,8};)/i', '&#038;$1', $label ) .'</a>';
2122
+ }
2123
+ }
2124
+
2125
+ /**
2126
+ * Display the previous posts page link.
2127
+ *
2128
+ * @since 0.71
2129
+ * @uses get_previous_posts_link()
2130
+ *
2131
+ * @param string $label Optional. Previous page link text.
2132
+ */
2133
+ function previous_posts_link( $label = null ) {
2134
+ echo get_previous_posts_link( $label );
2135
+ }
2136
+
2137
+ /**
2138
+ * Return post pages link navigation for previous and next pages.
2139
+ *
2140
+ * @since 2.8.0
2141
+ *
2142
+ * @param string|array $args Optional args.
2143
+ * @return string The posts link navigation.
2144
+ */
2145
+ function get_posts_nav_link( $args = array() ) {
2146
+ global $wp_query;
2147
+
2148
+ $return = '';
2149
+
2150
+ if ( !is_singular() ) {
2151
+ $defaults = array(
2152
+ 'sep' => ' &#8212; ',
2153
+ 'prelabel' => __('&laquo; Previous Page'),
2154
+ 'nxtlabel' => __('Next Page &raquo;'),
2155
+ );
2156
+ $args = wp_parse_args( $args, $defaults );
2157
+
2158
+ $max_num_pages = $wp_query->max_num_pages;
2159
+ $paged = get_query_var('paged');
2160
+
2161
+ //only have sep if there's both prev and next results
2162
+ if ($paged < 2 || $paged >= $max_num_pages) {
2163
+ $args['sep'] = '';
2164
+ }
2165
+
2166
+ if ( $max_num_pages > 1 ) {
2167
+ $return = get_previous_posts_link($args['prelabel']);
2168
+ $return .= preg_replace('/&([^#])(?![a-z]{1,8};)/i', '&#038;$1', $args['sep']);
2169
+ $return .= get_next_posts_link($args['nxtlabel']);
2170
+ }
2171
+ }
2172
+ return $return;
2173
+
2174
+ }
2175
+
2176
+ /**
2177
+ * Display post pages link navigation for previous and next pages.
2178
+ *
2179
+ * @since 0.71
2180
+ *
2181
+ * @param string $sep Optional. Separator for posts navigation links.
2182
+ * @param string $prelabel Optional. Label for previous pages.
2183
+ * @param string $nxtlabel Optional Label for next pages.
2184
+ */
2185
+ function posts_nav_link( $sep = '', $prelabel = '', $nxtlabel = '' ) {
2186
+ $args = array_filter( compact('sep', 'prelabel', 'nxtlabel') );
2187
+ echo get_posts_nav_link($args);
2188
+ }
2189
+
2190
+ /**
2191
+ * Retrieve comments page number link.
2192
+ *
2193
+ * @since 2.7.0
2194
+ *
2195
+ * @param int $pagenum Optional. Page number.
2196
+ * @return string
2197
+ */
2198
+ function get_comments_pagenum_link( $pagenum = 1, $max_page = 0 ) {
2199
+ global $wp_rewrite;
2200
+
2201
+ $pagenum = (int) $pagenum;
2202
+
2203
+ $result = get_permalink();
2204
+
2205
+ if ( 'newest' == get_option('default_comments_page') ) {
2206
+ if ( $pagenum != $max_page ) {
2207
+ if ( $wp_rewrite->using_permalinks() )
2208
+ $result = user_trailingslashit( trailingslashit($result) . 'comment-page-' . $pagenum, 'commentpaged');
2209
+ else
2210
+ $result = add_query_arg( 'cpage', $pagenum, $result );
2211
+ }
2212
+ } elseif ( $pagenum > 1 ) {
2213
+ if ( $wp_rewrite->using_permalinks() )
2214
+ $result = user_trailingslashit( trailingslashit($result) . 'comment-page-' . $pagenum, 'commentpaged');
2215
+ else
2216
+ $result = add_query_arg( 'cpage', $pagenum, $result );
2217
+ }
2218
+
2219
+ $result .= '#comments';
2220
+
2221
+ /**
2222
+ * Filter the comments page number link for the current request.
2223
+ *
2224
+ * @since 2.7.0
2225
+ *
2226
+ * @param string $result The comments page number link.
2227
+ */
2228
+ $result = apply_filters( 'get_comments_pagenum_link', $result );
2229
+
2230
+ return $result;
2231
+ }
2232
+
2233
+ /**
2234
+ * Return the link to next comments page.
2235
+ *
2236
+ * @since 2.7.1
2237
+ *
2238
+ * @param string $label Optional. Label for link text.
2239
+ * @param int $max_page Optional. Max page.
2240
+ * @return string|null
2241
+ */
2242
+ function get_next_comments_link( $label = '', $max_page = 0 ) {
2243
+ global $wp_query;
2244
+
2245
+ if ( !is_singular() || !get_option('page_comments') )
2246
+ return;
2247
+
2248
+ $page = get_query_var('cpage');
2249
+
2250
+ $nextpage = intval($page) + 1;
2251
+
2252
+ if ( empty($max_page) )
2253
+ $max_page = $wp_query->max_num_comment_pages;
2254
+
2255
+ if ( empty($max_page) )
2256
+ $max_page = get_comment_pages_count();
2257
+
2258
+ if ( $nextpage > $max_page )
2259
+ return;
2260
+
2261
+ if ( empty($label) )
2262
+ $label = __('Newer Comments &raquo;');
2263
+
2264
+ /**
2265
+ * Filter the anchor tag attributes for the next comments page link.
2266
+ *
2267
+ * @since 2.7.0
2268
+ *
2269
+ * @param string $attributes Attributes for the anchor tag.
2270
+ */
2271
+ return '<a href="' . esc_url( get_comments_pagenum_link( $nextpage, $max_page ) ) . '" ' . apply_filters( 'next_comments_link_attributes', '' ) . '>'. preg_replace('/&([^#])(?![a-z]{1,8};)/i', '&#038;$1', $label) .'</a>';
2272
+ }
2273
+
2274
+ /**
2275
+ * Display the link to next comments page.
2276
+ *
2277
+ * @since 2.7.0
2278
+ *
2279
+ * @param string $label Optional. Label for link text.
2280
+ * @param int $max_page Optional. Max page.
2281
+ */
2282
+ function next_comments_link( $label = '', $max_page = 0 ) {
2283
+ echo get_next_comments_link( $label, $max_page );
2284
+ }
2285
+
2286
+ /**
2287
+ * Return the previous comments page link.
2288
+ *
2289
+ * @since 2.7.1
2290
+ *
2291
+ * @param string $label Optional. Label for comments link text.
2292
+ * @return string|null
2293
+ */
2294
+ function get_previous_comments_link( $label = '' ) {
2295
+ if ( !is_singular() || !get_option('page_comments') )
2296
+ return;
2297
+
2298
+ $page = get_query_var('cpage');
2299
+
2300
+ if ( intval($page) <= 1 )
2301
+ return;
2302
+
2303
+ $prevpage = intval($page) - 1;
2304
+
2305
+ if ( empty($label) )
2306
+ $label = __('&laquo; Older Comments');
2307
+
2308
+ /**
2309
+ * Filter the anchor tag attributes for the previous comments page link.
2310
+ *
2311
+ * @since 2.7.0
2312
+ *
2313
+ * @param string $attributes Attributes for the anchor tag.
2314
+ */
2315
+ return '<a href="' . esc_url( get_comments_pagenum_link( $prevpage ) ) . '" ' . apply_filters( 'previous_comments_link_attributes', '' ) . '>' . preg_replace('/&([^#])(?![a-z]{1,8};)/i', '&#038;$1', $label) .'</a>';
2316
+ }
2317
+
2318
+ /**
2319
+ * Display the previous comments page link.
2320
+ *
2321
+ * @since 2.7.0
2322
+ *
2323
+ * @param string $label Optional. Label for comments link text.
2324
+ */
2325
+ function previous_comments_link( $label = '' ) {
2326
+ echo get_previous_comments_link( $label );
2327
+ }
2328
+
2329
+ /**
2330
+ * Create pagination links for the comments on the current post.
2331
+ *
2332
+ * @see paginate_links()
2333
+ * @since 2.7.0
2334
+ *
2335
+ * @param string|array $args Optional args. See paginate_links().
2336
+ * @return string Markup for pagination links.
2337
+ */
2338
+ function paginate_comments_links($args = array()) {
2339
+ global $wp_rewrite;
2340
+
2341
+ if ( !is_singular() || !get_option('page_comments') )
2342
+ return;
2343
+
2344
+ $page = get_query_var('cpage');
2345
+ if ( !$page )
2346
+ $page = 1;
2347
+ $max_page = get_comment_pages_count();
2348
+ $defaults = array(
2349
+ 'base' => add_query_arg( 'cpage', '%#%' ),
2350
+ 'format' => '',
2351
+ 'total' => $max_page,
2352
+ 'current' => $page,
2353
+ 'echo' => true,
2354
+ 'add_fragment' => '#comments'
2355
+ );
2356
+ if ( $wp_rewrite->using_permalinks() )
2357
+ $defaults['base'] = user_trailingslashit(trailingslashit(get_permalink()) . 'comment-page-%#%', 'commentpaged');
2358
+
2359
+ $args = wp_parse_args( $args, $defaults );
2360
+ $page_links = paginate_links( $args );
2361
+
2362
+ if ( $args['echo'] )
2363
+ echo $page_links;
2364
+ else
2365
+ return $page_links;
2366
+ }
2367
+
2368
+ /**
2369
+ * Retrieve the Press This bookmarklet link.
2370
+ *
2371
+ * Use this in 'a' element 'href' attribute.
2372
+ *
2373
+ * @since 2.6.0
2374
+ *
2375
+ * @return string
2376
+ */
2377
+ function get_shortcut_link() {
2378
+ // In case of breaking changes, version this. #WP20071
2379
+ $link = "javascript:
2380
+ var d=document,
2381
+ w=window,
2382
+ e=w.getSelection,
2383
+ k=d.getSelection,
2384
+ x=d.selection,
2385
+ s=(e?e():(k)?k():(x?x.createRange().text:0)),
2386
+ f='" . admin_url('press-this.php') . "',
2387
+ l=d.location,
2388
+ e=encodeURIComponent,
2389
+ u=f+'?u='+e(l.href)+'&t='+e(d.title)+'&s='+e(s)+'&v=4';
2390
+ a=function(){if(!w.open(u,'t','toolbar=0,resizable=1,scrollbars=1,status=1,width=720,height=570'))l.href=u;};
2391
+ if (/Firefox/.test(navigator.userAgent)) setTimeout(a, 0); else a();
2392
+ void(0)";
2393
+
2394
+ $link = str_replace(array("\r", "\n", "\t"), '', $link);
2395
+
2396
+ /**
2397
+ * Filter the Press This bookmarklet link.
2398
+ *
2399
+ * @since 2.6.0
2400
+ *
2401
+ * @param string $link The Press This bookmarklet link.
2402
+ */
2403
+ return apply_filters( 'shortcut_link', $link );
2404
+ }
2405
+
2406
+ /**
2407
+ * Retrieve the home url for the current site.
2408
+ *
2409
+ * Returns the 'home' option with the appropriate protocol, 'https' if
2410
+ * is_ssl() and 'http' otherwise. If $scheme is 'http' or 'https', is_ssl() is
2411
+ * overridden.
2412
+ *
2413
+ * @since 3.0.0
2414
+ *
2415
+ * @uses get_home_url()
2416
+ *
2417
+ * @param string $path (optional) Path relative to the home url.
2418
+ * @param string $scheme (optional) Scheme to give the home url context. Currently 'http', 'https', or 'relative'.
2419
+ * @return string Home url link with optional path appended.
2420
+ */
2421
+ function home_url( $path = '', $scheme = null ) {
2422
+ return get_home_url( null, $path, $scheme );
2423
+ }
2424
+
2425
+ /**
2426
+ * Retrieve the home url for a given site.
2427
+ *
2428
+ * Returns the 'home' option with the appropriate protocol, 'https' if
2429
+ * is_ssl() and 'http' otherwise. If $scheme is 'http' or 'https', is_ssl() is
2430
+ * overridden.
2431
+ *
2432
+ * @since 3.0.0
2433
+ *
2434
+ * @param int $blog_id (optional) Blog ID. Defaults to current blog.
2435
+ * @param string $path (optional) Path relative to the home url.
2436
+ * @param string $scheme (optional) Scheme to give the home url context. Currently 'http', 'https', or 'relative'.
2437
+ * @return string Home url link with optional path appended.
2438
+ */
2439
+ function get_home_url( $blog_id = null, $path = '', $scheme = null ) {
2440
+ $orig_scheme = $scheme;
2441
+
2442
+ if ( empty( $blog_id ) || !is_multisite() ) {
2443
+ $url = get_option( 'home' );
2444
+ } else {
2445
+ switch_to_blog( $blog_id );
2446
+ $url = get_option( 'home' );
2447
+ restore_current_blog();
2448
+ }
2449
+
2450
+ if ( ! in_array( $scheme, array( 'http', 'https', 'relative' ) ) ) {
2451
+ if ( is_ssl() && ! is_admin() && 'wp-login.php' !== $GLOBALS['pagenow'] )
2452
+ $scheme = 'https';
2453
+ else
2454
+ $scheme = parse_url( $url, PHP_URL_SCHEME );
2455
+ }
2456
+
2457
+ $url = set_url_scheme( $url, $scheme );
2458
+
2459
+ if ( $path && is_string( $path ) )
2460
+ $url .= '/' . ltrim( $path, '/' );
2461
+
2462
+ /**
2463
+ * Filter the home URL.
2464
+ *
2465
+ * @since 3.0.0
2466
+ *
2467
+ * @param string $url The complete home URL including scheme and path.
2468
+ * @param string $path Path relative to the home URL. Blank string if no path is specified.
2469
+ * @param string|null $orig_scheme Scheme to give the home URL context. Accepts 'http', 'https', 'relative' or null.
2470
+ * @param int|null $blog_id Blog ID, or null for the current blog.
2471
+ */
2472
+ return apply_filters( 'home_url', $url, $path, $orig_scheme, $blog_id );
2473
+ }
2474
+
2475
+ /**
2476
+ * Retrieve the site url for the current site.
2477
+ *
2478
+ * Returns the 'site_url' option with the appropriate protocol, 'https' if
2479
+ * is_ssl() and 'http' otherwise. If $scheme is 'http' or 'https', is_ssl() is
2480
+ * overridden.
2481
+ *
2482
+ * @since 3.0.0
2483
+ *
2484
+ * @uses get_site_url()
2485
+ *
2486
+ * @param string $path Optional. Path relative to the site url.
2487
+ * @param string $scheme Optional. Scheme to give the site url context. See set_url_scheme().
2488
+ * @return string Site url link with optional path appended.
2489
+ */
2490
+ function site_url( $path = '', $scheme = null ) {
2491
+ return get_site_url( null, $path, $scheme );
2492
+ }
2493
+
2494
+ /**
2495
+ * Retrieve the site url for a given site.
2496
+ *
2497
+ * Returns the 'site_url' option with the appropriate protocol, 'https' if
2498
+ * is_ssl() and 'http' otherwise. If $scheme is 'http' or 'https', is_ssl() is
2499
+ * overridden.
2500
+ *
2501
+ * @since 3.0.0
2502
+ *
2503
+ * @param int $blog_id (optional) Blog ID. Defaults to current blog.
2504
+ * @param string $path Optional. Path relative to the site url.
2505
+ * @param string $scheme Optional. Scheme to give the site url context. Currently 'http', 'https', 'login', 'login_post', 'admin', or 'relative'.
2506
+ * @return string Site url link with optional path appended.
2507
+ */
2508
+ function get_site_url( $blog_id = null, $path = '', $scheme = null ) {
2509
+ if ( empty( $blog_id ) || !is_multisite() ) {
2510
+ $url = get_option( 'siteurl' );
2511
+ } else {
2512
+ switch_to_blog( $blog_id );
2513
+ $url = get_option( 'siteurl' );
2514
+ restore_current_blog();
2515
+ }
2516
+
2517
+ $url = set_url_scheme( $url, $scheme );
2518
+
2519
+ if ( $path && is_string( $path ) )
2520
+ $url .= '/' . ltrim( $path, '/' );
2521
+
2522
+ /**
2523
+ * Filter the site URL.
2524
+ *
2525
+ * @since 2.7.0
2526
+ *
2527
+ * @param string $url The complete site URL including scheme and path.
2528
+ * @param string $path Path relative to the site URL. Blank string if no path is specified.
2529
+ * @param string|null $scheme Scheme to give the site URL context. Accepts 'http', 'https', 'login',
2530
+ * 'login_post', 'admin', 'relative' or null.
2531
+ * @param int|null $blog_id Blog ID, or null for the current blog.
2532
+ */
2533
+ return apply_filters( 'site_url', $url, $path, $scheme, $blog_id );
2534
+ }
2535
+
2536
+ /**
2537
+ * Retrieve the url to the admin area for the current site.
2538
+ *
2539
+ * @since 2.6.0
2540
+ *
2541
+ * @param string $path Optional path relative to the admin url.
2542
+ * @param string $scheme The scheme to use. Default is 'admin', which obeys force_ssl_admin() and is_ssl(). 'http' or 'https' can be passed to force those schemes.
2543
+ * @return string Admin url link with optional path appended.
2544
+ */
2545
+ function admin_url( $path = '', $scheme = 'admin' ) {
2546
+ return get_admin_url( null, $path, $scheme );
2547
+ }
2548
+
2549
+ /**
2550
+ * Retrieve the url to the admin area for a given site.
2551
+ *
2552
+ * @since 3.0.0
2553
+ *
2554
+ * @param int $blog_id (optional) Blog ID. Defaults to current blog.
2555
+ * @param string $path Optional path relative to the admin url.
2556
+ * @param string $scheme The scheme to use. Default is 'admin', which obeys force_ssl_admin() and is_ssl(). 'http' or 'https' can be passed to force those schemes.
2557
+ * @return string Admin url link with optional path appended.
2558
+ */
2559
+ function get_admin_url( $blog_id = null, $path = '', $scheme = 'admin' ) {
2560
+ $url = get_site_url($blog_id, 'wp-admin/', $scheme);
2561
+
2562
+ if ( $path && is_string( $path ) )
2563
+ $url .= ltrim( $path, '/' );
2564
+
2565
+ /**
2566
+ * Filter the admin area URL.
2567
+ *
2568
+ * @since 2.8.0
2569
+ *
2570
+ * @param string $url The complete admin area URL including scheme and path.
2571
+ * @param string $path Path relative to the admin area URL. Blank string if no path is specified.
2572
+ * @param int|null $blog_id Blog ID, or null for the current blog.
2573
+ */
2574
+ return apply_filters( 'admin_url', $url, $path, $blog_id );
2575
+ }
2576
+
2577
+ /**
2578
+ * Retrieve the url to the includes directory.
2579
+ *
2580
+ * @since 2.6.0
2581
+ *
2582
+ * @param string $path Optional. Path relative to the includes url.
2583
+ * @param string $scheme Optional. Scheme to give the includes url context.
2584
+ * @return string Includes url link with optional path appended.
2585
+ */
2586
+ function includes_url( $path = '', $scheme = null ) {
2587
+ $url = site_url( '/' . WPINC . '/', $scheme );
2588
+
2589
+ if ( $path && is_string( $path ) )
2590
+ $url .= ltrim($path, '/');
2591
+
2592
+ /**
2593
+ * Filter the URL to the includes directory.
2594
+ *
2595
+ * @since 2.8.0
2596
+ *
2597
+ * @param string $url The complete URL to the includes directory including scheme and path.
2598
+ * @param string $path Path relative to the URL to the wp-includes directory. Blank string
2599
+ * if no path is specified.
2600
+ */
2601
+ return apply_filters( 'includes_url', $url, $path );
2602
+ }
2603
+
2604
+ /**
2605
+ * Retrieve the url to the content directory.
2606
+ *
2607
+ * @since 2.6.0
2608
+ *
2609
+ * @param string $path Optional. Path relative to the content url.
2610
+ * @return string Content url link with optional path appended.
2611
+ */
2612
+ function content_url($path = '') {
2613
+ $url = set_url_scheme( WP_CONTENT_URL );
2614
+
2615
+ if ( $path && is_string( $path ) )
2616
+ $url .= '/' . ltrim($path, '/');
2617
+
2618
+ /**
2619
+ * Filter the URL to the content directory.
2620
+ *
2621
+ * @since 2.8.0
2622
+ *
2623
+ * @param string $url The complete URL to the content directory including scheme and path.
2624
+ * @param string $path Path relative to the URL to the content directory. Blank string
2625
+ * if no path is specified.
2626
+ */
2627
+ return apply_filters( 'content_url', $url, $path);
2628
+ }
2629
+
2630
+ /**
2631
+ * Retrieve a URL within the plugins or mu-plugins directory.
2632
+ *
2633
+ * Defaults to the plugins directory URL if no arguments are supplied.
2634
+ *
2635
+ * @since 2.6.0
2636
+ *
2637
+ * @param string $path Optional. Extra path appended to the end of the URL, including
2638
+ * the relative directory if $plugin is supplied. Default empty.
2639
+ * @param string $plugin Optional. A full path to a file inside a plugin or mu-plugin.
2640
+ * The URL will be relative to its directory. Default empty.
2641
+ * Typically this is done by passing `__FILE__` as the argument.
2642
+ * @return string Plugins URL link with optional paths appended.
2643
+ */
2644
+ function plugins_url( $path = '', $plugin = '' ) {
2645
+
2646
+ $path = wp_normalize_path( $path );
2647
+ $plugin = wp_normalize_path( $plugin );
2648
+ $mu_plugin_dir = wp_normalize_path( WPMU_PLUGIN_DIR );
2649
+
2650
+ if ( !empty($plugin) && 0 === strpos($plugin, $mu_plugin_dir) )
2651
+ $url = WPMU_PLUGIN_URL;
2652
+ else
2653
+ $url = WP_PLUGIN_URL;
2654
+
2655
+
2656
+ $url = set_url_scheme( $url );
2657
+
2658
+ if ( !empty($plugin) && is_string($plugin) ) {
2659
+ $folder = dirname(plugin_basename($plugin));
2660
+ if ( '.' != $folder )
2661
+ $url .= '/' . ltrim($folder, '/');
2662
+ }
2663
+
2664
+ if ( $path && is_string( $path ) )
2665
+ $url .= '/' . ltrim($path, '/');
2666
+
2667
+ /**
2668
+ * Filter the URL to the plugins directory.
2669
+ *
2670
+ * @since 2.8.0
2671
+ *
2672
+ * @param string $url The complete URL to the plugins directory including scheme and path.
2673
+ * @param string $path Path relative to the URL to the plugins directory. Blank string
2674
+ * if no path is specified.
2675
+ * @param string $plugin The plugin file path to be relative to. Blank string if no plugin
2676
+ * is specified.
2677
+ */
2678
+ return apply_filters( 'plugins_url', $url, $path, $plugin );
2679
+ }
2680
+
2681
+ /**
2682
+ * Retrieve the site url for the current network.
2683
+ *
2684
+ * Returns the site url with the appropriate protocol, 'https' if
2685
+ * is_ssl() and 'http' otherwise. If $scheme is 'http' or 'https', is_ssl() is
2686
+ * overridden.
2687
+ *
2688
+ * @since 3.0.0
2689
+ *
2690
+ * @param string $path Optional. Path relative to the site url.
2691
+ * @param string $scheme Optional. Scheme to give the site url context. See set_url_scheme().
2692
+ * @return string Site url link with optional path appended.
2693
+ */
2694
+ function network_site_url( $path = '', $scheme = null ) {
2695
+ if ( ! is_multisite() )
2696
+ return site_url($path, $scheme);
2697
+
2698
+ $current_site = get_current_site();
2699
+
2700
+ if ( 'relative' == $scheme )
2701
+ $url = $current_site->path;
2702
+ else
2703
+ $url = set_url_scheme( 'http://' . $current_site->domain . $current_site->path, $scheme );
2704
+
2705
+ if ( $path && is_string( $path ) )
2706
+ $url .= ltrim( $path, '/' );
2707
+
2708
+ /**
2709
+ * Filter the network site URL.
2710
+ *
2711
+ * @since 3.0.0
2712
+ *
2713
+ * @param string $url The complete network site URL including scheme and path.
2714
+ * @param string $path Path relative to the network site URL. Blank string if
2715
+ * no path is specified.
2716
+ * @param string|null $scheme Scheme to give the URL context. Accepts 'http', 'https',
2717
+ * 'relative' or null.
2718
+ */
2719
+ return apply_filters( 'network_site_url', $url, $path, $scheme );
2720
+ }
2721
+
2722
+ /**
2723
+ * Retrieve the home url for the current network.
2724
+ *
2725
+ * Returns the home url with the appropriate protocol, 'https' if
2726
+ * is_ssl() and 'http' otherwise. If $scheme is 'http' or 'https', is_ssl() is
2727
+ * overridden.
2728
+ *
2729
+ * @since 3.0.0
2730
+ *
2731
+ * @param string $path (optional) Path relative to the home url.
2732
+ * @param string $scheme (optional) Scheme to give the home url context. Currently 'http', 'https', or 'relative'.
2733
+ * @return string Home url link with optional path appended.
2734
+ */
2735
+ function network_home_url( $path = '', $scheme = null ) {
2736
+ if ( ! is_multisite() )
2737
+ return home_url($path, $scheme);
2738
+
2739
+ $current_site = get_current_site();
2740
+ $orig_scheme = $scheme;
2741
+
2742
+ if ( ! in_array( $scheme, array( 'http', 'https', 'relative' ) ) )
2743
+ $scheme = is_ssl() && ! is_admin() ? 'https' : 'http';
2744
+
2745
+ if ( 'relative' == $scheme )
2746
+ $url = $current_site->path;
2747
+ else
2748
+ $url = set_url_scheme( 'http://' . $current_site->domain . $current_site->path, $scheme );
2749
+
2750
+ if ( $path && is_string( $path ) )
2751
+ $url .= ltrim( $path, '/' );
2752
+
2753
+ /**
2754
+ * Filter the network home URL.
2755
+ *
2756
+ * @since 3.0.0
2757
+ *
2758
+ * @param string $url The complete network home URL including scheme and path.
2759
+ * @param string $path Path relative to the network home URL. Blank string
2760
+ * if no path is specified.
2761
+ * @param string|null $orig_scheme Scheme to give the URL context. Accepts 'http', 'https',
2762
+ * 'relative' or null.
2763
+ */
2764
+ return apply_filters( 'network_home_url', $url, $path, $orig_scheme);
2765
+ }
2766
+
2767
+ /**
2768
+ * Retrieve the url to the admin area for the network.
2769
+ *
2770
+ * @since 3.0.0
2771
+ *
2772
+ * @param string $path Optional path relative to the admin url.
2773
+ * @param string $scheme The scheme to use. Default is 'admin', which obeys force_ssl_admin() and is_ssl(). 'http' or 'https' can be passed to force those schemes.
2774
+ * @return string Admin url link with optional path appended.
2775
+ */
2776
+ function network_admin_url( $path = '', $scheme = 'admin' ) {
2777
+ if ( ! is_multisite() )
2778
+ return admin_url( $path, $scheme );
2779
+
2780
+ $url = network_site_url('wp-admin/network/', $scheme);
2781
+
2782
+ if ( $path && is_string( $path ) )
2783
+ $url .= ltrim($path, '/');
2784
+
2785
+ /**
2786
+ * Filter the network admin URL.
2787
+ *
2788
+ * @since 3.0.0
2789
+ *
2790
+ * @param string $url The complete network admin URL including scheme and path.
2791
+ * @param string $path Path relative to the network admin URL. Blank string if
2792
+ * no path is specified.
2793
+ */
2794
+ return apply_filters( 'network_admin_url', $url, $path );
2795
+ }
2796
+
2797
+ /**
2798
+ * Retrieve the url to the admin area for the current user.
2799
+ *
2800
+ * @since 3.0.0
2801
+ *
2802
+ * @param string $path Optional path relative to the admin url.
2803
+ * @param string $scheme The scheme to use. Default is 'admin', which obeys force_ssl_admin() and is_ssl(). 'http' or 'https' can be passed to force those schemes.
2804
+ * @return string Admin url link with optional path appended.
2805
+ */
2806
+ function user_admin_url( $path = '', $scheme = 'admin' ) {
2807
+ $url = network_site_url('wp-admin/user/', $scheme);
2808
+
2809
+ if ( $path && is_string( $path ) )
2810
+ $url .= ltrim($path, '/');
2811
+
2812
+ /**
2813
+ * Filter the user admin URL for the current user.
2814
+ *
2815
+ * @since 3.1.0
2816
+ *
2817
+ * @param string $url The complete URL including scheme and path.
2818
+ * @param string $path Path relative to the URL. Blank string if
2819
+ * no path is specified.
2820
+ */
2821
+ return apply_filters( 'user_admin_url', $url, $path );
2822
+ }
2823
+
2824
+ /**
2825
+ * Retrieve the url to the admin area for either the current blog or the network depending on context.
2826
+ *
2827
+ * @since 3.1.0
2828
+ *
2829
+ * @param string $path Optional path relative to the admin url.
2830
+ * @param string $scheme The scheme to use. Default is 'admin', which obeys force_ssl_admin() and is_ssl(). 'http' or 'https' can be passed to force those schemes.
2831
+ * @return string Admin url link with optional path appended.
2832
+ */
2833
+ function self_admin_url($path = '', $scheme = 'admin') {
2834
+ if ( is_network_admin() )
2835
+ return network_admin_url($path, $scheme);
2836
+ elseif ( is_user_admin() )
2837
+ return user_admin_url($path, $scheme);
2838
+ else
2839
+ return admin_url($path, $scheme);
2840
+ }
2841
+
2842
+ /**
2843
+ * Set the scheme for a URL
2844
+ *
2845
+ * @since 3.4.0
2846
+ *
2847
+ * @param string $url Absolute url that includes a scheme
2848
+ * @param string $scheme Optional. Scheme to give $url. Currently 'http', 'https', 'login', 'login_post', 'admin', or 'relative'.
2849
+ * @return string $url URL with chosen scheme.
2850
+ */
2851
+ function set_url_scheme( $url, $scheme = null ) {
2852
+ $orig_scheme = $scheme;
2853
+
2854
+ if ( ! $scheme ) {
2855
+ $scheme = is_ssl() ? 'https' : 'http';
2856
+ } elseif ( $scheme === 'admin' || $scheme === 'login' || $scheme === 'login_post' || $scheme === 'rpc' ) {
2857
+ $scheme = is_ssl() || force_ssl_admin() ? 'https' : 'http';
2858
+ } elseif ( $scheme !== 'http' && $scheme !== 'https' && $scheme !== 'relative' ) {
2859
+ $scheme = is_ssl() ? 'https' : 'http';
2860
+ }
2861
+
2862
+ $url = trim( $url );
2863
+ if ( substr( $url, 0, 2 ) === '//' )
2864
+ $url = 'http:' . $url;
2865
+
2866
+ if ( 'relative' == $scheme ) {
2867
+ $url = ltrim( preg_replace( '#^\w+://[^/]*#', '', $url ) );
2868
+ if ( $url !== '' && $url[0] === '/' )
2869
+ $url = '/' . ltrim($url , "/ \t\n\r\0\x0B" );
2870
+ } else {
2871
+ $url = preg_replace( '#^\w+://#', $scheme . '://', $url );
2872
+ }
2873
+
2874
+ /**
2875
+ * Filter the resulting URL after setting the scheme.
2876
+ *
2877
+ * @since 3.4.0
2878
+ *
2879
+ * @param string $url The complete URL including scheme and path.
2880
+ * @param string $scheme Scheme applied to the URL. One of 'http', 'https', or 'relative'.
2881
+ * @param string $orig_scheme Scheme requested for the URL. One of 'http', 'https', 'login',
2882
+ * 'login_post', 'admin', 'rpc', or 'relative'.
2883
+ */
2884
+ return apply_filters( 'set_url_scheme', $url, $scheme, $orig_scheme );
2885
+ }
2886
+
2887
+ /**
2888
+ * Get the URL to the user's dashboard.
2889
+ *
2890
+ * If a user does not belong to any site, the global user dashboard is used. If the user belongs to the current site,
2891
+ * the dashboard for the current site is returned. If the user cannot edit the current site, the dashboard to the user's
2892
+ * primary blog is returned.
2893
+ *
2894
+ * @since 3.1.0
2895
+ *
2896
+ * @param int $user_id Optional. User ID. Defaults to current user.
2897
+ * @param string $path Optional path relative to the dashboard. Use only paths known to both blog and user admins.
2898
+ * @param string $scheme The scheme to use. Default is 'admin', which obeys force_ssl_admin() and is_ssl(). 'http' or 'https' can be passed to force those schemes.
2899
+ * @return string Dashboard url link with optional path appended.
2900
+ */
2901
+ function get_dashboard_url( $user_id = 0, $path = '', $scheme = 'admin' ) {
2902
+ $user_id = $user_id ? (int) $user_id : get_current_user_id();
2903
+
2904
+ $blogs = get_blogs_of_user( $user_id );
2905
+ if ( ! is_super_admin() && empty($blogs) ) {
2906
+ $url = user_admin_url( $path, $scheme );
2907
+ } elseif ( ! is_multisite() ) {
2908
+ $url = admin_url( $path, $scheme );
2909
+ } else {
2910
+ $current_blog = get_current_blog_id();
2911
+ if ( $current_blog && ( is_super_admin( $user_id ) || in_array( $current_blog, array_keys( $blogs ) ) ) ) {
2912
+ $url = admin_url( $path, $scheme );
2913
+ } else {
2914
+ $active = get_active_blog_for_user( $user_id );
2915
+ if ( $active )
2916
+ $url = get_admin_url( $active->blog_id, $path, $scheme );
2917
+ else
2918
+ $url = user_admin_url( $path, $scheme );
2919
+ }
2920
+ }
2921
+
2922
+ /**
2923
+ * Filter the dashboard URL for a user.
2924
+ *
2925
+ * @since 3.1.0
2926
+ *
2927
+ * @param string $url The complete URL including scheme and path.
2928
+ * @param int $user_id The user ID.
2929
+ * @param string $path Path relative to the URL. Blank string if no path is specified.
2930
+ * @param string $scheme Scheme to give the URL context. Accepts 'http', 'https', 'login',
2931
+ * 'login_post', 'admin', 'relative' or null.
2932
+ */
2933
+ return apply_filters( 'user_dashboard_url', $url, $user_id, $path, $scheme);
2934
+ }
2935
+
2936
+ /**
2937
+ * Get the URL to the user's profile editor.
2938
+ *
2939
+ * @since 3.1.0
2940
+ *
2941
+ * @param int $user_id Optional. User ID. Defaults to current user.
2942
+ * @param string $scheme The scheme to use. Default is 'admin', which obeys force_ssl_admin() and is_ssl().
2943
+ * 'http' or 'https' can be passed to force those schemes.
2944
+ * @return string Dashboard url link with optional path appended.
2945
+ */
2946
+ function get_edit_profile_url( $user_id = 0, $scheme = 'admin' ) {
2947
+ $user_id = $user_id ? (int) $user_id : get_current_user_id();
2948
+
2949
+ if ( is_user_admin() )
2950
+ $url = user_admin_url( 'profile.php', $scheme );
2951
+ elseif ( is_network_admin() )
2952
+ $url = network_admin_url( 'profile.php', $scheme );
2953
+ else
2954
+ $url = get_dashboard_url( $user_id, 'profile.php', $scheme );
2955
+
2956
+ /**
2957
+ * Filter the URL for a user's profile editor.
2958
+ *
2959
+ * @since 3.1.0
2960
+ *
2961
+ * @param string $url The complete URL including scheme and path.
2962
+ * @param int $user_id The user ID.
2963
+ * @param string $scheme Scheme to give the URL context. Accepts 'http', 'https', 'login',
2964
+ * 'login_post', 'admin', 'relative' or null.
2965
+ */
2966
+ return apply_filters( 'edit_profile_url', $url, $user_id, $scheme);
2967
+ }
2968
+
2969
+ /**
2970
+ * Output rel=canonical for singular queries.
2971
+ *
2972
+ * @since 2.9.0
2973
+ */
2974
+ function rel_canonical() {
2975
+ if ( !is_singular() )
2976
+ return;
2977
+
2978
+ global $wp_the_query;
2979
+ if ( !$id = $wp_the_query->get_queried_object_id() )
2980
+ return;
2981
+
2982
+ $link = get_permalink( $id );
2983
+
2984
+ if ( $page = get_query_var('cpage') )
2985
+ $link = get_comments_pagenum_link( $page );
2986
+
2987
+ echo "<link rel='canonical' href='$link' />\n";
2988
+ }
2989
+
2990
+ /**
2991
+ * Return a shortlink for a post, page, attachment, or blog.
2992
+ *
2993
+ * This function exists to provide a shortlink tag that all themes and plugins can target. A plugin must hook in to
2994
+ * provide the actual shortlinks. Default shortlink support is limited to providing ?p= style links for posts.
2995
+ * Plugins can short-circuit this function via the pre_get_shortlink filter or filter the output
2996
+ * via the get_shortlink filter.
2997
+ *
2998
+ * @since 3.0.0.
2999
+ *
3000
+ * @param int $id A post or blog id. Default is 0, which means the current post or blog.
3001
+ * @param string $context Whether the id is a 'blog' id, 'post' id, or 'media' id. If 'post', the post_type of the post is consulted. If 'query', the current query is consulted to determine the id and context. Default is 'post'.
3002
+ * @param bool $allow_slugs Whether to allow post slugs in the shortlink. It is up to the plugin how and whether to honor this.
3003
+ * @return string A shortlink or an empty string if no shortlink exists for the requested resource or if shortlinks are not enabled.
3004
+ */
3005
+ function wp_get_shortlink($id = 0, $context = 'post', $allow_slugs = true) {
3006
+ /**
3007
+ * Filter whether to preempt generating a shortlink for the given post.
3008
+ *
3009
+ * Passing a truthy value to the filter will effectively short-circuit the
3010
+ * shortlink-generation process, returning that value instead.
3011
+ *
3012
+ * @since 3.0.0
3013
+ *
3014
+ * @param bool|string $return Short-circuit return value. Either false or a URL string.
3015
+ * @param int $id Post ID, or 0 for the current post.
3016
+ * @param string $context The context for the link. One of 'post' or 'query',
3017
+ * @param bool $allow_slugs Whether to allow post slugs in the shortlink.
3018
+ */
3019
+ $shortlink = apply_filters( 'pre_get_shortlink', false, $id, $context, $allow_slugs );
3020
+
3021
+ if ( false !== $shortlink )
3022
+ return $shortlink;
3023
+
3024
+ global $wp_query;
3025
+ $post_id = 0;
3026
+ if ( 'query' == $context && is_singular() ) {
3027
+ $post_id = $wp_query->get_queried_object_id();
3028
+ $post = get_post( $post_id );
3029
+ } elseif ( 'post' == $context ) {
3030
+ $post = get_post( $id );
3031
+ if ( ! empty( $post->ID ) )
3032
+ $post_id = $post->ID;
3033
+ }
3034
+
3035
+ $shortlink = '';
3036
+
3037
+ // Return p= link for all public post types.
3038
+ if ( ! empty( $post_id ) ) {
3039
+ $post_type = get_post_type_object( $post->post_type );
3040
+
3041
+ if ( 'page' === $post->post_type && $post->ID == get_option( 'page_on_front' ) && 'page' == get_option( 'show_on_front' ) ) {
3042
+ $shortlink = home_url( '/' );
3043
+ } elseif ( $post_type->public ) {
3044
+ $shortlink = home_url( '?p=' . $post_id );
3045
+ }
3046
+ }
3047
+
3048
+ /**
3049
+ * Filter the shortlink for a post.
3050
+ *
3051
+ * @since 3.0.0
3052
+ *
3053
+ * @param string $shortlink Shortlink URL.
3054
+ * @param int $id Post ID, or 0 for the current post.
3055
+ * @param string $context The context for the link. One of 'post' or 'query',
3056
+ * @param bool $allow_slugs Whether to allow post slugs in the shortlink. Not used by default.
3057
+ */
3058
+ return apply_filters( 'get_shortlink', $shortlink, $id, $context, $allow_slugs );
3059
+ }
3060
+
3061
+ /**
3062
+ * Inject rel=shortlink into head if a shortlink is defined for the current page.
3063
+ *
3064
+ * Attached to the wp_head action.
3065
+ *
3066
+ * @since 3.0.0
3067
+ *
3068
+ * @uses wp_get_shortlink()
3069
+ */
3070
+ function wp_shortlink_wp_head() {
3071
+ $shortlink = wp_get_shortlink( 0, 'query' );
3072
+
3073
+ if ( empty( $shortlink ) )
3074
+ return;
3075
+
3076
+ echo "<link rel='shortlink' href='" . esc_url( $shortlink ) . "' />\n";
3077
+ }
3078
+
3079
+ /**
3080
+ * Send a Link: rel=shortlink header if a shortlink is defined for the current page.
3081
+ *
3082
+ * Attached to the wp action.
3083
+ *
3084
+ * @since 3.0.0
3085
+ *
3086
+ * @uses wp_get_shortlink()
3087
+ */
3088
+ function wp_shortlink_header() {
3089
+ if ( headers_sent() )
3090
+ return;
3091
+
3092
+ $shortlink = wp_get_shortlink(0, 'query');
3093
+
3094
+ if ( empty($shortlink) )
3095
+ return;
3096
+
3097
+ header('Link: <' . $shortlink . '>; rel=shortlink', false);
3098
+ }
3099
+
3100
+ /**
3101
+ * Display the Short Link for a Post
3102
+ *
3103
+ * Must be called from inside "The Loop"
3104
+ *
3105
+ * Call like the_shortlink(__('Shortlinkage FTW'))
3106
+ *
3107
+ * @since 3.0.0
3108
+ *
3109
+ * @param string $text Optional The link text or HTML to be displayed. Defaults to 'This is the short link.'
3110
+ * @param string $title Optional The tooltip for the link. Must be sanitized. Defaults to the sanitized post title.
3111
+ * @param string $before Optional HTML to display before the link.
3112
+ * @param string $after Optional HTML to display after the link.
3113
+ */
3114
+ function the_shortlink( $text = '', $title = '', $before = '', $after = '' ) {
3115
+ $post = get_post();
3116
+
3117
+ if ( empty( $text ) )
3118
+ $text = __('This is the short link.');
3119
+
3120
+ if ( empty( $title ) )
3121
+ $title = the_title_attribute( array( 'echo' => false ) );
3122
+
3123
+ $shortlink = wp_get_shortlink( $post->ID );
3124
+
3125
+ if ( !empty( $shortlink ) ) {
3126
+ $link = '<a rel="shortlink" href="' . esc_url( $shortlink ) . '" title="' . $title . '">' . $text . '</a>';
3127
+
3128
+ /**
3129
+ * Filter the shortlink anchor tag for a post.
3130
+ *
3131
+ * @since 3.0.0
3132
+ *
3133
+ * @param string $link Shortlink anchor tag.
3134
+ * @param string $shortlink Shortlink URL.
3135
+ * @param string $text Shortlink's text.
3136
+ * @param string $title Shortlink's title attribute.
3137
+ */
3138
+ $link = apply_filters( 'the_shortlink', $link, $shortlink, $text, $title );
3139
+ echo $before, $link, $after;
3140
+ }
3141
+ }