From c64f74674f84dcaa26bde79d4e3c187bd27bf5d9 Mon Sep 17 00:00:00 2001 From: yeelight <91862060+FeiNiaoBF@users.noreply.github.com> Date: Thu, 29 Aug 2024 22:58:52 +0800 Subject: [PATCH] [add] blog --- .github/workflows/hugo.yaml | 78 ++ .gitignore | 9 + .gitmodules | 2 +- YBlog/.hugo_build.lock => .hugo_build.lock | 0 YBlog/.lh/.lhignore | 6 - .../CS/0.CS-Learning-Plan/index.zh-cn.md.json | 38 - .../CSLanguages/_index.zh-cn.md.json | 26 - .../CSAPP/CSAPP00/index.zh-cn.md.json | 18 - .../CS/Personal/update/index.zh-cn.md.json | 22 - .../0.CS-Learning-Plan/index.zh-cn.md.json | 182 ----- .../CSLanguages/Golang/_index.zh-cn.md.json | 26 - .../Golang/conclusion/_index.zh-cn.md.json | 30 - .../InterviewQuestions/index.zh-cn.md.json | 62 -- .../development/Problem/index.zh-cn.md.json | 42 -- .../Golang/development/_index.zh-cn.md.json | 30 - .../CSLanguages/Golang/index.zh-cn.md.json | 394 ---------- .../Golang/start/DataType/index.zh-cn.md.json | 138 ---- .../start/LearningPath/index.zh-cn.md.json | 62 -- .../Golang/start/Map/index.zh-cn.md.json | 34 - .../Golang/start/Resource/index.zh-cn.md.json | 50 -- .../Golang/start/Strings/index.zh-cn.md.json | 34 - .../Golang/start/_index.zh-cn.md.json | 58 -- .../Golang/start/bitop/index.zh-cn.md.json | 198 ----- .../Golang/start/keyword/index.zh-cn.md.json | 42 -- .../transition/GMP_Model/index.zh-cn.md.json | 34 - .../Golang/transition/Map/index.zh-cn.md.json | 30 - .../Golang/transition/_index.zh-cn.md.json | 26 - .../transition/goweb1/index.zh-cn.md.json | 74 -- .../transition/goweb2/index.zh-cn.md.json | 42 -- .../transition/goweb3/index.zh-cn.md.json | 38 - .../transition/goweb4/index.zh-cn.md.json | 30 - .../GolangDS/_index.zh-cn.md.json | 18 - .../CSAPP/CSAPP00/index.zh-cn.md.json | 18 - .../CSAPP/CSAPP01/index.zh-cn.md.json | 18 - .../CSAPP/CSAPP02/index.zh-cn.md.json | 18 - .../CSAPP/CSAPP03/index.zh-cn.md.json | 22 - .../3.OS/LinuxLearn/Notes/index.zh-cn.md.json | 22 - .../4.OS/LinuxLearn/Notes/index.zh-cn.md.json | 18 - .../5.Networking/http/index.zh-cn.md.json | 66 -- .../Gohh/Algorithms/backtrack/index.md.json | 46 -- .../post/Gohh/Algorithms/sort/index.md.json | 58 -- .../post/Gohh/CS61c/cache/index.zh-cn.md.json | 42 -- .../Gohh/Personal/update/index.zh-cn.md.json | 22 - .../post/Personal/update/index.zh-cn.md.json | 58 -- YBlog/.lh/content/post/_index.zh-cn.md.json | 22 - YBlog/.lh/hugo.yaml.json | 106 --- YBlog/public | 1 - YBlog/themes/hugo-theme-stack | 1 - .../archetypes => archetypes}/categories.md | 0 {YBlog/archetypes => archetypes}/default.md | 0 {YBlog/archetypes => archetypes}/tags.md | 0 {YBlog/assets => assets}/icons/archives.svg | 0 {YBlog/assets => assets}/icons/arrow-back.svg | 0 {YBlog/assets => assets}/icons/back.svg | 0 {YBlog/assets => assets}/icons/blog.svg | 0 .../assets => assets}/icons/brand-github.svg | 0 .../assets => assets}/icons/brand-twitter.svg | 0 {YBlog/assets => assets}/icons/categories.svg | 0 {YBlog/assets => assets}/icons/clock.svg | 0 {YBlog/assets => assets}/icons/copyright.svg | 0 {YBlog/assets => assets}/icons/date.svg | 0 {YBlog/assets => assets}/icons/hash.svg | 0 {YBlog/assets => assets}/icons/home.svg | 0 {YBlog/assets => assets}/icons/infinity.svg | 0 {YBlog/assets => assets}/icons/language.svg | 0 {YBlog/assets => assets}/icons/link.svg | 0 {YBlog/assets => assets}/icons/messages.svg | 0 {YBlog/assets => assets}/icons/rss.svg | 0 {YBlog/assets => assets}/icons/search.svg | 0 {YBlog/assets => assets}/icons/tag.svg | 0 .../assets => assets}/icons/toggle-left.svg | 0 .../assets => assets}/icons/toggle-right.svg | 0 {YBlog/assets => assets}/icons/user.svg | 0 {YBlog/assets => assets}/img/avatar.png | Bin {YBlog/assets => assets}/jsconfig.json | 0 .../assets => assets}/scss/breakpoints.scss | 0 {YBlog/assets => assets}/scss/custom.scss | 0 .../scss/external/normalize.scss | 0 {YBlog/assets => assets}/scss/general.scss | 0 {YBlog/assets => assets}/scss/grid.scss | 0 .../scss/partials/article.scss | 0 .../assets => assets}/scss/partials/base.scss | 0 .../scss/partials/comments/disqusjs.scss | 0 .../scss/partials/footer.scss | 0 .../scss/partials/highlight/common.scss | 0 .../scss/partials/highlight/dark.scss | 0 .../scss/partials/highlight/light.scss | 0 .../scss/partials/layout/404.scss | 0 .../scss/partials/layout/article.scss | 0 .../scss/partials/layout/list.scss | 0 .../scss/partials/layout/search.scss | 0 .../assets => assets}/scss/partials/menu.scss | 0 .../scss/partials/pagination.scss | 0 .../scss/partials/sidebar.scss | 0 .../scss/partials/widgets.scss | 0 {YBlog/assets => assets}/scss/style.scss | 0 {YBlog/assets => assets}/scss/variables.scss | 0 {YBlog/assets => assets}/ts/color.ts | 0 {YBlog/assets => assets}/ts/colorScheme.ts | 0 {YBlog/assets => assets}/ts/createElement.ts | 0 {YBlog/assets => assets}/ts/gallery.ts | 0 {YBlog/assets => assets}/ts/main.ts | 0 {YBlog/assets => assets}/ts/menu.ts | 0 {YBlog/assets => assets}/ts/scrollspy.ts | 0 {YBlog/assets => assets}/ts/search.tsx | 0 {YBlog/assets => assets}/ts/smoothAnchors.ts | 0 .../categories/Test/_index.en.md | 0 .../categories/Test/_index.zh-cn.md | 0 .../hutomo-abrianto-l2jk-uxb1BY-unsplash.jpg | Bin .../page/about/index.en.md | 0 .../page/about/index.zh-cn.md | 0 .../page/archives/index.en.md | 0 .../page/archives/index.zh-cn.md | 0 .../content => content}/page/blog/index.en.md | 0 .../page/blog/index.zh-cn.md | 0 .../page/links/index.en.md | 0 .../page/links/index.zh-cn.md | 0 .../page/links/ts-logo-128.jpg | Bin .../page/search/index.en.md | 0 .../page/search/index.zh-cn.md | 0 .../Gohh/0.CS-Learning-Plan/index.zh-cn.md | 0 .../matt-le-SJSpo9hQf7s-unsplash.jpg | Bin .../photo_2024-04-08_20-31-47.jpg | Bin .../BitwiseOperationsNotes/index.zh-cn.md | 0 .../CSLanguages/Golang/_index.zh-cn.md | 0 .../Golang/conclusion/GoReader/index.zh-cn.md | 0 .../Golang/conclusion/_index.zh-cn.md | 0 .../InterviewQuestions/index.zh-cn.md | 0 .../Golang/development/Problem/index.zh-cn.md | 0 .../Golang/development/_index.zh-cn.md | 0 .../Golang/start/DataType/index.zh-cn.md | 0 .../Golang/start/LearningPath/index.zh-cn.md | 0 .../Golang/start/Map/index.zh-cn.md | 0 .../Golang/start/Resource/index.zh-cn.md | 0 .../Golang/start/Strings/index.zh-cn.md | 0 .../CSLanguages/Golang/start/_index.zh-cn.md | 0 .../Golang/start/bitop/index.zh-cn.md | 0 .../CSLanguages/Golang/start/image.png | Bin .../Golang/start/keyword/index.zh-cn.md | 0 .../transition/Concurrency/index.zh-cn.md | 0 .../Golang/transition/GC/index.zh-cn.md | 0 .../transition/GMP_Model/index.zh-cn.md | 0 .../Golang/transition/Map/index.zh-cn.md | 0 .../Golang/transition/_index.zh-cn.md | 0 .../Golang/transition/goweb1/index.zh-cn.md | 0 .../Golang/transition/goweb2/index.zh-cn.md | 0 .../Golang/transition/goweb3/index.zh-cn.md | 0 .../Golang/transition/goweb4/index.zh-cn.md | 0 .../CSLanguages/_index.zh-cn.md | 0 .../GolangDS/Array/index.zh-cn.md | 0 .../GolangDS/Link/index.zh-cn.md | 0 .../GolangDS/Stack/index.zh-cn.md | 0 .../2.DataStructures/GolangDS/_index.zh-cn.md | 0 .../Gohh/3.Architecture/CS61c/_index.zh-cn.md | 0 .../CSAPP/CSAPP00/index.zh-cn.md | 0 .../CSAPP/CSAPP01/index.zh-cn.md | 0 .../CSAPP/CSAPP02/index.zh-cn.md | 0 .../CSAPP/CSAPP03/index.zh-cn.md | 0 .../Gohh/3.Architecture/CSAPP/_index.zh-cn.md | 0 .../Gohh/4.OS/LinuxLearn/FD/index.zh-cn.md | 0 .../Gohh/4.OS/LinuxLearn/Line/index.zh-cn.md | 0 .../Gohh/4.OS/LinuxLearn/Notes/index.zh-cn.md | 0 .../post/Gohh/4.OS/LinuxLearn/_index.zh-cn.md | 0 .../Gohh/4.OS/LinuxLearn/pipe/index.zh-cn.md | 0 .../post/Gohh/4.OS/S6.081/_index.zh-cn.md | 0 .../S6.081/xv6_file_system/index.zh-cn.md | 0 .../4.OS/S6.081/xv6_gdb_debug/index.zh-cn.md | 0 .../4.OS/S6.081/xv6_interrupt/index.zh-cn.md | 0 .../Gohh/4.OS/S6.081/xv6_learn/index.zh-cn.md | 0 .../Gohh/4.OS/S6.081/xv6_lock/index.zh-cn.md | 0 .../4.OS/S6.081/xv6_process/index.zh-cn.md | 0 .../Gohh/4.OS/S6.081/xv6_src/index.zh-cn.md | 0 .../Gohh/4.OS/S6.081/xv6_trap/index.zh-cn.md | 0 .../Gohh/4.OS/S6.081/xv6_vmem/index.zh-cn.md | 0 .../5.Networking/Internet0/index.zh-cn.md | 0 .../5.Networking/Internet1/index.zh-cn.md | 0 .../post/Gohh/5.Networking/_index.zh-cn.md | 0 .../Gohh/5.Networking/http/index.zh-cn.md | 0 .../6.Distribut/MIT6.824/01/index.zh-cn.md | 0 .../6.Distribut/MIT6.824/01lab/index.zh-cn.md | 0 .../Gohh/6.Distribut/MIT6.824/_index.zh-cn.md | 0 .../post/Gohh/88.Tools/GDB/index.zh-cn.md | 0 .../Gohh/88.Tools/Makefile/index.zh-cn.md | 0 .../post/Gohh/99.Problems/_index.zh-cn.md | 0 .../Gohh/99.Problems/issue/index.zh-cn.md | 0 .../post/Gohh/Algorithms/backtrack/index.md | 0 .../post/Gohh/Algorithms/sort/index.md | 0 .../post/Gohh/CS61c/cache/index.zh-cn.md | 0 .../post/Gohh/Personal/update/index.zh-cn.md | 0 {YBlog/content => content}/post/_index.en.md | 0 .../content => content}/post/_index.zh-cn.md | 0 {YBlog/data => data}/external.yaml | 0 YBlog/hugo.yaml => hugo.yaml | 0 {YBlog/i18n => i18n}/ar.yaml | 0 {YBlog/i18n => i18n}/be.yaml | 0 {YBlog/i18n => i18n}/bn.yaml | 0 {YBlog/i18n => i18n}/ca.yaml | 0 {YBlog/i18n => i18n}/cs.yaml | 0 {YBlog/i18n => i18n}/de.yaml | 0 {YBlog/i18n => i18n}/el.yaml | 0 {YBlog/i18n => i18n}/en.yaml | 0 {YBlog/i18n => i18n}/es.yaml | 0 {YBlog/i18n => i18n}/fa.yaml | 0 {YBlog/i18n => i18n}/fr.yaml | 0 {YBlog/i18n => i18n}/hi.yaml | 0 {YBlog/i18n => i18n}/hu.yaml | 0 {YBlog/i18n => i18n}/id.yaml | 0 {YBlog/i18n => i18n}/it.yaml | 0 {YBlog/i18n => i18n}/ja.yaml | 0 {YBlog/i18n => i18n}/ko.yaml | 0 {YBlog/i18n => i18n}/nl.yaml | 0 {YBlog/i18n => i18n}/pl.yaml | 0 {YBlog/i18n => i18n}/pt-br.yaml | 0 {YBlog/i18n => i18n}/pt-pt.yaml | 0 {YBlog/i18n => i18n}/ru.yaml | 0 {YBlog/i18n => i18n}/sk.yaml | 0 {YBlog/i18n => i18n}/th.yaml | 0 {YBlog/i18n => i18n}/tr.yaml | 0 {YBlog/i18n => i18n}/uk.yaml | 0 {YBlog/i18n => i18n}/vi.yaml | 0 {YBlog/i18n => i18n}/zh-cn.yaml | 0 {YBlog/i18n => i18n}/zh-hk.yaml | 0 {YBlog/i18n => i18n}/zh-tw.yaml | 0 {YBlog/layouts => layouts}/404.html | 0 .../_default/_markup/render-image.html | 0 .../_default/_markup/render-link.html | 0 .../_default/archives.html | 0 .../layouts => layouts}/_default/baseof.html | 0 {YBlog/layouts => layouts}/_default/list.html | 0 {YBlog/layouts => layouts}/_default/rss.xml | 0 .../layouts => layouts}/_default/single.html | 0 {YBlog/layouts => layouts}/index.html | 0 {YBlog/layouts => layouts}/page/search.html | 0 {YBlog/layouts => layouts}/page/search.json | 0 .../partials/article-list/compact.html | 0 .../partials/article-list/default.html | 0 .../partials/article-list/tile.html | 0 .../partials/article/article.html | 0 .../partials/article/components/content.html | 0 .../partials/article/components/details.html | 0 .../partials/article/components/footer.html | 0 .../partials/article/components/header.html | 0 .../partials/article/components/links.html | 0 .../partials/article/components/math.html | 0 .../article/components/photoswipe.html | 0 .../article/components/related-content.html | 0 .../partials/article/components/tags.html | 0 .../partials/comments/include.html | 0 .../partials/comments/provider/beaudar.html | 0 .../partials/comments/provider/cactus.html | 0 .../partials/comments/provider/cusdis.html | 0 .../partials/comments/provider/disqus.html | 0 .../partials/comments/provider/disqusjs.html | 0 .../partials/comments/provider/giscus.html | 0 .../partials/comments/provider/gitalk.html | 0 .../partials/comments/provider/remark42.html | 0 .../partials/comments/provider/twikoo.html | 0 .../comments/provider/utterances.html | 0 .../partials/comments/provider/vssue.html | 0 .../partials/comments/provider/waline.html | 0 .../partials/data/description.html | 0 .../partials/data/title.html | 0 .../footer/components/custom-font.html | 0 .../partials/footer/components/script.html | 0 .../partials/footer/custom.html | 0 .../partials/footer/footer.html | 0 .../partials/footer/include.html | 0 .../partials/head/colorScheme.html | 0 .../partials/head/custom.html | 0 .../partials/head/head.html | 0 .../partials/head/opengraph/include.html | 0 .../head/opengraph/provider/base.html | 0 .../head/opengraph/provider/twitter.html | 0 .../partials/head/script.html | 0 .../partials/head/style.html | 0 .../partials/helper/external.html | 0 .../partials/helper/icon.html | 0 .../partials/helper/image.html | 0 .../partials/pagination.html | 0 .../partials/sidebar/left.html | 0 .../partials/sidebar/right.html | 0 .../partials/widget/archives.html | 0 .../partials/widget/categories.html | 0 .../partials/widget/search.html | 0 .../partials/widget/tag-cloud.html | 0 .../partials/widget/toc.html | 0 .../shortcodes/bilibili.html | 0 .../shortcodes/gitlab.html | 0 .../layouts => layouts}/shortcodes/quote.html | 0 .../shortcodes/tencent.html | 0 .../layouts => layouts}/shortcodes/video.html | 0 .../shortcodes/youtube.html | 0 ...s_511aa33e99371f93fbf403479ebfd32e.content | 0 ...scss_511aa33e99371f93fbf403479ebfd32e.json | 0 ...s_77b10c8e87ff110a62c52933fe3f7f11.content | 10 + ...scss_77b10c8e87ff110a62c52933fe3f7f11.json | 1 + .../img/avatar_hu10384529077158532367.png | Bin ...f29f976348b4e1_4912_300x0_resize_box_3.png | Bin 0 -> 5752 bytes ...52927_ba0b8e744b36f1e48b9c54b5d2847004.jpg | Bin ...3edc0f93688bdd6_hu12733615224671643161.jpg | Bin 0 -> 5295 bytes ...uxb1BY-unsplash_hu13714511474273067689.jpg | Bin ...3f78_52927_120x120_fill_q75_box_smart1.jpg | Bin 0 -> 2500 bytes ...5ac_14205_120x120_fill_q75_box_smart1.jpg" | Bin ...479ecc5ac_14205_1600x0_resize_q75_box.jpg" | Bin ...5479ecc5ac_14205_800x0_resize_q75_box.jpg" | Bin ...15_152725_120x120_fill_q75_box_smart1.jpg" | Bin ...4b1d3615_152725_1600x0_resize_q75_box.jpg" | Bin ...04b1d3615_152725_800x0_resize_q75_box.jpg" | Bin ...cb_138328_120x120_fill_q75_box_smart1.jpg" | Bin ...f733c7cb_138328_1600x0_resize_q75_box.jpg" | Bin ...cf733c7cb_138328_800x0_resize_q75_box.jpg" | Bin ...ca_602824_120x120_fill_q75_box_smart1.jpg" | Bin ...0eb350ca_602824_1600x0_resize_q75_box.jpg" | Bin ...f0eb350ca_602824_800x0_resize_q75_box.jpg" | Bin ...cb_138328_120x120_fill_q75_box_smart1.jpg" | Bin ...f733c7cb_138328_1600x0_resize_q75_box.jpg" | Bin ...cf733c7cb_138328_800x0_resize_q75_box.jpg" | Bin {YBlog/static => static}/favicon.ico | Bin .../hugo-theme-stack/.devcontainer/Dockerfile | 31 + .../.devcontainer/devcontainer.json | 45 ++ themes/hugo-theme-stack/.github/FUNDING.yml | 2 + .../.github/ISSUE_TEMPLATE/bug_report.yml | 65 ++ .../.github/ISSUE_TEMPLATE/config.yml | 5 + themes/hugo-theme-stack/.gitignore | 4 + themes/hugo-theme-stack/LICENSE | 674 ++++++++++++++++++ themes/hugo-theme-stack/README.md | 28 + .../hugo-theme-stack/archetypes/categories.md | 7 + themes/hugo-theme-stack/archetypes/default.md | 11 + themes/hugo-theme-stack/archetypes/tags.md | 5 + .../assets/icons/archives.svg | 8 + .../assets/icons/arrow-back.svg | 6 + themes/hugo-theme-stack/assets/icons/back.svg | 6 + .../assets/icons/brand-github.svg | 6 + .../assets/icons/brand-twitter.svg | 6 + .../assets/icons/categories.svg | 9 + .../hugo-theme-stack/assets/icons/clock.svg | 7 + .../assets/icons/copyright.svg | 7 + themes/hugo-theme-stack/assets/icons/date.svg | 9 + themes/hugo-theme-stack/assets/icons/hash.svg | 9 + themes/hugo-theme-stack/assets/icons/home.svg | 8 + .../assets/icons/infinity.svg | 6 + .../assets/icons/language.svg | 10 + themes/hugo-theme-stack/assets/icons/link.svg | 7 + .../assets/icons/messages.svg | 7 + themes/hugo-theme-stack/assets/icons/rss.svg | 8 + .../hugo-theme-stack/assets/icons/search.svg | 7 + themes/hugo-theme-stack/assets/icons/tag.svg | 7 + .../assets/icons/toggle-left.svg | 7 + .../assets/icons/toggle-right.svg | 7 + themes/hugo-theme-stack/assets/icons/user.svg | 7 + themes/hugo-theme-stack/assets/img/avatar.png | Bin 0 -> 373 bytes .../assets/scss/breakpoints.scss | 17 + .../hugo-theme-stack/assets/scss/custom.scss | 1 + .../assets/scss/external/normalize.scss | 349 +++++++++ .../hugo-theme-stack/assets/scss/general.scss | 31 + themes/hugo-theme-stack/assets/scss/grid.scss | 101 +++ .../assets/scss/partials/article.scss | 277 +++++++ .../assets/scss/partials/base.scss | 38 + .../scss/partials/comments/disqusjs.scss | 394 ++++++++++ .../assets/scss/partials/footer.scss | 30 + .../scss/partials/highlight/common.scss | 428 +++++++++++ .../assets/scss/partials/highlight/dark.scss | 14 + .../assets/scss/partials/highlight/light.scss | 14 + .../assets/scss/partials/layout/404.scss | 6 + .../assets/scss/partials/layout/article.scss | 462 ++++++++++++ .../assets/scss/partials/layout/list.scss | 71 ++ .../assets/scss/partials/layout/search.scss | 82 +++ .../assets/scss/partials/menu.scss | 229 ++++++ .../assets/scss/partials/pagination.scss | 21 + .../assets/scss/partials/sidebar.scss | 199 ++++++ .../assets/scss/partials/widgets.scss | 67 ++ .../hugo-theme-stack/assets/scss/style.scss | 28 + .../assets/scss/variables.scss | 167 +++++ themes/hugo-theme-stack/assets/ts/color.ts | 63 ++ .../hugo-theme-stack/assets/ts/colorScheme.ts | 88 +++ .../assets/ts/createElement.ts | 34 + themes/hugo-theme-stack/assets/ts/gallery.ts | 186 +++++ themes/hugo-theme-stack/assets/ts/main.ts | 112 +++ themes/hugo-theme-stack/assets/ts/menu.ts | 83 +++ .../hugo-theme-stack/assets/ts/scrollspy.ts | 131 ++++ themes/hugo-theme-stack/assets/ts/search.tsx | 326 +++++++++ .../assets/ts/smoothAnchors.ts | 37 + themes/hugo-theme-stack/config.yaml | 149 ++++ themes/hugo-theme-stack/data/external.yaml | 44 ++ themes/hugo-theme-stack/debug.sh | 1 + .../hugo-theme-stack/exampleSite/.gitignore | 30 + themes/hugo-theme-stack/exampleSite/LICENSE | 21 + themes/hugo-theme-stack/exampleSite/README.md | 3 + .../exampleSite/content/_index.md | 8 + .../exampleSite/content/_index.zh-cn.md | 8 + .../content/categories/Test/_index.md | 9 + .../hutomo-abrianto-l2jk-uxb1BY-unsplash.jpg | Bin 0 -> 52927 bytes .../exampleSite/content/page/about/index.md | 34 + .../content/page/about/index.zh-cn.md | 10 + .../content/page/archives/index.md | 11 + .../exampleSite/content/page/links/index.md | 37 + .../content/page/links/ts-logo-128.jpg | Bin 0 -> 2071 bytes .../exampleSite/content/page/search/index.md | 13 + .../florian-klauer-nptLmg6jqDo-unsplash.jpg | Bin 0 -> 13854 bytes .../helena-hertz-wWZzXlDpMog-unsplash.jpg | Bin 0 -> 15530 bytes .../hudai-gayiran-3Od_VKcDEAA-unsplash.jpg | Bin 0 -> 18711 bytes .../content/post/chinese-test/index.zh-cn.md | 39 + .../luca-bravo-alS7ewQ41M8-unsplash.jpg | Bin 0 -> 32400 bytes .../content/post/emoji-support/index.md | 50 ++ ...creative-exchange-d2zvqp3fpro-unsplash.jpg | Bin 0 -> 35369 bytes .../content/post/markdown-syntax/index.md | 168 +++++ .../pawel-czerwinski-8uZPynIu-rQ-unsplash.jpg | Bin 0 -> 55974 bytes .../content/post/math-typesetting/index.md | 45 ++ .../content/post/placeholder-text/index.ar.md | 32 + .../content/post/placeholder-text/index.md | 51 ++ .../matt-le-SJSpo9hQf7s-unsplash.jpg | Bin 0 -> 14205 bytes .../content/post/rich-content/index.md | 67 ++ themes/hugo-theme-stack/exampleSite/hugo.yaml | 251 +++++++ themes/hugo-theme-stack/go.mod | 3 + themes/hugo-theme-stack/i18n/ar.yaml | 74 ++ themes/hugo-theme-stack/i18n/be.yaml | 72 ++ themes/hugo-theme-stack/i18n/bn.yaml | 73 ++ themes/hugo-theme-stack/i18n/ca.yaml | 73 ++ themes/hugo-theme-stack/i18n/cs.yaml | 73 ++ themes/hugo-theme-stack/i18n/de.yaml | 74 ++ themes/hugo-theme-stack/i18n/el.yaml | 70 ++ themes/hugo-theme-stack/i18n/en.yaml | 73 ++ themes/hugo-theme-stack/i18n/es.yaml | 73 ++ themes/hugo-theme-stack/i18n/fa.yaml | 73 ++ themes/hugo-theme-stack/i18n/fr.yaml | 69 ++ themes/hugo-theme-stack/i18n/hi.yaml | 73 ++ themes/hugo-theme-stack/i18n/hu.yaml | 73 ++ themes/hugo-theme-stack/i18n/id.yaml | 73 ++ themes/hugo-theme-stack/i18n/it.yaml | 73 ++ themes/hugo-theme-stack/i18n/ja.yaml | 70 ++ themes/hugo-theme-stack/i18n/ko.yaml | 72 ++ themes/hugo-theme-stack/i18n/nl.yaml | 59 ++ themes/hugo-theme-stack/i18n/pl.yaml | 82 +++ themes/hugo-theme-stack/i18n/pt-br.yaml | 67 ++ themes/hugo-theme-stack/i18n/pt-pt.yaml | 67 ++ themes/hugo-theme-stack/i18n/ru.yaml | 63 ++ themes/hugo-theme-stack/i18n/sk.yaml | 71 ++ themes/hugo-theme-stack/i18n/th.yaml | 70 ++ themes/hugo-theme-stack/i18n/tr.yaml | 53 ++ themes/hugo-theme-stack/i18n/uk.yaml | 71 ++ themes/hugo-theme-stack/i18n/vi.yaml | 74 ++ themes/hugo-theme-stack/i18n/zh-cn.yaml | 67 ++ themes/hugo-theme-stack/i18n/zh-hk.yaml | 73 ++ themes/hugo-theme-stack/i18n/zh-tw.yaml | 73 ++ themes/hugo-theme-stack/images/screenshot.png | Bin 0 -> 51344 bytes themes/hugo-theme-stack/images/tn.png | Bin 0 -> 24703 bytes themes/hugo-theme-stack/layouts/404.html | 7 + .../_default/_markup/render-heading.html | 6 + .../_default/_markup/render-image.html | 41 ++ .../layouts/_default/_markup/render-link.html | 3 + .../layouts/_default/archives.html | 35 + .../layouts/_default/baseof.html | 28 + .../layouts/_default/list.html | 85 +++ .../hugo-theme-stack/layouts/_default/rss.xml | 48 ++ .../layouts/_default/single.html | 46 ++ themes/hugo-theme-stack/layouts/index.html | 19 + .../hugo-theme-stack/layouts/page/search.html | 33 + .../hugo-theme-stack/layouts/page/search.json | 26 + .../partials/article-list/compact.html | 40 ++ .../partials/article-list/default.html | 4 + .../layouts/partials/article-list/tile.html | 39 + .../layouts/partials/article/article.html | 11 + .../partials/article/components/content.html | 5 + .../partials/article/components/details.html | 61 ++ .../partials/article/components/footer.html | 19 + .../partials/article/components/header.html | 35 + .../partials/article/components/links.html | 30 + .../partials/article/components/math.html | 13 + .../article/components/photoswipe.html | 68 ++ .../article/components/related-content.html | 13 + .../partials/article/components/tags.html | 7 + .../layouts/partials/comments/include.html | 3 + .../partials/comments/provider/beaudar.html | 46 ++ .../partials/comments/provider/cactus.html | 29 + .../partials/comments/provider/cusdis.html | 21 + .../partials/comments/provider/disqus.html | 22 + .../partials/comments/provider/disqusjs.html | 61 ++ .../partials/comments/provider/giscus.html | 51 ++ .../partials/comments/provider/gitalk.html | 30 + .../partials/comments/provider/remark42.html | 29 + .../partials/comments/provider/twikoo.html | 58 ++ .../comments/provider/utterances.html | 46 ++ .../partials/comments/provider/vssue.html | 27 + .../partials/comments/provider/waline.html | 34 + .../layouts/partials/data/description.html | 17 + .../layouts/partials/data/title.html | 38 + .../footer/components/custom-font.html | 11 + .../partials/footer/components/script.html | 12 + .../layouts/partials/footer/custom.html | 0 .../layouts/partials/footer/footer.html | 23 + .../layouts/partials/footer/include.html | 3 + .../layouts/partials/head/colorScheme.html | 39 + .../layouts/partials/head/custom.html | 0 .../layouts/partials/head/head.html | 26 + .../partials/head/opengraph/include.html | 2 + .../head/opengraph/provider/base.html | 43 ++ .../head/opengraph/provider/twitter.html | 16 + .../layouts/partials/head/script.html | 0 .../layouts/partials/head/style.html | 3 + .../layouts/partials/helper/external.html | 29 + .../layouts/partials/helper/icon.html | 6 + .../layouts/partials/helper/image.html | 61 ++ .../layouts/partials/pagination.html | 26 + .../layouts/partials/sidebar/left.html | 103 +++ .../layouts/partials/sidebar/right.html | 16 + .../layouts/partials/widget/archives.html | 35 + .../layouts/partials/widget/categories.html | 16 + .../layouts/partials/widget/search.html | 16 + .../layouts/partials/widget/tag-cloud.html | 16 + .../layouts/partials/widget/toc.html | 12 + .../layouts/shortcodes/bilibili.html | 23 + .../layouts/shortcodes/gitlab.html | 4 + .../layouts/shortcodes/quote.html | 15 + .../layouts/shortcodes/tencent.html | 10 + .../layouts/shortcodes/video.html | 14 + .../layouts/shortcodes/youtube.html | 13 + themes/hugo-theme-stack/netlify.toml | 26 + themes/hugo-theme-stack/theme.toml | 27 + 518 files changed, 10301 insertions(+), 2323 deletions(-) create mode 100644 .github/workflows/hugo.yaml create mode 100644 .gitignore rename YBlog/.hugo_build.lock => .hugo_build.lock (100%) delete mode 100644 YBlog/.lh/.lhignore delete mode 100644 YBlog/.lh/content/post/CS/0.CS-Learning-Plan/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/CS/1.ComputerBasics/CSLanguages/_index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/CS/3.Architecture/CSAPP/CSAPP00/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/CS/Personal/update/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/0.CS-Learning-Plan/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/conclusion/_index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/InterviewQuestions/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/Problem/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/_index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/_index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/bitop/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/keyword/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/GMP_Model/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/Map/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/_index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb1/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb2/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb3/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb4/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/2.DataStructures/GolangDS/_index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/3.Architecture/CSAPP/CSAPP00/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/3.Architecture/CSAPP/CSAPP01/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/3.Architecture/CSAPP/CSAPP02/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/3.Architecture/CSAPP/CSAPP03/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/3.OS/LinuxLearn/Notes/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/4.OS/LinuxLearn/Notes/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/5.Networking/http/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/Algorithms/backtrack/index.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/Algorithms/sort/index.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/CS61c/cache/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Gohh/Personal/update/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/Personal/update/index.zh-cn.md.json delete mode 100644 YBlog/.lh/content/post/_index.zh-cn.md.json delete mode 100644 YBlog/.lh/hugo.yaml.json delete mode 160000 YBlog/public delete mode 160000 YBlog/themes/hugo-theme-stack rename {YBlog/archetypes => archetypes}/categories.md (100%) rename {YBlog/archetypes => archetypes}/default.md (100%) rename {YBlog/archetypes => archetypes}/tags.md (100%) rename {YBlog/assets => assets}/icons/archives.svg (100%) rename {YBlog/assets => assets}/icons/arrow-back.svg (100%) rename {YBlog/assets => assets}/icons/back.svg (100%) rename {YBlog/assets => assets}/icons/blog.svg (100%) rename {YBlog/assets => assets}/icons/brand-github.svg (100%) rename {YBlog/assets => assets}/icons/brand-twitter.svg (100%) rename {YBlog/assets => assets}/icons/categories.svg (100%) rename {YBlog/assets => assets}/icons/clock.svg (100%) rename {YBlog/assets => assets}/icons/copyright.svg (100%) rename {YBlog/assets => assets}/icons/date.svg (100%) rename {YBlog/assets => assets}/icons/hash.svg (100%) rename {YBlog/assets => assets}/icons/home.svg (100%) rename {YBlog/assets => assets}/icons/infinity.svg (100%) rename {YBlog/assets => assets}/icons/language.svg (100%) rename {YBlog/assets => assets}/icons/link.svg (100%) rename {YBlog/assets => assets}/icons/messages.svg (100%) rename {YBlog/assets => assets}/icons/rss.svg (100%) rename {YBlog/assets => assets}/icons/search.svg (100%) rename {YBlog/assets => assets}/icons/tag.svg (100%) rename {YBlog/assets => assets}/icons/toggle-left.svg (100%) rename {YBlog/assets => assets}/icons/toggle-right.svg (100%) rename {YBlog/assets => assets}/icons/user.svg (100%) rename {YBlog/assets => assets}/img/avatar.png (100%) rename {YBlog/assets => assets}/jsconfig.json (100%) rename {YBlog/assets => assets}/scss/breakpoints.scss (100%) rename {YBlog/assets => assets}/scss/custom.scss (100%) rename {YBlog/assets => assets}/scss/external/normalize.scss (100%) rename {YBlog/assets => assets}/scss/general.scss (100%) rename {YBlog/assets => assets}/scss/grid.scss (100%) rename {YBlog/assets => assets}/scss/partials/article.scss (100%) rename {YBlog/assets => assets}/scss/partials/base.scss (100%) rename {YBlog/assets => assets}/scss/partials/comments/disqusjs.scss (100%) rename {YBlog/assets => assets}/scss/partials/footer.scss (100%) rename {YBlog/assets => assets}/scss/partials/highlight/common.scss (100%) rename {YBlog/assets => assets}/scss/partials/highlight/dark.scss (100%) rename {YBlog/assets => assets}/scss/partials/highlight/light.scss (100%) rename {YBlog/assets => assets}/scss/partials/layout/404.scss (100%) rename {YBlog/assets => assets}/scss/partials/layout/article.scss (100%) rename {YBlog/assets => assets}/scss/partials/layout/list.scss (100%) rename {YBlog/assets => assets}/scss/partials/layout/search.scss (100%) rename {YBlog/assets => assets}/scss/partials/menu.scss (100%) rename {YBlog/assets => assets}/scss/partials/pagination.scss (100%) rename {YBlog/assets => assets}/scss/partials/sidebar.scss (100%) rename {YBlog/assets => assets}/scss/partials/widgets.scss (100%) rename {YBlog/assets => assets}/scss/style.scss (100%) rename {YBlog/assets => assets}/scss/variables.scss (100%) rename {YBlog/assets => assets}/ts/color.ts (100%) rename {YBlog/assets => assets}/ts/colorScheme.ts (100%) rename {YBlog/assets => assets}/ts/createElement.ts (100%) rename {YBlog/assets => assets}/ts/gallery.ts (100%) rename {YBlog/assets => assets}/ts/main.ts (100%) rename {YBlog/assets => assets}/ts/menu.ts (100%) rename {YBlog/assets => assets}/ts/scrollspy.ts (100%) rename {YBlog/assets => assets}/ts/search.tsx (100%) rename {YBlog/assets => assets}/ts/smoothAnchors.ts (100%) rename {YBlog/content => content}/categories/Test/_index.en.md (100%) rename {YBlog/content => content}/categories/Test/_index.zh-cn.md (100%) rename {YBlog/content => content}/categories/Test/hutomo-abrianto-l2jk-uxb1BY-unsplash.jpg (100%) rename {YBlog/content => content}/page/about/index.en.md (100%) rename {YBlog/content => content}/page/about/index.zh-cn.md (100%) rename {YBlog/content => content}/page/archives/index.en.md (100%) rename {YBlog/content => content}/page/archives/index.zh-cn.md (100%) rename {YBlog/content => content}/page/blog/index.en.md (100%) rename {YBlog/content => content}/page/blog/index.zh-cn.md (100%) rename {YBlog/content => content}/page/links/index.en.md (100%) rename {YBlog/content => content}/page/links/index.zh-cn.md (100%) rename {YBlog/content => content}/page/links/ts-logo-128.jpg (100%) rename {YBlog/content => content}/page/search/index.en.md (100%) rename {YBlog/content => content}/page/search/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/0.CS-Learning-Plan/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/0.CS-Learning-Plan/matt-le-SJSpo9hQf7s-unsplash.jpg (100%) rename {YBlog/content => content}/post/Gohh/0.CS-Learning-Plan/photo_2024-04-08_20-31-47.jpg (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/BitwiseOperationsNotes/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/conclusion/GoReader/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/conclusion/_index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/InterviewQuestions/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/Problem/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/_index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/_index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/bitop/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/image.png (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/keyword/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/Concurrency/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/GC/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/GMP_Model/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/Map/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/_index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb1/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb2/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb3/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb4/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/1.ComputerBasics/CSLanguages/_index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/2.DataStructures/GolangDS/Array/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/2.DataStructures/GolangDS/Link/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/2.DataStructures/GolangDS/Stack/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/2.DataStructures/GolangDS/_index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/3.Architecture/CS61c/_index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/3.Architecture/CSAPP/CSAPP00/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/3.Architecture/CSAPP/CSAPP01/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/3.Architecture/CSAPP/CSAPP02/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/3.Architecture/CSAPP/CSAPP03/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/3.Architecture/CSAPP/_index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/4.OS/LinuxLearn/FD/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/4.OS/LinuxLearn/Line/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/4.OS/LinuxLearn/Notes/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/4.OS/LinuxLearn/_index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/4.OS/LinuxLearn/pipe/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/4.OS/S6.081/_index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/4.OS/S6.081/xv6_file_system/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/4.OS/S6.081/xv6_gdb_debug/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/4.OS/S6.081/xv6_interrupt/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/4.OS/S6.081/xv6_learn/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/4.OS/S6.081/xv6_lock/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/4.OS/S6.081/xv6_process/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/4.OS/S6.081/xv6_src/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/4.OS/S6.081/xv6_trap/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/4.OS/S6.081/xv6_vmem/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/5.Networking/Internet0/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/5.Networking/Internet1/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/5.Networking/_index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/5.Networking/http/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/6.Distribut/MIT6.824/01/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/6.Distribut/MIT6.824/01lab/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/6.Distribut/MIT6.824/_index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/88.Tools/GDB/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/88.Tools/Makefile/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/99.Problems/_index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/99.Problems/issue/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/Algorithms/backtrack/index.md (100%) rename {YBlog/content => content}/post/Gohh/Algorithms/sort/index.md (100%) rename {YBlog/content => content}/post/Gohh/CS61c/cache/index.zh-cn.md (100%) rename {YBlog/content => content}/post/Gohh/Personal/update/index.zh-cn.md (100%) rename {YBlog/content => content}/post/_index.en.md (100%) rename {YBlog/content => content}/post/_index.zh-cn.md (100%) rename {YBlog/data => data}/external.yaml (100%) rename YBlog/hugo.yaml => hugo.yaml (100%) rename {YBlog/i18n => i18n}/ar.yaml (100%) rename {YBlog/i18n => i18n}/be.yaml (100%) rename {YBlog/i18n => i18n}/bn.yaml (100%) rename {YBlog/i18n => i18n}/ca.yaml (100%) rename {YBlog/i18n => i18n}/cs.yaml (100%) rename {YBlog/i18n => i18n}/de.yaml (100%) rename {YBlog/i18n => i18n}/el.yaml (100%) rename {YBlog/i18n => i18n}/en.yaml (100%) rename {YBlog/i18n => i18n}/es.yaml (100%) rename {YBlog/i18n => i18n}/fa.yaml (100%) rename {YBlog/i18n => i18n}/fr.yaml (100%) rename {YBlog/i18n => i18n}/hi.yaml (100%) rename {YBlog/i18n => i18n}/hu.yaml (100%) rename {YBlog/i18n => i18n}/id.yaml (100%) rename {YBlog/i18n => i18n}/it.yaml (100%) rename {YBlog/i18n => i18n}/ja.yaml (100%) rename {YBlog/i18n => i18n}/ko.yaml (100%) rename {YBlog/i18n => i18n}/nl.yaml (100%) rename {YBlog/i18n => i18n}/pl.yaml (100%) rename {YBlog/i18n => i18n}/pt-br.yaml (100%) rename {YBlog/i18n => i18n}/pt-pt.yaml (100%) rename {YBlog/i18n => i18n}/ru.yaml (100%) rename {YBlog/i18n => i18n}/sk.yaml (100%) rename {YBlog/i18n => i18n}/th.yaml (100%) rename {YBlog/i18n => i18n}/tr.yaml (100%) rename {YBlog/i18n => i18n}/uk.yaml (100%) rename {YBlog/i18n => i18n}/vi.yaml (100%) rename {YBlog/i18n => i18n}/zh-cn.yaml (100%) rename {YBlog/i18n => i18n}/zh-hk.yaml (100%) rename {YBlog/i18n => i18n}/zh-tw.yaml (100%) rename {YBlog/layouts => layouts}/404.html (100%) rename {YBlog/layouts => layouts}/_default/_markup/render-image.html (100%) rename {YBlog/layouts => layouts}/_default/_markup/render-link.html (100%) rename {YBlog/layouts => layouts}/_default/archives.html (100%) rename {YBlog/layouts => layouts}/_default/baseof.html (100%) rename {YBlog/layouts => layouts}/_default/list.html (100%) rename {YBlog/layouts => layouts}/_default/rss.xml (100%) rename {YBlog/layouts => layouts}/_default/single.html (100%) rename {YBlog/layouts => layouts}/index.html (100%) rename {YBlog/layouts => layouts}/page/search.html (100%) rename {YBlog/layouts => layouts}/page/search.json (100%) rename {YBlog/layouts => layouts}/partials/article-list/compact.html (100%) rename {YBlog/layouts => layouts}/partials/article-list/default.html (100%) rename {YBlog/layouts => layouts}/partials/article-list/tile.html (100%) rename {YBlog/layouts => layouts}/partials/article/article.html (100%) rename {YBlog/layouts => layouts}/partials/article/components/content.html (100%) rename {YBlog/layouts => layouts}/partials/article/components/details.html (100%) rename {YBlog/layouts => layouts}/partials/article/components/footer.html (100%) rename {YBlog/layouts => layouts}/partials/article/components/header.html (100%) rename {YBlog/layouts => layouts}/partials/article/components/links.html (100%) rename {YBlog/layouts => layouts}/partials/article/components/math.html (100%) rename {YBlog/layouts => layouts}/partials/article/components/photoswipe.html (100%) rename {YBlog/layouts => layouts}/partials/article/components/related-content.html (100%) rename {YBlog/layouts => layouts}/partials/article/components/tags.html (100%) rename {YBlog/layouts => layouts}/partials/comments/include.html (100%) rename {YBlog/layouts => layouts}/partials/comments/provider/beaudar.html (100%) rename {YBlog/layouts => layouts}/partials/comments/provider/cactus.html (100%) rename {YBlog/layouts => layouts}/partials/comments/provider/cusdis.html (100%) rename {YBlog/layouts => layouts}/partials/comments/provider/disqus.html (100%) rename {YBlog/layouts => layouts}/partials/comments/provider/disqusjs.html (100%) rename {YBlog/layouts => layouts}/partials/comments/provider/giscus.html (100%) rename {YBlog/layouts => layouts}/partials/comments/provider/gitalk.html (100%) rename {YBlog/layouts => layouts}/partials/comments/provider/remark42.html (100%) rename {YBlog/layouts => layouts}/partials/comments/provider/twikoo.html (100%) rename {YBlog/layouts => layouts}/partials/comments/provider/utterances.html (100%) rename {YBlog/layouts => layouts}/partials/comments/provider/vssue.html (100%) rename {YBlog/layouts => layouts}/partials/comments/provider/waline.html (100%) rename {YBlog/layouts => layouts}/partials/data/description.html (100%) rename {YBlog/layouts => layouts}/partials/data/title.html (100%) rename {YBlog/layouts => layouts}/partials/footer/components/custom-font.html (100%) rename {YBlog/layouts => layouts}/partials/footer/components/script.html (100%) rename {YBlog/layouts => layouts}/partials/footer/custom.html (100%) rename {YBlog/layouts => layouts}/partials/footer/footer.html (100%) rename {YBlog/layouts => layouts}/partials/footer/include.html (100%) rename {YBlog/layouts => layouts}/partials/head/colorScheme.html (100%) rename {YBlog/layouts => layouts}/partials/head/custom.html (100%) rename {YBlog/layouts => layouts}/partials/head/head.html (100%) rename {YBlog/layouts => layouts}/partials/head/opengraph/include.html (100%) rename {YBlog/layouts => layouts}/partials/head/opengraph/provider/base.html (100%) rename {YBlog/layouts => layouts}/partials/head/opengraph/provider/twitter.html (100%) rename {YBlog/layouts => layouts}/partials/head/script.html (100%) rename {YBlog/layouts => layouts}/partials/head/style.html (100%) rename {YBlog/layouts => layouts}/partials/helper/external.html (100%) rename {YBlog/layouts => layouts}/partials/helper/icon.html (100%) rename {YBlog/layouts => layouts}/partials/helper/image.html (100%) rename {YBlog/layouts => layouts}/partials/pagination.html (100%) rename {YBlog/layouts => layouts}/partials/sidebar/left.html (100%) rename {YBlog/layouts => layouts}/partials/sidebar/right.html (100%) rename {YBlog/layouts => layouts}/partials/widget/archives.html (100%) rename {YBlog/layouts => layouts}/partials/widget/categories.html (100%) rename {YBlog/layouts => layouts}/partials/widget/search.html (100%) rename {YBlog/layouts => layouts}/partials/widget/tag-cloud.html (100%) rename {YBlog/layouts => layouts}/partials/widget/toc.html (100%) rename {YBlog/layouts => layouts}/shortcodes/bilibili.html (100%) rename {YBlog/layouts => layouts}/shortcodes/gitlab.html (100%) rename {YBlog/layouts => layouts}/shortcodes/quote.html (100%) rename {YBlog/layouts => layouts}/shortcodes/tencent.html (100%) rename {YBlog/layouts => layouts}/shortcodes/video.html (100%) rename {YBlog/layouts => layouts}/shortcodes/youtube.html (100%) rename {YBlog/resources => resources}/_gen/assets/scss/style.scss_511aa33e99371f93fbf403479ebfd32e.content (100%) rename {YBlog/resources => resources}/_gen/assets/scss/style.scss_511aa33e99371f93fbf403479ebfd32e.json (100%) create mode 100644 resources/_gen/assets/scss/style.scss_77b10c8e87ff110a62c52933fe3f7f11.content create mode 100644 resources/_gen/assets/scss/style.scss_77b10c8e87ff110a62c52933fe3f7f11.json rename YBlog/resources/_gen/images/img/avatar_hu22c762c923636fe3e0f29f976348b4e1_4912_300x0_resize_box_3.png => resources/_gen/images/img/avatar_hu10384529077158532367.png (100%) create mode 100644 resources/_gen/images/img/avatar_hu22c762c923636fe3e0f29f976348b4e1_4912_300x0_resize_box_3.png rename {YBlog/resources => resources}/_gen/images/zh-cn/categories/test/_hu8102ac0a5989befdf52fa5096a373f78_52927_ba0b8e744b36f1e48b9c54b5d2847004.jpg (100%) create mode 100644 resources/_gen/images/zh-cn/categories/test/hutomo-abrianto-l2jk-uxb1BY-unsplash.bec89fe99958d89413edc0f93688bdd6_hu12733615224671643161.jpg rename YBlog/resources/_gen/images/zh-cn/categories/test/hutomo-abrianto-l2jk-uxb1BY-unsplash_hu8102ac0a5989befdf52fa5096a373f78_52927_120x120_fill_q75_box_smart1.jpg => resources/_gen/images/zh-cn/categories/test/hutomo-abrianto-l2jk-uxb1BY-unsplash_hu13714511474273067689.jpg (100%) create mode 100644 resources/_gen/images/zh-cn/categories/test/hutomo-abrianto-l2jk-uxb1BY-unsplash_hu8102ac0a5989befdf52fa5096a373f78_52927_120x120_fill_q75_box_smart1.jpg rename "YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/matt-le-SJSpo9hQf7s-unsplash_hu958d513eeefe5556a31d065479ecc5ac_14205_120x120_fill_q75_box_smart1.jpg" => "resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/matt-le-SJSpo9hQf7s-unsplash_hu958d513eeefe5556a31d065479ecc5ac_14205_120x120_fill_q75_box_smart1.jpg" (100%) rename "YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/matt-le-SJSpo9hQf7s-unsplash_hu958d513eeefe5556a31d065479ecc5ac_14205_1600x0_resize_q75_box.jpg" => "resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/matt-le-SJSpo9hQf7s-unsplash_hu958d513eeefe5556a31d065479ecc5ac_14205_1600x0_resize_q75_box.jpg" (100%) rename "YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/matt-le-SJSpo9hQf7s-unsplash_hu958d513eeefe5556a31d065479ecc5ac_14205_800x0_resize_q75_box.jpg" => "resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/matt-le-SJSpo9hQf7s-unsplash_hu958d513eeefe5556a31d065479ecc5ac_14205_800x0_resize_q75_box.jpg" (100%) rename "YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-47_hu5dad4d9514f270d8c1798d204b1d3615_152725_120x120_fill_q75_box_smart1.jpg" => "resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-47_hu5dad4d9514f270d8c1798d204b1d3615_152725_120x120_fill_q75_box_smart1.jpg" (100%) rename "YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-47_hu5dad4d9514f270d8c1798d204b1d3615_152725_1600x0_resize_q75_box.jpg" => "resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-47_hu5dad4d9514f270d8c1798d204b1d3615_152725_1600x0_resize_q75_box.jpg" (100%) rename "YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-47_hu5dad4d9514f270d8c1798d204b1d3615_152725_800x0_resize_q75_box.jpg" => "resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-47_hu5dad4d9514f270d8c1798d204b1d3615_152725_800x0_resize_q75_box.jpg" (100%) rename "YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_120x120_fill_q75_box_smart1.jpg" => "resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_120x120_fill_q75_box_smart1.jpg" (100%) rename "YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_1600x0_resize_q75_box.jpg" => "resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_1600x0_resize_q75_box.jpg" (100%) rename "YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_800x0_resize_q75_box.jpg" => "resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_800x0_resize_q75_box.jpg" (100%) rename "YBlog/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/pexels-andreea-ch-1166643_hu5459c0360c2b0cb7a147d2df0eb350ca_602824_120x120_fill_q75_box_smart1.jpg" => "resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/pexels-andreea-ch-1166643_hu5459c0360c2b0cb7a147d2df0eb350ca_602824_120x120_fill_q75_box_smart1.jpg" (100%) rename "YBlog/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/pexels-andreea-ch-1166643_hu5459c0360c2b0cb7a147d2df0eb350ca_602824_1600x0_resize_q75_box.jpg" => "resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/pexels-andreea-ch-1166643_hu5459c0360c2b0cb7a147d2df0eb350ca_602824_1600x0_resize_q75_box.jpg" (100%) rename "YBlog/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/pexels-andreea-ch-1166643_hu5459c0360c2b0cb7a147d2df0eb350ca_602824_800x0_resize_q75_box.jpg" => "resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/pexels-andreea-ch-1166643_hu5459c0360c2b0cb7a147d2df0eb350ca_602824_800x0_resize_q75_box.jpg" (100%) rename "YBlog/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_120x120_fill_q75_box_smart1.jpg" => "resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_120x120_fill_q75_box_smart1.jpg" (100%) rename "YBlog/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_1600x0_resize_q75_box.jpg" => "resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_1600x0_resize_q75_box.jpg" (100%) rename "YBlog/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_800x0_resize_q75_box.jpg" => "resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_800x0_resize_q75_box.jpg" (100%) rename {YBlog/static => static}/favicon.ico (100%) create mode 100644 themes/hugo-theme-stack/.devcontainer/Dockerfile create mode 100644 themes/hugo-theme-stack/.devcontainer/devcontainer.json create mode 100644 themes/hugo-theme-stack/.github/FUNDING.yml create mode 100644 themes/hugo-theme-stack/.github/ISSUE_TEMPLATE/bug_report.yml create mode 100644 themes/hugo-theme-stack/.github/ISSUE_TEMPLATE/config.yml create mode 100644 themes/hugo-theme-stack/.gitignore create mode 100644 themes/hugo-theme-stack/LICENSE create mode 100644 themes/hugo-theme-stack/README.md create mode 100644 themes/hugo-theme-stack/archetypes/categories.md create mode 100644 themes/hugo-theme-stack/archetypes/default.md create mode 100644 themes/hugo-theme-stack/archetypes/tags.md create mode 100644 themes/hugo-theme-stack/assets/icons/archives.svg create mode 100644 themes/hugo-theme-stack/assets/icons/arrow-back.svg create mode 100644 themes/hugo-theme-stack/assets/icons/back.svg create mode 100644 themes/hugo-theme-stack/assets/icons/brand-github.svg create mode 100644 themes/hugo-theme-stack/assets/icons/brand-twitter.svg create mode 100644 themes/hugo-theme-stack/assets/icons/categories.svg create mode 100644 themes/hugo-theme-stack/assets/icons/clock.svg create mode 100644 themes/hugo-theme-stack/assets/icons/copyright.svg create mode 100644 themes/hugo-theme-stack/assets/icons/date.svg create mode 100644 themes/hugo-theme-stack/assets/icons/hash.svg create mode 100644 themes/hugo-theme-stack/assets/icons/home.svg create mode 100644 themes/hugo-theme-stack/assets/icons/infinity.svg create mode 100644 themes/hugo-theme-stack/assets/icons/language.svg create mode 100644 themes/hugo-theme-stack/assets/icons/link.svg create mode 100644 themes/hugo-theme-stack/assets/icons/messages.svg create mode 100644 themes/hugo-theme-stack/assets/icons/rss.svg create mode 100644 themes/hugo-theme-stack/assets/icons/search.svg create mode 100644 themes/hugo-theme-stack/assets/icons/tag.svg create mode 100644 themes/hugo-theme-stack/assets/icons/toggle-left.svg create mode 100644 themes/hugo-theme-stack/assets/icons/toggle-right.svg create mode 100644 themes/hugo-theme-stack/assets/icons/user.svg create mode 100644 themes/hugo-theme-stack/assets/img/avatar.png create mode 100644 themes/hugo-theme-stack/assets/scss/breakpoints.scss create mode 100644 themes/hugo-theme-stack/assets/scss/custom.scss create mode 100644 themes/hugo-theme-stack/assets/scss/external/normalize.scss create mode 100644 themes/hugo-theme-stack/assets/scss/general.scss create mode 100644 themes/hugo-theme-stack/assets/scss/grid.scss create mode 100644 themes/hugo-theme-stack/assets/scss/partials/article.scss create mode 100644 themes/hugo-theme-stack/assets/scss/partials/base.scss create mode 100644 themes/hugo-theme-stack/assets/scss/partials/comments/disqusjs.scss create mode 100644 themes/hugo-theme-stack/assets/scss/partials/footer.scss create mode 100644 themes/hugo-theme-stack/assets/scss/partials/highlight/common.scss create mode 100644 themes/hugo-theme-stack/assets/scss/partials/highlight/dark.scss create mode 100644 themes/hugo-theme-stack/assets/scss/partials/highlight/light.scss create mode 100644 themes/hugo-theme-stack/assets/scss/partials/layout/404.scss create mode 100644 themes/hugo-theme-stack/assets/scss/partials/layout/article.scss create mode 100644 themes/hugo-theme-stack/assets/scss/partials/layout/list.scss create mode 100644 themes/hugo-theme-stack/assets/scss/partials/layout/search.scss create mode 100644 themes/hugo-theme-stack/assets/scss/partials/menu.scss create mode 100644 themes/hugo-theme-stack/assets/scss/partials/pagination.scss create mode 100644 themes/hugo-theme-stack/assets/scss/partials/sidebar.scss create mode 100644 themes/hugo-theme-stack/assets/scss/partials/widgets.scss create mode 100644 themes/hugo-theme-stack/assets/scss/style.scss create mode 100644 themes/hugo-theme-stack/assets/scss/variables.scss create mode 100644 themes/hugo-theme-stack/assets/ts/color.ts create mode 100644 themes/hugo-theme-stack/assets/ts/colorScheme.ts create mode 100644 themes/hugo-theme-stack/assets/ts/createElement.ts create mode 100644 themes/hugo-theme-stack/assets/ts/gallery.ts create mode 100644 themes/hugo-theme-stack/assets/ts/main.ts create mode 100644 themes/hugo-theme-stack/assets/ts/menu.ts create mode 100644 themes/hugo-theme-stack/assets/ts/scrollspy.ts create mode 100644 themes/hugo-theme-stack/assets/ts/search.tsx create mode 100644 themes/hugo-theme-stack/assets/ts/smoothAnchors.ts create mode 100644 themes/hugo-theme-stack/config.yaml create mode 100644 themes/hugo-theme-stack/data/external.yaml create mode 100755 themes/hugo-theme-stack/debug.sh create mode 100644 themes/hugo-theme-stack/exampleSite/.gitignore create mode 100644 themes/hugo-theme-stack/exampleSite/LICENSE create mode 100644 themes/hugo-theme-stack/exampleSite/README.md create mode 100644 themes/hugo-theme-stack/exampleSite/content/_index.md create mode 100644 themes/hugo-theme-stack/exampleSite/content/_index.zh-cn.md create mode 100644 themes/hugo-theme-stack/exampleSite/content/categories/Test/_index.md create mode 100644 themes/hugo-theme-stack/exampleSite/content/categories/Test/hutomo-abrianto-l2jk-uxb1BY-unsplash.jpg create mode 100644 themes/hugo-theme-stack/exampleSite/content/page/about/index.md create mode 100644 themes/hugo-theme-stack/exampleSite/content/page/about/index.zh-cn.md create mode 100644 themes/hugo-theme-stack/exampleSite/content/page/archives/index.md create mode 100644 themes/hugo-theme-stack/exampleSite/content/page/links/index.md create mode 100644 themes/hugo-theme-stack/exampleSite/content/page/links/ts-logo-128.jpg create mode 100644 themes/hugo-theme-stack/exampleSite/content/page/search/index.md create mode 100644 themes/hugo-theme-stack/exampleSite/content/post/chinese-test/florian-klauer-nptLmg6jqDo-unsplash.jpg create mode 100644 themes/hugo-theme-stack/exampleSite/content/post/chinese-test/helena-hertz-wWZzXlDpMog-unsplash.jpg create mode 100644 themes/hugo-theme-stack/exampleSite/content/post/chinese-test/hudai-gayiran-3Od_VKcDEAA-unsplash.jpg create mode 100644 themes/hugo-theme-stack/exampleSite/content/post/chinese-test/index.zh-cn.md create mode 100644 themes/hugo-theme-stack/exampleSite/content/post/chinese-test/luca-bravo-alS7ewQ41M8-unsplash.jpg create mode 100644 themes/hugo-theme-stack/exampleSite/content/post/emoji-support/index.md create mode 100644 themes/hugo-theme-stack/exampleSite/content/post/emoji-support/the-creative-exchange-d2zvqp3fpro-unsplash.jpg create mode 100644 themes/hugo-theme-stack/exampleSite/content/post/markdown-syntax/index.md create mode 100644 themes/hugo-theme-stack/exampleSite/content/post/markdown-syntax/pawel-czerwinski-8uZPynIu-rQ-unsplash.jpg create mode 100644 themes/hugo-theme-stack/exampleSite/content/post/math-typesetting/index.md create mode 100644 themes/hugo-theme-stack/exampleSite/content/post/placeholder-text/index.ar.md create mode 100644 themes/hugo-theme-stack/exampleSite/content/post/placeholder-text/index.md create mode 100644 themes/hugo-theme-stack/exampleSite/content/post/placeholder-text/matt-le-SJSpo9hQf7s-unsplash.jpg create mode 100644 themes/hugo-theme-stack/exampleSite/content/post/rich-content/index.md create mode 100644 themes/hugo-theme-stack/exampleSite/hugo.yaml create mode 100644 themes/hugo-theme-stack/go.mod create mode 100644 themes/hugo-theme-stack/i18n/ar.yaml create mode 100644 themes/hugo-theme-stack/i18n/be.yaml create mode 100644 themes/hugo-theme-stack/i18n/bn.yaml create mode 100644 themes/hugo-theme-stack/i18n/ca.yaml create mode 100644 themes/hugo-theme-stack/i18n/cs.yaml create mode 100644 themes/hugo-theme-stack/i18n/de.yaml create mode 100644 themes/hugo-theme-stack/i18n/el.yaml create mode 100644 themes/hugo-theme-stack/i18n/en.yaml create mode 100644 themes/hugo-theme-stack/i18n/es.yaml create mode 100644 themes/hugo-theme-stack/i18n/fa.yaml create mode 100644 themes/hugo-theme-stack/i18n/fr.yaml create mode 100644 themes/hugo-theme-stack/i18n/hi.yaml create mode 100644 themes/hugo-theme-stack/i18n/hu.yaml create mode 100644 themes/hugo-theme-stack/i18n/id.yaml create mode 100644 themes/hugo-theme-stack/i18n/it.yaml create mode 100644 themes/hugo-theme-stack/i18n/ja.yaml create mode 100644 themes/hugo-theme-stack/i18n/ko.yaml create mode 100644 themes/hugo-theme-stack/i18n/nl.yaml create mode 100644 themes/hugo-theme-stack/i18n/pl.yaml create mode 100644 themes/hugo-theme-stack/i18n/pt-br.yaml create mode 100644 themes/hugo-theme-stack/i18n/pt-pt.yaml create mode 100644 themes/hugo-theme-stack/i18n/ru.yaml create mode 100644 themes/hugo-theme-stack/i18n/sk.yaml create mode 100644 themes/hugo-theme-stack/i18n/th.yaml create mode 100644 themes/hugo-theme-stack/i18n/tr.yaml create mode 100644 themes/hugo-theme-stack/i18n/uk.yaml create mode 100644 themes/hugo-theme-stack/i18n/vi.yaml create mode 100644 themes/hugo-theme-stack/i18n/zh-cn.yaml create mode 100644 themes/hugo-theme-stack/i18n/zh-hk.yaml create mode 100644 themes/hugo-theme-stack/i18n/zh-tw.yaml create mode 100644 themes/hugo-theme-stack/images/screenshot.png create mode 100644 themes/hugo-theme-stack/images/tn.png create mode 100644 themes/hugo-theme-stack/layouts/404.html create mode 100644 themes/hugo-theme-stack/layouts/_default/_markup/render-heading.html create mode 100644 themes/hugo-theme-stack/layouts/_default/_markup/render-image.html create mode 100644 themes/hugo-theme-stack/layouts/_default/_markup/render-link.html create mode 100644 themes/hugo-theme-stack/layouts/_default/archives.html create mode 100644 themes/hugo-theme-stack/layouts/_default/baseof.html create mode 100644 themes/hugo-theme-stack/layouts/_default/list.html create mode 100644 themes/hugo-theme-stack/layouts/_default/rss.xml create mode 100644 themes/hugo-theme-stack/layouts/_default/single.html create mode 100644 themes/hugo-theme-stack/layouts/index.html create mode 100644 themes/hugo-theme-stack/layouts/page/search.html create mode 100644 themes/hugo-theme-stack/layouts/page/search.json create mode 100644 themes/hugo-theme-stack/layouts/partials/article-list/compact.html create mode 100644 themes/hugo-theme-stack/layouts/partials/article-list/default.html create mode 100644 themes/hugo-theme-stack/layouts/partials/article-list/tile.html create mode 100644 themes/hugo-theme-stack/layouts/partials/article/article.html create mode 100644 themes/hugo-theme-stack/layouts/partials/article/components/content.html create mode 100644 themes/hugo-theme-stack/layouts/partials/article/components/details.html create mode 100644 themes/hugo-theme-stack/layouts/partials/article/components/footer.html create mode 100644 themes/hugo-theme-stack/layouts/partials/article/components/header.html create mode 100644 themes/hugo-theme-stack/layouts/partials/article/components/links.html create mode 100644 themes/hugo-theme-stack/layouts/partials/article/components/math.html create mode 100644 themes/hugo-theme-stack/layouts/partials/article/components/photoswipe.html create mode 100644 themes/hugo-theme-stack/layouts/partials/article/components/related-content.html create mode 100644 themes/hugo-theme-stack/layouts/partials/article/components/tags.html create mode 100644 themes/hugo-theme-stack/layouts/partials/comments/include.html create mode 100644 themes/hugo-theme-stack/layouts/partials/comments/provider/beaudar.html create mode 100644 themes/hugo-theme-stack/layouts/partials/comments/provider/cactus.html create mode 100644 themes/hugo-theme-stack/layouts/partials/comments/provider/cusdis.html create mode 100644 themes/hugo-theme-stack/layouts/partials/comments/provider/disqus.html create mode 100644 themes/hugo-theme-stack/layouts/partials/comments/provider/disqusjs.html create mode 100644 themes/hugo-theme-stack/layouts/partials/comments/provider/giscus.html create mode 100644 themes/hugo-theme-stack/layouts/partials/comments/provider/gitalk.html create mode 100644 themes/hugo-theme-stack/layouts/partials/comments/provider/remark42.html create mode 100644 themes/hugo-theme-stack/layouts/partials/comments/provider/twikoo.html create mode 100644 themes/hugo-theme-stack/layouts/partials/comments/provider/utterances.html create mode 100644 themes/hugo-theme-stack/layouts/partials/comments/provider/vssue.html create mode 100644 themes/hugo-theme-stack/layouts/partials/comments/provider/waline.html create mode 100644 themes/hugo-theme-stack/layouts/partials/data/description.html create mode 100644 themes/hugo-theme-stack/layouts/partials/data/title.html create mode 100644 themes/hugo-theme-stack/layouts/partials/footer/components/custom-font.html create mode 100644 themes/hugo-theme-stack/layouts/partials/footer/components/script.html create mode 100644 themes/hugo-theme-stack/layouts/partials/footer/custom.html create mode 100644 themes/hugo-theme-stack/layouts/partials/footer/footer.html create mode 100644 themes/hugo-theme-stack/layouts/partials/footer/include.html create mode 100644 themes/hugo-theme-stack/layouts/partials/head/colorScheme.html create mode 100644 themes/hugo-theme-stack/layouts/partials/head/custom.html create mode 100644 themes/hugo-theme-stack/layouts/partials/head/head.html create mode 100644 themes/hugo-theme-stack/layouts/partials/head/opengraph/include.html create mode 100644 themes/hugo-theme-stack/layouts/partials/head/opengraph/provider/base.html create mode 100644 themes/hugo-theme-stack/layouts/partials/head/opengraph/provider/twitter.html create mode 100644 themes/hugo-theme-stack/layouts/partials/head/script.html create mode 100644 themes/hugo-theme-stack/layouts/partials/head/style.html create mode 100644 themes/hugo-theme-stack/layouts/partials/helper/external.html create mode 100644 themes/hugo-theme-stack/layouts/partials/helper/icon.html create mode 100644 themes/hugo-theme-stack/layouts/partials/helper/image.html create mode 100644 themes/hugo-theme-stack/layouts/partials/pagination.html create mode 100644 themes/hugo-theme-stack/layouts/partials/sidebar/left.html create mode 100644 themes/hugo-theme-stack/layouts/partials/sidebar/right.html create mode 100644 themes/hugo-theme-stack/layouts/partials/widget/archives.html create mode 100644 themes/hugo-theme-stack/layouts/partials/widget/categories.html create mode 100644 themes/hugo-theme-stack/layouts/partials/widget/search.html create mode 100644 themes/hugo-theme-stack/layouts/partials/widget/tag-cloud.html create mode 100644 themes/hugo-theme-stack/layouts/partials/widget/toc.html create mode 100644 themes/hugo-theme-stack/layouts/shortcodes/bilibili.html create mode 100644 themes/hugo-theme-stack/layouts/shortcodes/gitlab.html create mode 100644 themes/hugo-theme-stack/layouts/shortcodes/quote.html create mode 100644 themes/hugo-theme-stack/layouts/shortcodes/tencent.html create mode 100644 themes/hugo-theme-stack/layouts/shortcodes/video.html create mode 100644 themes/hugo-theme-stack/layouts/shortcodes/youtube.html create mode 100644 themes/hugo-theme-stack/netlify.toml create mode 100644 themes/hugo-theme-stack/theme.toml diff --git a/.github/workflows/hugo.yaml b/.github/workflows/hugo.yaml new file mode 100644 index 0000000..eb9b9e1 --- /dev/null +++ b/.github/workflows/hugo.yaml @@ -0,0 +1,78 @@ +# Sample workflow for building and deploying a Hugo site to GitHub Pages +name: Deploy Hugo site to Pages + +on: + # Runs on pushes targeting the default branch + push: + branches: + - main + + # Allows you to run this workflow manually from the Actions tab + workflow_dispatch: + +# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages +permissions: + contents: read + pages: write + id-token: write + +# Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued. +# However, do NOT cancel in-progress runs as we want to allow these production deployments to complete. +concurrency: + group: "pages" + cancel-in-progress: false + +# Default to bash +defaults: + run: + shell: bash + +jobs: + # Build job + build: + runs-on: ubuntu-latest + env: + HUGO_VERSION: 0.132.0 + steps: + - name: Install Hugo CLI + run: | + wget -O ${{ runner.temp }}/hugo.deb https://github.com/gohugoio/hugo/releases/download/v${HUGO_VERSION}/hugo_extended_${HUGO_VERSION}_linux-amd64.deb \ + && sudo dpkg -i ${{ runner.temp }}/hugo.deb + - name: Install Dart Sass + run: sudo snap install dart-sass + - name: Checkout + uses: actions/checkout@v4 + with: + submodules: recursive + fetch-depth: 0 + - name: Setup Pages + id: pages + uses: actions/configure-pages@v5 + - name: Install Node.js dependencies + run: "[[ -f package-lock.json || -f npm-shrinkwrap.json ]] && npm ci || true" + - name: Build with Hugo + env: + HUGO_CACHEDIR: ${{ runner.temp }}/hugo_cache + HUGO_ENVIRONMENT: production + TZ: America/Los_Angeles + run: | + hugo \ + --gc \ + --minify \ + --baseURL "${{ steps.pages.outputs.base_url }}/" + - name: Upload artifact + uses: actions/upload-pages-artifact@v3 + with: + path: ./public + + # Deployment job + deploy: + environment: + name: github-pages + url: ${{ steps.deployment.outputs.page_url }} + runs-on: ubuntu-latest + needs: build + steps: + - name: Deploy to GitHub Pages + id: deployment + uses: actions/deploy-pages@v4 diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..1f3958a --- /dev/null +++ b/.gitignore @@ -0,0 +1,9 @@ +public/ +themes/*/node_modules/ +*.log +*.swp +.DS_Store +.lh +.hugo_cache/ +.vscode/ + diff --git a/.gitmodules b/.gitmodules index 391ebca..5dcec21 100644 --- a/.gitmodules +++ b/.gitmodules @@ -1,3 +1,3 @@ [submodule "YBlog/themes/hugo-theme-stack"] - path = YBlog/themes/hugo-theme-stack + path = themes/hugo-theme-stack url = https://github.com/CaiJimmy/hugo-theme-stack/ diff --git a/YBlog/.hugo_build.lock b/.hugo_build.lock similarity index 100% rename from YBlog/.hugo_build.lock rename to .hugo_build.lock diff --git a/YBlog/.lh/.lhignore b/YBlog/.lh/.lhignore deleted file mode 100644 index 1de5100..0000000 --- a/YBlog/.lh/.lhignore +++ /dev/null @@ -1,6 +0,0 @@ -# list file to not track by the local-history extension. comment line starts with a '#' character -# each line describe a regular expression pattern (search for 'Javascript regex') -# it will relate to the workspace directory root. for example: -# '.*\.txt' ignores any file with 'txt' extension -# '/test/.*' ignores all the files under the 'test' directory -# '.*/test/.*' ignores all the files under any 'test' directory (even under sub-folders) diff --git a/YBlog/.lh/content/post/CS/0.CS-Learning-Plan/index.zh-cn.md.json b/YBlog/.lh/content/post/CS/0.CS-Learning-Plan/index.zh-cn.md.json deleted file mode 100644 index 41c65f9..0000000 --- a/YBlog/.lh/content/post/CS/0.CS-Learning-Plan/index.zh-cn.md.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "sourceFile": "content/post/CS/0.CS-Learning-Plan/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 5, - "patches": [ - { - "date": 1712579698345, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1712579726571, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,15 +1,15 @@\n ---\n-title: \"CS学习计划\"\n+title: 'CS学习计划'\n date: 2024-03-10T15:58:41+08:00\n draft: false\n taps: ['CS', 'plan']\n categories: ['learning', 'OS']\n-author: [\"Yeelight\"]\n+author: ['Yeelight']\n showtoc: true\n weight: -100\n readingTime: true\n-image: 'photo_2024-04-08_20-31-53.jpg'\n+image: 'content/post/CS/0.CS-Learning-Plan/photo_2024-04-08_20-31-53.jpg'\n ---\n \n ## 计算机语言基础\n \n@@ -36,19 +36,20 @@\n ### 基础结构\n \n - **[数组]({{< relref \"\" >}})**:是一种线性表数据结构,用于存储相同类型的数据元素。\n \n+ - [x] _二分搜索_\n+ - [x] _冒泡排序_\n+ - [ ] _动态规划_\n+ - ... ...\n \n- - [x] *二分搜索*\n- - [x] *冒泡排序*\n- - [ ] *动态规划*\n- - ... ...\n - **[链表]({{< relref \"\" >}})**:由一系列节点组成的数据结构,每个节点包含数据和指向下一个节点的指针。\n \n- - [ ] *反转链表*\n- - [ ] *环形链表*\n- - [ ] *LRU 缓存算法*\n+ - [ ] _反转链表_\n+ - [ ] _环形链表_\n+ - [ ] _LRU 缓存算法_\n - ... ...\n+\n - **栈**:一种遵循后进先出(LIFO)原则的数据结构,只允许在表的一端进行插入和删除操作。\n - [ ]\n - **队列**:一种遵循先进先出(FIFO)原则的数据结构,允许在表的一端进行插入,在另一端进行删除操作。\n - [ ]\n@@ -114,19 +115,18 @@\n ## 计算机网络\n \n ## CS 后续学习路径\n \n- 为自身打造的路径\n-_\n+为自身打造的路径\n+\\_\n 目标:人工智能**Artificial intelligence**\n 数学\n [Search --- Graph theory]({{< relref \"\" >}})\n \n [Knowledge --- Boolean logic]({{< relref \"\" >}})\n \n [Uncertainty --- Probability]({{< relref \"\" >}})\n \n-\n 目标:应用程序开发**Application Developer**\n \n [Full Stack]({{< relref \"\" >}})\n \n" - }, - { - "date": 1712579753455, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -7,9 +7,9 @@\n author: ['Yeelight']\n showtoc: true\n weight: -100\n readingTime: true\n-image: 'content/post/CS/0.CS-Learning-Plan/photo_2024-04-08_20-31-53.jpg'\n+image: 'content/post/CS/0.CS-Learning-Plan/photo_2024-04-08_20-31-47.jpg'\n ---\n \n ## 计算机语言基础\n \n" - }, - { - "date": 1712579774459, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -7,9 +7,9 @@\n author: ['Yeelight']\n showtoc: true\n weight: -100\n readingTime: true\n-image: 'content/post/CS/0.CS-Learning-Plan/photo_2024-04-08_20-31-47.jpg'\n+image: 'photo_2024-04-08_20-31-47.jpg\"\n ---\n \n ## 计算机语言基础\n \n" - }, - { - "date": 1712579787769, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -7,9 +7,9 @@\n author: ['Yeelight']\n showtoc: true\n weight: -100\n readingTime: true\n-image: 'photo_2024-04-08_20-31-47.jpg\"\n+image: \"content/post/CS/0.CS-Learning-Plan/matt-le-SJSpo9hQf7s-unsplash.jpg\"\n ---\n \n ## 计算机语言基础\n \n" - }, - { - "date": 1712579798526, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -7,9 +7,9 @@\n author: ['Yeelight']\n showtoc: true\n weight: -100\n readingTime: true\n-image: \"content/post/CS/0.CS-Learning-Plan/matt-le-SJSpo9hQf7s-unsplash.jpg\"\n+image: \"photo_2024-04-08_20-31-47.jpg\"\n ---\n \n ## 计算机语言基础\n \n" - } - ], - "date": 1712579698345, - "name": "Commit-0", - "content": "---\ntitle: \"CS学习计划\"\ndate: 2024-03-10T15:58:41+08:00\ndraft: false\ntaps: ['CS', 'plan']\ncategories: ['learning', 'OS']\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight: -100\nreadingTime: true\nimage: 'photo_2024-04-08_20-31-53.jpg'\n---\n\n## 计算机语言基础\n\n### C 语言\n\n**项目练习**\n\n### Go 语言\n\n———> [Go 语言学习]({{< relref \"post/CS/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md\" >}})\n\n**项目练习**\n\n### python 语言\n\n**项目练习**\n\n1. [TG_bot]({{< relref \"\" >}})\n\n## 数据结构\n\n数据结构是对计算机高级语言最能体现打基础的学习,目前有许多常见的数据结构,我喜欢分类来处理。\n\n### 基础结构\n\n- **[数组]({{< relref \"\" >}})**:是一种线性表数据结构,用于存储相同类型的数据元素。\n\n\n - [x] *二分搜索*\n - [x] *冒泡排序*\n - [ ] *动态规划*\n - ... ...\n- **[链表]({{< relref \"\" >}})**:由一系列节点组成的数据结构,每个节点包含数据和指向下一个节点的指针。\n\n - [ ] *反转链表*\n - [ ] *环形链表*\n - [ ] *LRU 缓存算法*\n - ... ...\n- **栈**:一种遵循后进先出(LIFO)原则的数据结构,只允许在表的一端进行插入和删除操作。\n - [ ]\n- **队列**:一种遵循先进先出(FIFO)原则的数据结构,允许在表的一端进行插入,在另一端进行删除操作。\n - [ ]\n- **树**:一种非线性数据结构,由节点组成,节点之间存在层次关系。\n - [ ]\n- **图**:由节点(或顶点)和边组成的数据结构,用于表示多对多的关系。\n - [ ]\n\n### 其他结构\n\n- **并查集**:一种用于处理不相交集合的数据结构,常用于解决连接性问题。\n- **字典树**:一种用于快速检索的树形数据结构,常用于字符串检索。\n- **散列表**:利用哈希函数将关键字映射到表中一个位置来访问记录的数据结构。\n- **树状数组**:一种高效的数据结构,用于维护序列前缀和的动态查询。\n- **映射**:一种将键映射到值的抽象数据类型,常用于快速查找。\n- **集合**:一种抽象数据类型,用于存储互不相同的元素的集合。\n\n### 真实世界\n\n在实际项目中,数据结构和算法的选择取决于具体的应用场景和问题需求。一般来说,对于不涉及高精尖、复杂算法的项目,可以尽量选择简单的数据结构。以下是一些建议和实践:\n\n1. **根据场景选择数据结构**:静态数组适合元素不超过 100 的场合,动态数组适合元素不超过 1000 的场合,链表适合元素不超过 3000 的场合。在需要动态分配内存的场合,可以考虑使用静态内存,以提高程序稳定性。\n\n2. **实际项目中的应用**:数据结构和算法在实际项目中扮演着重要角色,可以通过实际项目场景来说明一种数据结构解决了什么实际问题,以及其各种操作时间复杂度、优缺点等。这有助于理解数据结构在编程中的重要性。\n\n3. **权衡选择**:在实际开发中,需要权衡选择使用哪种数据结构和算法。除了考虑算法的时间复杂度、空间复杂度,还需要考虑其在具体场景下的执行效率、易用性、维护成本等因素\n\n综上所述,实际项目中的数据结构和算法选择应该根据具体的应用场景和问题需求进行权衡和取舍,以达到最优的解决方案。\n\n## 算法(AI)\n\n算法是解决问题的一系列清晰指令,是计算机科学的基础。在实际开发中,选择合适的数据结构和算法对程序的性能和效率至关重要。在学习算法时,需要权衡选择使用哪种数据结构和算法,不能简单地用复杂度来表示执行性能。此外,编程算法面试经验总结中提到,算法面试常涉及的主题、考察形式和评价方式,对求职备考的朋友们有所帮助。另外,算法也在机器学习领域有着广泛的应用,比如预测住房价格、探索客户的人口统计学数据以确定模式等。在实际开发中,对于数组的算法,可以通过合并两个有序数组来进行实现。对于统计相同数字出现的次数,可以利用数组元素下标对应数字,用数组元素的值表示对应数字出现的次数,这是一种典型的空间换时间的算法。如果整数的范围是 1 到 n,可以考虑使用其他的算法来实现。\n\n### 关键要点\n\n1. **目的和问题解决:** 算法的设计旨在解决特定问题或执行特定任务。它们用于执行各种计算和操作,从简单的搜索和排序到复杂的图算法和机器学习。\n2. **输入和输出:** 算法接受一个或多个输入,通过执行一系列计算操作,产生一个输出。输入可以是数据、问题描述或其他形式的信息。\n3. **有限性:** 算法是有限步骤的集合,每一步都可以在有限的时间内完成。这确保了算法的执行是可以终止的。\n4. **确定性:** 算法的每一步都是确定性的,即对于给定的输入,它总是产生相同的输出。这使得算法在不同的环境中具有可重复性。\n5. **效率:** 算法的效率是一个关键方面,通常通过时间复杂度和空间复杂度来衡量。好的算法能够以较低的时间和空间开销解决问题。\n6. **可读性和可维护性:** 除了效率,算法的可读性和可维护性也是重要的。一个清晰、简单、易于理解的算法更容易被其他人理解和维护。\n\n### 算法的分类\n\n- **搜索算法:** 用于在数据集中查找特定元素的算法,如线性搜索和二分搜索。\n- **排序算法:** 对一组元素进行排列的算法,例如冒泡排序、快速排序、归并排序等。\n- **图算法:** 处理图数据结构的算法,包括深度优先搜索、广度优先搜索、最短路径算法等。\n- **动态规划:** 将复杂问题分解为简单子问题,并通过保存已解决的子问题的解来加速求解的算法。\n- **贪心算法:** 在每一步选择中都采取当前状态下最好或最优的选择,从而希望得到全局最好或最优解的算法。\n- **回溯算法:** 通过不断试错找到问题的解,是一种递归的算法。\n- **分治算法:** 将问题分解成相互独立且与原问题相同的子问题,然后递归地解决子问题。\n- **随机化算法:** 使用随机数来解决问题的算法,例如快速排序的随机化版本。\n- **机器学习算法:** 用于构建模型、分类和预测的一系列算法,如决策树、支持向量机、神经网络等。\n\n算法是计算机科学的核心,它们不仅仅是问题求解的工具,也是构建复杂系统和应对实际挑战的基础。深入理解和熟练运用各种算法,有助于提高问题解决和计算机科学建模的能力。\n\n## 体系结构\n\n## 操作系统\n\n[操作系统的具体学习目录]({{< relref \"\">}})\n\n## 计算机网络\n\n## CS 后续学习路径\n\n 为自身打造的路径\n_\n目标:人工智能**Artificial intelligence**\n数学\n[Search --- Graph theory]({{< relref \"\" >}})\n\n[Knowledge --- Boolean logic]({{< relref \"\" >}})\n\n[Uncertainty --- Probability]({{< relref \"\" >}})\n\n\n目标:应用程序开发**Application Developer**\n\n[Full Stack]({{< relref \"\" >}})\n\n目标:计算机图形学**Computer graphics**\n\n目标:软件工程**Software engineering**\n\n## LeetCode\n\n每日任务\n[合并两个有序数组]({{< relref \"\" >}})\n\n[移除元素]({{< relref \"\" >}})\n\n[删除有序数组中的重复项]({{< relref \"\" >}})\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/CS/1.ComputerBasics/CSLanguages/_index.zh-cn.md.json b/YBlog/.lh/content/post/CS/1.ComputerBasics/CSLanguages/_index.zh-cn.md.json deleted file mode 100644 index 7f96f01..0000000 --- a/YBlog/.lh/content/post/CS/1.ComputerBasics/CSLanguages/_index.zh-cn.md.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "sourceFile": "content/post/CS/1.ComputerBasics/CSLanguages/_index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 2, - "patches": [ - { - "date": 1712579608801, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1712579631226, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -8,6 +8,6 @@\n showtoc: true\n weight:\n math: false\n readingTime: true\n-i\n+image: '/home/yeekox/blog/HiBlog/YBlog/content/post/CS/1.ComputerBasics/CSLanguages/Golang/photo_2024-04-08_20-31-53.jpg'\n ---\n" - }, - { - "date": 1712579694565, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -8,6 +8,6 @@\n showtoc: true\n weight:\n math: false\n readingTime: true\n-image: '/home/yeekox/blog/HiBlog/YBlog/content/post/CS/1.ComputerBasics/CSLanguages/Golang/photo_2024-04-08_20-31-53.jpg'\n+\n ---\n" - } - ], - "date": 1712579608801, - "name": "Commit-0", - "content": "---\ntitle: \"Languages\"\ndate: 2024-03-14T21:53:46+08:00\ndraft: false\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\ni\n---\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/CS/3.Architecture/CSAPP/CSAPP00/index.zh-cn.md.json b/YBlog/.lh/content/post/CS/3.Architecture/CSAPP/CSAPP00/index.zh-cn.md.json deleted file mode 100644 index 7c62fe4..0000000 --- a/YBlog/.lh/content/post/CS/3.Architecture/CSAPP/CSAPP00/index.zh-cn.md.json +++ /dev/null @@ -1,18 +0,0 @@ -{ - "sourceFile": "content/post/CS/3.Architecture/CSAPP/CSAPP00/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 0, - "patches": [ - { - "date": 1712578977562, - "content": "Index: \n===================================================================\n--- \n+++ \n" - } - ], - "date": 1712578977562, - "name": "Commit-0", - "content": "---\ntitle: \"零.深入理解计算机系统(CSAPP)\"\ndate: 2023-03-12T21:46:39+08:00\ndraft: false\ntags: [CSAPP]\ncategories: [\"CSAPP\",\"CS\"]\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight: 1\nreadingTime: true\n---\n\n## 前言\n\n>### 有志,有识,有恒,则断无不成之事\n\n我自己在2022年学习过`CS61c`,这门课主要是讲解了计算机的体系结构,终于踏入了计算机的门槛。计算机体系结构,这是一个计算机十分难啃的一门知识,内容之多、范围之广,无论里面的`数的表示、编译原理、CPU的基本架构、内存、虚拟内存、流水线、线程级并行、I/O、OS、网络等等`,每个方面都可以单独拎出来成为一门课程。而想要精通这些知识需要耗费大量的时间和精力,即使学习十年也不嫌少。哈哈哈。\n\n我对计算机的热爱促使我非正式地学习了 `CS61c`(可惜我不是伯克利的学子)过后,我发现,它给我的是课堂上没有的一些思想,比如:为什么?通过已经有的事实发出提问(即存在有缘由,而不是想当然的存在即真理)。\n\n在我上大学的时候我就知道一本`神书`《深入理解计算机系统》(即:***《Computer Systems: A Programmer’s Perspective》***),可是一直没有机会读一读(也看不懂 😂 ,也正是在有CS61c的基础上我想去好好的通读一遍它。\n\n这本书好在哪里?它是一本以程序员的视角来看计算机的底层机制,不需要你对物理,电子层面有多么高的水准来看计算机,如果有的话更好的(在这里就不得不吐槽国内的教学了)。它里面的内容也是十分的丰富,结合了计算机组成与体系结构,链接与装载,程序优化,内存存储层次,操作系统,网络等基础知识。\n\n好的,说那么多,我也想把我在学习的过程写下来这也不失成为我的一场回忆。\n\n## 学习目的\n> 知其然而不知其所以然\n\n在看这本书的时候问问自己,这本书可以给我带来什么?我为什么要学习这本书?正如上面的这句话一样,况且我也不想做一个”代码的搬运工“。\n\n### 学到什么?\n\n> - 可以对计算机底层系统有一个更加全面且深入的认识。\n> - 系统的理解计算机系统底层的工作原理。\n> - 写出更加健壮的、安全的代码。\n> - 走向现实层面的计算机。\n> - 打下编译原理、操作系统的基础。\n> - 等等\n\n学习是要你静下心来,认真思考,积极动手的,用我的话来说就是:事无巨细\n\n## 计算机系统漫游\n\n接下来就看看我们要学什么。\n\n### 信息`bit`化\n\n人类与机器交互最大的问题是`语言不通`。让我们回到五六十年代,那时没有像现在这样方便的手机、iPad和电脑操作方式。那个\"古老时代\"没有图像、键盘或字符,只有打孔器、巨型电子管和满屋子的电线......我们唯一能与计算机交流的方法就是通过电流和“疯狂”的思维。\n\n而随着物理学和数学的发展,计算机得以快速发展,并且我们开始使用二进制来与机器进行交互,这比以前好多了。\n\n但仍然存在一个问题:“为什么要使用二进制?”因为它适用于我们的电路(高/低电压)和逻辑门(0/1),似乎所有事情都变成了二进制。 我们在这里已经迈出了很大的步伐。\n\n在计算机领域里面,我们叫一个可以正常显示0/1的位叫`bit`,而后续的研究证明了一次性对8bit进行操作是十分成功的,因此**1 Byte = 8 bit**(注意大小写),在后面我们的位越来越多,我们使用了`十六进制`。由此来看,人类是很富有想象力的种族。\n\n在后面的学习中,数值的表示是很重要的知识点,计算机就是为精准,快速计算这些数值,特别是浮点数(float)的计算而发展的。\n\n### 编译系统\n\n```c\n\n    int main()\n\n    {\n\n        printf(\"Hello World\\n\");\n\n        return 0;\n\n    }\n\n```\n\n上面是一个简单的C语言程序,打印一个\"Hello World\"(并且换行),但是,它要经过好几个步骤才能打印在你的屏幕上,分别是:编译(Compiler),汇编(Assembler),装载器(Loader),链接器(Linker)。\n\n我们在这一部分将要学到从 `高级语言 --> 汇编语言 --> 机器语言` 这一过程的具体实现,这使我们能够更深入地了解系统的底层。。\n\n### CPU基本结构\n\nCPU(中央处理器),可以说是本世纪最伟大的发明了,一个小小的芯片装载着人类的智慧,这一部分我们要了解 CPU 的内部构造,下面是一张 CPU 的大致图片:\n\n![cpu8085.png](https://s2.loli.net/2023/07/24/sU86Dw3jgNBOoV2.png)\n\n这是一个复杂但十分有趣的部分,相信我,你会体会它的魅力的。\n\n### 操作系统\n\n操作系统(***Operating System***),是来控制电脑的执行硬件、软件资源,控制**I/O**操作,提供基本的用户互动等。\n\n它也负责加载程序、处理服务(如网络堆栈和文件系统)以及为多个程序复用资源,但它实际上是要负责隔离各个程序,使得一个给定的程序不会干扰另一个程序的内存或执行。\n\n### 网络通信\n\n\n这一部分我也写了自己的[学习笔记](https://clever-klepon-d14cb6.netlify.app/posts/internet-0/)\n\n## 外部链接\n\n[Computer Science from the Bottom Up](https://www.bottomupcs.com/index.html)\n\n[小土刀博主的『读薄』](https://wdxtub.com/)\n\n[fengmuzi2003up主的计算机系统漫游](https://fengmuzi2003.gitbook.io/csapp3e/)\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/CS/Personal/update/index.zh-cn.md.json b/YBlog/.lh/content/post/CS/Personal/update/index.zh-cn.md.json deleted file mode 100644 index bbada8a..0000000 --- a/YBlog/.lh/content/post/CS/Personal/update/index.zh-cn.md.json +++ /dev/null @@ -1,22 +0,0 @@ -{ - "sourceFile": "content/post/CS/Personal/update/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 1, - "patches": [ - { - "date": 1712581302678, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1712581312252, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n title: '博客搭建更新日记✨'\n date: 2023-03-08T19:56:58+08:00\n draft: false\n-taps: []\n-categories: []\n+taps: ['update']\n+categories: ['update']\n author: ['Yeelight']\n showtoc: true\n weight: -110\n math: false\n" - } - ], - "date": 1712581302678, - "name": "Commit-0", - "content": "---\ntitle: '博客搭建更新日记✨'\ndate: 2023-03-08T19:56:58+08:00\ndraft: false\ntaps: []\ncategories: []\nauthor: ['Yeelight']\nshowtoc: true\nweight: -110\nmath: false\nreadingTime: true\nimage: 'pexels-andreea-ch-1166643.jpg'\n---\n\n## Hello\n\n你好,这是,这里面是记录我对自己的博客 web 更新的日记。\n\n## March 10,2023\n\n博客使用 hugo 了\n\n## April 20, 2023\n\n我使用了图床,蛮好用的 😁\n\n## April 25, 2023\n\n我更新了一些社交方式\n\n更新一下我的博客的配置\n\n## Mar 10,2024\n\n好久不见了,这一次我把近一年的笔记进行一个整理,然后更新到了博客上。\n也做了许多的计划和之后的规划\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/0.CS-Learning-Plan/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/0.CS-Learning-Plan/index.zh-cn.md.json deleted file mode 100644 index d97a049..0000000 --- a/YBlog/.lh/content/post/Gohh/0.CS-Learning-Plan/index.zh-cn.md.json +++ /dev/null @@ -1,182 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/0.CS-Learning-Plan/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 41, - "patches": [ - { - "date": 1712581801347, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1712581828118, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -7,9 +7,9 @@\n author: ['Yeelight']\n showtoc: true\n weight: -100\n readingTime: true\n-image: \"photo_2024-04-08_20-31-47.jpg\"\n+image: \"https://s2.loli.net/2024/04/08/Xej8au1VkhZN4HT.jpg\"\n ---\n \n ## 计算机语言基础\n \n" - }, - { - "date": 1715563198054, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -18,9 +18,9 @@\n **项目练习**\n \n ### Go 语言\n \n-———> [Go 语言学习]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md\" >}})\n+———> [Go 语言学习]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/index.zh-cn.md\" >}})\n \n **项目练习**\n \n ### python 语言\n" - }, - { - "date": 1715564242648, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -18,9 +18,9 @@\n **项目练习**\n \n ### Go 语言\n \n-———> [Go 语言学习]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/index.zh-cn.md\" >}})\n+———> [Go 语言学习]()\n \n **项目练习**\n \n ### python 语言\n" - }, - { - "date": 1715564252017, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -18,9 +18,9 @@\n **项目练习**\n \n ### Go 语言\n \n-———> [Go 语言学习]()\n+———> [Go 语言学习](../1.ComputerBasics/)\n \n **项目练习**\n \n ### python 语言\n" - }, - { - "date": 1715564271919, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -18,17 +18,17 @@\n **项目练习**\n \n ### Go 语言\n \n-———> [Go 语言学习](../1.ComputerBasics/)\n+———> [Go 语言学习](../1.ComputerBasics/CSLanguages/Golang/index.zh-cn.md)\n \n **项目练习**\n \n ### python 语言\n \n **项目练习**\n \n-1. [TG_bot]({{< relref \"\" >}})\n+\n \n ## 数据结构\n \n 数据结构是对计算机高级语言最能体现打基础的学习,目前有许多常见的数据结构,我喜欢分类来处理。\n" - }, - { - "date": 1715564279262, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -34,9 +34,9 @@\n 数据结构是对计算机高级语言最能体现打基础的学习,目前有许多常见的数据结构,我喜欢分类来处理。\n \n ### 基础结构\n \n-- **[数组]({{< relref \"\" >}})**:是一种线性表数据结构,用于存储相同类型的数据元素。\n+- **[数组](../)**:是一种线性表数据结构,用于存储相同类型的数据元素。\n \n - [x] _二分搜索_\n - [x] _冒泡排序_\n - [ ] _动态规划_\n" - }, - { - "date": 1715564284797, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -34,9 +34,9 @@\n 数据结构是对计算机高级语言最能体现打基础的学习,目前有许多常见的数据结构,我喜欢分类来处理。\n \n ### 基础结构\n \n-- **[数组](../)**:是一种线性表数据结构,用于存储相同类型的数据元素。\n+- **[数组](../2.DataStructures_Algorithms/GolangDS/Array/index.zh-cn.md)**:是一种线性表数据结构,用于存储相同类型的数据元素。\n \n - [x] _二分搜索_\n - [x] _冒泡排序_\n - [ ] _动态规划_\n" - }, - { - "date": 1715564289893, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -41,9 +41,9 @@\n - [x] _冒泡排序_\n - [ ] _动态规划_\n - ... ...\n \n-- **[链表]({{< relref \"\" >}})**:由一系列节点组成的数据结构,每个节点包含数据和指向下一个节点的指针。\n+- **[链表](../)**:由一系列节点组成的数据结构,每个节点包含数据和指向下一个节点的指针。\n \n - [ ] _反转链表_\n - [ ] _环形链表_\n - [ ] _LRU 缓存算法_\n" - }, - { - "date": 1715564295660, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -41,9 +41,9 @@\n - [x] _冒泡排序_\n - [ ] _动态规划_\n - ... ...\n \n-- **[链表](../)**:由一系列节点组成的数据结构,每个节点包含数据和指向下一个节点的指针。\n+- **[链表](../2.DataStructures_Algorithms/GolangDS/Link/index.zh-cn.md)**:由一系列节点组成的数据结构,每个节点包含数据和指向下一个节点的指针。\n \n - [ ] _反转链表_\n - [ ] _环形链表_\n - [ ] _LRU 缓存算法_\n" - }, - { - "date": 1715564313637, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -48,15 +48,15 @@\n - [ ] _环形链表_\n - [ ] _LRU 缓存算法_\n - ... ...\n \n-- **栈**:一种遵循后进先出(LIFO)原则的数据结构,只允许在表的一端进行插入和删除操作。\n+- **[栈]**:一种遵循后进先出(LIFO)原则的数据结构,只允许在表的一端进行插入和删除操作。\n - [ ]\n-- **队列**:一种遵循先进先出(FIFO)原则的数据结构,允许在表的一端进行插入,在另一端进行删除操作。\n+- **[队列]**:一种遵循先进先出(FIFO)原则的数据结构,允许在表的一端进行插入,在另一端进行删除操作。\n - [ ]\n-- **树**:一种非线性数据结构,由节点组成,节点之间存在层次关系。\n+- **[树]**:一种非线性数据结构,由节点组成,节点之间存在层次关系。\n - [ ]\n-- **图**:由节点(或顶点)和边组成的数据结构,用于表示多对多的关系。\n+- **[图]**:由节点(或顶点)和边组成的数据结构,用于表示多对多的关系。\n - [ ]\n \n ### 其他结构\n \n" - }, - { - "date": 1715564325174, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -48,9 +48,9 @@\n - [ ] _环形链表_\n - [ ] _LRU 缓存算法_\n - ... ...\n \n-- **[栈]**:一种遵循后进先出(LIFO)原则的数据结构,只允许在表的一端进行插入和删除操作。\n+- **[栈](**:一种遵循后进先出(LIFO)原则的数据结构,只允许在表的一端进行插入和删除操作。\n - [ ]\n - **[队列]**:一种遵循先进先出(FIFO)原则的数据结构,允许在表的一端进行插入,在另一端进行删除操作。\n - [ ]\n - **[树]**:一种非线性数据结构,由节点组成,节点之间存在层次关系。\n" - }, - { - "date": 1715564331575, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -48,9 +48,9 @@\n - [ ] _环形链表_\n - [ ] _LRU 缓存算法_\n - ... ...\n \n-- **[栈](**:一种遵循后进先出(LIFO)原则的数据结构,只允许在表的一端进行插入和删除操作。\n+- **[栈](../2.DataStructures_Algorithms/GolangDS/Stack/index.zh-cn.md**:一种遵循后进先出(LIFO)原则的数据结构,只允许在表的一端进行插入和删除操作。\n - [ ]\n - **[队列]**:一种遵循先进先出(FIFO)原则的数据结构,允许在表的一端进行插入,在另一端进行删除操作。\n - [ ]\n - **[树]**:一种非线性数据结构,由节点组成,节点之间存在层次关系。\n" - }, - { - "date": 1715566685747, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -18,9 +18,9 @@\n **项目练习**\n \n ### Go 语言\n \n-———> [Go 语言学习](../1.ComputerBasics/CSLanguages/Golang/index.zh-cn.md)\n+———> [Go 语言学习]()\n \n **项目练习**\n \n ### python 语言\n@@ -48,9 +48,9 @@\n - [ ] _环形链表_\n - [ ] _LRU 缓存算法_\n - ... ...\n \n-- **[栈](../2.DataStructures_Algorithms/GolangDS/Stack/index.zh-cn.md**:一种遵循后进先出(LIFO)原则的数据结构,只允许在表的一端进行插入和删除操作。\n+- **[栈](../2.DataStructures_Algorithms/GolangDS/Stack/index.zh-cn.md)**:一种遵循后进先出(LIFO)原则的数据结构,只允许在表的一端进行插入和删除操作。\n - [ ]\n - **[队列]**:一种遵循先进先出(FIFO)原则的数据结构,允许在表的一端进行插入,在另一端进行删除操作。\n - [ ]\n - **[树]**:一种非线性数据结构,由节点组成,节点之间存在层次关系。\n" - }, - { - "date": 1715566694031, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -18,9 +18,9 @@\n **项目练习**\n \n ### Go 语言\n \n-———> [Go 语言学习]()\n+———> [Go 语言学习]({{< re>}})\n \n **项目练习**\n \n ### python 语言\n" - }, - { - "date": 1715566702035, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -18,9 +18,9 @@\n **项目练习**\n \n ### Go 语言\n \n-———> [Go 语言学习]({{< re>}})\n+———> [Go 语言学习]({{< ref \"/content/\">}})\n \n **项目练习**\n \n ### python 语言\n" - }, - { - "date": 1715566710281, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -18,9 +18,9 @@\n **项目练习**\n \n ### Go 语言\n \n-———> [Go 语言学习]({{< ref \"/content/\">}})\n+———> [Go 语言学习]({{< ref \"/content/post/Gohh/1.ComputerBasics/CSLanguages/\">}})\n \n **项目练习**\n \n ### python 语言\n" - }, - { - "date": 1715566716031, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -18,9 +18,9 @@\n **项目练习**\n \n ### Go 语言\n \n-———> [Go 语言学习]({{< ref \"/content/post/Gohh/1.ComputerBasics/CSLanguages/\">}})\n+———> [Go 语言学习]({{< ref \"/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md\">}})\n \n **项目练习**\n \n ### python 语言\n" - }, - { - "date": 1715566722697, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -18,9 +18,9 @@\n **项目练习**\n \n ### Go 语言\n \n-———> [Go 语言学习]({{< ref \"/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md\">}})\n+———> [Go 语言学习]({{< ref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md\">}})\n \n **项目练习**\n \n ### python 语言\n" - }, - { - "date": 1715567201412, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -34,9 +34,9 @@\n 数据结构是对计算机高级语言最能体现打基础的学习,目前有许多常见的数据结构,我喜欢分类来处理。\n \n ### 基础结构\n \n-- **[数组](../2.DataStructures_Algorithms/GolangDS/Array/index.zh-cn.md)**:是一种线性表数据结构,用于存储相同类型的数据元素。\n+- **数组**:是一种线性表数据结构,用于存储相同类型的数据元素。\n \n - [x] _二分搜索_\n - [x] _冒泡排序_\n - [ ] _动态规划_\n" - }, - { - "date": 1715567207711, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -32,9 +32,9 @@\n ## 数据结构\n \n 数据结构是对计算机高级语言最能体现打基础的学习,目前有许多常见的数据结构,我喜欢分类来处理。\n \n-### 基础结构\n+### {基础结构}\n \n - **数组**:是一种线性表数据结构,用于存储相同类型的数据元素。\n \n - [x] _二分搜索_\n" - }, - { - "date": 1715567213321, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -32,9 +32,9 @@\n ## 数据结构\n \n 数据结构是对计算机高级语言最能体现打基础的学习,目前有许多常见的数据结构,我喜欢分类来处理。\n \n-### {基础结构}\n+### [基础结构]\n \n - **数组**:是一种线性表数据结构,用于存储相同类型的数据元素。\n \n - [x] _二分搜索_\n" - }, - { - "date": 1715567220384, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -32,9 +32,9 @@\n ## 数据结构\n \n 数据结构是对计算机高级语言最能体现打基础的学习,目前有许多常见的数据结构,我喜欢分类来处理。\n \n-### [基础结构]\n+### [基础结构]({})\n \n - **数组**:是一种线性表数据结构,用于存储相同类型的数据元素。\n \n - [x] _二分搜索_\n" - }, - { - "date": 1715567227386, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -32,9 +32,9 @@\n ## 数据结构\n \n 数据结构是对计算机高级语言最能体现打基础的学习,目前有许多常见的数据结构,我喜欢分类来处理。\n \n-### [基础结构]({})\n+### [基础结构]({{< ref \"\">}})\n \n - **数组**:是一种线性表数据结构,用于存储相同类型的数据元素。\n \n - [x] _二分搜索_\n" - }, - { - "date": 1715567239487, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -32,9 +32,9 @@\n ## 数据结构\n \n 数据结构是对计算机高级语言最能体现打基础的学习,目前有许多常见的数据结构,我喜欢分类来处理。\n \n-### [基础结构]({{< ref \"\">}})\n+### [基础结构]({{< ref \"/\">}})\n \n - **数组**:是一种线性表数据结构,用于存储相同类型的数据元素。\n \n - [x] _二分搜索_\n" - }, - { - "date": 1715567245166, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -32,9 +32,9 @@\n ## 数据结构\n \n 数据结构是对计算机高级语言最能体现打基础的学习,目前有许多常见的数据结构,我喜欢分类来处理。\n \n-### [基础结构]({{< ref \"/\">}})\n+### [基础结构]({{< ref \"/content/post/Gohh/\">}})\n \n - **数组**:是一种线性表数据结构,用于存储相同类型的数据元素。\n \n - [x] _二分搜索_\n" - }, - { - "date": 1715567252993, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -32,9 +32,9 @@\n ## 数据结构\n \n 数据结构是对计算机高级语言最能体现打基础的学习,目前有许多常见的数据结构,我喜欢分类来处理。\n \n-### [基础结构]({{< ref \"/content/post/Gohh/\">}})\n+### [基础结构]({{< ref \"post/Gohh/2.DataStructures_Algorithms/GolangDS/_index.zh-cn.md\">}})\n \n - **数组**:是一种线性表数据结构,用于存储相同类型的数据元素。\n \n - [x] _二分搜索_\n" - }, - { - "date": 1715567269038, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -41,9 +41,9 @@\n - [x] _冒泡排序_\n - [ ] _动态规划_\n - ... ...\n \n-- **[链表](../2.DataStructures_Algorithms/GolangDS/Link/index.zh-cn.md)**:由一系列节点组成的数据结构,每个节点包含数据和指向下一个节点的指针。\n+- **链表**:由一系列节点组成的数据结构,每个节点包含数据和指向下一个节点的指针。\n \n - [ ] _反转链表_\n - [ ] _环形链表_\n - [ ] _LRU 缓存算法_\n" - }, - { - "date": 1715567274313, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -48,9 +48,9 @@\n - [ ] _环形链表_\n - [ ] _LRU 缓存算法_\n - ... ...\n \n-- **[栈](../2.DataStructures_Algorithms/GolangDS/Stack/index.zh-cn.md)**:一种遵循后进先出(LIFO)原则的数据结构,只允许在表的一端进行插入和删除操作。\n+- **栈**:一种遵循后进先出(LIFO)原则的数据结构,只允许在表的一端进行插入和删除操作。\n - [ ]\n - **[队列]**:一种遵循先进先出(FIFO)原则的数据结构,允许在表的一端进行插入,在另一端进行删除操作。\n - [ ]\n - **[树]**:一种非线性数据结构,由节点组成,节点之间存在层次关系。\n" - }, - { - "date": 1715567284244, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -109,9 +109,9 @@\n ## 体系结构\n \n ## 操作系统\n \n-[操作系统的具体学习目录]({{< relref \"\">}})\n+[操作系统的具体学习目录]({{< ref\"\">}})\n \n ## 计算机网络\n \n ## CS 后续学习路径\n" - }, - { - "date": 1715567292528, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -109,9 +109,9 @@\n ## 体系结构\n \n ## 操作系统\n \n-[操作系统的具体学习目录]({{< ref\"\">}})\n+[操作系统的具体学习目录]({{< ref\"/content/post/Gohh/\">}})\n \n ## 计算机网络\n \n ## CS 后续学习路径\n" - }, - { - "date": 1715567339668, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -109,9 +109,9 @@\n ## 体系结构\n \n ## 操作系统\n \n-[操作系统的具体学习目录]({{< ref\"/content/post/Gohh/\">}})\n+[操作系统的具体学习目录]({{< ref\"/content/post/Gohh/4.OS/S6.081/\">}})\n \n ## 计算机网络\n \n ## CS 后续学习路径\n" - }, - { - "date": 1715567348286, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -109,9 +109,9 @@\n ## 体系结构\n \n ## 操作系统\n \n-[操作系统的具体学习目录]({{< ref\"/content/post/Gohh/4.OS/S6.081/\">}})\n+[操作系统的具体学习目录]({{< ref\"/content/post/Gohh/5.OS/S6.081/_index.zh-cn.md\">}})\n \n ## 计算机网络\n \n ## CS 后续学习路径\n" - }, - { - "date": 1715567357369, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -109,9 +109,9 @@\n ## 体系结构\n \n ## 操作系统\n \n-[操作系统的具体学习目录]({{< ref\"/content/post/Gohh/5.OS/S6.081/_index.zh-cn.md\">}})\n+[操作系统的具体学习目录]({{< ref \"post/Gohh/4.OS/S6.081/_index.zh-cn.md\">}})\n \n ## 计算机网络\n \n ## CS 后续学习路径\n" - }, - { - "date": 1715567366333, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -109,9 +109,9 @@\n ## 体系结构\n \n ## 操作系统\n \n-[操作系统的具体学习目录]({{< ref \"post/Gohh/4.OS/S6.081/_index.zh-cn.md\">}})\n+[操作系统的具体学习目录]({{< ref \"post/Gohh/4.OS/S6.081/_index.zh-cn.md\" >}})\n \n ## 计算机网络\n \n ## CS 后续学习路径\n" - }, - { - "date": 1715567382126, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -109,9 +109,9 @@\n ## 体系结构\n \n ## 操作系统\n \n-[操作系统的具体学习目录]({{< ref \"post/Gohh/4.OS/S6.081/_index.zh-cn.md\" >}})\n+[操作系统的具体学习目录]({{< ref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md\">}})\n \n ## 计算机网络\n \n ## CS 后续学习路径\n" - }, - { - "date": 1715567435616, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -109,9 +109,9 @@\n ## 体系结构\n \n ## 操作系统\n \n-[操作系统的具体学习目录]({{< ref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md\">}})\n+[操作系统的具体学习目录]({{< ref \"post/Gohh/_index.zh-cn.md\">}})\n \n ## 计算机网络\n \n ## CS 后续学习路径\n" - }, - { - "date": 1715567441336, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -109,9 +109,9 @@\n ## 体系结构\n \n ## 操作系统\n \n-[操作系统的具体学习目录]({{< ref \"post/Gohh/_index.zh-cn.md\">}})\n+[操作系统的具体学习目录]({{< ref \"post/Gohh/\">}})\n \n ## 计算机网络\n \n ## CS 后续学习路径\n" - }, - { - "date": 1715567448679, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -109,9 +109,9 @@\n ## 体系结构\n \n ## 操作系统\n \n-[操作系统的具体学习目录]({{< ref \"post/Gohh/\">}})\n+[操作系统的具体学习目录]({{< ref \"post/Gohh/4.OS \">}})\n \n ## 计算机网络\n \n ## CS 后续学习路径\n" - }, - { - "date": 1715567462923, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -109,9 +109,9 @@\n ## 体系结构\n \n ## 操作系统\n \n-[操作系统的具体学习目录]({{< ref \"post/Gohh/4.OS \">}})\n+[操作系统的具体学习目录]({{< ref \"post/Gohh/4.OS/\">}})\n \n ## 计算机网络\n \n ## CS 后续学习路径\n" - }, - { - "date": 1715567469472, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -109,9 +109,9 @@\n ## 体系结构\n \n ## 操作系统\n \n-[操作系统的具体学习目录]({{< ref \"post/Gohh/4.OS/\">}})\n+[操作系统的具体学习目录]({{< ref \"post/Gohh/4.OS/S6.081\">}})\n \n ## 计算机网络\n \n ## CS 后续学习路径\n" - }, - { - "date": 1715567478310, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -109,9 +109,9 @@\n ## 体系结构\n \n ## 操作系统\n \n-[操作系统的具体学习目录]({{< ref \"post/Gohh/4.OS/S6.081/_index.zh-cn\">}})\n+[操作系统的具体学习目录]({{< ref \"post/Gohh/4.OS/S6.081/_index.zh-cn.\">}})\n \n ## 计算机网络\n \n ## CS 后续学习路径\n" - } - ], - "date": 1712581801347, - "name": "Commit-0", - "content": "---\ntitle: 'CS学习计划'\ndate: 2024-03-10T15:58:41+08:00\ndraft: false\ntaps: ['CS', 'plan']\ncategories: ['learning', 'OS']\nauthor: ['Yeelight']\nshowtoc: true\nweight: -100\nreadingTime: true\nimage: \"photo_2024-04-08_20-31-47.jpg\"\n---\n\n## 计算机语言基础\n\n### C 语言\n\n**项目练习**\n\n### Go 语言\n\n———> [Go 语言学习]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md\" >}})\n\n**项目练习**\n\n### python 语言\n\n**项目练习**\n\n1. [TG_bot]({{< relref \"\" >}})\n\n## 数据结构\n\n数据结构是对计算机高级语言最能体现打基础的学习,目前有许多常见的数据结构,我喜欢分类来处理。\n\n### 基础结构\n\n- **[数组]({{< relref \"\" >}})**:是一种线性表数据结构,用于存储相同类型的数据元素。\n\n - [x] _二分搜索_\n - [x] _冒泡排序_\n - [ ] _动态规划_\n - ... ...\n\n- **[链表]({{< relref \"\" >}})**:由一系列节点组成的数据结构,每个节点包含数据和指向下一个节点的指针。\n\n - [ ] _反转链表_\n - [ ] _环形链表_\n - [ ] _LRU 缓存算法_\n - ... ...\n\n- **栈**:一种遵循后进先出(LIFO)原则的数据结构,只允许在表的一端进行插入和删除操作。\n - [ ]\n- **队列**:一种遵循先进先出(FIFO)原则的数据结构,允许在表的一端进行插入,在另一端进行删除操作。\n - [ ]\n- **树**:一种非线性数据结构,由节点组成,节点之间存在层次关系。\n - [ ]\n- **图**:由节点(或顶点)和边组成的数据结构,用于表示多对多的关系。\n - [ ]\n\n### 其他结构\n\n- **并查集**:一种用于处理不相交集合的数据结构,常用于解决连接性问题。\n- **字典树**:一种用于快速检索的树形数据结构,常用于字符串检索。\n- **散列表**:利用哈希函数将关键字映射到表中一个位置来访问记录的数据结构。\n- **树状数组**:一种高效的数据结构,用于维护序列前缀和的动态查询。\n- **映射**:一种将键映射到值的抽象数据类型,常用于快速查找。\n- **集合**:一种抽象数据类型,用于存储互不相同的元素的集合。\n\n### 真实世界\n\n在实际项目中,数据结构和算法的选择取决于具体的应用场景和问题需求。一般来说,对于不涉及高精尖、复杂算法的项目,可以尽量选择简单的数据结构。以下是一些建议和实践:\n\n1. **根据场景选择数据结构**:静态数组适合元素不超过 100 的场合,动态数组适合元素不超过 1000 的场合,链表适合元素不超过 3000 的场合。在需要动态分配内存的场合,可以考虑使用静态内存,以提高程序稳定性。\n\n2. **实际项目中的应用**:数据结构和算法在实际项目中扮演着重要角色,可以通过实际项目场景来说明一种数据结构解决了什么实际问题,以及其各种操作时间复杂度、优缺点等。这有助于理解数据结构在编程中的重要性。\n\n3. **权衡选择**:在实际开发中,需要权衡选择使用哪种数据结构和算法。除了考虑算法的时间复杂度、空间复杂度,还需要考虑其在具体场景下的执行效率、易用性、维护成本等因素\n\n综上所述,实际项目中的数据结构和算法选择应该根据具体的应用场景和问题需求进行权衡和取舍,以达到最优的解决方案。\n\n## 算法(AI)\n\n算法是解决问题的一系列清晰指令,是计算机科学的基础。在实际开发中,选择合适的数据结构和算法对程序的性能和效率至关重要。在学习算法时,需要权衡选择使用哪种数据结构和算法,不能简单地用复杂度来表示执行性能。此外,编程算法面试经验总结中提到,算法面试常涉及的主题、考察形式和评价方式,对求职备考的朋友们有所帮助。另外,算法也在机器学习领域有着广泛的应用,比如预测住房价格、探索客户的人口统计学数据以确定模式等。在实际开发中,对于数组的算法,可以通过合并两个有序数组来进行实现。对于统计相同数字出现的次数,可以利用数组元素下标对应数字,用数组元素的值表示对应数字出现的次数,这是一种典型的空间换时间的算法。如果整数的范围是 1 到 n,可以考虑使用其他的算法来实现。\n\n### 关键要点\n\n1. **目的和问题解决:** 算法的设计旨在解决特定问题或执行特定任务。它们用于执行各种计算和操作,从简单的搜索和排序到复杂的图算法和机器学习。\n2. **输入和输出:** 算法接受一个或多个输入,通过执行一系列计算操作,产生一个输出。输入可以是数据、问题描述或其他形式的信息。\n3. **有限性:** 算法是有限步骤的集合,每一步都可以在有限的时间内完成。这确保了算法的执行是可以终止的。\n4. **确定性:** 算法的每一步都是确定性的,即对于给定的输入,它总是产生相同的输出。这使得算法在不同的环境中具有可重复性。\n5. **效率:** 算法的效率是一个关键方面,通常通过时间复杂度和空间复杂度来衡量。好的算法能够以较低的时间和空间开销解决问题。\n6. **可读性和可维护性:** 除了效率,算法的可读性和可维护性也是重要的。一个清晰、简单、易于理解的算法更容易被其他人理解和维护。\n\n### 算法的分类\n\n- **搜索算法:** 用于在数据集中查找特定元素的算法,如线性搜索和二分搜索。\n- **排序算法:** 对一组元素进行排列的算法,例如冒泡排序、快速排序、归并排序等。\n- **图算法:** 处理图数据结构的算法,包括深度优先搜索、广度优先搜索、最短路径算法等。\n- **动态规划:** 将复杂问题分解为简单子问题,并通过保存已解决的子问题的解来加速求解的算法。\n- **贪心算法:** 在每一步选择中都采取当前状态下最好或最优的选择,从而希望得到全局最好或最优解的算法。\n- **回溯算法:** 通过不断试错找到问题的解,是一种递归的算法。\n- **分治算法:** 将问题分解成相互独立且与原问题相同的子问题,然后递归地解决子问题。\n- **随机化算法:** 使用随机数来解决问题的算法,例如快速排序的随机化版本。\n- **机器学习算法:** 用于构建模型、分类和预测的一系列算法,如决策树、支持向量机、神经网络等。\n\n算法是计算机科学的核心,它们不仅仅是问题求解的工具,也是构建复杂系统和应对实际挑战的基础。深入理解和熟练运用各种算法,有助于提高问题解决和计算机科学建模的能力。\n\n## 体系结构\n\n## 操作系统\n\n[操作系统的具体学习目录]({{< relref \"\">}})\n\n## 计算机网络\n\n## CS 后续学习路径\n\n为自身打造的路径\n\\_\n目标:人工智能**Artificial intelligence**\n数学\n[Search --- Graph theory]({{< relref \"\" >}})\n\n[Knowledge --- Boolean logic]({{< relref \"\" >}})\n\n[Uncertainty --- Probability]({{< relref \"\" >}})\n\n目标:应用程序开发**Application Developer**\n\n[Full Stack]({{< relref \"\" >}})\n\n目标:计算机图形学**Computer graphics**\n\n目标:软件工程**Software engineering**\n\n## LeetCode\n\n每日任务\n[合并两个有序数组]({{< relref \"\" >}})\n\n[移除元素]({{< relref \"\" >}})\n\n[删除有序数组中的重复项]({{< relref \"\" >}})\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md.json deleted file mode 100644 index a4ad4ea..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 2, - "patches": [ - { - "date": 1715561026096, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1715566246685, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -6,36 +6,6 @@\n categories: [\"Golang\", \"CS\", \"Languages\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight: -100\n+readingTime: true\n ---\n-## “起”\n-> Let's get going Golang!\n-\n-[[Golang学习之路]]\n-[[Golang资源集合]]\n-[[Golang --- 关键字与标识符]]\n-[[Golang --- 常量与变量]]\n-[[Golang --- 数据类型]]\n-[[Golang --- 数据类型基础]]\n-[[Golang --- 运算操作符]]\n-[[Golang --- 字符串]]\n-[[Golang --- 包和文件]]\n-\n-\n-## “承”\n-[[Golang问题集]]\n-[[Golang面试集]]\n-\n-\n-## “转”\n-### 底层实现\n-[[GMP 模型]]\n-[[GC 垃圾回收]]\n-[[Go并发编程]]\n-[[make 一个 map 会发生什么]]\n-\n-### 源码解读\n-[[Go - os package]]\n-## “合”\n-\n-[[GoReader]]\n" - }, - { - "date": 1715566258698, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -6,6 +6,5 @@\n categories: [\"Golang\", \"CS\", \"Languages\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight: -100\n-readingTime: true\n ---\n" - } - ], - "date": 1715561026096, - "name": "Commit-0", - "content": "---\ntitle: \"Golang 语言学习\"\ndate: 2024-03-10T16:02:27+08:00\ndraft: false\ntaps: [\"Golang\"]\ncategories: [\"Golang\", \"CS\", \"Languages\"]\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight: -100\n---\n## “起”\n> Let's get going Golang!\n\n[[Golang学习之路]]\n[[Golang资源集合]]\n[[Golang --- 关键字与标识符]]\n[[Golang --- 常量与变量]]\n[[Golang --- 数据类型]]\n[[Golang --- 数据类型基础]]\n[[Golang --- 运算操作符]]\n[[Golang --- 字符串]]\n[[Golang --- 包和文件]]\n\n\n## “承”\n[[Golang问题集]]\n[[Golang面试集]]\n\n\n## “转”\n### 底层实现\n[[GMP 模型]]\n[[GC 垃圾回收]]\n[[Go并发编程]]\n[[make 一个 map 会发生什么]]\n\n### 源码解读\n[[Go - os package]]\n## “合”\n\n[[GoReader]]\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/conclusion/_index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/conclusion/_index.zh-cn.md.json deleted file mode 100644 index 84e74ca..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/conclusion/_index.zh-cn.md.json +++ /dev/null @@ -1,30 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/conclusion/_index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 3, - "patches": [ - { - "date": 1715567111712, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1715567138939, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: \"承\"\n+title: \"合\"\n date: 2024-03-14T21:53:46+08:00\n draft: false\n taps: []\n categories: []\n" - }, - { - "date": 1715567149888, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,7 @@\n ---\n title: \"合\"\n+\n date: 2024-03-14T21:53:46+08:00\n draft: false\n taps: []\n categories: []\n" - }, - { - "date": 1715567158420, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,7 +1,6 @@\n ---\n title: \"合\"\n-\n date: 2024-03-14T21:53:46+08:00\n draft: false\n taps: []\n categories: []\n@@ -9,6 +8,5 @@\n showtoc: true\n weight: -70\n math: false\n readingTime: true\n-\n ---\n" - } - ], - "date": 1715567111712, - "name": "Commit-0", - "content": "---\ntitle: \"承\"\ndate: 2024-03-14T21:53:46+08:00\ndraft: false\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight: -70\nmath: false\nreadingTime: true\n\n---\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/InterviewQuestions/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/InterviewQuestions/index.zh-cn.md.json deleted file mode 100644 index b4a38a7..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/InterviewQuestions/index.zh-cn.md.json +++ /dev/null @@ -1,62 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/InterviewQuestions/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 11, - "patches": [ - { - "date": 1715565613725, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1715565622137, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -13,31 +13,30 @@\n \n ## 成功软件 4.24\n \n - 主要是以项目问问题---后端项目小银行\n-\t- 问具体数据表\n-\t\t有三个表,数据库的范式\n-\t\t怎么使用的(我这里忘记有一个表是做什么了 : ( )\n-\t- ORM: 第三方的库的 sqlc\n-\t- 项目中具体的 API 的实现\n-\t\tGo 中的 Gin\n-\t\tRESTful\n-\t- 配置管理(这个是项目的配置,不是面对用户的)\n+- 问具体数据表\n+ 有三个表,数据库的范式\n+ 怎么使用的(我这里忘记有一个表是做什么了 : ( )\n+- ORM: 第三方的库的 sqlc\n+- 项目中具体的 API 的实现\n+ Go 中的 Gin\n+ RESTful\n+- 配置管理(这个是项目的配置,不是面对用户的)\n - 吃豆人的项目\n-\t- Go 协程的使用(我没说清楚)\n+- Go 协程的使用(我没说清楚)\n - Docker 的使用\n-\t- 怎么理解容器-容器为什么叫容器\n-\t- 映像和容器的区别\n-\t- Docker 是什么\n-\t- Docker File(我不会就没问)\n-\t- docker run 的使用\n+- 怎么理解容器-容器为什么叫容器\n+- 映像和容器的区别\n+- Docker 是什么\n+- Docker File(我不会就没问)\n+- docker run 的使用\n - Github Action\n - Makefile 用来做什么\n - Go 中的 context 的使用(我没具体的看过)\n - Go 的标准库有哪些使用和了解\n - 一些操作系统的问题\n-\t- 文件系统-log\n-\t- lock-原子操作\n+- 文件系统-log\n+- lock-原子操作\n - Linux 常用命令\n - git 常用命令\n-\t- 有一串每个提交它那有一串那个数字英文的组合 - SHA-1哈希算法-哈希值\n-\n+- 有一串每个提交它那有一串那个数字英文的组合 - SHA-1哈希算法-哈希值\n" - }, - { - "date": 1715565629266, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,8 +1,8 @@\n ---\n title: \"InterviewQuestions\"\n date: 2024-05-13T09:13:20+08:00\n-draft: true\n+draft: fa\n taps: []\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n" - }, - { - "date": 1715565644499, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n-title: \"InterviewQuestions\"\n+title: \"Golang面试集\"\n date: 2024-05-13T09:13:20+08:00\n-draft: fa\n-taps: []\n+draft: false\n+taps: [\"\"]\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - }, - { - "date": 1715565650400, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"Golang面试集\"\n date: 2024-05-13T09:13:20+08:00\n draft: false\n-taps: [\"\"]\n+taps: [\"]\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - }, - { - "date": 1715565657785, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"Golang面试集\"\n date: 2024-05-13T09:13:20+08:00\n draft: false\n-taps: [\"]\n+taps: [\"Golang\", \"I]\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - }, - { - "date": 1715565665844, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n title: \"Golang面试集\"\n date: 2024-05-13T09:13:20+08:00\n draft: false\n-taps: [\"Golang\", \"I]\n-categories: []\n+taps: [\"Golang\", \"Interview\"]\n+categories: [\"Golang\", \"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1715565672608, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -2,9 +2,9 @@\n title: \"Golang面试集\"\n date: 2024-05-13T09:13:20+08:00\n draft: false\n taps: [\"Golang\", \"Interview\"]\n-categories: [\"Golang\", \"]\n+categories: [\"Golang\", \"de\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1715565680921, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -2,9 +2,9 @@\n title: \"Golang面试集\"\n date: 2024-05-13T09:13:20+08:00\n draft: false\n taps: [\"Golang\", \"Interview\"]\n-categories: [\"Golang\", \"de\"]\n+categories: [\"Golang\", \"development\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n@@ -15,9 +15,9 @@\n \n - 主要是以项目问问题---后端项目小银行\n - 问具体数据表\n 有三个表,数据库的范式\n- 怎么使用的(我这里忘记有一个表是做什么了 : ( )\n+ 怎么使用的(我这里忘记有一个表是做什么了 :)\n - ORM: 第三方的库的 sqlc\n - 项目中具体的 API 的实现\n Go 中的 Gin\n RESTful\n" - }, - { - "date": 1715565686451, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -15,9 +15,9 @@\n \n - 主要是以项目问问题---后端项目小银行\n - 问具体数据表\n 有三个表,数据库的范式\n- 怎么使用的(我这里忘记有一个表是做什么了 :)\n+ 怎么使用的(我这里忘记有一个表是做什么了 :()\n - ORM: 第三方的库的 sqlc\n - 项目中具体的 API 的实现\n Go 中的 Gin\n RESTful\n" - }, - { - "date": 1715565997823, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -15,9 +15,9 @@\n \n - 主要是以项目问问题---后端项目小银行\n - 问具体数据表\n 有三个表,数据库的范式\n- 怎么使用的(我这里忘记有一个表是做什么了 :()\n+ 怎么使用的(我这里忘记有一个表是做什么了 :( )\n - ORM: 第三方的库的 sqlc\n - 项目中具体的 API 的实现\n Go 中的 Gin\n RESTful\n" - }, - { - "date": 1715566102947, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: \"Golang面试集\"\n+title: \"面试集\"\n date: 2024-05-13T09:13:20+08:00\n draft: false\n taps: [\"Golang\", \"Interview\"]\n categories: [\"Golang\", \"development\"]\n" - } - ], - "date": 1715565613725, - "name": "Commit-0", - "content": "---\ntitle: \"InterviewQuestions\"\ndate: 2024-05-13T09:13:20+08:00\ndraft: true\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n\n## 成功软件 4.24\n\n- 主要是以项目问问题---后端项目小银行\n\t- 问具体数据表\n\t\t有三个表,数据库的范式\n\t\t怎么使用的(我这里忘记有一个表是做什么了 : ( )\n\t- ORM: 第三方的库的 sqlc\n\t- 项目中具体的 API 的实现\n\t\tGo 中的 Gin\n\t\tRESTful\n\t- 配置管理(这个是项目的配置,不是面对用户的)\n- 吃豆人的项目\n\t- Go 协程的使用(我没说清楚)\n- Docker 的使用\n\t- 怎么理解容器-容器为什么叫容器\n\t- 映像和容器的区别\n\t- Docker 是什么\n\t- Docker File(我不会就没问)\n\t- docker run 的使用\n- Github Action\n- Makefile 用来做什么\n- Go 中的 context 的使用(我没具体的看过)\n- Go 的标准库有哪些使用和了解\n- 一些操作系统的问题\n\t- 文件系统-log\n\t- lock-原子操作\n- Linux 常用命令\n- git 常用命令\n\t- 有一串每个提交它那有一串那个数字英文的组合 - SHA-1哈希算法-哈希值\n\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/Problem/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/Problem/index.zh-cn.md.json deleted file mode 100644 index d2b0f5d..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/Problem/index.zh-cn.md.json +++ /dev/null @@ -1,42 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/Problem/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 6, - "patches": [ - { - "date": 1715566004530, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1715566014372, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -9,4 +9,35 @@\n weight:\n math: false\n readingTime: true\n ---\n+\n+## Introduction\n+\n+## 一般问题\n+\n+1. Go 语言的显式范围和垃圾回收和变量逃逸\n+\t1. 在一个包范围内声明的变量,如果在函数内部声明了同名变量,那么这两个变量是不同的实体,作用域不同,垃圾回收器会分别管理它们。\n+\t2. 发生逃逸的情况包括:变量生命周期不确定、变量占用内存较大、变量不确定类型、变量不确定大小。\n+2. 使用更好的注释\n+3. Go 的命名规则\n+4. 对于类型中的底层类型\n+5. 内置类型中 string 是否和 c 中的一样有 `\\0`\n+\t没有 C 语言定义字符用的结尾 `\\0`,而且获取长度的时间复杂度是常数时间,消除了获取字符串长度的开销\n+6. `type boolean = bool` 和 `type boolean bool` 区别\n+\t定义声明和别名声明\n+7. 常量和变量之间的转化\n+\t1. 常量可以赋值给变量,但变量不能赋值给常量,因为常量的值在编译时就必须是确定的。\n+\t2. 常量可以转换为不同类型的变量,只要这个转换是安全的,即不会丢失信息或导致溢出。\n+\t3. 变量之间也可以进行类型转换,但必须满足类型转换的规则\n+8. 定义时传递方法不同\n+\t数组是值类型,拥有固定的长度,重点是它是值传递的,所以说他是值类型。切片的话则是传递地址或者说指针,所以说它是引用类型,而且他的长度是可以变化的可以扩容的。\n+9.\n+\n+## 主要问题\n+\n+1. Go Modules 的使用有感\n+2. Go Package 的使用\n+3. [[Goroutine 并行的开始]]\n+4. [[Go 中的 Interfaces type]]\n+5.\n+\n" - }, - { - "date": 1715566021421, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -15,23 +15,23 @@\n \n ## 一般问题\n \n 1. Go 语言的显式范围和垃圾回收和变量逃逸\n-\t1. 在一个包范围内声明的变量,如果在函数内部声明了同名变量,那么这两个变量是不同的实体,作用域不同,垃圾回收器会分别管理它们。\n-\t2. 发生逃逸的情况包括:变量生命周期不确定、变量占用内存较大、变量不确定类型、变量不确定大小。\n+1. 在一个包范围内声明的变量,如果在函数内部声明了同名变量,那么这两个变量是不同的实体,作用域不同,垃圾回收器会分别管理它们。\n+2. 发生逃逸的情况包括:变量生命周期不确定、变量占用内存较大、变量不确定类型、变量不确定大小。\n 2. 使用更好的注释\n 3. Go 的命名规则\n 4. 对于类型中的底层类型\n 5. 内置类型中 string 是否和 c 中的一样有 `\\0`\n-\t没有 C 语言定义字符用的结尾 `\\0`,而且获取长度的时间复杂度是常数时间,消除了获取字符串长度的开销\n+ 没有 C 语言定义字符用的结尾 `\\0`,而且获取长度的时间复杂度是常数时间,消除了获取字符串长度的开销\n 6. `type boolean = bool` 和 `type boolean bool` 区别\n-\t定义声明和别名声明\n+ 定义声明和别名声明\n 7. 常量和变量之间的转化\n-\t1. 常量可以赋值给变量,但变量不能赋值给常量,因为常量的值在编译时就必须是确定的。\n-\t2. 常量可以转换为不同类型的变量,只要这个转换是安全的,即不会丢失信息或导致溢出。\n-\t3. 变量之间也可以进行类型转换,但必须满足类型转换的规则\n+1. 常量可以赋值给变量,但变量不能赋值给常量,因为常量的值在编译时就必须是确定的。\n+2. 常量可以转换为不同类型的变量,只要这个转换是安全的,即不会丢失信息或导致溢出。\n+3. 变量之间也可以进行类型转换,但必须满足类型转换的规则\n 8. 定义时传递方法不同\n-\t数组是值类型,拥有固定的长度,重点是它是值传递的,所以说他是值类型。切片的话则是传递地址或者说指针,所以说它是引用类型,而且他的长度是可以变化的可以扩容的。\n+ 数组是值类型,拥有固定的长度,重点是它是值传递的,所以说他是值类型。切片的话则是传递地址或者说指针,所以说它是引用类型,而且他的长度是可以变化的可以扩容的。\n 9.\n \n ## 主要问题\n \n@@ -39,5 +39,4 @@\n 2. Go Package 的使用\n 3. [[Goroutine 并行的开始]]\n 4. [[Go 中的 Interfaces type]]\n 5.\n-\n" - }, - { - "date": 1715566028094, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -15,23 +15,23 @@\n \n ## 一般问题\n \n 1. Go 语言的显式范围和垃圾回收和变量逃逸\n-1. 在一个包范围内声明的变量,如果在函数内部声明了同名变量,那么这两个变量是不同的实体,作用域不同,垃圾回收器会分别管理它们。\n-2. 发生逃逸的情况包括:变量生命周期不确定、变量占用内存较大、变量不确定类型、变量不确定大小。\n+\t1. 在一个包范围内声明的变量,如果在函数内部声明了同名变量,那么这两个变量是不同的实体,作用域不同,垃圾回收器会分别管理它们。\n+\t2. 发生逃逸的情况包括:变量生命周期不确定、变量占用内存较大、变量不确定类型、变量不确定大小。\n 2. 使用更好的注释\n 3. Go 的命名规则\n 4. 对于类型中的底层类型\n 5. 内置类型中 string 是否和 c 中的一样有 `\\0`\n- 没有 C 语言定义字符用的结尾 `\\0`,而且获取长度的时间复杂度是常数时间,消除了获取字符串长度的开销\n+\t没有 C 语言定义字符用的结尾 `\\0`,而且获取长度的时间复杂度是常数时间,消除了获取字符串长度的开销\n 6. `type boolean = bool` 和 `type boolean bool` 区别\n- 定义声明和别名声明\n+\t定义声明和别名声明\n 7. 常量和变量之间的转化\n-1. 常量可以赋值给变量,但变量不能赋值给常量,因为常量的值在编译时就必须是确定的。\n-2. 常量可以转换为不同类型的变量,只要这个转换是安全的,即不会丢失信息或导致溢出。\n-3. 变量之间也可以进行类型转换,但必须满足类型转换的规则\n+\t1. 常量可以赋值给变量,但变量不能赋值给常量,因为常量的值在编译时就必须是确定的。\n+\t2. 常量可以转换为不同类型的变量,只要这个转换是安全的,即不会丢失信息或导致溢出。\n+\t3. 变量之间也可以进行类型转换,但必须满足类型转换的规则\n 8. 定义时传递方法不同\n- 数组是值类型,拥有固定的长度,重点是它是值传递的,所以说他是值类型。切片的话则是传递地址或者说指针,所以说它是引用类型,而且他的长度是可以变化的可以扩容的。\n+\t数组是值类型,拥有固定的长度,重点是它是值传递的,所以说他是值类型。切片的话则是传递地址或者说指针,所以说它是引用类型,而且他的长度是可以变化的可以扩容的。\n 9.\n \n ## 主要问题\n \n" - }, - { - "date": 1715566034735, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,8 +1,8 @@\n ---\n title: \"Problem\"\n date: 2024-05-13T09:13:33+08:00\n-draft: true\n+draft: false\n taps: []\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n" - }, - { - "date": 1715566042114, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"Problem\"\n date: 2024-05-13T09:13:33+08:00\n draft: false\n-taps: []\n+taps: [\"Golang\"]\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - }, - { - "date": 1715566049798, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"Problem\"\n date: 2024-05-13T09:13:33+08:00\n draft: false\n-taps: [\"Golang\", \"]\n+taps: [\"Golang\", \"\"]\n categories: [\"Golang\", \"development\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - } - ], - "date": 1715566004530, - "name": "Commit-0", - "content": "---\ntitle: \"Problem\"\ndate: 2024-05-13T09:13:33+08:00\ndraft: true\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/_index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/_index.zh-cn.md.json deleted file mode 100644 index ac600ac..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/_index.zh-cn.md.json +++ /dev/null @@ -1,30 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/_index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 3, - "patches": [ - { - "date": 1715566188051, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1715566194175, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: \"\"\n+title: \"development\"\n date: 2024-03-14T21:53:46+08:00\n draft: false\n taps: []\n categories: []\n" - }, - { - "date": 1715567064092, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: \"development\"\n+title: \"承\"\n date: 2024-03-14T21:53:46+08:00\n draft: false\n taps: []\n categories: []\n" - }, - { - "date": 1715567071779, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -5,9 +5,9 @@\n taps: []\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n-weight:\n+weight: -90\n math: false\n readingTime: true\n \n ---\n" - } - ], - "date": 1715566188051, - "name": "Commit-0", - "content": "---\ntitle: \"\"\ndate: 2024-03-14T21:53:46+08:00\ndraft: false\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n\n---\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/index.zh-cn.md.json deleted file mode 100644 index 7ff65d4..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/index.zh-cn.md.json +++ /dev/null @@ -1,394 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 94, - "patches": [ - { - "date": 1715561164274, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1715561169388, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -5,9 +5,10 @@\n taps: [\"Golang\"]\n categories: [\"Golang\", \"CS\", \"Languages\"]\n author: [\"Yeelight\"]\n showtoc: true\n-weight: -100readingTime: true\n+weight: -100\n+readingTime: true\n ---\n ## “起”\n > Let's get going Golang!\n \n" - }, - { - "date": 1715562993594, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -11,9 +11,9 @@\n ---\n ## “起”\n > Let's get going Golang!\n \n-[[Golang学习之路]]\n+[[Golang学习之路]\n [[Golang资源集合]]\n [[Golang --- 关键字与标识符]]\n [[Golang --- 常量与变量]]\n [[Golang --- 数据类型]]\n" - }, - { - "date": 1715563049190, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -11,9 +11,9 @@\n ---\n ## “起”\n > Let's get going Golang!\n \n-[[Golang学习之路]\n+[Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md\" >}})\n [[Golang资源集合]]\n [[Golang --- 关键字与标识符]]\n [[Golang --- 常量与变量]]\n [[Golang --- 数据类型]]\n" - }, - { - "date": 1715563058090, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -11,9 +11,9 @@\n ---\n ## “起”\n > Let's get going Golang!\n \n-[Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md\" >}})\n+[Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/\" >}})\n [[Golang资源集合]]\n [[Golang --- 关键字与标识符]]\n [[Golang --- 常量与变量]]\n [[Golang --- 数据类型]]\n" - }, - { - "date": 1715563075317, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -11,9 +11,9 @@\n ---\n ## “起”\n > Let's get going Golang!\n \n-[Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/\" >}})\n+[Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/\"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md >}})\n [[Golang资源集合]]\n [[Golang --- 关键字与标识符]]\n [[Golang --- 常量与变量]]\n [[Golang --- 数据类型]]\n" - }, - { - "date": 1715563081776, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -11,9 +11,9 @@\n ---\n ## “起”\n > Let's get going Golang!\n \n-[Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/\"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md >}})\n+[Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n [[Golang资源集合]]\n [[Golang --- 关键字与标识符]]\n [[Golang --- 常量与变量]]\n [[Golang --- 数据类型]]\n" - }, - { - "date": 1715563094852, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -11,9 +11,9 @@\n ---\n ## “起”\n > Let's get going Golang!\n \n-[Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/content/post/Gohh/1.ComputerBasics/CSLanguages/Golc/start/LearningPath/index.zh-cn.md\" >}})\n [[Golang资源集合]]\n [[Golang --- 关键字与标识符]]\n [[Golang --- 常量与变量]]\n [[Golang --- 数据类型]]\n" - }, - { - "date": 1715563136840, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -11,9 +11,9 @@\n ---\n ## “起”\n > Let's get going Golang!\n \n-[Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/content/post/Gohh/1.ComputerBasics/CSLanguages/Golc/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n [[Golang资源集合]]\n [[Golang --- 关键字与标识符]]\n [[Golang --- 常量与变量]]\n [[Golang --- 数据类型]]\n" - }, - { - "date": 1715563614531, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -11,9 +11,9 @@\n ---\n ## “起”\n > Let's get going Golang!\n \n-[Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< relref >}})\n [[Golang资源集合]]\n [[Golang --- 关键字与标识符]]\n [[Golang --- 常量与变量]]\n [[Golang --- 数据类型]]\n" - }, - { - "date": 1715563621679, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -11,9 +11,9 @@\n ---\n ## “起”\n > Let's get going Golang!\n \n-[Golang学习之路]({{< relref >}})\n+[Golang学习之路]({{< relref >}})\n [[Golang资源集合]]\n [[Golang --- 关键字与标识符]]\n [[Golang --- 常量与变量]]\n [[Golang --- 数据类型]]\n" - }, - { - "date": 1715563634445, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -11,17 +11,17 @@\n ---\n ## “起”\n > Let's get going Golang!\n \n-[Golang学习之路]({{< relref >}})\n-[[Golang资源集合]]\n-[[Golang --- 关键字与标识符]]\n-[[Golang --- 常量与变量]]\n-[[Golang --- 数据类型]]\n-[[Golang --- 数据类型基础]]\n-[[Golang --- 运算操作符]]\n-[[Golang --- 字符串]]\n-[[Golang --- 包和文件]]\n+[Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[[Golang资源集合]]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[[Golang --- 关键字与标识符]]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[[Golang --- 常量与变量]]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[[Golang --- 数据类型]]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[[Golang --- 数据类型基础]]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[[Golang --- 运算操作符]]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[[Golang --- 字符串]]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[[Golang --- 包和文件]]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n \n \n ## “承”\n [[Golang问题集]]\n" - }, - { - "date": 1715563645146, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -12,16 +12,16 @@\n ## “起”\n > Let's get going Golang!\n \n [Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[[Golang资源集合]]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[[Golang --- 关键字与标识符]]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[[Golang --- 常量与变量]]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[[Golang --- 数据类型]]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[[Golang --- 数据类型基础]]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[[Golang --- 运算操作符]]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[[Golang --- 字符串]]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[[Golang --- 包和文件]]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[Golang --- 关键字与标识符]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[Golang --- 常量与变量]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[Golang --- 数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[Golang --- 数据类型基础]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[Golang --- 运算操作符]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[Golang --- 字符串]]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[Golang --- 包和文件]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n \n \n ## “承”\n [[Golang问题集]]\n" - }, - { - "date": 1715563656013, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -13,14 +13,14 @@\n > Let's get going Golang!\n \n [Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[Golang --- 关键字与标识符]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[关键字与标识符]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [Golang --- 常量与变量]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [Golang --- 数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [Golang --- 数据类型基础]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [Golang --- 运算操作符]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[Golang --- 字符串]]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[Golang --- 字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [Golang --- 包和文件]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n \n \n ## “承”\n" - }, - { - "date": 1715563661369, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -14,12 +14,12 @@\n \n [Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [关键字与标识符]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[Golang --- 常量与变量]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[Golang --- 数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[Golang --- 数据类型基础]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[Golang --- 运算操作符]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[常量与变量]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[数据类型基础]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[运算操作符]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [Golang --- 字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [Golang --- 包和文件]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n \n \n" - }, - { - "date": 1715563686138, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -12,16 +12,16 @@\n ## “起”\n > Let's get going Golang!\n \n [Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start//index.zh-cn.md\">}})\n [关键字与标识符]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [常量与变量]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [数据类型基础]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [运算操作符]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[Golang --- 字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[Golang --- 包和文件]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[包和文件]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n \n \n ## “承”\n [[Golang问题集]]\n" - }, - { - "date": 1715563693099, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -12,9 +12,9 @@\n ## “起”\n > Let's get going Golang!\n \n [Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start//index.zh-cn.md\">}})\n+[Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\">}})\n [关键字与标识符]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [常量与变量]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [数据类型基础]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n" - }, - { - "date": 1715563704242, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -13,9 +13,9 @@\n > Let's get going Golang!\n \n [Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\">}})\n-[关键字与标识符]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+\n [常量与变量]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [数据类型基础]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [运算操作符]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n" - }, - { - "date": 1715563710596, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -14,9 +14,9 @@\n \n [Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\">}})\n \n-[常量与变量]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+\n [数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [数据类型基础]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [运算操作符]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n" - }, - { - "date": 1715563716594, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -15,9 +15,9 @@\n [Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\">}})\n \n \n-[数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start//index.zh-cn.md\">}})\n [数据类型基础]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [运算操作符]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [包和文件]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n" - }, - { - "date": 1715563730864, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -15,9 +15,9 @@\n [Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\">}})\n \n \n-[数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start//index.zh-cn.md\">}})\n+[数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Data/index.zh-cn.md\">}})\n [数据类型基础]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [运算操作符]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [包和文件]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n" - }, - { - "date": 1715563740334, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -15,10 +15,9 @@\n [Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\">}})\n \n \n-[数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Data/index.zh-cn.md\">}})\n-[数据类型基础]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md\">}})\n [运算操作符]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [包和文件]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n \n" - }, - { - "date": 1715563748620, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -16,10 +16,9 @@\n [Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\">}})\n \n \n [数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md\">}})\n-[运算操作符]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md\">}})\n [包和文件]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n \n \n ## “承”\n" - }, - { - "date": 1715563755850, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -17,9 +17,9 @@\n \n \n [数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md\">}})\n [字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md\">}})\n-[包和文件]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[Map]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n \n \n ## “承”\n [[Golang问题集]]\n" - }, - { - "date": 1715563762462, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -17,9 +17,9 @@\n \n \n [数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md\">}})\n [字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md\">}})\n-[Map]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[Map]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md\">}})\n \n \n ## “承”\n [[Golang问题集]]\n" - }, - { - "date": 1715563900922, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -9,8 +9,9 @@\n weight: -100\n readingTime: true\n ---\n ## “起”\n+>\n > Let's get going Golang!\n \n [Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\">}})\n@@ -21,20 +22,25 @@\n [Map]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md\">}})\n \n \n ## “承”\n+\n [[Golang问题集]]\n [[Golang面试集]]\n \n \n ## “转”\n+\n ### 底层实现\n+\n [[GMP 模型]]\n [[GC 垃圾回收]]\n [[Go并发编程]]\n [[make 一个 map 会发生什么]]\n \n ### 源码解读\n+\n [[Go - os package]]\n+\n ## “合”\n \n [[GoReader]]\n" - }, - { - "date": 1715564008983, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -18,17 +18,15 @@\n \n \n [数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md\">}})\n [字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md\">}})\n-[Map]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md\">}})\n+[Map](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md\">}})\n \n-\n ## “承”\n \n [[Golang问题集]]\n [[Golang面试集]]\n \n-\n ## “转”\n \n ### 底层实现\n \n" - }, - { - "date": 1715564015986, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -17,10 +17,10 @@\n [Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\">}})\n \n \n [数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md\">}})\n-[字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md\">}})\n-[Map](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md\">}})\n+[字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md)\n+[Map](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md)\n \n ## “承”\n \n [[Golang问题集]]\n" - }, - { - "date": 1715564021163, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -16,10 +16,10 @@\n [Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n [Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\">}})\n \n \n-[数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md\">}})\n-[字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md)\n+[数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md)\n+[字符串](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md)\n [Map](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md)\n \n ## “承”\n \n" - }, - { - "date": 1715564029724, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -13,12 +13,12 @@\n >\n > Let's get going Golang!\n \n [Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n-[Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\">}})\n+[Golang资源集合](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md)\n \n \n-[数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md)\n+[数据类型](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md)\n [字符串](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md)\n [Map](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md)\n \n ## “承”\n" - }, - { - "date": 1715564035930, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -12,9 +12,9 @@\n ## “起”\n >\n > Let's get going Golang!\n \n-[Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\">}})\n+[Golang学习之路](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md)\n [Golang资源集合](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md)\n \n \n [数据类型](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md)\n" - }, - { - "date": 1715564045668, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -13,9 +13,11 @@\n >\n > Let's get going Golang!\n \n [Golang学习之路](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md)\n+\n [Golang资源集合](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md)\n+\n \n \n [数据类型](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md)\n [字符串](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md)\n" - }, - { - "date": 1715564084603, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -12,9 +12,9 @@\n ## “起”\n >\n > Let's get going Golang!\n \n-[Golang学习之路](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md)\n+[Golang学习之路](start/LearningPath/index.zh-cn.md)\n \n [Golang资源集合](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md)\n \n \n" - }, - { - "date": 1715564090244, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -12,9 +12,9 @@\n ## “起”\n >\n > Let's get going Golang!\n \n-[Golang学习之路](start/LearningPath/index.zh-cn.md)\n+[Golang学习之路](./start/start/LearningPath/index.zh-cn.md)\n \n [Golang资源集合](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md)\n \n \n" - }, - { - "date": 1715564096500, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -12,9 +12,9 @@\n ## “起”\n >\n > Let's get going Golang!\n \n-[Golang学习之路](./start/start/LearningPath/index.zh-cn.md)\n+[Golang学习之路](./start/LearningPath/index.zh-cn.mdstart/LearningPath/index.zh-cn.md)\n \n [Golang资源集合](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md)\n \n \n" - }, - { - "date": 1715564104593, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -12,11 +12,11 @@\n ## “起”\n >\n > Let's get going Golang!\n \n-[Golang学习之路](./start/LearningPath/index.zh-cn.mdstart/LearningPath/index.zh-cn.md)\n+[Golang学习之路](./start/LearningPath/index.zh-cn.md)\n \n-[Golang资源集合](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md)\n+[Golang资源集合](start/Resource/index.zh-cn.md)\n \n \n \n [数据类型](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md)\n" - }, - { - "date": 1715564111780, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -18,11 +18,11 @@\n [Golang资源集合](start/Resource/index.zh-cn.md)\n \n \n \n-[数据类型](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md)\n-[字符串](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md)\n-[Map](post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md)\n+[数据类型](start/DataType/index.zh-cn.md)\n+[字符串](start/Strings/index.zh-cn.md)\n+[Map](start/Map/index.zh-cn.md)\n \n ## “承”\n \n [[Golang问题集]]\n" - }, - { - "date": 1715564126148, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -14,9 +14,9 @@\n > Let's get going Golang!\n \n [Golang学习之路](./start/LearningPath/index.zh-cn.md)\n \n-[Golang资源集合](start/Resource/index.zh-cn.md)\n+[Golang资源集合](./start/Resource/index.zh-cn.md)\n \n \n \n [数据类型](start/DataType/index.zh-cn.md)\n" - }, - { - "date": 1715564134297, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -18,16 +18,16 @@\n [Golang资源集合](./start/Resource/index.zh-cn.md)\n \n \n \n-[数据类型](start/DataType/index.zh-cn.md)\n-[字符串](start/Strings/index.zh-cn.md)\n-[Map](start/Map/index.zh-cn.md)\n+[数据类型](./start/DataType/index.zh-cn.md)\n+[字符串](./start/Strings/index.zh-cn.md)\n+[Map](./start/Map/index.zh-cn.md)\n \n ## “承”\n \n-[[Golang问题集]]\n-[[Golang面试集]]\n+[Golang问题集]\n+[Golang面试集]\n \n ## “转”\n \n ### 底层实现\n" - }, - { - "date": 1715564146089, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -24,9 +24,9 @@\n [Map](./start/Map/index.zh-cn.md)\n \n ## “承”\n \n-[Golang问题集]\n+[Golang问题集](./development/)\n [Golang面试集]\n \n ## “转”\n \n" - }, - { - "date": 1715564151850, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -24,10 +24,10 @@\n [Map](./start/Map/index.zh-cn.md)\n \n ## “承”\n \n-[Golang问题集](./development/)\n-[Golang面试集]\n+[Golang问题集](./development/Problem/index.zh-cn.md)\n+[Golang面试集](./)\n \n ## “转”\n \n ### 底层实现\n" - }, - { - "date": 1715564157618, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -25,9 +25,9 @@\n \n ## “承”\n \n [Golang问题集](./development/Problem/index.zh-cn.md)\n-[Golang面试集](./)\n+[Golang面试集](./development/InterviewQuestions/index.zh-cn.md)\n \n ## “转”\n \n ### 底层实现\n" - }, - { - "date": 1715564165005, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -31,12 +31,12 @@\n ## “转”\n \n ### 底层实现\n \n-[[GMP 模型]]\n-[[GC 垃圾回收]]\n-[[Go并发编程]]\n-[[make 一个 map 会发生什么]]\n+[GMP 模型]\n+[GC 垃圾回收]\n+[Go并发编程]\n+[make 一个 map 会发生什么]\n \n ### 源码解读\n \n [[Go - os package]]\n" - }, - { - "date": 1715564173644, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -31,9 +31,9 @@\n ## “转”\n \n ### 底层实现\n \n-[GMP 模型]\n+[GMP 模型](./)\n [GC 垃圾回收]\n [Go并发编程]\n [make 一个 map 会发生什么]\n \n" - }, - { - "date": 1715564179622, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -31,9 +31,9 @@\n ## “转”\n \n ### 底层实现\n \n-[GMP 模型](./)\n+[GMP 模型](./transition/GMP_Model/index.zh-cn.md)\n [GC 垃圾回收]\n [Go并发编程]\n [make 一个 map 会发生什么]\n \n" - }, - { - "date": 1715564185263, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -32,9 +32,9 @@\n \n ### 底层实现\n \n [GMP 模型](./transition/GMP_Model/index.zh-cn.md)\n-[GC 垃圾回收]\n+[GC 垃圾回收](./transition/)\n [Go并发编程]\n [make 一个 map 会发生什么]\n \n ### 源码解读\n" - }, - { - "date": 1715564191505, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -32,10 +32,10 @@\n \n ### 底层实现\n \n [GMP 模型](./transition/GMP_Model/index.zh-cn.md)\n-[GC 垃圾回收](./transition/)\n-[Go并发编程]\n+[GC 垃圾回收](./transition/GC/index.zh-cn.md)\n+[Go并发编程](./)\n [make 一个 map 会发生什么]\n \n ### 源码解读\n \n" - }, - { - "date": 1715564197854, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -33,9 +33,9 @@\n ### 底层实现\n \n [GMP 模型](./transition/GMP_Model/index.zh-cn.md)\n [GC 垃圾回收](./transition/GC/index.zh-cn.md)\n-[Go并发编程](./)\n+[Go并发编程](./transition/Concurrency/index.zh-cn.md)\n [make 一个 map 会发生什么]\n \n ### 源码解读\n \n" - }, - { - "date": 1715564203438, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -34,9 +34,9 @@\n \n [GMP 模型](./transition/GMP_Model/index.zh-cn.md)\n [GC 垃圾回收](./transition/GC/index.zh-cn.md)\n [Go并发编程](./transition/Concurrency/index.zh-cn.md)\n-[make 一个 map 会发生什么]\n+[make一个map 会发生什么]\n \n ### 源码解读\n \n [[Go - os package]]\n" - }, - { - "date": 1715564208990, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -34,9 +34,9 @@\n \n [GMP 模型](./transition/GMP_Model/index.zh-cn.md)\n [GC 垃圾回收](./transition/GC/index.zh-cn.md)\n [Go并发编程](./transition/Concurrency/index.zh-cn.md)\n-[make一个map 会发生什么]\n+[make一个map会发生什么](./)\n \n ### 源码解读\n \n [[Go - os package]]\n" - }, - { - "date": 1715564219245, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -34,13 +34,13 @@\n \n [GMP 模型](./transition/GMP_Model/index.zh-cn.md)\n [GC 垃圾回收](./transition/GC/index.zh-cn.md)\n [Go并发编程](./transition/Concurrency/index.zh-cn.md)\n-[make一个map会发生什么](./)\n+[make一个map会发生什么](./transition/Map/index.zh-cn.md)\n \n ### 源码解读\n \n-[[Go - os package]]\n+[Go - os package]\n \n ## “合”\n \n-[[GoReader]]\n+[GoReader]\n" - }, - { - "date": 1715564226811, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -38,9 +38,9 @@\n [make一个map会发生什么](./transition/Map/index.zh-cn.md)\n \n ### 源码解读\n \n-[Go - os package]\n+\n \n ## “合”\n \n [GoReader]\n" - }, - { - "date": 1715564359558, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -15,11 +15,8 @@\n \n [Golang学习之路](./start/LearningPath/index.zh-cn.md)\n \n [Golang资源集合](./start/Resource/index.zh-cn.md)\n-\n-\n-\n [数据类型](./start/DataType/index.zh-cn.md)\n [字符串](./start/Strings/index.zh-cn.md)\n [Map](./start/Map/index.zh-cn.md)\n \n@@ -42,5 +39,5 @@\n \n \n ## “合”\n \n-[GoReader]\n+\n" - }, - { - "date": 1715564364775, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -15,10 +15,13 @@\n \n [Golang学习之路](./start/LearningPath/index.zh-cn.md)\n \n [Golang资源集合](./start/Resource/index.zh-cn.md)\n+\n [数据类型](./start/DataType/index.zh-cn.md)\n+\n [字符串](./start/Strings/index.zh-cn.md)\n+\n [Map](./start/Map/index.zh-cn.md)\n \n ## “承”\n \n" - }, - { - "date": 1715564370487, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -25,8 +25,9 @@\n \n ## “承”\n \n [Golang问题集](./development/Problem/index.zh-cn.md)\n+\n [Golang面试集](./development/InterviewQuestions/index.zh-cn.md)\n \n ## “转”\n \n" - }, - { - "date": 1715564539765, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,8 +22,14 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n+[Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\" >}})\n+[数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md\" >}})\n+[字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md\" >}})\n+[Map]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md\" >}})\n+\n ## “承”\n \n [Golang问题集](./development/Problem/index.zh-cn.md)\n \n@@ -33,10 +39,13 @@\n \n ### 底层实现\n \n [GMP 模型](./transition/GMP_Model/index.zh-cn.md)\n+\n [GC 垃圾回收](./transition/GC/index.zh-cn.md)\n+\n [Go并发编程](./transition/Concurrency/index.zh-cn.md)\n+\n [make一个map会发生什么](./transition/Map/index.zh-cn.md)\n \n ### 源码解读\n \n" - }, - { - "date": 1715564571959, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< relref \"Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n [Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\" >}})\n [数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md\" >}})\n [字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md\" >}})\n [Map]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md\" >}})\n" - }, - { - "date": 1715564577328, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -23,12 +23,12 @@\n \n [Map](./start/Map/index.zh-cn.md)\n \n [Golang学习之路]({{< relref \"Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n-[Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\" >}})\n+\n \n ## “承”\n \n [Golang问题集](./development/Problem/index.zh-cn.md)\n" - }, - { - "date": 1715564631974, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -23,12 +23,12 @@\n \n [Map](./start/Map/index.zh-cn.md)\n \n [Golang学习之路]({{< relref \"Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n-\n+[Map]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md\" >}})\n \n ## “承”\n \n [Golang问题集](./development/Problem/index.zh-cn.md)\n" - }, - { - "date": 1715564639484, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -23,9 +23,9 @@\n \n [Map](./start/Map/index.zh-cn.md)\n \n [Golang学习之路]({{< relref \"Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n-[Golang资源集合]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\" >}})\n+[Golang资源集合]({{< relref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\" >}})\n [数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md\" >}})\n [字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md\" >}})\n [Map]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md\" >}})\n \n" - }, - { - "date": 1715564645488, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< relref \"Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< relref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n [Golang资源集合]({{< relref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\" >}})\n [数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md\" >}})\n [字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md\" >}})\n [Map]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md\" >}})\n" - }, - { - "date": 1715564718884, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,13 +22,13 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< relref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< relref \"/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n [Golang资源集合]({{< relref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\" >}})\n-[数据类型]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md\" >}})\n-[字符串]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md\" >}})\n-[Map]({{< relref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md\" >}})\n+[数据类型]({{< relref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md\" >}})\n+[字符串]({{< relref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md\" >}})\n+[Map]({{< relref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md\" >}})\n \n ## “承”\n \n [Golang问题集](./development/Problem/index.zh-cn.md)\n" - }, - { - "date": 1715564724016, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -23,11 +23,11 @@\n \n [Map](./start/Map/index.zh-cn.md)\n \n [Golang学习之路]({{< relref \"/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n-[Golang资源集合]({{< relref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\" >}})\n-[数据类型]({{< relref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md\" >}})\n-[字符串]({{< relref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md\" >}})\n+[Golang资源集合]({{< relref \"/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\" >}})\n+[数据类型]({{< relref \"/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md\" >}})\n+[字符串]({{< relref /post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md\" >}})\n [Map]({{< relref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md\" >}})\n \n ## “承”\n \n" - }, - { - "date": 1715564732606, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -23,13 +23,10 @@\n \n [Map](./start/Map/index.zh-cn.md)\n \n [Golang学习之路]({{< relref \"/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n-[Golang资源集合]({{< relref \"/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md\" >}})\n-[数据类型]({{< relref \"/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md\" >}})\n-[字符串]({{< relref /post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md\" >}})\n-[Map]({{< relref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md\" >}})\n \n+\n ## “承”\n \n [Golang问题集](./development/Problem/index.zh-cn.md)\n \n" - }, - { - "date": 1715564742080, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< relref \"/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< relref \"/posts/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715564782246, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< relref \"/posts/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< relref \"/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715564788506, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< relref \"/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< relref \"Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715564803383, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< relref \"Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< relref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715564814377, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -23,10 +23,10 @@\n \n [Map](./start/Map/index.zh-cn.md)\n \n [Golang学习之路]({{< relref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+https://github.com/FeiNiaoBF/HiBlog/blob/main/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\n \n-\n ## “承”\n \n [Golang问题集](./development/Problem/index.zh-cn.md)\n \n" - }, - { - "date": 1715564819897, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -23,10 +23,10 @@\n \n [Map](./start/Map/index.zh-cn.md)\n \n [Golang学习之路]({{< relref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+\n https://github.com/FeiNiaoBF/HiBlog/blob/main/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\n-\n ## “承”\n \n [Golang问题集](./development/Problem/index.zh-cn.md)\n \n" - }, - { - "date": 1715564825197, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -24,9 +24,9 @@\n [Map](./start/Map/index.zh-cn.md)\n \n [Golang学习之路]({{< relref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n \n-https://github.com/FeiNiaoBF/HiBlog/blob/main/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\n+\n ## “承”\n \n [Golang问题集](./development/Problem/index.zh-cn.md)\n \n" - }, - { - "date": 1715564888299, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< relref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< ref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715564924158, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< ref \"content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< ref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715564932658, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< ref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< ref \"/contentpost/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715564941668, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< ref \"/contentpost/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< ref \"/\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715564950858, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< ref \"/\" >}})\n+[Golang学习之路]({{< ref \"/content/post/\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715564957278, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< ref \"/content/post/\" >}})\n+[Golang学习之路]({{< ref \"/content/post/Gohh/\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715564971359, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< ref \"/content/post/Gohh/\" >}})\n+[Golang学习之路]({{< ref \"/content/post/Gohh/1.ComputerBasics/CSLanguages/\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715564977809, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< ref \"/content/post/Gohh/1.ComputerBasics/CSLanguages/\" >}})\n+[Golang学习之路]({{< ref \"/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715564984433, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< ref \"/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start\" >}})\n+[Golang学习之路]({{< ref \"/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715565119790, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< ref \"/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< ref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715565132413, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< ref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< refre \"/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715565141418, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< refre \"/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]()\n \n \n ## “承”\n \n" - }, - { - "date": 1715565147025, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]()\n+[Golang学习之路]({})\n \n \n ## “承”\n \n" - }, - { - "date": 1715565157219, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({})\n+[Golang学习之路]({{< re>}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715565163698, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< re>}})\n+[Golang学习之路]({{< relref \"start/LearningPath/index.zh-cn.md\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715565186802, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< relref \"start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< relref \"./start/LearningPath/index.zh-cn.md\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715565199033, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< relref \"./start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< ref \"./start/LearningPath/index.zh-cn.md\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715565361710, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< ref \"./start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< ref \"/\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715565368675, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< ref \"/\" >}})\n+[Golang学习之路]({{< ref \"/content/post/Gohh/\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715565419402, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< ref \"/content/post/Gohh/\" >}})\n+[Golang学习之路]({{< ref \"/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715565472351, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< ref \"/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< ref \"/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715565731533, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< ref \"/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n+[Golang学习之路]({{< ref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n \n \n ## “承”\n \n" - }, - { - "date": 1715565760582, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,11 +22,9 @@\n [字符串](./start/Strings/index.zh-cn.md)\n \n [Map](./start/Map/index.zh-cn.md)\n \n-[Golang学习之路]({{< ref \"post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md\" >}})\n \n-\n ## “承”\n \n [Golang问题集](./development/Problem/index.zh-cn.md)\n \n" - }, - { - "date": 1715566238306, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -8,44 +8,4 @@\n showtoc: true\n weight: -100\n readingTime: true\n ---\n-## “起”\n->\n-> Let's get going Golang!\n-\n-[Golang学习之路](./start/LearningPath/index.zh-cn.md)\n-\n-[Golang资源集合](./start/Resource/index.zh-cn.md)\n-\n-[数据类型](./start/DataType/index.zh-cn.md)\n-\n-[字符串](./start/Strings/index.zh-cn.md)\n-\n-[Map](./start/Map/index.zh-cn.md)\n-\n-\n-## “承”\n-\n-[Golang问题集](./development/Problem/index.zh-cn.md)\n-\n-[Golang面试集](./development/InterviewQuestions/index.zh-cn.md)\n-\n-## “转”\n-\n-### 底层实现\n-\n-[GMP 模型](./transition/GMP_Model/index.zh-cn.md)\n-\n-[GC 垃圾回收](./transition/GC/index.zh-cn.md)\n-\n-[Go并发编程](./transition/Concurrency/index.zh-cn.md)\n-\n-[make一个map会发生什么](./transition/Map/index.zh-cn.md)\n-\n-### 源码解读\n-\n-\n-\n-## “合”\n-\n-\n" - } - ], - "date": 1715561164274, - "name": "Commit-0", - "content": "---\ntitle: \"Golang 语言学习\"\ndate: 2024-03-10T16:02:27+08:00\ndraft: false\ntaps: [\"Golang\"]\ncategories: [\"Golang\", \"CS\", \"Languages\"]\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight: -100readingTime: true\n---\n## “起”\n> Let's get going Golang!\n\n[[Golang学习之路]]\n[[Golang资源集合]]\n[[Golang --- 关键字与标识符]]\n[[Golang --- 常量与变量]]\n[[Golang --- 数据类型]]\n[[Golang --- 数据类型基础]]\n[[Golang --- 运算操作符]]\n[[Golang --- 字符串]]\n[[Golang --- 包和文件]]\n\n\n## “承”\n[[Golang问题集]]\n[[Golang面试集]]\n\n\n## “转”\n### 底层实现\n[[GMP 模型]]\n[[GC 垃圾回收]]\n[[Go并发编程]]\n[[make 一个 map 会发生什么]]\n\n### 源码解读\n[[Go - os package]]\n## “合”\n\n[[GoReader]]\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md.json deleted file mode 100644 index 6cf0798..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md.json +++ /dev/null @@ -1,138 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 30, - "patches": [ - { - "date": 1715565776498, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1715565782785, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -12,27 +12,28 @@\n ---\n \n \n ## Go 语言中的数据结构\n+\n ### 基础数据结构\n \n 1. **数组(Array)** - 由固定长度的相同类型元素组成的数据结构。\n 2. **切片(Slice)** - 由数组构成的动态长度序列,提供了更灵活的操作方式。\n 3. **映射(Map)** - 存储键值对的集合,用于快速检索数据。\n 4. **结构体(Struct)** - 可以包含不同类型字段的复合数据类型。\n \n-\n ### 其他数据结构和类型\n \n 1. **通道(Channel)** - 用于在 Go 协程之间进行通信的类型。\n 2. **接口(Interface)** - 定义对象的行为,是一种抽象类型。\n 3. **指针(Pointer)** - 存储变量的内存地址,用于直接访问内存中的值。\n \n #### 通道(Channel)\n+\n #### 接口(Interface)\n+\n #### 指针(Pointer)\n \n-\n ## 命名规范\n \n 注意:\n > **首字母大小写:** 以大写字母开头的标识符是 **public** 的(可导出的),可以被其他包访问。以小写字母开头的标识符是私有的,只能在当前包内访问。\n@@ -47,9 +48,8 @@\n 6. **结构体**:结构体的命名同样使用驼峰命名法,例如 `type MyStruct struct`。\n 7. **接口**:接口的命名同样使用驼峰命名法,例如 `type MyInterface interface`。\n 8. **枚举**:枚举的命名同样使用驼峰命名法,例如 `type Color int`。\n \n-\n 在 Go 语言中,命名变量时有一些常见的命名规范,这些规范有助于编写清晰、易读的代码。\n \n 1. 使用驼峰命名法:变量名应该使用驼峰命名法,即除第一个单词外,其余单词的首字母大写,例如 `myVariable`。\n 2. 使用有意义的名称:变量名应该具有描述性,能够清晰地表达变量的用途和含义。\n@@ -58,5 +58,4 @@\n 5. 使用全大写命名的常量:在 Go 语言中,全大写的变量名通常用于表示常量。\n 6. 遵循约定俗成的命名规范:Go 语言社区有一些常见的命名约定,比如用 `i` 表示循环变量,用 `err` 表示错误变量等,建议遵循这些约定以保持代码风格的一致性。\n \n 这些命名规范有助于编写清晰、易读的代码,并且有助于提高代码的可维护性。\n-\n" - }, - { - "date": 1715565788494, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,8 +1,8 @@\n ---\n title: \"DataType\"\n date: 2024-05-13T09:10:19+08:00\n-draft: true\n+draft: false\n taps: []\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n" - }, - { - "date": 1715565795300, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n title: \"DataType\"\n date: 2024-05-13T09:10:19+08:00\n draft: false\n-taps: []\n-categories: []\n+taps: [\"Golang\", \"start\"]\n+categories: [\"Golang\", \"CS\", \"Languages\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1716172904011, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -2,9 +2,9 @@\n title: \"DataType\"\n date: 2024-05-13T09:10:19+08:00\n draft: false\n taps: [\"Golang\", \"start\"]\n-categories: [\"Golang\", \"CS\", \"Languages\"]\n+categories: [\"Golang\", \"CS\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n@@ -26,14 +26,9 @@\n 1. **通道(Channel)** - 用于在 Go 协程之间进行通信的类型。\n 2. **接口(Interface)** - 定义对象的行为,是一种抽象类型。\n 3. **指针(Pointer)** - 存储变量的内存地址,用于直接访问内存中的值。\n \n-#### 通道(Channel)\n \n-#### 接口(Interface)\n-\n-#### 指针(Pointer)\n-\n ## 命名规范\n \n 注意:\n > **首字母大小写:** 以大写字母开头的标识符是 **public** 的(可导出的),可以被其他包访问。以小写字母开头的标识符是私有的,只能在当前包内访问。\n" - }, - { - "date": 1716172910265, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -45,12 +45,4 @@\n 8. **枚举**:枚举的命名同样使用驼峰命名法,例如 `type Color int`。\n \n 在 Go 语言中,命名变量时有一些常见的命名规范,这些规范有助于编写清晰、易读的代码。\n \n-1. 使用驼峰命名法:变量名应该使用驼峰命名法,即除第一个单词外,其余单词的首字母大写,例如 `myVariable`。\n-2. 使用有意义的名称:变量名应该具有描述性,能够清晰地表达变量的用途和含义。\n-3. 避免使用单个字符作为变量名:除非是临时变量或者循环变量,否则应该避免使用单个字符作为变量名,以提高代码的可读性。\n-4. 使用短小的名称:变量名应该尽量简洁,但又能清晰表达变量的含义。\n-5. 使用全大写命名的常量:在 Go 语言中,全大写的变量名通常用于表示常量。\n-6. 遵循约定俗成的命名规范:Go 语言社区有一些常见的命名约定,比如用 `i` 表示循环变量,用 `err` 表示错误变量等,建议遵循这些约定以保持代码风格的一致性。\n-\n-这些命名规范有助于编写清晰、易读的代码,并且有助于提高代码的可维护性。\n" - }, - { - "date": 1716172917311, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -30,9 +30,9 @@\n \n ## 命名规范\n \n 注意:\n-> **首字母大小写:** 以大写字母开头的标识符是 **public** 的(可导出的),可以被其他包访问。以小写字母开头的标识符是私有的,只能在当前包内访问。\n+> **首字母大小写** 以大写字母开头的标识符是 **public** 的(可导出的),可以被其他包访问。以小写字母开头的标识符是私有的,只能在当前包内访问。\n \n 在 Go 语言中,有一些命名规范适用于不同的命名情况。以下是一些常见的命名规范:\n \n 1. **包名**:包名应该使用单数形式,且应该是小写的,例如 `utils`。\n@@ -42,7 +42,4 @@\n 5. **函数**:函数名同样使用驼峰命名法,例如 `calculateTotal`。\n 6. **结构体**:结构体的命名同样使用驼峰命名法,例如 `type MyStruct struct`。\n 7. **接口**:接口的命名同样使用驼峰命名法,例如 `type MyInterface interface`。\n 8. **枚举**:枚举的命名同样使用驼峰命名法,例如 `type Color int`。\n-\n-在 Go 语言中,命名变量时有一些常见的命名规范,这些规范有助于编写清晰、易读的代码。\n-\n" - }, - { - "date": 1716172925422, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -30,9 +30,9 @@\n \n ## 命名规范\n \n 注意:\n-> **首字母大小写** 以大写字母开头的标识符是 **public** 的(可导出的),可以被其他包访问。以小写字母开头的标识符是私有的,只能在当前包内访问。\n+> **首字母大小写:** 以大写字母开头的标识符是 **public** 的(可导出的),可以被其他包访问。以小写字母开头的标识符是私有的,只能在当前包内访问。\n \n 在 Go 语言中,有一些命名规范适用于不同的命名情况。以下是一些常见的命名规范:\n \n 1. **包名**:包名应该使用单数形式,且应该是小写的,例如 `utils`。\n@@ -42,4 +42,183 @@\n 5. **函数**:函数名同样使用驼峰命名法,例如 `calculateTotal`。\n 6. **结构体**:结构体的命名同样使用驼峰命名法,例如 `type MyStruct struct`。\n 7. **接口**:接口的命名同样使用驼峰命名法,例如 `type MyInterface interface`。\n 8. **枚举**:枚举的命名同样使用驼峰命名法,例如 `type Color int`。\n+\n+> 目前(Go 1.21),Go有26个类型种类。\n+\n+## 类型\n+\n+### 类型定义(type definition declaration)\n+\n+用如下形式来定义新的类型。`type`为一个关键字。\n+```go\n+// 定义单个类型。\n+type NewTypeName SourceType\n+\n+// 定义多个类型(将多个类型描述合并在一个声明中)。\n+type (\n+\tNewTypeName1 SourceType1\n+\tNewTypeName2 SourceType2\n+)\n+```\n+\n+- 一个新定义的类型和它的源类型为两个不同的类型。\n+- 在两个不同的类型定义中所定义的两个类型肯定是两个不同的类型。\n+- 一个新定义的类型和它的源类型的底层类型一致并且它们的值可以相互显式转换。\n+- 类型定义可以出现在函数体内(局部)。\n+\n+> 请注意:从Go 1.9到Go 1.17,Go白皮书曾经把预声明类型视为定义类型。 但是从Go 1.18开始,Go白皮书明确说明预声明类型不再属于定义类型。\n+\n+### 具名类型\n+\n+> 在Go 1.9之前,**具名类型**这个术语在Go白皮书中是精确定义的。 在那时,一个具名类型被定义为一个可以用标识符表示的类型。 随着在Go 1.9中引入了自定义类型别名(见下一节),**具名类型**这个术语被从白皮书中删除了;取而代之的是**定义类型**。 随着Go 1.18中引入了自定义泛型,**具名类型**这个术语又被重新加回到白皮书。\n+\n+一个具名类型可能为\n+- 一个预声明类型;\n+- 一个定义(非自定义泛型)类型;\n+- 一个(泛型类型的)实例化类型;\n+- 一个类型参数类型(使用在自定义泛型中)。\n+\n+其它类型称为无名类型。一个无名类型肯定是一个组合类型(反之则未必)。\n+\n+### 类型别名声明\n+\n+```go\n+type (\n+\tName = string\n+\tAge = int\n+)\n+\n+type table = map[string]int\n+type Table = map[Name]Age\n+```\n+其中 `map[string]int` 和 `map[Name]Age` 表示同一类型\n+\n+### 底层类型(underlying type)\n+\n+规则:\n+\n+- 一个内置类型的底层类型为它自己。\n+- `unsafe`标准库包中定义的`Pointer`类型的底层类型是它自己。 (至少我们可以认为是这样。事实上,关于`unsafe.Pointer`类型的底层类型,官方文档中并没有清晰的说明。我们也可以认为`unsafe.Pointer`类型的底层类型为`*T`,其中`T`表示一个任意类型。) `unsafe.Pointer`也被视为一个内置类型。\n+- 一个无名类型(必为一个组合类型)的底层类型为它自己。\n+- 在一个类型声明中,新声明的类型和源类型共享底层类型。\n+\n+```go\n+// 这四个类型的底层类型均为内置类型int。\n+type (\n+\tMyInt int\n+\tAge MyInt\n+)\n+\n+// 下面这三个新声明的类型的底层类型各不相同。\n+type (\n+\tIntSlice []int // 底层类型为[]int\n+\tMyIntSlice []MyInt // 底层类型为[]MyInt\n+\tAgeSlice []Age // 底层类型为[]Age\n+)\n+\n+// 类型[]Age、Ages和AgeSlice的底层类型均为[]Age。\n+type Ages AgeSlice\n+```\n+\n+#### 在 Go 中,\n+- 底层类型为内置类型`bool`的类型称为**布尔类型**;\n+- 底层类型为任一内置整数类型的类型称为**整数类型**;\n+- 底层类型为内置类型`float32`或者`float64`的类型称为**浮点数类型**;\n+- 底层类型为内置类型`complex64`或`complex128`的类型称为**复数类型**;\n+- 整数类型、浮点数类型和复数类型统称为**数字值类型**;\n+- 底层类型为内置类型`string`的类型称为**字符串类型**。\n+\n+## 值(value)\n+\n+一个类型的一个实例称为此类型的一个值。一个类型可以有很多不同的值,其中一个为它的零值。同一类型的不同值共享很多相同的属性。\n+\n+每个类型有一个零值。一个类型的零值可以看作是此类型的默认值。预声明的标识符 `nil` 可以看作是切片、映射、函数、通道、指针(包括非类型安全指针)和接口类型的零值的字面量表示。\n+\n+值分为类型确定的和类型不确定的。\n+\n+Go 中还有另外两种的字面量表示形式:函数字面量表示形式和组合字面量表示形式(composite literal)。\n+- 函数字面量表示形式用来表示函数值。事实上,一个函数声明是由一个**标识符**(函数名)和一个**函数字面量**表示形式组成。\n+- 组合字面量表示形式用来表示**结构体类型值**和**容器类型**(数组、切片和映射)值。\n+\n+### 值部(value part)\n+>这个术语并没有在 Go 白皮书中定义。它仅使用在 _《Go 语言101》_ 这本书中,用来简化一些解释并帮助 Go 程序员更好地理解 Go 类型和值。\n+\n+in run time, 很多值是存储在**内存**的。每个这样的值都有一个**直接部分**,但是有一些值还可能有一个或多个**间接部分**。每个值部分在内存中都占据一段连续空间。\n+\n+### 值尺寸(value size)\n+> Go白皮书没有规定非数值类型值的尺寸。\n+\n+一个值存储在内存中是要占据一定的空间的。此空间的大小称为此值的尺寸。值尺寸是用字节数来衡量的。 在Go中,当我们谈及一个值的尺寸,如果没有特殊说明,我们一般是指此值的直接部分的尺寸。 某个特定类别的所有类型的值的尺寸都是一样的。因为这个原因,我们也常将一个值的尺寸说成是它的类型的尺寸(或值尺寸)。\n+\n+\n+## 其他概念\n+\n+### 指针类型的基类型(base type)\n+\n+若一个指针类型的底层类型表示为 `*T`,则此指针类型的基类型为 `T` 所表示的类型。\n+\n+### 结构体类型的字段(field)\n+\n+一个结构体类型由若干成员变量组成。每个这样的成员变量称为此结构体的一个字段。\n+### 函数类型的签名(signature)\n+\n+一个函数和其类型的签名由此函数的**输入参数**和**返回结果**的类型列表组成。函数名称和函数体不属于函数签名的构成部分。\n+如:\n+```go\n+\tWrite(p []byte) (n int, err error)\n+```\n+### 类型的方法(method)和方法集(method set)\n+\n+在 Go 中,我们可以给满足某些条件的类型(构造器)声明方法。方法也常被称为成员函数。一个类型的所有方法组成了此类型的**方法集**。\n+\n+### 接口类型的动态类型和动态值\n+\n+接口类型的值称为**接口值**。一个接口值可以包裹装载一个非接口值。_包裹在一个接口值中的非接口值称为此接口值的动态值_。此动态值的类型称为此接口值的动态类型。 一个什么也没包裹的接口值为一个零值接口值。零值接口值的动态值和动态类型均为不存在。\n+一个接口类型可以指定若干个(可以是零个)方法,这些方法形成了此接口类型的方法集。\n+如果一个类型(可以是接口或者非接口类型)的方法集是一个接口类型的方法集的超集,则我们说此类型实现了此接口类型。\n+\n+### 一个值的具体类型(concrete type)和具体值(concrete value)\n+\n+对于一个(类型确定的)非接口值,它的具体类型就是它的类型,它的具体值就是它自己。\n+一个 _零值接口值_ 没有具体类型和具体值。对于一个非零值接口值,它的具体类型和具体值就是它的动态类型和动态值。\n+\n+### 容器类型\n+\n+**数组** `[]int`、**切片** `slice` 和**映射** `map` 是 Go 中的三种正式意义上的内置容器类型。\n+有时候,**字符串**和**通道类型**也可以被非正式地看作是容器类型。\n+(正式和非正式的)容器类型的每个值都有一个**长度属性**。\n+\n+### 映射类型的键值(key)类型\n+\n+如果一个映射类型的底层类型表示为 `map[Tkey]T`,则此映射类型的键值类型为 `Tkey`。 `Tkey` 必须为一个**可比较类型** 。\n+\n+### 容器类型的元素(element)类型\n+\n+存储在一个容器值中的所有元素的类型必须为同一个类型。此同一类型称为此容器值的(容器)类型的元素类型。\n+\n+### 通道类型的方向\n+\n+一个通道值可以被看作是 **先入先出(first-in-first-out,FIFO)** 队列。一个通道值可能是可读可写的、只读的(receive-only)或者只写的(send-only)。\n+- 一个可读可写的通道值也称为一个双向通道。 一个双向通道类型的底层类型可以被表示为`chan T`。\n+- 我们只能向一个只写的通道值发送数据,而不能从其中接收数据。 只写通道类型的底层类型可以被表示为`chan<- T`。\n+- 我们只能从一个只读的通道值接收数据,而不能向其发送数据。 只读通道类型的底层类型可以被表示为`<-chan T`。\n+\n+## 值得提的事\n+\n+### 可比较类型和不可比较类型\n+\n+目前(~~Go 1.21~~),下面这些类型的值不支持(使用 `==` 和 `!=` 运算标识符)比较。这些类型称为 _不可比较类型_。\n+- 切片类型\n+- 映射类型\n+- 函数类型\n+- 任何包含有不可比较类型的字段的结构体类型和任何元素类型为不可比较类型的数组类型。\n+其它类型称为可比较类型。\n+映射类型的键值类型必须为可比较类型。\n+\n+## 外部链接\n+\n+[Go 101](https://gfw.go101.org/article/type-system-overview.html)\n+\n+\n+\n" - }, - { - "date": 1716172935420, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -26,9 +26,8 @@\n 1. **通道(Channel)** - 用于在 Go 协程之间进行通信的类型。\n 2. **接口(Interface)** - 定义对象的行为,是一种抽象类型。\n 3. **指针(Pointer)** - 存储变量的内存地址,用于直接访问内存中的值。\n \n-\n ## 命名规范\n \n 注意:\n > **首字母大小写:** 以大写字母开头的标识符是 **public** 的(可导出的),可以被其他包访问。以小写字母开头的标识符是私有的,只能在当前包内访问。\n@@ -50,16 +49,17 @@\n \n ### 类型定义(type definition declaration)\n \n 用如下形式来定义新的类型。`type`为一个关键字。\n+\n ```go\n // 定义单个类型。\n type NewTypeName SourceType\n \n // 定义多个类型(将多个类型描述合并在一个声明中)。\n type (\n-\tNewTypeName1 SourceType1\n-\tNewTypeName2 SourceType2\n+ NewTypeName1 SourceType1\n+ NewTypeName2 SourceType2\n )\n ```\n \n - 一个新定义的类型和它的源类型为两个不同的类型。\n@@ -73,8 +73,9 @@\n \n > 在Go 1.9之前,**具名类型**这个术语在Go白皮书中是精确定义的。 在那时,一个具名类型被定义为一个可以用标识符表示的类型。 随着在Go 1.9中引入了自定义类型别名(见下一节),**具名类型**这个术语被从白皮书中删除了;取而代之的是**定义类型**。 随着Go 1.18中引入了自定义泛型,**具名类型**这个术语又被重新加回到白皮书。\n \n 一个具名类型可能为\n+\n - 一个预声明类型;\n - 一个定义(非自定义泛型)类型;\n - 一个(泛型类型的)实例化类型;\n - 一个类型参数类型(使用在自定义泛型中)。\n@@ -84,15 +85,16 @@\n ### 类型别名声明\n \n ```go\n type (\n-\tName = string\n-\tAge = int\n+ Name = string\n+ Age = int\n )\n \n type table = map[string]int\n type Table = map[Name]Age\n ```\n+\n 其中 `map[string]int` 和 `map[Name]Age` 表示同一类型\n \n ### 底层类型(underlying type)\n \n@@ -105,24 +107,25 @@\n \n ```go\n // 这四个类型的底层类型均为内置类型int。\n type (\n-\tMyInt int\n-\tAge MyInt\n+ MyInt int\n+ Age MyInt\n )\n \n // 下面这三个新声明的类型的底层类型各不相同。\n type (\n-\tIntSlice []int // 底层类型为[]int\n-\tMyIntSlice []MyInt // 底层类型为[]MyInt\n-\tAgeSlice []Age // 底层类型为[]Age\n+ IntSlice []int // 底层类型为[]int\n+ MyIntSlice []MyInt // 底层类型为[]MyInt\n+ AgeSlice []Age // 底层类型为[]Age\n )\n \n // 类型[]Age、Ages和AgeSlice的底层类型均为[]Age。\n type Ages AgeSlice\n ```\n \n-#### 在 Go 中,\n+#### 在 Go 中\n+\n - 底层类型为内置类型`bool`的类型称为**布尔类型**;\n - 底层类型为任一内置整数类型的类型称为**整数类型**;\n - 底层类型为内置类型`float32`或者`float64`的类型称为**浮点数类型**;\n - 底层类型为内置类型`complex64`或`complex128`的类型称为**复数类型**;\n@@ -137,22 +140,24 @@\n \n 值分为类型确定的和类型不确定的。\n \n Go 中还有另外两种的字面量表示形式:函数字面量表示形式和组合字面量表示形式(composite literal)。\n+\n - 函数字面量表示形式用来表示函数值。事实上,一个函数声明是由一个**标识符**(函数名)和一个**函数字面量**表示形式组成。\n - 组合字面量表示形式用来表示**结构体类型值**和**容器类型**(数组、切片和映射)值。\n \n ### 值部(value part)\n+>\n >这个术语并没有在 Go 白皮书中定义。它仅使用在 _《Go 语言101》_ 这本书中,用来简化一些解释并帮助 Go 程序员更好地理解 Go 类型和值。\n \n in run time, 很多值是存储在**内存**的。每个这样的值都有一个**直接部分**,但是有一些值还可能有一个或多个**间接部分**。每个值部分在内存中都占据一段连续空间。\n \n ### 值尺寸(value size)\n+>\n > Go白皮书没有规定非数值类型值的尺寸。\n \n 一个值存储在内存中是要占据一定的空间的。此空间的大小称为此值的尺寸。值尺寸是用字节数来衡量的。 在Go中,当我们谈及一个值的尺寸,如果没有特殊说明,我们一般是指此值的直接部分的尺寸。 某个特定类别的所有类型的值的尺寸都是一样的。因为这个原因,我们也常将一个值的尺寸说成是它的类型的尺寸(或值尺寸)。\n \n-\n ## 其他概念\n \n ### 指针类型的基类型(base type)\n \n@@ -160,15 +165,18 @@\n \n ### 结构体类型的字段(field)\n \n 一个结构体类型由若干成员变量组成。每个这样的成员变量称为此结构体的一个字段。\n+\n ### 函数类型的签名(signature)\n \n 一个函数和其类型的签名由此函数的**输入参数**和**返回结果**的类型列表组成。函数名称和函数体不属于函数签名的构成部分。\n 如:\n+\n ```go\n-\tWrite(p []byte) (n int, err error)\n+ Write(p []byte) (n int, err error)\n ```\n+\n ### 类型的方法(method)和方法集(method set)\n \n 在 Go 中,我们可以给满足某些条件的类型(构造器)声明方法。方法也常被称为成员函数。一个类型的所有方法组成了此类型的**方法集**。\n \n@@ -199,8 +207,9 @@\n \n ### 通道类型的方向\n \n 一个通道值可以被看作是 **先入先出(first-in-first-out,FIFO)** 队列。一个通道值可能是可读可写的、只读的(receive-only)或者只写的(send-only)。\n+\n - 一个可读可写的通道值也称为一个双向通道。 一个双向通道类型的底层类型可以被表示为`chan T`。\n - 我们只能向一个只写的通道值发送数据,而不能从其中接收数据。 只写通道类型的底层类型可以被表示为`chan<- T`。\n - 我们只能从一个只读的通道值接收数据,而不能向其发送数据。 只读通道类型的底层类型可以被表示为`<-chan T`。\n \n@@ -208,8 +217,9 @@\n \n ### 可比较类型和不可比较类型\n \n 目前(~~Go 1.21~~),下面这些类型的值不支持(使用 `==` 和 `!=` 运算标识符)比较。这些类型称为 _不可比较类型_。\n+\n - 切片类型\n - 映射类型\n - 函数类型\n - 任何包含有不可比较类型的字段的结构体类型和任何元素类型为不可比较类型的数组类型。\n@@ -218,7 +228,4 @@\n \n ## 外部链接\n \n [Go 101](https://gfw.go101.org/article/type-system-overview.html)\n-\n-\n-\n" - }, - { - "date": 1716172944982, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,26 +1,25 @@\n ---\n-title: \"DataType\"\n+title: 'DataType'\n date: 2024-05-13T09:10:19+08:00\n draft: false\n-taps: [\"Golang\", \"start\"]\n-categories: [\"Golang\", \"CS\"]\n-author: [\"Yeelight\"]\n+taps: ['Golang', 'start']\n+categories: ['Golang', 'CS']\n+author: ['Yeelight']\n showtoc: true\n weight:\n math: false\n readingTime: true\n ---\n \n-\n ## Go 语言中的数据结构\n \n ### 基础数据结构\n \n- 1. **数组(Array)** - 由固定长度的相同类型元素组成的数据结构。\n- 2. **切片(Slice)** - 由数组构成的动态长度序列,提供了更灵活的操作方式。\n- 3. **映射(Map)** - 存储键值对的集合,用于快速检索数据。\n- 4. **结构体(Struct)** - 可以包含不同类型字段的复合数据类型。\n+1. **数组(Array)** - 由固定长度的相同类型元素组成的数据结构。\n+2. **切片(Slice)** - 由数组构成的动态长度序列,提供了更灵活的操作方式。\n+3. **映射(Map)** - 存储键值对的集合,用于快速检索数据。\n+4. **结构体(Struct)** - 可以包含不同类型字段的复合数据类型。\n \n ### 其他数据结构和类型\n \n 1. **通道(Channel)** - 用于在 Go 协程之间进行通信的类型。\n@@ -29,8 +28,9 @@\n \n ## 命名规范\n \n 注意:\n+\n > **首字母大小写:** 以大写字母开头的标识符是 **public** 的(可导出的),可以被其他包访问。以小写字母开头的标识符是私有的,只能在当前包内访问。\n \n 在 Go 语言中,有一些命名规范适用于不同的命名情况。以下是一些常见的命名规范:\n \n@@ -42,9 +42,9 @@\n 6. **结构体**:结构体的命名同样使用驼峰命名法,例如 `type MyStruct struct`。\n 7. **接口**:接口的命名同样使用驼峰命名法,例如 `type MyInterface interface`。\n 8. **枚举**:枚举的命名同样使用驼峰命名法,例如 `type Color int`。\n \n-> 目前(Go 1.21),Go有26个类型种类。\n+> 目前(Go 1.21),Go 有 26 个类型种类。\n \n ## 类型\n \n ### 类型定义(type definition declaration)\n@@ -66,13 +66,13 @@\n - 在两个不同的类型定义中所定义的两个类型肯定是两个不同的类型。\n - 一个新定义的类型和它的源类型的底层类型一致并且它们的值可以相互显式转换。\n - 类型定义可以出现在函数体内(局部)。\n \n-> 请注意:从Go 1.9到Go 1.17,Go白皮书曾经把预声明类型视为定义类型。 但是从Go 1.18开始,Go白皮书明确说明预声明类型不再属于定义类型。\n+> 请注意:从 Go 1.9 到 Go 1.17,Go 白皮书曾经把预声明类型视为定义类型。 但是从 Go 1.18 开始,Go 白皮书明确说明预声明类型不再属于定义类型。\n \n ### 具名类型\n \n-> 在Go 1.9之前,**具名类型**这个术语在Go白皮书中是精确定义的。 在那时,一个具名类型被定义为一个可以用标识符表示的类型。 随着在Go 1.9中引入了自定义类型别名(见下一节),**具名类型**这个术语被从白皮书中删除了;取而代之的是**定义类型**。 随着Go 1.18中引入了自定义泛型,**具名类型**这个术语又被重新加回到白皮书。\n+> 在 Go 1.9 之前,**具名类型**这个术语在 Go 白皮书中是精确定义的。 在那时,一个具名类型被定义为一个可以用标识符表示的类型。 随着在 Go 1.9 中引入了自定义类型别名(见下一节),**具名类型**这个术语被从白皮书中删除了;取而代之的是**定义类型**。 随着 Go 1.18 中引入了自定义泛型,**具名类型**这个术语又被重新加回到白皮书。\n \n 一个具名类型可能为\n \n - 一个预声明类型;\n@@ -145,19 +145,19 @@\n - 函数字面量表示形式用来表示函数值。事实上,一个函数声明是由一个**标识符**(函数名)和一个**函数字面量**表示形式组成。\n - 组合字面量表示形式用来表示**结构体类型值**和**容器类型**(数组、切片和映射)值。\n \n ### 值部(value part)\n->\n->这个术语并没有在 Go 白皮书中定义。它仅使用在 _《Go 语言101》_ 这本书中,用来简化一些解释并帮助 Go 程序员更好地理解 Go 类型和值。\n \n+> 这个术语并没有在 Go 白皮书中定义。它仅使用在 _《Go 语言 101》_ 这本书中,用来简化一些解释并帮助 Go 程序员更好地理解 Go 类型和值。\n+\n in run time, 很多值是存储在**内存**的。每个这样的值都有一个**直接部分**,但是有一些值还可能有一个或多个**间接部分**。每个值部分在内存中都占据一段连续空间。\n \n ### 值尺寸(value size)\n->\n-> Go白皮书没有规定非数值类型值的尺寸。\n \n-一个值存储在内存中是要占据一定的空间的。此空间的大小称为此值的尺寸。值尺寸是用字节数来衡量的。 在Go中,当我们谈及一个值的尺寸,如果没有特殊说明,我们一般是指此值的直接部分的尺寸。 某个特定类别的所有类型的值的尺寸都是一样的。因为这个原因,我们也常将一个值的尺寸说成是它的类型的尺寸(或值尺寸)。\n+> Go 白皮书没有规定非数值类型值的尺寸。\n \n+一个值存储在内存中是要占据一定的空间的。此空间的大小称为此值的尺寸。值尺寸是用字节数来衡量的。 在 Go 中,当我们谈及一个值的尺寸,如果没有特殊说明,我们一般是指此值的直接部分的尺寸。 某个特定类别的所有类型的值的尺寸都是一样的。因为这个原因,我们也常将一个值的尺寸说成是它的类型的尺寸(或值尺寸)。\n+\n ## 其他概念\n \n ### 指针类型的基类型(base type)\n \n@@ -192,9 +192,9 @@\n 一个 _零值接口值_ 没有具体类型和具体值。对于一个非零值接口值,它的具体类型和具体值就是它的动态类型和动态值。\n \n ### 容器类型\n \n-**数组** `[]int`、**切片** `slice` 和**映射** `map` 是 Go 中的三种正式意义上的内置容器类型。\n+**数组** `[]int`、**切片** `slice` 和**映射** `map` 是 Go 中的三种正式意义上的内置容器类型。\n 有时候,**字符串**和**通道类型**也可以被非正式地看作是容器类型。\n (正式和非正式的)容器类型的每个值都有一个**长度属性**。\n \n ### 映射类型的键值(key)类型\n@@ -222,10 +222,10 @@\n - 切片类型\n - 映射类型\n - 函数类型\n - 任何包含有不可比较类型的字段的结构体类型和任何元素类型为不可比较类型的数组类型。\n-其它类型称为可比较类型。\n-映射类型的键值类型必须为可比较类型。\n+ 其它类型称为可比较类型。\n+ 映射类型的键值类型必须为可比较类型。\n \n ## 外部链接\n \n [Go 101](https://gfw.go101.org/article/type-system-overview.html)\n" - }, - { - "date": 1716173020264, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -66,9 +66,8 @@\n - 在两个不同的类型定义中所定义的两个类型肯定是两个不同的类型。\n - 一个新定义的类型和它的源类型的底层类型一致并且它们的值可以相互显式转换。\n - 类型定义可以出现在函数体内(局部)。\n \n-> 请注意:从 Go 1.9 到 Go 1.17,Go 白皮书曾经把预声明类型视为定义类型。 但是从 Go 1.18 开始,Go 白皮书明确说明预声明类型不再属于定义类型。\n \n ### 具名类型\n \n > 在 Go 1.9 之前,**具名类型**这个术语在 Go 白皮书中是精确定义的。 在那时,一个具名类型被定义为一个可以用标识符表示的类型。 随着在 Go 1.9 中引入了自定义类型别名(见下一节),**具名类型**这个术语被从白皮书中删除了;取而代之的是**定义类型**。 随着 Go 1.18 中引入了自定义泛型,**具名类型**这个术语又被重新加回到白皮书。\n" - }, - { - "date": 1716173039517, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -66,13 +66,10 @@\n - 在两个不同的类型定义中所定义的两个类型肯定是两个不同的类型。\n - 一个新定义的类型和它的源类型的底层类型一致并且它们的值可以相互显式转换。\n - 类型定义可以出现在函数体内(局部)。\n \n-\n ### 具名类型\n \n-> 在 Go 1.9 之前,**具名类型**这个术语在 Go 白皮书中是精确定义的。 在那时,一个具名类型被定义为一个可以用标识符表示的类型。 随着在 Go 1.9 中引入了自定义类型别名(见下一节),**具名类型**这个术语被从白皮书中删除了;取而代之的是**定义类型**。 随着 Go 1.18 中引入了自定义泛型,**具名类型**这个术语又被重新加回到白皮书。\n-\n 一个具名类型可能为\n \n - 一个预声明类型;\n - 一个定义(非自定义泛型)类型;\n" - }, - { - "date": 1716173045933, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -75,9 +75,9 @@\n - 一个定义(非自定义泛型)类型;\n - 一个(泛型类型的)实例化类型;\n - 一个类型参数类型(使用在自定义泛型中)。\n \n-其它类型称为无名类型。一个无名类型肯定是一个组合类型(反之则未必)。\n+其它类型称为*无名类型。一个无名类型肯定是一个组合类型(反之则未必)。\n \n ### 类型别名声明\n \n ```go\n" - }, - { - "date": 1716173054754, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -75,9 +75,9 @@\n - 一个定义(非自定义泛型)类型;\n - 一个(泛型类型的)实例化类型;\n - 一个类型参数类型(使用在自定义泛型中)。\n \n-其它类型称为*无名类型。一个无名类型肯定是一个组合类型(反之则未必)。\n+其它类型称为*无名类型*。一个无名类型肯定是一个*组合类型*(反之则未必)。\n \n ### 类型别名声明\n \n ```go\n" - }, - { - "date": 1716173062872, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -66,9 +66,9 @@\n - 在两个不同的类型定义中所定义的两个类型肯定是两个不同的类型。\n - 一个新定义的类型和它的源类型的底层类型一致并且它们的值可以相互显式转换。\n - 类型定义可以出现在函数体内(局部)。\n \n-### 具名类型\n+### 具名类型()\n \n 一个具名类型可能为\n \n - 一个预声明类型;\n" - }, - { - "date": 1716173068080, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -66,9 +66,9 @@\n - 在两个不同的类型定义中所定义的两个类型肯定是两个不同的类型。\n - 一个新定义的类型和它的源类型的底层类型一致并且它们的值可以相互显式转换。\n - 类型定义可以出现在函数体内(局部)。\n \n-### 具名类型()\n+### 具名类型(named ty)\n \n 一个具名类型可能为\n \n - 一个预声明类型;\n" - }, - { - "date": 1716173224526, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -66,9 +66,9 @@\n - 在两个不同的类型定义中所定义的两个类型肯定是两个不同的类型。\n - 一个新定义的类型和它的源类型的底层类型一致并且它们的值可以相互显式转换。\n - 类型定义可以出现在函数体内(局部)。\n \n-### 具名类型(named ty)\n+### 具名类型(named type)\n \n 一个具名类型可能为\n \n - 一个预声明类型;\n@@ -77,8 +77,9 @@\n - 一个类型参数类型(使用在自定义泛型中)。\n \n 其它类型称为*无名类型*。一个无名类型肯定是一个*组合类型*(反之则未必)。\n \n+\n ### 类型别名声明\n \n ```go\n type (\n" - }, - { - "date": 1716173232300, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -76,10 +76,10 @@\n - 一个(泛型类型的)实例化类型;\n - 一个类型参数类型(使用在自定义泛型中)。\n \n 其它类型称为*无名类型*。一个无名类型肯定是一个*组合类型*(反之则未必)。\n+[Named and Unnamed Types](https://stackoverflow.com/questions/32983546/named-and-unnamed-types)\n \n-\n ### 类型别名声明\n \n ```go\n type (\n" - }, - { - "date": 1716173246951, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -75,9 +75,9 @@\n - 一个定义(非自定义泛型)类型;\n - 一个(泛型类型的)实例化类型;\n - 一个类型参数类型(使用在自定义泛型中)。\n \n-其它类型称为*无名类型*。一个无名类型肯定是一个*组合类型*(反之则未必)。\n+其它类型称为*无名类型*。一个无名类型肯定是一个*组合类型*\n [Named and Unnamed Types](https://stackoverflow.com/questions/32983546/named-and-unnamed-types)\n \n ### 类型别名声明\n \n" - }, - { - "date": 1716173285012, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -75,9 +75,9 @@\n - 一个定义(非自定义泛型)类型;\n - 一个(泛型类型的)实例化类型;\n - 一个类型参数类型(使用在自定义泛型中)。\n \n-其它类型称为*无名类型*。一个无名类型肯定是一个*组合类型*\n+其它类型称为*无名类型*。一个无名类型肯定是一个*组合类型*。\n [Named and Unnamed Types](https://stackoverflow.com/questions/32983546/named-and-unnamed-types)\n \n ### 类型别名声明\n \n@@ -97,9 +97,9 @@\n \n 规则:\n \n - 一个内置类型的底层类型为它自己。\n-- `unsafe`标准库包中定义的`Pointer`类型的底层类型是它自己。 (至少我们可以认为是这样。事实上,关于`unsafe.Pointer`类型的底层类型,官方文档中并没有清晰的说明。我们也可以认为`unsafe.Pointer`类型的底层类型为`*T`,其中`T`表示一个任意类型。) `unsafe.Pointer`也被视为一个内置类型。\n+- `unsafe`标准库包中定义的`Pointer`类型的底层类型是它自己。 `unsafe.Pointer`也被视为一个内置类型。\n - 一个无名类型(必为一个组合类型)的底层类型为它自己。\n - 在一个类型声明中,新声明的类型和源类型共享底层类型。\n \n ```go\n" - }, - { - "date": 1716173339579, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -97,9 +97,9 @@\n \n 规则:\n \n - 一个内置类型的底层类型为它自己。\n-- `unsafe`标准库包中定义的`Pointer`类型的底层类型是它自己。 `unsafe.Pointer`也被视为一个内置类型。\n+- `unsafe`标准库包中定义的`Pointer`类型的底层类型是它自己。`unsafe.Pointer`也被视为一个内置类型。\n - 一个无名类型(必为一个组合类型)的底层类型为它自己。\n - 在一个类型声明中,新声明的类型和源类型共享底层类型。\n \n ```go\n@@ -143,10 +143,8 @@\n - 组合字面量表示形式用来表示**结构体类型值**和**容器类型**(数组、切片和映射)值。\n \n ### 值部(value part)\n \n-> 这个术语并没有在 Go 白皮书中定义。它仅使用在 _《Go 语言 101》_ 这本书中,用来简化一些解释并帮助 Go 程序员更好地理解 Go 类型和值。\n-\n in run time, 很多值是存储在**内存**的。每个这样的值都有一个**直接部分**,但是有一些值还可能有一个或多个**间接部分**。每个值部分在内存中都占据一段连续空间。\n \n ### 值尺寸(value size)\n \n" - }, - { - "date": 1716173355402, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -136,10 +136,8 @@\n 每个类型有一个零值。一个类型的零值可以看作是此类型的默认值。预声明的标识符 `nil` 可以看作是切片、映射、函数、通道、指针(包括非类型安全指针)和接口类型的零值的字面量表示。\n \n 值分为类型确定的和类型不确定的。\n \n-Go 中还有另外两种的字面量表示形式:函数字面量表示形式和组合字面量表示形式(composite literal)。\n-\n - 函数字面量表示形式用来表示函数值。事实上,一个函数声明是由一个**标识符**(函数名)和一个**函数字面量**表示形式组成。\n - 组合字面量表示形式用来表示**结构体类型值**和**容器类型**(数组、切片和映射)值。\n \n ### 值部(value part)\n" - }, - { - "date": 1716173375128, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -136,10 +136,8 @@\n 每个类型有一个零值。一个类型的零值可以看作是此类型的默认值。预声明的标识符 `nil` 可以看作是切片、映射、函数、通道、指针(包括非类型安全指针)和接口类型的零值的字面量表示。\n \n 值分为类型确定的和类型不确定的。\n \n-- 函数字面量表示形式用来表示函数值。事实上,一个函数声明是由一个**标识符**(函数名)和一个**函数字面量**表示形式组成。\n-- 组合字面量表示形式用来表示**结构体类型值**和**容器类型**(数组、切片和映射)值。\n \n ### 值部(value part)\n \n in run time, 很多值是存储在**内存**的。每个这样的值都有一个**直接部分**,但是有一些值还可能有一个或多个**间接部分**。每个值部分在内存中都占据一段连续空间。\n" - }, - { - "date": 1716173389345, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -130,9 +130,9 @@\n - 底层类型为内置类型`string`的类型称为**字符串类型**。\n \n ## 值(value)\n \n-一个类型的一个实例称为此类型的一个值。一个类型可以有很多不同的值,其中一个为它的零值。同一类型的不同值共享很多相同的属性。\n+一个类型的一个****实例**称为此类型的一个值。一个类型可以有很多不同的值,其中一个为它的零值。同一类型的不同值共享很多相同的属性。\n \n 每个类型有一个零值。一个类型的零值可以看作是此类型的默认值。预声明的标识符 `nil` 可以看作是切片、映射、函数、通道、指针(包括非类型安全指针)和接口类型的零值的字面量表示。\n \n 值分为类型确定的和类型不确定的。\n" - }, - { - "date": 1716173405698, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -130,15 +130,14 @@\n - 底层类型为内置类型`string`的类型称为**字符串类型**。\n \n ## 值(value)\n \n-一个类型的一个****实例**称为此类型的一个值。一个类型可以有很多不同的值,其中一个为它的零值。同一类型的不同值共享很多相同的属性。\n+一个类型的一个**实例**称为此类型的一个值。一个类型可以有很多不同的值,其中一个为它的零值。同一类型的不同值共享很多相同的属性。\n \n 每个类型有一个零值。一个类型的零值可以看作是此类型的默认值。预声明的标识符 `nil` 可以看作是切片、映射、函数、通道、指针(包括非类型安全指针)和接口类型的零值的字面量表示。\n \n 值分为类型确定的和类型不确定的。\n \n-\n ### 值部(value part)\n \n in run time, 很多值是存储在**内存**的。每个这样的值都有一个**直接部分**,但是有一些值还可能有一个或多个**间接部分**。每个值部分在内存中都占据一段连续空间。\n \n" - }, - { - "date": 1716173414494, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -136,18 +136,9 @@\n 每个类型有一个零值。一个类型的零值可以看作是此类型的默认值。预声明的标识符 `nil` 可以看作是切片、映射、函数、通道、指针(包括非类型安全指针)和接口类型的零值的字面量表示。\n \n 值分为类型确定的和类型不确定的。\n \n-### 值部(value part)\n \n-in run time, 很多值是存储在**内存**的。每个这样的值都有一个**直接部分**,但是有一些值还可能有一个或多个**间接部分**。每个值部分在内存中都占据一段连续空间。\n-\n-### 值尺寸(value size)\n-\n-> Go 白皮书没有规定非数值类型值的尺寸。\n-\n-一个值存储在内存中是要占据一定的空间的。此空间的大小称为此值的尺寸。值尺寸是用字节数来衡量的。 在 Go 中,当我们谈及一个值的尺寸,如果没有特殊说明,我们一般是指此值的直接部分的尺寸。 某个特定类别的所有类型的值的尺寸都是一样的。因为这个原因,我们也常将一个值的尺寸说成是它的类型的尺寸(或值尺寸)。\n-\n ## 其他概念\n \n ### 指针类型的基类型(base type)\n \n" - }, - { - "date": 1716173433857, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -136,9 +136,8 @@\n 每个类型有一个零值。一个类型的零值可以看作是此类型的默认值。预声明的标识符 `nil` 可以看作是切片、映射、函数、通道、指针(包括非类型安全指针)和接口类型的零值的字面量表示。\n \n 值分为类型确定的和类型不确定的。\n \n-\n ## 其他概念\n \n ### 指针类型的基类型(base type)\n \n@@ -162,16 +161,16 @@\n 在 Go 中,我们可以给满足某些条件的类型(构造器)声明方法。方法也常被称为成员函数。一个类型的所有方法组成了此类型的**方法集**。\n \n ### 接口类型的动态类型和动态值\n \n-接口类型的值称为**接口值**。一个接口值可以包裹装载一个非接口值。_包裹在一个接口值中的非接口值称为此接口值的动态值_。此动态值的类型称为此接口值的动态类型。 一个什么也没包裹的接口值为一个零值接口值。零值接口值的动态值和动态类型均为不存在。\n+接口类型的值称为**接口值**。一个接口值可以包裹装载一个非接口值。*包裹在一个接口值中的非接口值称为此接口值的动态值*。此动态值的类型称为此接口值的动态类型。 一个什么也没包裹的接口值为一个零值接口值。零值接口值的动态值和动态类型均为不存在。\n 一个接口类型可以指定若干个(可以是零个)方法,这些方法形成了此接口类型的方法集。\n 如果一个类型(可以是接口或者非接口类型)的方法集是一个接口类型的方法集的超集,则我们说此类型实现了此接口类型。\n \n ### 一个值的具体类型(concrete type)和具体值(concrete value)\n \n 对于一个(类型确定的)非接口值,它的具体类型就是它的类型,它的具体值就是它自己。\n-一个 _零值接口值_ 没有具体类型和具体值。对于一个非零值接口值,它的具体类型和具体值就是它的动态类型和动态值。\n+一个 *零值接口值* 没有具体类型和具体值。对于一个非零值接口值,它的具体类型和具体值就是它的动态类型和动态值。\n \n ### 容器类型\n \n **数组** `[]int`、**切片** `slice` 和**映射** `map` 是 Go 中的三种正式意义上的内置容器类型。\n@@ -197,9 +196,9 @@\n ## 值得提的事\n \n ### 可比较类型和不可比较类型\n \n-目前(~~Go 1.21~~),下面这些类型的值不支持(使用 `==` 和 `!=` 运算标识符)比较。这些类型称为 _不可比较类型_。\n+目前(~~Go 1.21~~),下面这些类型的值不支持(使用 `==` 和 `!=` 运算标识符)比较。这些类型称为 *不可比较类型*。\n \n - 切片类型\n - 映射类型\n - 函数类型\n" - }, - { - "date": 1716173464827, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -192,10 +192,8 @@\n - 一个可读可写的通道值也称为一个双向通道。 一个双向通道类型的底层类型可以被表示为`chan T`。\n - 我们只能向一个只写的通道值发送数据,而不能从其中接收数据。 只写通道类型的底层类型可以被表示为`chan<- T`。\n - 我们只能从一个只读的通道值接收数据,而不能向其发送数据。 只读通道类型的底层类型可以被表示为`<-chan T`。\n \n-## 值得提的事\n-\n ### 可比较类型和不可比较类型\n \n 目前(~~Go 1.21~~),下面这些类型的值不支持(使用 `==` 和 `!=` 运算标识符)比较。这些类型称为 *不可比较类型*。\n \n" - }, - { - "date": 1716173475202, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: 'DataType'\n+title: 'Go 语言中的数据结构'\n date: 2024-05-13T09:10:19+08:00\n draft: false\n taps: ['Golang', 'start']\n categories: ['Golang', 'CS']\n" - }, - { - "date": 1716173480937, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: 'Go 语言中的数据结构'\n+title: '数据结构和'\n date: 2024-05-13T09:10:19+08:00\n draft: false\n taps: ['Golang', 'start']\n categories: ['Golang', 'CS']\n" - }, - { - "date": 1716173488460, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: '数据结构和'\n+title: '数据结构和理论知识'\n date: 2024-05-13T09:10:19+08:00\n draft: false\n taps: ['Golang', 'start']\n categories: ['Golang', 'CS']\n" - } - ], - "date": 1715565776498, - "name": "Commit-0", - "content": "---\ntitle: \"DataType\"\ndate: 2024-05-13T09:10:19+08:00\ndraft: true\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n\n\n## Go 语言中的数据结构\n### 基础数据结构\n\n 1. **数组(Array)** - 由固定长度的相同类型元素组成的数据结构。\n 2. **切片(Slice)** - 由数组构成的动态长度序列,提供了更灵活的操作方式。\n 3. **映射(Map)** - 存储键值对的集合,用于快速检索数据。\n 4. **结构体(Struct)** - 可以包含不同类型字段的复合数据类型。\n\n\n### 其他数据结构和类型\n\n1. **通道(Channel)** - 用于在 Go 协程之间进行通信的类型。\n2. **接口(Interface)** - 定义对象的行为,是一种抽象类型。\n3. **指针(Pointer)** - 存储变量的内存地址,用于直接访问内存中的值。\n\n#### 通道(Channel)\n#### 接口(Interface)\n#### 指针(Pointer)\n\n\n## 命名规范\n\n注意:\n> **首字母大小写:** 以大写字母开头的标识符是 **public** 的(可导出的),可以被其他包访问。以小写字母开头的标识符是私有的,只能在当前包内访问。\n\n在 Go 语言中,有一些命名规范适用于不同的命名情况。以下是一些常见的命名规范:\n\n1. **包名**:包名应该使用单数形式,且应该是小写的,例如 `utils`。\n2. **文件名**:文件名应该全部使用小写字母,可以包含下划线 `_`,例如 `my_file.go`。\n3. **变量**:变量名使用驼峰命名法,例如 `myVariable`。私有变量的命名应该以小写字母开头,公共变量则以大写字母开头。\n4. **常量**:常量的命名应该全部使用大写字母,可以包含下划线 `_`,例如 `MAX_SIZE`。\n5. **函数**:函数名同样使用驼峰命名法,例如 `calculateTotal`。\n6. **结构体**:结构体的命名同样使用驼峰命名法,例如 `type MyStruct struct`。\n7. **接口**:接口的命名同样使用驼峰命名法,例如 `type MyInterface interface`。\n8. **枚举**:枚举的命名同样使用驼峰命名法,例如 `type Color int`。\n\n\n在 Go 语言中,命名变量时有一些常见的命名规范,这些规范有助于编写清晰、易读的代码。\n\n1. 使用驼峰命名法:变量名应该使用驼峰命名法,即除第一个单词外,其余单词的首字母大写,例如 `myVariable`。\n2. 使用有意义的名称:变量名应该具有描述性,能够清晰地表达变量的用途和含义。\n3. 避免使用单个字符作为变量名:除非是临时变量或者循环变量,否则应该避免使用单个字符作为变量名,以提高代码的可读性。\n4. 使用短小的名称:变量名应该尽量简洁,但又能清晰表达变量的含义。\n5. 使用全大写命名的常量:在 Go 语言中,全大写的变量名通常用于表示常量。\n6. 遵循约定俗成的命名规范:Go 语言社区有一些常见的命名约定,比如用 `i` 表示循环变量,用 `err` 表示错误变量等,建议遵循这些约定以保持代码风格的一致性。\n\n这些命名规范有助于编写清晰、易读的代码,并且有助于提高代码的可维护性。\n\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md.json deleted file mode 100644 index 5809540..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md.json +++ /dev/null @@ -1,62 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 11, - "patches": [ - { - "date": 1715563395135, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1715563401311, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,8 +1,8 @@\n ---\n title: \"LearningPath\"\n date: 2024-05-13T09:08:32+08:00\n-draft:\n+draft: false\n taps: []\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n" - }, - { - "date": 1715563409629, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -9,4 +9,56 @@\n weight:\n math: false\n readingTime: true\n ---\n+\n+## Hello, Golang\n+\n+Go 语言是 Google 开发的一种**静态强类型**、**编译型**、**并发型**,并具有**垃圾回收功能**的编程语言。\n+\n+>下载地址:[Downloads - The Go Programming Language](https://go.dev/dl/)\n+\n+## 快速开始\n+\n+- 下载 Go 到你的学习机上,检查 go 的现状\n+```shell\n+go version\n+```\n+- 在你喜欢的 Workspace 上 Create a new directory\n+```shell\n+mkdir gowork\n+```\n+- 添加一个名为 `hello.go` 的文件,在其中输入代码\n+> In vim, vscode ...\n+\n+```go\n+package main\n+\n+import \"fmt\"\n+\n+func main() {\n+\tfmt.Println(\"Hello, world\")\n+}\n+```\n+\n+> In shell\n+\n+```shell\n+echo\n+\"package main\n+\n+import \"fmt\"\n+\n+func main() {\n+\tfmt.Println(\"Hello, world\")\n+}\" >> hello.go\n+```\n+- 运行它\n+```\n+go run hell.go\n+```\n+\n+Welcome to Go!\n+\n+## 其他\n+\n+![](https://s2.loli.net/2024/05/06/pE3MQOLJI2lNGRY.png)\n" - }, - { - "date": 1715563419017, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -19,25 +19,30 @@\n \n ## 快速开始\n \n - 下载 Go 到你的学习机上,检查 go 的现状\n+\n ```shell\n go version\n ```\n+\n - 在你喜欢的 Workspace 上 Create a new directory\n+\n ```shell\n mkdir gowork\n ```\n+\n - 添加一个名为 `hello.go` 的文件,在其中输入代码\n+\n > In vim, vscode ...\n \n ```go\n package main\n \n import \"fmt\"\n \n func main() {\n-\tfmt.Println(\"Hello, world\")\n+ fmt.Println(\"Hello, world\")\n }\n ```\n \n > In shell\n@@ -48,12 +53,14 @@\n \n import \"fmt\"\n \n func main() {\n-\tfmt.Println(\"Hello, world\")\n+ fmt.Println(\"Hello, world\")\n }\" >> hello.go\n ```\n+\n - 运行它\n+\n ```\n go run hell.go\n ```\n \n" - }, - { - "date": 1715564388179, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"LearningPath\"\n date: 2024-05-13T09:08:32+08:00\n draft: false\n-taps: []\n+taps: [\"]\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n@@ -59,9 +59,9 @@\n ```\n \n - 运行它\n \n-```\n+```shell\n go run hell.go\n ```\n \n Welcome to Go!\n" - }, - { - "date": 1715564393520, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"LearningPath\"\n date: 2024-05-13T09:08:32+08:00\n draft: false\n-taps: [\"]\n+taps: [\"Golang\", ]\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - }, - { - "date": 1715564399979, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n title: \"LearningPath\"\n date: 2024-05-13T09:08:32+08:00\n draft: false\n-taps: [\"Golang\", ]\n-categories: []\n+taps: [\"Golang\", \"start\"]\n+categories: [\"Golang\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1715564413491, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -2,9 +2,9 @@\n title: \"LearningPath\"\n date: 2024-05-13T09:08:32+08:00\n draft: false\n taps: [\"Golang\", \"start\"]\n-categories: [\"Golang\"]\n+categories: [\"Golang\", \"CS\", \"Languages\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n@@ -14,9 +14,9 @@\n ## Hello, Golang\n \n Go 语言是 Google 开发的一种**静态强类型**、**编译型**、**并发型**,并具有**垃圾回收功能**的编程语言。\n \n->下载地址:[Downloads - The Go Programming Language](https://go.dev/dl/)\n+> 下载地址:[Downloads - The Go Programming Language](https://go.dev/dl/)\n \n ## 快速开始\n \n - 下载 Go 到你的学习机上,检查 go 的现状\n" - }, - { - "date": 1715564421156, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -14,9 +14,9 @@\n ## Hello, Golang\n \n Go 语言是 Google 开发的一种**静态强类型**、**编译型**、**并发型**,并具有**垃圾回收功能**的编程语言。\n \n-> 下载地址:[Downloads - The Go Programming Language](https://go.dev/dl/)\n+>下载地址:[Downloads - The Go Programming Language](https://go.dev/dl/)\n \n ## 快速开始\n \n - 下载 Go 到你的学习机上,检查 go 的现状\n" - }, - { - "date": 1715565809202, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"LearningPath\"\n date: 2024-05-13T09:08:32+08:00\n draft: false\n-taps: [\"Golang\", \"start\"]\n+taps: [\"Golang\", ]\n categories: [\"Golang\", \"CS\", \"Languages\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - }, - { - "date": 1716172781799, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"LearningPath\"\n date: 2024-05-13T09:08:32+08:00\n draft: false\n-taps: [\"Golang\", ]\n+taps: [\"Golang\", \"start\"]\n categories: [\"Golang\", \"CS\", \"Languages\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - }, - { - "date": 1716175496301, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: \"LearningPath\"\n+title: \"学习之路\"\n date: 2024-05-13T09:08:32+08:00\n draft: false\n taps: [\"Golang\", \"start\"]\n categories: [\"Golang\", \"CS\", \"Languages\"]\n" - } - ], - "date": 1715563395135, - "name": "Commit-0", - "content": "---\ntitle: \"LearningPath\"\ndate: 2024-05-13T09:08:32+08:00\ndraft:\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md.json deleted file mode 100644 index 78b708a..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md.json +++ /dev/null @@ -1,34 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 4, - "patches": [ - { - "date": 1716172784699, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1716172813333, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: \"Map\"\n+title: \"Map的\"\n date: 2024-05-13T09:10:47+08:00\n draft: true\n taps: [\"Golang\", \"start\"]\n categories: [\"Golang\", \"CS\", \"Languages\"]\n" - }, - { - "date": 1716172818469, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: \"Map的\"\n+title: \"Map的基础\"\n date: 2024-05-13T09:10:47+08:00\n draft: true\n taps: [\"Golang\", \"start\"]\n categories: [\"Golang\", \"CS\", \"Languages\"]\n" - }, - { - "date": 1716172828647, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -9,4 +9,5 @@\n weight:\n math: false\n readingTime: true\n ---\n+\n" - }, - { - "date": 1716175504477, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -9,5 +9,4 @@\n weight:\n math: false\n readingTime: true\n ---\n-\n" - } - ], - "date": 1716172784699, - "name": "Commit-0", - "content": "---\ntitle: \"Map\"\ndate: 2024-05-13T09:10:47+08:00\ndraft: true\ntaps: [\"Golang\", \"start\"]\ncategories: [\"Golang\", \"CS\", \"Languages\"]\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md.json deleted file mode 100644 index f334e96..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md.json +++ /dev/null @@ -1,50 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 8, - "patches": [ - { - "date": 1715565567788, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1715565572923, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"Resource\"\n date: 2024-05-13T09:08:51+08:00\n-draft: true\n-taps: []\n+draft: false\n+taps: [\"]\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n@@ -23,6 +23,4 @@\n \n [Reddit 上的go社区](https://www.reddit.com/r/golang/)\n \n ## 书籍推荐\n-\n-\n" - }, - { - "date": 1715565580801, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n title: \"Resource\"\n date: 2024-05-13T09:08:51+08:00\n draft: false\n-taps: [\"]\n-categories: []\n+taps: [\"Golang\", \"start\"]\n+categories: [\"Golang\", \"CS\", \"\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1716172549949, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -2,9 +2,9 @@\n title: \"Resource\"\n date: 2024-05-13T09:08:51+08:00\n draft: false\n taps: [\"Golang\", \"start\"]\n-categories: [\"Golang\", \"CS\", \"\"]\n+categories: [\"Golang\", \"CS\", \"Resource\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n@@ -23,4 +23,18 @@\n \n [Reddit 上的go社区](https://www.reddit.com/r/golang/)\n \n ## 书籍推荐\n+\n+### 电子书\n+[Golang修养之路](https://www.yuque.com/aceld/golang)\n+[Go 语言设计与实现](https://draveness.me/golang/)\n+[Golang中文学习文档站](https://golang.halfiisland.com/)\n+[Go 语言原本](https://golang.design/under-the-hood/)\n+[Go语言101](https://gfw.go101.org/)\n+\n+### 实体书\n+\n+\n+## Github stars\n+\n+[Starred to github](https://github.com/stars/FeiNiaoBF/lists/golang)\n" - }, - { - "date": 1716172557414, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -25,16 +25,16 @@\n \n ## 书籍推荐\n \n ### 电子书\n+\n [Golang修养之路](https://www.yuque.com/aceld/golang)\n [Go 语言设计与实现](https://draveness.me/golang/)\n [Golang中文学习文档站](https://golang.halfiisland.com/)\n [Go 语言原本](https://golang.design/under-the-hood/)\n [Go语言101](https://gfw.go101.org/)\n \n ### 实体书\n \n-\n ## Github stars\n \n [Starred to github](https://github.com/stars/FeiNiaoBF/lists/golang)\n" - }, - { - "date": 1716172564357, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: \"Resource\"\n+title: \"\"\n date: 2024-05-13T09:08:51+08:00\n draft: false\n taps: [\"Golang\", \"start\"]\n categories: [\"Golang\", \"CS\", \"Resource\"]\n" - }, - { - "date": 1716172572729, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: \"\"\n+title: \"Gozi'yuan\"\n date: 2024-05-13T09:08:51+08:00\n draft: false\n taps: [\"Golang\", \"start\"]\n categories: [\"Golang\", \"CS\", \"Resource\"]\n" - }, - { - "date": 1716172579010, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: \"Gozi'yuan\"\n+title: \"Go学习资源\"\n date: 2024-05-13T09:08:51+08:00\n draft: false\n taps: [\"Golang\", \"start\"]\n categories: [\"Golang\", \"CS\", \"Resource\"]\n" - }, - { - "date": 1716172789639, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -2,9 +2,9 @@\n title: \"Go学习资源\"\n date: 2024-05-13T09:08:51+08:00\n draft: false\n taps: [\"Golang\", \"start\"]\n-categories: [\"Golang\", \"CS\", \"Resource\"]\n+categories: [\"Golang\", \"CS\", \"Languages\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - } - ], - "date": 1715565567788, - "name": "Commit-0", - "content": "---\ntitle: \"Resource\"\ndate: 2024-05-13T09:08:51+08:00\ndraft: true\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n\n## 入门资料\n\n[官方Docs](https://go.dev/doc/effective_go) ,官方的文档是最好的入门资料,强烈推荐看,如果可以完整看完、理解并实践的话说明就吃透 Go 语言了。\n\n[Go by Example](https://gobyexample.com/),是一个集合了 Go 语言基础类型、特性等众多示例的网站,你可以通过这些实例来初步了解和学习 Go 语言的使用。\n\n[Learn GO with Tests](https://quii.gitbook.io/learn-go-with-tests),该网址是通过使用 Test 来学习 Go 的开源书籍,在其中作者将以如何使用 Go 自带的 `testing` 库来一步一步的认识 Go 语言当中的类型和其他特性。从中将学习到 **TDD** 的技术、Go 语言的单元测试、学习测试驱动开发等,很大的提升自己的 Go 语言的使用和开发\n\n## 社交平台\n\n[Reddit 上的go社区](https://www.reddit.com/r/golang/)\n\n## 书籍推荐\n\n\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md.json deleted file mode 100644 index 6970b31..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md.json +++ /dev/null @@ -1,34 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 4, - "patches": [ - { - "date": 1715565831192, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1715565836601, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,8 +1,8 @@\n ---\n title: \"Strings\"\n date: 2024-05-13T09:10:39+08:00\n-draft: true\n+draft: false\n taps: []\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n" - }, - { - "date": 1715565842522, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n title: \"Strings\"\n date: 2024-05-13T09:10:39+08:00\n draft: false\n-taps: []\n-categories: []\n+taps: [\"Golang\"]\n+categories: [\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1715565847786, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -2,9 +2,9 @@\n title: \"Strings\"\n date: 2024-05-13T09:10:39+08:00\n draft: false\n taps: [\"Golang\"]\n-categories: [\"]\n+categories: [\"Golang\", \"CS\",\"start\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1716172845835, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n title: \"Strings\"\n date: 2024-05-13T09:10:39+08:00\n draft: false\n-taps: [\"Golang\"]\n-categories: [\"Golang\", \"CS\",\"start\"]\n+taps: [\"Golang\", \"string\",\"start\"]\n+categories: [\"Golang\", \"CS\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - } - ], - "date": 1715565831192, - "name": "Commit-0", - "content": "---\ntitle: \"Strings\"\ndate: 2024-05-13T09:10:39+08:00\ndraft: true\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n\n## UTF-8编码和 Unicode 文本区别\n\n在 Golang 中字符串的底层结构字节使用 UTF-8 编码来表示 Unicode 文本\n\n其中 _Unicode_ 是一个**字符集**,定义了字符和它们的唯一**代码点**,而 _UTF-8_ 是一种**编码方式**,用于将 Unicode 字符表示为字节序列。\n\n## 字符串\n\nGo 语言中的字符串值是一个可空的**字节序列**,字节序列中的字节个数称为该字符串的长度。String 类型其实是一个\"**描述符**”,它本身并不真正存储字符串数据,而是由一个指向底层存储的指针和字符串的长度字段组成的\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/_index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/_index.zh-cn.md.json deleted file mode 100644 index abdbb2e..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/_index.zh-cn.md.json +++ /dev/null @@ -1,58 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/_index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 10, - "patches": [ - { - "date": 1715566200732, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1715566786853, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -5,9 +5,9 @@\n taps: []\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n-weight:\n+weight: 1\n math: false\n readingTime: true\n \n ---\n" - }, - { - "date": 1715566862711, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -8,6 +8,6 @@\n showtoc: true\n weight: 1\n math: false\n readingTime: true\n-\n+i\n ---\n" - }, - { - "date": 1715566869192, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -8,6 +8,6 @@\n showtoc: true\n weight: 1\n math: false\n readingTime: true\n-i\n+icon: \"🚀\"\n ---\n" - }, - { - "date": 1715566884973, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -8,6 +8,6 @@\n showtoc: true\n weight: 1\n math: false\n readingTime: true\n-icon: \"🚀\"\n+\n ---\n" - }, - { - "date": 1715566892212, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -5,9 +5,9 @@\n taps: []\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n-weight: 1\n+weight: \n math: false\n readingTime: true\n \n ---\n" - }, - { - "date": 1715566900740, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -5,9 +5,8 @@\n taps: []\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n-weight: \n+weight: -100\n math: false\n readingTime: true\n-\n ---\n" - }, - { - "date": 1715566996853, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -8,5 +8,6 @@\n showtoc: true\n weight: -100\n math: false\n readingTime: true\n+image: \n ---\n" - }, - { - "date": 1715567004719, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -8,6 +8,6 @@\n showtoc: true\n weight: -100\n math: false\n readingTime: true\n-image: \n+image: \"./image.png\"\n ---\n" - }, - { - "date": 1715567029338, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -8,6 +8,5 @@\n showtoc: true\n weight: -100\n math: false\n readingTime: true\n-image: \"./image.png\"\n ---\n" - }, - { - "date": 1715567045176, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: \"start\"\n+title: \"起\"\n date: 2024-03-14T21:53:46+08:00\n draft: false\n taps: []\n categories: []\n" - } - ], - "date": 1715566200732, - "name": "Commit-0", - "content": "---\ntitle: \"start\"\ndate: 2024-03-14T21:53:46+08:00\ndraft: false\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n\n---\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/bitop/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/bitop/index.zh-cn.md.json deleted file mode 100644 index 27f2d72..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/bitop/index.zh-cn.md.json +++ /dev/null @@ -1,198 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/bitop/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 45, - "patches": [ - { - "date": 1716173682729, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1716173699183, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -9,4 +9,62 @@\n weight:\n math: false\n readingTime: true\n ---\n+\n+## 运算操作符\n+\n+运算操作符包括算术运算符、位运算符、比较运算符、布尔运算符和字符串衔接运算符这些二元(需要两个操作数)或一元(需要一个操作数)\n+\n+满足二元条件\n+- 如果这两个操作数都是**类型确定值**,则它们的类型必须相同,或者其中一个操作数可以被隐式转换到另一个操作数的类型。\n+- 如果其中有一个操作数是**类型确定**的,另外一个为**类型不确定**操作数可以表示为此类型确定操作数的类型的值,要么此类型不确定操作数的默认类型的任何值可以被隐式转换到此类型确定操作数的类型。\n+- 如果这两个操作数都是**类型不确定**的,则它们必须同时都为两个布尔值,同时都为两个字符串值,或者同时都为两个基本数字值。\n+二元条件:\n+```go\n+// 清零 go 特有的\n+z := 0b1101 &^ 0b0001\n+fmt.Printf(\"z: %b\", z) // 1100\n+```\n+\n+\n+满足一元条件\n+- 如果这个操作数是类型确定的,则它的类型必须为所要求的特定类型,或者此操作数可以被隐式转换为所要求的特定类型。\n+- 如果一个操作数是类型不确定的,则要么此操作数可以表示为所要求的特定类型值,要么此操作数的默认类型的任何值可以被隐式转换为所要求的特定类型。\n+一元条件:\n+**`^` 位反(或位补)**\n+\n+- 一个类型确定数字型常量所表示的值是不能溢出它的类型的表示范围的。\n+- 一个类型不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。 当一个类型不确定数字常量值溢出它的默认类型的表示范围时,此数值不会被截断(亦即回绕)。\n+- 将一个非常量数字值转换为其它数字类型时,此非常量数字值可以溢出转化结果的类型。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断(亦即回绕)表示。\n+\n+## 数值运算符\n+\n+#### 除法和余数运算\n+\n+如果除数 `y` 是一个常量,则它必须不为0,否则编译不通过。如果它是一个整数型非常量,则在运行时刻将抛出一个**恐慌**(panic)。恐慌类似与某些其它语言中的异常(exception)。我们将在以后的文章中了解到 Go 中的恐慌和恐慌恢复机制。如果除数 `y` 非整数型的非常量,则运算结果为一个无穷大(Inf,当被除数不为0时)或者 `NaN`(not a number,当被除数为0时)\n+\n+#### 自增和自减操作符\n+\n+和很多其它流行语言一样,Go 也支持自增(`++`)和自减(`--`)操作符。不过和其它语言不一样的是,自增(`aNumber++`)和自减(`aNumber--`)操作没有返回值,所以它们不能当做 _表达式_ 来使用。另一个显著区别是,在 Go 中,自增(`++`)和自减(`--`)操作符只能后置,不能前\n+\n+\n+## 字符串衔接运算符\n+\n+```go\n+var a = \"Go\"\n+a += \"lang\"\n+```\n+\n+如果一个字符串衔接运算中的一个操作值为类型确定的,则结果字符串是一个类型和此操作数类型相同的类型确定值。否则,结果字符串是一个类型不确定值(肯定是一个常量)。\n+\n+### 操作符运算的优先级\n+\n+```go\n+* / % << >> & &^ // 1\n++ - | ^ // 2\n+== != < <= > >= // 3\n+&& // 4\n+|| // 5\n+```\n+移位运算`<<`和`>>`的优先级比加减法`+`和`-`的优先级要高。\n+\n" - }, - { - "date": 1716173711509, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -15,20 +15,22 @@\n \n 运算操作符包括算术运算符、位运算符、比较运算符、布尔运算符和字符串衔接运算符这些二元(需要两个操作数)或一元(需要一个操作数)\n \n 满足二元条件\n+\n - 如果这两个操作数都是**类型确定值**,则它们的类型必须相同,或者其中一个操作数可以被隐式转换到另一个操作数的类型。\n - 如果其中有一个操作数是**类型确定**的,另外一个为**类型不确定**操作数可以表示为此类型确定操作数的类型的值,要么此类型不确定操作数的默认类型的任何值可以被隐式转换到此类型确定操作数的类型。\n - 如果这两个操作数都是**类型不确定**的,则它们必须同时都为两个布尔值,同时都为两个字符串值,或者同时都为两个基本数字值。\n 二元条件:\n+\n ```go\n // 清零 go 特有的\n z := 0b1101 &^ 0b0001\n fmt.Printf(\"z: %b\", z) // 1100\n ```\n \n+满足一元条件\n \n-满足一元条件\n - 如果这个操作数是类型确定的,则它的类型必须为所要求的特定类型,或者此操作数可以被隐式转换为所要求的特定类型。\n - 如果一个操作数是类型不确定的,则要么此操作数可以表示为所要求的特定类型值,要么此操作数的默认类型的任何值可以被隐式转换为所要求的特定类型。\n 一元条件:\n **`^` 位反(或位补)**\n@@ -46,9 +48,8 @@\n #### 自增和自减操作符\n \n 和很多其它流行语言一样,Go 也支持自增(`++`)和自减(`--`)操作符。不过和其它语言不一样的是,自增(`aNumber++`)和自减(`aNumber--`)操作没有返回值,所以它们不能当做 _表达式_ 来使用。另一个显著区别是,在 Go 中,自增(`++`)和自减(`--`)操作符只能后置,不能前\n \n-\n ## 字符串衔接运算符\n \n ```go\n var a = \"Go\"\n@@ -65,6 +66,6 @@\n == != < <= > >= // 3\n && // 4\n || // 5\n ```\n+\n 移位运算`<<`和`>>`的优先级比加减法`+`和`-`的优先级要高。\n-\n" - }, - { - "date": 1716173722458, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -40,9 +40,9 @@\n - 将一个非常量数字值转换为其它数字类型时,此非常量数字值可以溢出转化结果的类型。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断(亦即回绕)表示。\n \n ## 数值运算符\n \n-#### 除法和余数运算\n+### 除法和余数运算\n \n 如果除数 `y` 是一个常量,则它必须不为0,否则编译不通过。如果它是一个整数型非常量,则在运行时刻将抛出一个**恐慌**(panic)。恐慌类似与某些其它语言中的异常(exception)。我们将在以后的文章中了解到 Go 中的恐慌和恐慌恢复机制。如果除数 `y` 非整数型的非常量,则运算结果为一个无穷大(Inf,当被除数不为0时)或者 `NaN`(not a number,当被除数为0时)\n \n #### 自增和自减操作符\n" - }, - { - "date": 1716173730459, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -32,9 +32,9 @@\n \n - 如果这个操作数是类型确定的,则它的类型必须为所要求的特定类型,或者此操作数可以被隐式转换为所要求的特定类型。\n - 如果一个操作数是类型不确定的,则要么此操作数可以表示为所要求的特定类型值,要么此操作数的默认类型的任何值可以被隐式转换为所要求的特定类型。\n 一元条件:\n-**`^` 位反(或位补)**\n+**`^` 位反(或位补) **\n \n - 一个类型确定数字型常量所表示的值是不能溢出它的类型的表示范围的。\n - 一个类型不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。 当一个类型不确定数字常量值溢出它的默认类型的表示范围时,此数值不会被截断(亦即回绕)。\n - 将一个非常量数字值转换为其它数字类型时,此非常量数字值可以溢出转化结果的类型。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断(亦即回绕)表示。\n@@ -44,9 +44,9 @@\n ### 除法和余数运算\n \n 如果除数 `y` 是一个常量,则它必须不为0,否则编译不通过。如果它是一个整数型非常量,则在运行时刻将抛出一个**恐慌**(panic)。恐慌类似与某些其它语言中的异常(exception)。我们将在以后的文章中了解到 Go 中的恐慌和恐慌恢复机制。如果除数 `y` 非整数型的非常量,则运算结果为一个无穷大(Inf,当被除数不为0时)或者 `NaN`(not a number,当被除数为0时)\n \n-#### 自增和自减操作符\n+### 自增和自减操作符\n \n 和很多其它流行语言一样,Go 也支持自增(`++`)和自减(`--`)操作符。不过和其它语言不一样的是,自增(`aNumber++`)和自减(`aNumber--`)操作没有返回值,所以它们不能当做 _表达式_ 来使用。另一个显著区别是,在 Go 中,自增(`++`)和自减(`--`)操作符只能后置,不能前\n \n ## 字符串衔接运算符\n" - }, - { - "date": 1716173750980, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -12,9 +12,9 @@\n ---\n \n ## 运算操作符\n \n-运算操作符包括算术运算符、位运算符、比较运算符、布尔运算符和字符串衔接运算符这些二元(需要两个操作数)或一元(需要一个操作数)\n+运算操作符包括`算术运算符`、位运算符、比较运算符、布尔运算符和字符串衔接运算符这些二元(需要两个操作数)或一元(需要一个操作数)\n \n 满足二元条件\n \n - 如果这两个操作数都是**类型确定值**,则它们的类型必须相同,或者其中一个操作数可以被隐式转换到另一个操作数的类型。\n@@ -32,9 +32,9 @@\n \n - 如果这个操作数是类型确定的,则它的类型必须为所要求的特定类型,或者此操作数可以被隐式转换为所要求的特定类型。\n - 如果一个操作数是类型不确定的,则要么此操作数可以表示为所要求的特定类型值,要么此操作数的默认类型的任何值可以被隐式转换为所要求的特定类型。\n 一元条件:\n-**`^` 位反(或位补) **\n+**`^` 位反(或位补)**\n \n - 一个类型确定数字型常量所表示的值是不能溢出它的类型的表示范围的。\n - 一个类型不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。 当一个类型不确定数字常量值溢出它的默认类型的表示范围时,此数值不会被截断(亦即回绕)。\n - 将一个非常量数字值转换为其它数字类型时,此非常量数字值可以溢出转化结果的类型。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断(亦即回绕)表示。\n" - }, - { - "date": 1716173756836, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -12,9 +12,9 @@\n ---\n \n ## 运算操作符\n \n-运算操作符包括`算术运算符`、位运算符、比较运算符、布尔运算符和字符串衔接运算符这些二元(需要两个操作数)或一元(需要一个操作数)\n+运算操作符包括`算术运算符`、`位运算符`、`比较运算符`、`布尔运算符`和字符串衔接运算符这些二元(需要两个操作数)或一元(需要一个操作数)\n \n 满足二元条件\n \n - 如果这两个操作数都是**类型确定值**,则它们的类型必须相同,或者其中一个操作数可以被隐式转换到另一个操作数的类型。\n" - }, - { - "date": 1716173763719, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -12,9 +12,9 @@\n ---\n \n ## 运算操作符\n \n-运算操作符包括`算术运算符`、`位运算符`、`比较运算符`、`布尔运算符`和字符串衔接运算符这些二元(需要两个操作数)或一元(需要一个操作数)\n+运算操作符包括`算术运算符`、`位运算符`、`比较运算符`、`布尔运算符`和`字符串衔接运算符`这些二元(需要两个操作数)或一元(需要一个操作数)\n \n 满足二元条件\n \n - 如果这两个操作数都是**类型确定值**,则它们的类型必须相同,或者其中一个操作数可以被隐式转换到另一个操作数的类型。\n" - }, - { - "date": 1716173770434, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -12,9 +12,9 @@\n ---\n \n ## 运算操作符\n \n-运算操作符包括`算术运算符`、`位运算符`、`比较运算符`、`布尔运算符`和`字符串衔接运算符`这些二元(需要两个操作数)或一元(需要一个操作数)\n+运算操作符包括`算术运算符`、`位运算符`、`比较运算符`、`布尔运算符`和`字符串衔接运算符`这些二元(需要两个操作数)或一元(需要一个操作数)操作符\n \n 满足二元条件\n \n - 如果这两个操作数都是**类型确定值**,则它们的类型必须相同,或者其中一个操作数可以被隐式转换到另一个操作数的类型。\n" - }, - { - "date": 1716173781340, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -12,11 +12,11 @@\n ---\n \n ## 运算操作符\n \n-运算操作符包括`算术运算符`、`位运算符`、`比较运算符`、`布尔运算符`和`字符串衔接运算符`这些二元(需要两个操作数)或一元(需要一个操作数)操作符\n+运算操作符包括`算术运算符`、`位运算符`、`比较运算符`、`布尔运算符`和`字符串衔接运算符`这些二元(需要两个操作数)或一元(需要一个操作数)操作符。\n \n-满足二元条件\n+## 满足二元条件\n \n - 如果这两个操作数都是**类型确定值**,则它们的类型必须相同,或者其中一个操作数可以被隐式转换到另一个操作数的类型。\n - 如果其中有一个操作数是**类型确定**的,另外一个为**类型不确定**操作数可以表示为此类型确定操作数的类型的值,要么此类型不确定操作数的默认类型的任何值可以被隐式转换到此类型确定操作数的类型。\n - 如果这两个操作数都是**类型不确定**的,则它们必须同时都为两个布尔值,同时都为两个字符串值,或者同时都为两个基本数字值。\n" - }, - { - "date": 1716173790813, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -27,9 +27,9 @@\n z := 0b1101 &^ 0b0001\n fmt.Printf(\"z: %b\", z) // 1100\n ```\n \n-满足一元条件\n+## 满足一元条件\n \n - 如果这个操作数是类型确定的,则它的类型必须为所要求的特定类型,或者此操作数可以被隐式转换为所要求的特定类型。\n - 如果一个操作数是类型不确定的,则要么此操作数可以表示为所要求的特定类型值,要么此操作数的默认类型的任何值可以被隐式转换为所要求的特定类型。\n 一元条件:\n" - }, - { - "date": 1716173800916, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -22,9 +22,8 @@\n - 如果这两个操作数都是**类型不确定**的,则它们必须同时都为两个布尔值,同时都为两个字符串值,或者同时都为两个基本数字值。\n 二元条件:\n \n ```go\n-// 清零 go 特有的\n z := 0b1101 &^ 0b0001\n fmt.Printf(\"z: %b\", z) // 1100\n ```\n \n" - }, - { - "date": 1716174790462, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -11,11 +11,18 @@\n readingTime: true\n ---\n \n ## 运算操作符\n+算术运算符:如加减乘除等。\n \n-运算操作符包括`算术运算符`、`位运算符`、`比较运算符`、`布尔运算符`和`字符串衔接运算符`这些二元(需要两个操作数)或一元(需要一个操作数)操作符。\n+位运算符:如按位与、或、异或等。\n \n+比较运算符:如等于、不等于、大于、小于等。\n+\n+布尔运算符:如逻辑与、或、非。\n+\n+字符串衔接运算符:用于连接字符串。\n+\n ## 满足二元条件\n \n - 如果这两个操作数都是**类型确定值**,则它们的类型必须相同,或者其中一个操作数可以被隐式转换到另一个操作数的类型。\n - 如果其中有一个操作数是**类型确定**的,另外一个为**类型不确定**操作数可以表示为此类型确定操作数的类型的值,要么此类型不确定操作数的默认类型的任何值可以被隐式转换到此类型确定操作数的类型。\n" - }, - { - "date": 1716174796720, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -11,10 +11,10 @@\n readingTime: true\n ---\n \n ## 运算操作符\n-算术运算符:如加减乘除等。\n \n+- 算术运算符:如加减乘除等。\n 位运算符:如按位与、或、异或等。\n \n 比较运算符:如等于、不等于、大于、小于等。\n \n" - }, - { - "date": 1716174802185, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -13,12 +13,11 @@\n \n ## 运算操作符\n \n - 算术运算符:如加减乘除等。\n-位运算符:如按位与、或、异或等。\n+- 位运算符:如按位与、或、异或等。\n+- 比较运算符:如等于、不等于、大于、小于等。\n \n-比较运算符:如等于、不等于、大于、小于等。\n-\n 布尔运算符:如逻辑与、或、非。\n \n 字符串衔接运算符:用于连接字符串。\n \n" - }, - { - "date": 1716174807383, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -15,13 +15,11 @@\n \n - 算术运算符:如加减乘除等。\n - 位运算符:如按位与、或、异或等。\n - 比较运算符:如等于、不等于、大于、小于等。\n+- 布尔运算符:如逻辑与、或、非。\n+- 字符串衔接运算符:用于连接字符串。\n \n-布尔运算符:如逻辑与、或、非。\n-\n-字符串衔接运算符:用于连接字符串。\n-\n ## 满足二元条件\n \n - 如果这两个操作数都是**类型确定值**,则它们的类型必须相同,或者其中一个操作数可以被隐式转换到另一个操作数的类型。\n - 如果其中有一个操作数是**类型确定**的,另外一个为**类型不确定**操作数可以表示为此类型确定操作数的类型的值,要么此类型不确定操作数的默认类型的任何值可以被隐式转换到此类型确定操作数的类型。\n" - }, - { - "date": 1716174827433, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -20,13 +20,13 @@\n - 字符串衔接运算符:用于连接字符串。\n \n ## 满足二元条件\n \n-- 如果这两个操作数都是**类型确定值**,则它们的类型必须相同,或者其中一个操作数可以被隐式转换到另一个操作数的类型。\n-- 如果其中有一个操作数是**类型确定**的,另外一个为**类型不确定**操作数可以表示为此类型确定操作数的类型的值,要么此类型不确定操作数的默认类型的任何值可以被隐式转换到此类型确定操作数的类型。\n-- 如果这两个操作数都是**类型不确定**的,则它们必须同时都为两个布尔值,同时都为两个字符串值,或者同时都为两个基本数字值。\n-二元条件:\n+二元运算符条件\n+操作数必须类型相同或可隐式转换。\n \n+类型不确定的操作数需能表示为类型确定操作数的类型。\n+\n ```go\n z := 0b1101 &^ 0b0001\n fmt.Printf(\"z: %b\", z) // 1100\n ```\n" - }, - { - "date": 1716174833270, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -20,11 +20,9 @@\n - 字符串衔接运算符:用于连接字符串。\n \n ## 满足二元条件\n \n-二元运算符条件\n-操作数必须类型相同或可隐式转换。\n-\n+- 操作数必须类型相同或可隐式转换。\n 类型不确定的操作数需能表示为类型确定操作数的类型。\n \n ```go\n z := 0b1101 &^ 0b0001\n" - }, - { - "date": 1716174840441, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -21,9 +21,9 @@\n \n ## 满足二元条件\n \n - 操作数必须类型相同或可隐式转换。\n-类型不确定的操作数需能表示为类型确定操作数的类型。\n+- 类型不确定的操作数需能表示为类型确定操作数的类型。\n \n ```go\n z := 0b1101 &^ 0b0001\n fmt.Printf(\"z: %b\", z) // 1100\n@@ -32,8 +32,10 @@\n ## 满足一元条件\n \n - 如果这个操作数是类型确定的,则它的类型必须为所要求的特定类型,或者此操作数可以被隐式转换为所要求的特定类型。\n - 如果一个操作数是类型不确定的,则要么此操作数可以表示为所要求的特定类型值,要么此操作数的默认类型的任何值可以被隐式转换为所要求的特定类型。\n+\n+\n 一元条件:\n **`^` 位反(或位补)**\n \n - 一个类型确定数字型常量所表示的值是不能溢出它的类型的表示范围的。\n" - }, - { - "date": 1716174886247, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -34,8 +34,9 @@\n - 如果这个操作数是类型确定的,则它的类型必须为所要求的特定类型,或者此操作数可以被隐式转换为所要求的特定类型。\n - 如果一个操作数是类型不确定的,则要么此操作数可以表示为所要求的特定类型值,要么此操作数的默认类型的任何值可以被隐式转换为所要求的特定类型。\n \n \n+-\n 一元条件:\n **`^` 位反(或位补)**\n \n - 一个类型确定数字型常量所表示的值是不能溢出它的类型的表示范围的。\n" - }, - { - "date": 1716174894514, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -33,10 +33,9 @@\n \n - 如果这个操作数是类型确定的,则它的类型必须为所要求的特定类型,或者此操作数可以被隐式转换为所要求的特定类型。\n - 如果一个操作数是类型不确定的,则要么此操作数可以表示为所要求的特定类型值,要么此操作数的默认类型的任何值可以被隐式转换为所要求的特定类型。\n \n-\n--\n+- 操作数\n 一元条件:\n **`^` 位反(或位补)**\n \n - 一个类型确定数字型常量所表示的值是不能溢出它的类型的表示范围的。\n" - }, - { - "date": 1716174902315, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -33,9 +33,10 @@\n \n - 如果这个操作数是类型确定的,则它的类型必须为所要求的特定类型,或者此操作数可以被隐式转换为所要求的特定类型。\n - 如果一个操作数是类型不确定的,则要么此操作数可以表示为所要求的特定类型值,要么此操作数的默认类型的任何值可以被隐式转换为所要求的特定类型。\n \n-- 操作数\n+- 操作数类型确定\n+-\n 一元条件:\n **`^` 位反(或位补)**\n \n - 一个类型确定数字型常量所表示的值是不能溢出它的类型的表示范围的。\n" - }, - { - "date": 1716174917429, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -34,9 +34,9 @@\n - 如果这个操作数是类型确定的,则它的类型必须为所要求的特定类型,或者此操作数可以被隐式转换为所要求的特定类型。\n - 如果一个操作数是类型不确定的,则要么此操作数可以表示为所要求的特定类型值,要么此操作数的默认类型的任何值可以被隐式转换为所要求的特定类型。\n \n - 操作数类型确定\n--\n+- 操作数类型确定\n 一元条件:\n **`^` 位反(或位补)**\n \n - 一个类型确定数字型常量所表示的值是不能溢出它的类型的表示范围的。\n" - }, - { - "date": 1716174926566, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -30,13 +30,10 @@\n ```\n \n ## 满足一元条件\n \n-- 如果这个操作数是类型确定的,则它的类型必须为所要求的特定类型,或者此操作数可以被隐式转换为所要求的特定类型。\n-- 如果一个操作数是类型不确定的,则要么此操作数可以表示为所要求的特定类型值,要么此操作数的默认类型的任何值可以被隐式转换为所要求的特定类型。\n-\n - 操作数类型确定\n-- 操作数类型确定\n+- 操作数类型可以被隐式转换\n 一元条件:\n **`^` 位反(或位补)**\n \n - 一个类型确定数字型常量所表示的值是不能溢出它的类型的表示范围的。\n" - }, - { - "date": 1716174993146, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -32,14 +32,15 @@\n ## 满足一元条件\n \n - 操作数类型确定\n - 操作数类型可以被隐式转换\n+\n 一元条件:\n **`^` 位反(或位补)**\n \n - 一个类型确定数字型常量所表示的值是不能溢出它的类型的表示范围的。\n - 一个类型不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。 当一个类型不确定数字常量值溢出它的默认类型的表示范围时,此数值不会被截断(亦即回绕)。\n-- 将一个非常量数字值转换为其它数字类型时,此非常量数字值可以溢出转化结果的类型。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断(亦即回绕)表示。\n+- 将一个非常量数字值转换为其它数字类型时,此非常量数字值可以溢出转化结果的类型。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断表示。\n \n ## 数值运算符\n \n ### 除法和余数运算\n" - }, - { - "date": 1716175006553, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -36,10 +36,10 @@\n \n 一元条件:\n **`^` 位反(或位补)**\n \n-- 一个类型确定数字型常量所表示的值是不能溢出它的类型的表示范围的。\n-- 一个类型不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。 当一个类型不确定数字常量值溢出它的默认类型的表示范围时,此数值不会被截断(亦即回绕)。\n+- 一个类型为数字型常量所表示的值是不能溢出它的类型的表示范围的。\n+- 一个类型不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。 当一个类型不确定数字常量值溢出它的默认类型的表示范围时,此数值不会被截断。\n - 将一个非常量数字值转换为其它数字类型时,此非常量数字值可以溢出转化结果的类型。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断表示。\n \n ## 数值运算符\n \n" - }, - { - "date": 1716175017255, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -36,9 +36,9 @@\n \n 一元条件:\n **`^` 位反(或位补)**\n \n-- 一个类型为数字型常量所表示的值是不能溢出它的类型的表示范围的。\n+- 类型为数字型常量所表示的值是*不能溢出它的类型的表示范围的。\n - 一个类型不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。 当一个类型不确定数字常量值溢出它的默认类型的表示范围时,此数值不会被截断。\n - 将一个非常量数字值转换为其它数字类型时,此非常量数字值可以溢出转化结果的类型。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断表示。\n \n ## 数值运算符\n" - }, - { - "date": 1716175022836, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -36,10 +36,10 @@\n \n 一元条件:\n **`^` 位反(或位补)**\n \n-- 类型为数字型常量所表示的值是*不能溢出它的类型的表示范围的。\n-- 一个类型不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。 当一个类型不确定数字常量值溢出它的默认类型的表示范围时,此数值不会被截断。\n+- 类型为数字型常量所表示的值是*不能溢出*它的类型的表示范围的。\n+- 类型不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。 当一个类型不确定数字常量值溢出它的默认类型的表示范围时,此数值不会被截断。\n - 将一个非常量数字值转换为其它数字类型时,此非常量数字值可以溢出转化结果的类型。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断表示。\n \n ## 数值运算符\n \n" - }, - { - "date": 1716175028213, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -37,9 +37,9 @@\n 一元条件:\n **`^` 位反(或位补)**\n \n - 类型为数字型常量所表示的值是*不能溢出*它的类型的表示范围的。\n-- 类型不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。 当一个类型不确定数字常量值溢出它的默认类型的表示范围时,此数值不会被截断。\n+- 类型为不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。 当一个类型不确定数字常量值溢出它的默认类型的表示范围时,此数值不会被截断。\n - 将一个非常量数字值转换为其它数字类型时,此非常量数字值可以溢出转化结果的类型。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断表示。\n \n ## 数值运算符\n \n" - }, - { - "date": 1716175040275, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -37,9 +37,9 @@\n 一元条件:\n **`^` 位反(或位补)**\n \n - 类型为数字型常量所表示的值是*不能溢出*它的类型的表示范围的。\n-- 类型为不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。 当一个类型不确定数字常量值溢出它的默认类型的表示范围时,此数值不会被截断。\n+- 类型为不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。此数值不会被截断。\n - 将一个非常量数字值转换为其它数字类型时,此非常量数字值可以溢出转化结果的类型。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断表示。\n \n ## 数值运算符\n \n" - }, - { - "date": 1716175054877, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -38,9 +38,9 @@\n **`^` 位反(或位补)**\n \n - 类型为数字型常量所表示的值是*不能溢出*它的类型的表示范围的。\n - 类型为不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。此数值不会被截断。\n-- 将一个非常量数字值转换为其它数字类型时,此非常量数字值可以溢出转化结果的类型。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断表示。\n+- 将一个非常量数字xie转换为其它数字类型时,此非常量数字值可以溢出转化结果的类型。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断表示。\n \n ## 数值运算符\n \n ### 除法和余数运算\n" - }, - { - "date": 1716175077570, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -38,9 +38,9 @@\n **`^` 位反(或位补)**\n \n - 类型为数字型常量所表示的值是*不能溢出*它的类型的表示范围的。\n - 类型为不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。此数值不会被截断。\n-- 将一个非常量数字xie转换为其它数字类型时,此非常量数字值可以溢出转化结果的类型。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断表示。\n+- 将一个非常量数字型转换为其它数字类型时,此非常量数字值可以溢出转化结果的类型*。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断表示。\n \n ## 数值运算符\n \n ### 除法和余数运算\n" - }, - { - "date": 1716175086212, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -37,10 +37,10 @@\n 一元条件:\n **`^` 位反(或位补)**\n \n - 类型为数字型常量所表示的值是*不能溢出*它的类型的表示范围的。\n-- 类型为不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。此数值不会被截断。\n-- 将一个非常量数字型转换为其它数字类型时,此非常量数字值可以溢出转化结果的类型*。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断表示。\n+- 类型为不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。此数值*不会被截断*。\n+- 将一个非常量数字型转换为其它数字类型时,此非常量数字值*可以溢出转化结果的类型*。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断表示。\n \n ## 数值运算符\n \n ### 除法和余数运算\n" - }, - { - "date": 1716175091877, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -36,9 +36,9 @@\n \n 一元条件:\n **`^` 位反(或位补)**\n \n-- 类型为数字型常量所表示的值是*不能溢出*它的类型的表示范围的。\n+- 类型为数字型常量所表示的值是**不能溢出*它的类型的表示范围的。\n - 类型为不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。此数值*不会被截断*。\n - 将一个非常量数字型转换为其它数字类型时,此非常量数字值*可以溢出转化结果的类型*。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断表示。\n \n ## 数值运算符\n" - }, - { - "date": 1716175097025, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -36,11 +36,11 @@\n \n 一元条件:\n **`^` 位反(或位补)**\n \n-- 类型为数字型常量所表示的值是**不能溢出*它的类型的表示范围的。\n-- 类型为不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。此数值*不会被截断*。\n-- 将一个非常量数字型转换为其它数字类型时,此非常量数字值*可以溢出转化结果的类型*。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断表示。\n+- 类型为数字型常量所表示的值是**不能溢出**它的类型的表示范围的。\n+- 类型为不确定数字型常量所表示的值是可以溢出它的默认类型的表示范围的。此数值**不会被截断**。\n+- 将一个非常量数字型转换为其它数字类型时,此非常量数字值**可以溢出转化结果的类型**。 在此转换中,当溢出发生时,转化结果为此非常量数字值的截断表示。\n \n ## 数值运算符\n \n ### 除法和余数运算\n" - }, - { - "date": 1716175114204, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -44,9 +44,9 @@\n ## 数值运算符\n \n ### 除法和余数运算\n \n-如果除数 `y` 是一个常量,则它必须不为0,否则编译不通过。如果它是一个整数型非常量,则在运行时刻将抛出一个**恐慌**(panic)。恐慌类似与某些其它语言中的异常(exception)。我们将在以后的文章中了解到 Go 中的恐慌和恐慌恢复机制。如果除数 `y` 非整数型的非常量,则运算结果为一个无穷大(Inf,当被除数不为0时)或者 `NaN`(not a number,当被除数为0时)\n+如果除数 `y` 是一个常量,则它必须不为0,否则编译不通过。如果它是一个整数型非常量,则在运行时刻将抛出一个**恐慌**(panic)。恐慌类似与某些其它语言中的异常(exception)。如果除数 `y` 非整数型的非常量,则运算结果为一个无穷大(Inf,当被除数不为0时)或者 `NaN`(not a number,当被除数为0时)\n \n ### 自增和自减操作符\n \n 和很多其它流行语言一样,Go 也支持自增(`++`)和自减(`--`)操作符。不过和其它语言不一样的是,自增(`aNumber++`)和自减(`aNumber--`)操作没有返回值,所以它们不能当做 _表达式_ 来使用。另一个显著区别是,在 Go 中,自增(`++`)和自减(`--`)操作符只能后置,不能前\n" - }, - { - "date": 1716175123040, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -44,9 +44,9 @@\n ## 数值运算符\n \n ### 除法和余数运算\n \n-如果除数 `y` 是一个常量,则它必须不为0,否则编译不通过。如果它是一个整数型非常量,则在运行时刻将抛出一个**恐慌**(panic)。恐慌类似与某些其它语言中的异常(exception)。如果除数 `y` 非整数型的非常量,则运算结果为一个无穷大(Inf,当被除数不为0时)或者 `NaN`(not a number,当被除数为0时)\n+如果除数 `y` 是一个常量,则它必须不为0,否则编译不通过。如果它是一个整数型非常量,则在运行时刻将抛出一个**恐慌**()。如果除数 `y` 非整数型的非常量,则运算结果为一个无穷大(Inf,当被除数不为0时)或者 `NaN`(not a number,当被除数为0时)\n \n ### 自增和自减操作符\n \n 和很多其它流行语言一样,Go 也支持自增(`++`)和自减(`--`)操作符。不过和其它语言不一样的是,自增(`aNumber++`)和自减(`aNumber--`)操作没有返回值,所以它们不能当做 _表达式_ 来使用。另一个显著区别是,在 Go 中,自增(`++`)和自减(`--`)操作符只能后置,不能前\n" - }, - { - "date": 1716175129766, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -44,9 +44,9 @@\n ## 数值运算符\n \n ### 除法和余数运算\n \n-如果除数 `y` 是一个常量,则它必须不为0,否则编译不通过。如果它是一个整数型非常量,则在运行时刻将抛出一个**恐慌**()。如果除数 `y` 非整数型的非常量,则运算结果为一个无穷大(Inf,当被除数不为0时)或者 `NaN`(not a number,当被除数为0时)\n+如果除数 `y` 是一个常量,则它必须不为0,否则编译不通过。如果它是一个整数型非常量,则在运行时刻将抛出一个**panic**。如果除数 `y` 非整数型的非常量,则运算结果为一个无穷大(Inf,当被除数不为0时)或者 `NaN`(not a number,当被除数为0时)\n \n ### 自增和自减操作符\n \n 和很多其它流行语言一样,Go 也支持自增(`++`)和自减(`--`)操作符。不过和其它语言不一样的是,自增(`aNumber++`)和自减(`aNumber--`)操作没有返回值,所以它们不能当做 _表达式_ 来使用。另一个显著区别是,在 Go 中,自增(`++`)和自减(`--`)操作符只能后置,不能前\n" - }, - { - "date": 1716175142817, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -44,9 +44,9 @@\n ## 数值运算符\n \n ### 除法和余数运算\n \n-如果除数 `y` 是一个常量,则它必须不为0,否则编译不通过。如果它是一个整数型非常量,则在运行时刻将抛出一个**panic**。如果除数 `y` 非整数型的非常量,则运算结果为一个无穷大(Inf,当被除数不为0时)或者 `NaN`(not a number,当被除数为0时)\n+如果除数 `y` 是一个常量,则它必须不为0,否则编译不通过。如果它是一个整数型非常量,则在运行时刻将抛出一个**panic**。如果除数 `y` 为非整数型的非常量,则运算结果为一个无穷大(Inf,当被除数不为0时)或者 `NaN`(not a number,当被除数为0时)\n \n ### 自增和自减操作符\n \n 和很多其它流行语言一样,Go 也支持自增(`++`)和自减(`--`)操作符。不过和其它语言不一样的是,自增(`aNumber++`)和自减(`aNumber--`)操作没有返回值,所以它们不能当做 _表达式_ 来使用。另一个显著区别是,在 Go 中,自增(`++`)和自减(`--`)操作符只能后置,不能前\n" - }, - { - "date": 1716175155233, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -44,9 +44,10 @@\n ## 数值运算符\n \n ### 除法和余数运算\n \n-如果除数 `y` 是一个常量,则它必须不为0,否则编译不通过。如果它是一个整数型非常量,则在运行时刻将抛出一个**panic**。如果除数 `y` 为非整数型的非常量,则运算结果为一个无穷大(Inf,当被除数不为0时)或者 `NaN`(not a number,当被除数为0时)\n+如果除数 `y` 是一个常量,则它必须不为0,否则编译不通过。如果它是一个整数型非常量,则在运行时刻将抛出一个**panic**。\n+如果除数 `y` 为一个非整数型的非常量,则运算结果为一个无穷大(Inf,当被除数不为0时)或者 `NaN`(not a number,当被除数为0时)\n \n ### 自增和自减操作符\n \n 和很多其它流行语言一样,Go 也支持自增(`++`)和自减(`--`)操作符。不过和其它语言不一样的是,自增(`aNumber++`)和自减(`aNumber--`)操作没有返回值,所以它们不能当做 _表达式_ 来使用。另一个显著区别是,在 Go 中,自增(`++`)和自减(`--`)操作符只能后置,不能前\n" - }, - { - "date": 1716175168122, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -45,13 +45,14 @@\n \n ### 除法和余数运算\n \n 如果除数 `y` 是一个常量,则它必须不为0,否则编译不通过。如果它是一个整数型非常量,则在运行时刻将抛出一个**panic**。\n+\n 如果除数 `y` 为一个非整数型的非常量,则运算结果为一个无穷大(Inf,当被除数不为0时)或者 `NaN`(not a number,当被除数为0时)\n \n ### 自增和自减操作符\n \n-和很多其它流行语言一样,Go 也支持自增(`++`)和自减(`--`)操作符。不过和其它语言不一样的是,自增(`aNumber++`)和自减(`aNumber--`)操作没有返回值,所以它们不能当做 _表达式_ 来使用。另一个显著区别是,在 Go 中,自增(`++`)和自减(`--`)操作符只能后置,不能前\n+Go 也支持自增(`++`)和自减(`--`)操作符。不过和其它语言不一样的是,自增(`aNumber++`)和自减(`aNumber--`)操作没有返回值,所以它们不能当做 _表达式_ 来使用。另一个显著区别是,在 Go 中,自增(`++`)和自减(`--`)操作符只能后置,不能前\n \n ## 字符串衔接运算符\n \n ```go\n" - }, - { - "date": 1716175176744, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -50,9 +50,10 @@\n 如果除数 `y` 为一个非整数型的非常量,则运算结果为一个无穷大(Inf,当被除数不为0时)或者 `NaN`(not a number,当被除数为0时)\n \n ### 自增和自减操作符\n \n-Go 也支持自增(`++`)和自减(`--`)操作符。不过和其它语言不一样的是,自增(`aNumber++`)和自减(`aNumber--`)操作没有返回值,所以它们不能当做 _表达式_ 来使用。另一个显著区别是,在 Go 中,自增(`++`)和自减(`--`)操作符只能后置,不能前\n+Go 支持自增(`++`)和自减(`--`)操作符。\n+自增(`aNumber++`)和自减(`aNumber--`)操作没有返回值,所以它们不能当做 _表达式_ 来使用。另一个显著区别是,在 Go 中,自增(`++`)和自减(`--`)操作符只能后置,不能前\n \n ## 字符串衔接运算符\n \n ```go\n" - }, - { - "date": 1716175185431, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -51,9 +51,9 @@\n \n ### 自增和自减操作符\n \n Go 支持自增(`++`)和自减(`--`)操作符。\n-自增(`aNumber++`)和自减(`aNumber--`)操作没有返回值,所以它们不能当做 _表达式_ 来使用。另一个显著区别是,在 Go 中,自增(`++`)和自减(`--`)操作符只能后置,不能前\n+但是,自增(`a++`)和自减(`aNumber--`)操作没有返回值,所以它们不能当做 _表达式_ 来使用。另一个显著区别是,在 Go 中,自增(`++`)和自减(`--`)操作符只能后置,不能前\n \n ## 字符串衔接运算符\n \n ```go\n" - }, - { - "date": 1716175193602, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -51,9 +51,9 @@\n \n ### 自增和自减操作符\n \n Go 支持自增(`++`)和自减(`--`)操作符。\n-但是,自增(`a++`)和自减(`aNumber--`)操作没有返回值,所以它们不能当做 _表达式_ 来使用。另一个显著区别是,在 Go 中,自增(`++`)和自减(`--`)操作符只能后置,不能前\n+但是,自增(`a++`)和自减(`a--`)操作**没有返回值**,所以它们不能当做 _表达式_ 来使用。另一个显著区别是,在 Go 中,自增(`++`)和自减(`--`)操作符只能后置,不能前\n \n ## 字符串衔接运算符\n \n ```go\n" - }, - { - "date": 1716175372133, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,8 +1,8 @@\n ---\n title: \"运算操作符\"\n date: 2024-05-20T10:54:30+08:00\n-draft: true\n+draft: false\n taps: []\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n" - }, - { - "date": 1716175381911, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n title: \"运算操作符\"\n date: 2024-05-20T10:54:30+08:00\n draft: false\n-taps: []\n-categories: []\n+taps: ['Golang', 'start']\n+categories: ['Golang', 'CS']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - } - ], - "date": 1716173682729, - "name": "Commit-0", - "content": "---\ntitle: \"运算操作符\"\ndate: 2024-05-20T10:54:30+08:00\ndraft: true\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/keyword/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/keyword/index.zh-cn.md.json deleted file mode 100644 index 6eec755..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/keyword/index.zh-cn.md.json +++ /dev/null @@ -1,42 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/keyword/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 6, - "patches": [ - { - "date": 1716172732165, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1716172738006, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,8 +1,9 @@\n ---\n title: \"Keyword\"\n date: 2024-05-20T10:37:53+08:00\n-draft: fa\n+draft: false\n+taps: []\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - }, - { - "date": 1716172743912, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -9,4 +9,24 @@\n weight:\n math: false\n readingTime: true\n ---\n+\n+## 25个关键字\n+\n+```go\n+break default func interface select\n+case defer go map struct\n+chan else goto package switch\n+const fallthrough if range type\n+continue for import return var\n+```\n+\n+## 规定的标识符(Unicode 字符)\n+\n+- 标识符由字母(Unicode字母,包括中文等)、数字和下划线(`_`)组成。\n+- 标识符的第一个字符必须是字母或下划线。\n+- 标识符区分大小写,例如`count`和`Count`是两个不同的标识符。\n+- 标识符不能是Go语言的关键字。\n+\n+注意:\n+\t中文的标识符是 `private` \n" - }, - { - "date": 1716172749335, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -28,5 +28,5 @@\n - 标识符区分大小写,例如`count`和`Count`是两个不同的标识符。\n - 标识符不能是Go语言的关键字。\n \n 注意:\n-\t中文的标识符是 `private` \n+ 中文的标识符是 `private`\n" - }, - { - "date": 1716172764541, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n title: \"Keyword\"\n date: 2024-05-20T10:37:53+08:00\n draft: false\n-taps: []\n-categories: []\n+taps: [\"Golang\"]\n+categories: [\"Golang\", \"CS\", \"Languages\",\"start\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1716172773005, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n title: \"Keyword\"\n date: 2024-05-20T10:37:53+08:00\n draft: false\n-taps: [\"Golang\"]\n-categories: [\"Golang\", \"CS\", \"Languages\",\"start\"]\n+taps: [\"Golang\"\"start\"]\n+categories: [\"Golang\", \"CS\", \"Languages\",]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1716172806658, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n-title: \"Keyword\"\n+title: \"关键字与标识符\"\n date: 2024-05-20T10:37:53+08:00\n draft: false\n-taps: [\"Golang\"\"start\"]\n-categories: [\"Golang\", \"CS\", \"Languages\",]\n+taps: [\"Golang\", \"start\"]\n+categories: [\"Golang\", \"CS\", \"Languages\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - } - ], - "date": 1716172732165, - "name": "Commit-0", - "content": "---\ntitle: \"Keyword\"\ndate: 2024-05-20T10:37:53+08:00\ndraft: fa\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/GMP_Model/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/GMP_Model/index.zh-cn.md.json deleted file mode 100644 index f7f2edb..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/GMP_Model/index.zh-cn.md.json +++ /dev/null @@ -1,34 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/GMP_Model/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 4, - "patches": [ - { - "date": 1715565877095, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1715565884282, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -23,8 +23,9 @@\n \n 这段 Go 代码定义了一个函数 `stealWork`,用于尝试从其他的处理器(P)中窃取一个可运行的 goroutine 或定时器。这个函数是 Go 的调度器的一部分,用于在多个处理器之间平衡工作负载。以下是代码的详细解析:\n \n ### 函数签名\n+\n `func stealWork(now int64) (gp *g, inheritTime bool, rnow, pollUntil int64, newWork bool)`\n \n - **参数**:\n - `now`: 当前的时间,用于处理定时器。如果为 0,则函数会自行获取当前时间。\n@@ -38,61 +39,76 @@\n \n ### 函数体解析\n \n 1. **获取当前 P 的指针**:\n+\n ```go\n pp := getg().m.p.ptr()\n ```\n+\n 这行代码获取当前 Goroutine 的 M(操作系统线程)关联的 P(处理器)的指针。\n \n 2. **初始化变量**:\n+\n ```go\n ranTimer := false\n ```\n+\n 初始化一个标志,用于记录是否运行了定时器。\n \n 3. **尝试窃取工作的循环**:\n+\n ```go\n const stealTries = 4\n for i := 0; i < stealTries; i++ {\n ...\n }\n ```\n+\n 函数尝试四次(由 `stealTries` 常量定义)来窃取工作。\n \n 4. **遍历所有 P 以窃取工作**:\n+\n ```go\n for enum := stealOrder.start(cheaprand()); !enum.done(); enum.next() {\n ...\n }\n ```\n+\n 使用一个随机的开始点,遍历所有的 P。`stealOrder` 是一个遍历序列,可能基于当前状态进行优化选择。\n \n 5. **检查垃圾回收状态**:\n+\n ```go\n if sched.gcwaiting.Load() {\n return nil, false, now, pollUntil, true\n }\n ```\n+\n 如果正在等待垃圾回收,直接返回,表示可能有 GC 相关的工作要做。\n \n 6. **检查和窃取定时器**:\n+\n ```go\n if stealTimersOrRunNextG && timerpMask.read(enum.position()) {\n ...\n }\n ```\n+\n 在最后一次尝试中,尝试从其他 P 中窃取定时器。如果运行了定时器,可能会使一些 goroutine 变为可运行状态,这时会尝试从本地运行队列中获取一个 goroutine。\n \n 7. **尝试窃取运行队列中的 goroutine**:\n+\n ```go\n if gp := runqsteal(pp, p2, stealTimersOrRunNextG); gp != nil {\n return gp, false, now, pollUntil, ranTimer\n }\n ```\n+\n 如果未运行定时器或定时器未使 goroutine 就绪,尝试从其他 P 的运行队列中窃取 goroutine。\n \n 8. **返回结果**:\n 如果所有尝试都失败了,返回 nil 和相关的时间信息。\n \n ### 总结\n+\n 这个函数是 Go 语言运行时的一部分,专门用于在多核处理器环境下优化 goroutine 的调度,通过窃取其他处理器上的工作来避免某些处理器闲置而其他处理器过载。这有助于提高整体的运行效率和响应性。\n" - }, - { - "date": 1715565899061, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -108,7 +108,5 @@\n \n 8. **返回结果**:\n 如果所有尝试都失败了,返回 nil 和相关的时间信息。\n \n-### 总结\n \n-这个函数是 Go 语言运行时的一部分,专门用于在多核处理器环境下优化 goroutine 的调度,通过窃取其他处理器上的工作来避免某些处理器闲置而其他处理器过载。这有助于提高整体的运行效率和响应性。\n" - }, - { - "date": 1715565904578, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"GMP_Model\"\n date: 2024-05-13T09:14:13+08:00\n draft: true\n-taps: []\n+taps: [\"Golang\"]\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n@@ -107,6 +107,4 @@\n 如果未运行定时器或定时器未使 goroutine 就绪,尝试从其他 P 的运行队列中窃取 goroutine。\n \n 8. **返回结果**:\n 如果所有尝试都失败了,返回 nil 和相关的时间信息。\n-\n-\n" - }, - { - "date": 1715565910889, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n title: \"GMP_Model\"\n date: 2024-05-13T09:14:13+08:00\n draft: true\n-taps: [\"Golang\"]\n-categories: []\n+taps: [\"Golang\", \"GMP\"]\n+categories: [\"Golang\", \"CS\", \"Languages\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - } - ], - "date": 1715565877095, - "name": "Commit-0", - "content": "---\ntitle: \"GMP_Model\"\ndate: 2024-05-13T09:14:13+08:00\ndraft: true\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n\n## Goroutine 协程\n\n## Processor 逻辑处理器\n\n## Thread 线程\n\n## 设计策略\n\n## 生命周期\n\n这段 Go 代码定义了一个函数 `stealWork`,用于尝试从其他的处理器(P)中窃取一个可运行的 goroutine 或定时器。这个函数是 Go 的调度器的一部分,用于在多个处理器之间平衡工作负载。以下是代码的详细解析:\n\n### 函数签名\n`func stealWork(now int64) (gp *g, inheritTime bool, rnow, pollUntil int64, newWork bool)`\n\n- **参数**:\n - `now`: 当前的时间,用于处理定时器。如果为 0,则函数会自行获取当前时间。\n\n- **返回值**:\n - `gp`: 返回被窃取的 goroutine 的指针。\n - `inheritTime`: 布尔值,表示返回的 goroutine 是否应继承调度时间。\n - `rnow`: 返回的当前时间或传入的时间。\n - `pollUntil`: 表示下一个定时器事件的时间。\n - `newWork`: 布尔值,表示是否有新的工作被准备好。\n\n### 函数体解析\n\n1. **获取当前 P 的指针**:\n ```go\n pp := getg().m.p.ptr()\n ```\n 这行代码获取当前 Goroutine 的 M(操作系统线程)关联的 P(处理器)的指针。\n\n2. **初始化变量**:\n ```go\n ranTimer := false\n ```\n 初始化一个标志,用于记录是否运行了定时器。\n\n3. **尝试窃取工作的循环**:\n ```go\n const stealTries = 4\n for i := 0; i < stealTries; i++ {\n ...\n }\n ```\n 函数尝试四次(由 `stealTries` 常量定义)来窃取工作。\n\n4. **遍历所有 P 以窃取工作**:\n ```go\n for enum := stealOrder.start(cheaprand()); !enum.done(); enum.next() {\n ...\n }\n ```\n 使用一个随机的开始点,遍历所有的 P。`stealOrder` 是一个遍历序列,可能基于当前状态进行优化选择。\n\n5. **检查垃圾回收状态**:\n ```go\n if sched.gcwaiting.Load() {\n return nil, false, now, pollUntil, true\n }\n ```\n 如果正在等待垃圾回收,直接返回,表示可能有 GC 相关的工作要做。\n\n6. **检查和窃取定时器**:\n ```go\n if stealTimersOrRunNextG && timerpMask.read(enum.position()) {\n ...\n }\n ```\n 在最后一次尝试中,尝试从其他 P 中窃取定时器。如果运行了定时器,可能会使一些 goroutine 变为可运行状态,这时会尝试从本地运行队列中获取一个 goroutine。\n\n7. **尝试窃取运行队列中的 goroutine**:\n ```go\n if gp := runqsteal(pp, p2, stealTimersOrRunNextG); gp != nil {\n return gp, false, now, pollUntil, ranTimer\n }\n ```\n 如果未运行定时器或定时器未使 goroutine 就绪,尝试从其他 P 的运行队列中窃取 goroutine。\n\n8. **返回结果**:\n 如果所有尝试都失败了,返回 nil 和相关的时间信息。\n\n### 总结\n这个函数是 Go 语言运行时的一部分,专门用于在多核处理器环境下优化 goroutine 的调度,通过窃取其他处理器上的工作来避免某些处理器闲置而其他处理器过载。这有助于提高整体的运行效率和响应性。\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/Map/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/Map/index.zh-cn.md.json deleted file mode 100644 index 9c1afc8..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/Map/index.zh-cn.md.json +++ /dev/null @@ -1,30 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/Map/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 3, - "patches": [ - { - "date": 1715565930838, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1715565936943, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"Map\"\n date: 2024-05-13T09:15:16+08:00\n draft: true\n-taps: []\n+taps: [\"Golang\", \"transition\"]\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - }, - { - "date": 1715565944556, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n title: \"Map\"\n date: 2024-05-13T09:15:16+08:00\n draft: true\n-taps: [\"Golang\", \"transition\"]\n-categories: []\n+taps: [\"Golang\", ]\n+categories: [\"Golang\", \"CS\",\"transition\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1715565950166, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"Map\"\n date: 2024-05-13T09:15:16+08:00\n draft: true\n-taps: [\"Golang\", ]\n+taps: [\"Golang\", \"map\"]\n categories: [\"Golang\", \"CS\",\"transition\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - } - ], - "date": 1715565930838, - "name": "Commit-0", - "content": "---\ntitle: \"Map\"\ndate: 2024-05-13T09:15:16+08:00\ndraft: true\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n\n## map 是什么\n\n## map 的底层结构\n\n## Make 一个 map 的流程\n\n### 初始化 map\n\n### 加入字面量\n\n### map 的访问\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/_index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/_index.zh-cn.md.json deleted file mode 100644 index d9132d8..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/_index.zh-cn.md.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/_index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 2, - "patches": [ - { - "date": 1715566206188, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1715567120126, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,13 +1,13 @@\n ---\n-title: \"\"\n+title: \"transition\"\n date: 2024-03-14T21:53:46+08:00\n draft: false\n taps: []\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n-weight:\n+weight: -80\n math: false\n readingTime: true\n \n ---\n" - }, - { - "date": 1715567125722, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: \"transition\"\n+title: \"转\"\n date: 2024-03-14T21:53:46+08:00\n draft: false\n taps: []\n categories: []\n" - } - ], - "date": 1715566206188, - "name": "Commit-0", - "content": "---\ntitle: \"\"\ndate: 2024-03-14T21:53:46+08:00\ndraft: false\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n\n---\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb1/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb1/index.zh-cn.md.json deleted file mode 100644 index 99d22a6..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb1/index.zh-cn.md.json +++ /dev/null @@ -1,74 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb1/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 14, - "patches": [ - { - "date": 1718117149726, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1718117159499, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -9,4 +9,68 @@\n weight:\n math: false\n readingTime: true\n ---\n+\n+> 如何通过 Go 来编写 Web\n+>\n+## Web\n+\n+### HTTP 是什么\n+\n+-> [[http 是什么]]\n+\n+Web 是什么,有些人认为是一个网页,有些人认为是 World Wide Web(万维网)系统,有些人认为是网路时代的代指。都没错,但为了不在下面的文字中模糊这个词,孤自认为 Web 是一个管理资源的**服务端**,而 Go 所做的就是搭建这个服务端。\n+\n+一个 Web 服务器,它监听来自客服端的请求,并通过 **HTTP 协议**将自己与客户端通信。这个客户端通常指的是 *Web Browser*。\n+\n+### Web 服务器\n+\n+Web 服务器的工作流程为:\n+\n+1. 监听来自客户端通过 **TCP/IP 协议**建立到服务器的 TCP 连接请求\n+2. **处理并解析**请求的内容,确定客户端请求的是哪个资源\n+3. 服务端根据请求处理的结果生成 **HTTP 响应**\n+4. 服务端将响应和(静态/动态)资源通过互联网**送回**客户端\n+5. **持久连接/非持久连接**\n+\n+### RESTful 架构\n+\n+表现层状态转换(**Representational State Transfer**)是根基于**超文本传输协议(HTTP)** 之上而确定的一组约束和属性,是一种设计提供万维网络服务的**软件构建风格**。符合或兼容于这种架构风格(简称为 REST 或 RESTful)的网络服务,允许客户端发出以**统一资源标识符**访问和操作网络资源的请求,而与预先定义好的无状态操作集一致化。\n+![](https://s2.loli.net/2024/05/26/IO7laRYz1WBTG94.png)\n+\n+- 每一个 **URI** 代表一种资源\n+- 客户端和服务器之间,传递这种资源的某种表现层\n+- 客户端通过四个 HTTP 方法,对服务器端资源进行操作,实现\"表现层状态转化\"\n+\n+## net/http package\n+\n+`net/http` 是 Go 官方的标准包\n+\n+我对 net/http 的原理解析-> [[http package]]\n+\n+```go\n+func SayHello(w http.ResponseWriter, r *http.Request) {\n+ _, err := fmt.Fprintln(w, \"Hello Go Web\")\n+ if err != nil {\n+ return\n+ }\n+}\n+\n+func main() {\n+ http.HandleFunc(\"/hello\", SayHello)\n+ http.ListenAndServe(\":9999\", nil)\n+}\n+```\n+\n+Go 中的 http 很体贴的将一些过程抽象了,其中就只有 `ListenAndServe` 来监听客户端的请求,`HandleFunc` 来注册一个处理器和对应的 pattem 建立 route ,`SayHello` 是具体的 Handler 函数。\n+\n+Web 工作方式的几个概念\n+\n+- Request:用户请求的信息,用来解析用户的请求信息,包括 post、get、cookie、url 等信息\n+- Response:服务器需要反馈给客户端的信息\n+- Conn:用户的每次请求链接\n+- Handler:处理请求和生成返回信息的处理逻辑\n+\n+## 外部链接\n+\n+[理解RESTful架构](https://www.ruanyifeng.com/blog/2011/09/restful.html)\n" - }, - { - "date": 1718117174327, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -35,9 +35,9 @@\n \n ### RESTful 架构\n \n 表现层状态转换(**Representational State Transfer**)是根基于**超文本传输协议(HTTP)** 之上而确定的一组约束和属性,是一种设计提供万维网络服务的**软件构建风格**。符合或兼容于这种架构风格(简称为 REST 或 RESTful)的网络服务,允许客户端发出以**统一资源标识符**访问和操作网络资源的请求,而与预先定义好的无状态操作集一致化。\n-![](https://s2.loli.net/2024/05/26/IO7laRYz1WBTG94.png)\n+![URL](https://s2.loli.net/2024/05/26/IO7laRYz1WBTG94.png)\n \n - 每一个 **URI** 代表一种资源\n - 客户端和服务器之间,传递这种资源的某种表现层\n - 客户端通过四个 HTTP 方法,对服务器端资源进行操作,实现\"表现层状态转化\"\n" - }, - { - "date": 1718117187553, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -35,9 +35,9 @@\n \n ### RESTful 架构\n \n 表现层状态转换(**Representational State Transfer**)是根基于**超文本传输协议(HTTP)** 之上而确定的一组约束和属性,是一种设计提供万维网络服务的**软件构建风格**。符合或兼容于这种架构风格(简称为 REST 或 RESTful)的网络服务,允许客户端发出以**统一资源标识符**访问和操作网络资源的请求,而与预先定义好的无状态操作集一致化。\n-![URL](https://s2.loli.net/2024/05/26/IO7laRYz1WBTG94.png)\n+![URL&URI&URT](https://s2.loli.net/2024/05/26/IO7laRYz1WBTG94.png)\n \n - 每一个 **URI** 代表一种资源\n - 客户端和服务器之间,传递这种资源的某种表现层\n - 客户端通过四个 HTTP 方法,对服务器端资源进行操作,实现\"表现层状态转化\"\n" - }, - { - "date": 1718117233611, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -16,8 +16,9 @@\n ## Web\n \n ### HTTP 是什么\n \n+// \n -> [[http 是什么]]\n \n Web 是什么,有些人认为是一个网页,有些人认为是 World Wide Web(万维网)系统,有些人认为是网路时代的代指。都没错,但为了不在下面的文字中模糊这个词,孤自认为 Web 是一个管理资源的**服务端**,而 Go 所做的就是搭建这个服务端。\n \n@@ -35,9 +36,9 @@\n \n ### RESTful 架构\n \n 表现层状态转换(**Representational State Transfer**)是根基于**超文本传输协议(HTTP)** 之上而确定的一组约束和属性,是一种设计提供万维网络服务的**软件构建风格**。符合或兼容于这种架构风格(简称为 REST 或 RESTful)的网络服务,允许客户端发出以**统一资源标识符**访问和操作网络资源的请求,而与预先定义好的无状态操作集一致化。\n-![URL&URI&URT](https://s2.loli.net/2024/05/26/IO7laRYz1WBTG94.png)\n+![URL&URI&URN](https://s2.loli.net/2024/05/26/IO7laRYz1WBTG94.png)\n \n - 每一个 **URI** 代表一种资源\n - 客户端和服务器之间,传递这种资源的某种表现层\n - 客户端通过四个 HTTP 方法,对服务器端资源进行操作,实现\"表现层状态转化\"\n" - }, - { - "date": 1718117240814, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -16,9 +16,9 @@\n ## Web\n \n ### HTTP 是什么\n \n-// \n+\n -> [[http 是什么]]\n \n Web 是什么,有些人认为是一个网页,有些人认为是 World Wide Web(万维网)系统,有些人认为是网路时代的代指。都没错,但为了不在下面的文字中模糊这个词,孤自认为 Web 是一个管理资源的**服务端**,而 Go 所做的就是搭建这个服务端。\n \n" - }, - { - "date": 1718117271673, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,8 +1,8 @@\n ---\n title: \"Go Web的学习1\"\n date: 2024-06-11T22:45:30+08:00\n-draft: true\n+draft: false\n taps: []\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n" - }, - { - "date": 1718117277250, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -2,9 +2,9 @@\n title: \"Go Web的学习1\"\n date: 2024-06-11T22:45:30+08:00\n draft: false\n taps: []\n-categories: []\n+categories: ['']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1718117283420, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -2,9 +2,9 @@\n title: \"Go Web的学习1\"\n date: 2024-06-11T22:45:30+08:00\n draft: false\n taps: []\n-categories: ['']\n+categories: ['Golang', 'Web']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1718117289499, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"Go Web的学习1\"\n date: 2024-06-11T22:45:30+08:00\n draft: false\n-taps: []\n+taps: ['web']\n categories: ['Golang', 'Web']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - }, - { - "date": 1718117625345, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -46,9 +46,9 @@\n ## net/http package\n \n `net/http` 是 Go 官方的标准包\n \n-我对 net/http 的原理解析-> [[http package]]\n+我对 net/http 的原理解析-> [基础结构]({{< ref \"post/Gohh/2.DataStructures/GolangDS/_index.zh-cn.md\">}})\n \n ```go\n func SayHello(w http.ResponseWriter, r *http.Request) {\n _, err := fmt.Fprintln(w, \"Hello Go Web\")\n" - }, - { - "date": 1718117631459, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -46,9 +46,9 @@\n ## net/http package\n \n `net/http` 是 Go 官方的标准包\n \n-我对 net/http 的原理解析-> [基础结构]({{< ref \"post/Gohh/2.DataStructures/GolangDS/_index.zh-cn.md\">}})\n+我对 net/http 的原理解析-> [http package]\n \n ```go\n func SayHello(w http.ResponseWriter, r *http.Request) {\n _, err := fmt.Fprintln(w, \"Hello Go Web\")\n" - }, - { - "date": 1718117638696, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -46,10 +46,11 @@\n ## net/http package\n \n `net/http` 是 Go 官方的标准包\n \n-我对 net/http 的原理解析-> [http package]\n \n+我对 net/http 的原理解析-> [[http package]]\n+\n ```go\n func SayHello(w http.ResponseWriter, r *http.Request) {\n _, err := fmt.Fprintln(w, \"Hello Go Web\")\n if err != nil {\n" - }, - { - "date": 1718117652291, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -17,9 +17,9 @@\n \n ### HTTP 是什么\n \n \n--> [[http 是什么]]\n+-> [[http 是什么]\n \n Web 是什么,有些人认为是一个网页,有些人认为是 World Wide Web(万维网)系统,有些人认为是网路时代的代指。都没错,但为了不在下面的文字中模糊这个词,孤自认为 Web 是一个管理资源的**服务端**,而 Go 所做的就是搭建这个服务端。\n \n 一个 Web 服务器,它监听来自客服端的请求,并通过 **HTTP 协议**将自己与客户端通信。这个客户端通常指的是 *Web Browser*。\n@@ -46,8 +46,9 @@\n ## net/http package\n \n `net/http` 是 Go 官方的标准包\n \n+🚧🚧🚧\n \n 我对 net/http 的原理解析-> [[http package]]\n \n ```go\n" - }, - { - "date": 1718117658571, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -17,9 +17,9 @@\n \n ### HTTP 是什么\n \n \n--> [http 是什么]\n+-> [http 是什么][基础结构]({{< ref \"post/Gohh/2.DataStructures/GolangDS/_index.zh-cn.md\">}})\n \n Web 是什么,有些人认为是一个网页,有些人认为是 World Wide Web(万维网)系统,有些人认为是网路时代的代指。都没错,但为了不在下面的文字中模糊这个词,孤自认为 Web 是一个管理资源的**服务端**,而 Go 所做的就是搭建这个服务端。\n \n 一个 Web 服务器,它监听来自客服端的请求,并通过 **HTTP 协议**将自己与客户端通信。这个客户端通常指的是 *Web Browser*。\n" - } - ], - "date": 1718117149725, - "name": "Commit-0", - "content": "---\ntitle: \"Go Web的学习1\"\ndate: 2024-06-11T22:45:30+08:00\ndraft: true\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb2/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb2/index.zh-cn.md.json deleted file mode 100644 index 87550e8..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb2/index.zh-cn.md.json +++ /dev/null @@ -1,42 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb2/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 6, - "patches": [ - { - "date": 1718117713199, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1718117742154, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: \"Go Web的学习1\"\n+title: \"Go Web的学习2\"\n date: 2024-06-11T22:45:30+08:00\n draft: false\n taps: ['web']\n categories: ['Golang', 'Web']\n@@ -9,4 +9,136 @@\n weight:\n math: false\n readingTime: true\n ---\n+\n+## Router 框架\n+> 大门管理员\n+### 路由功能\n+为了将代码模块化,而随之带来的另外一个问题是关于前端页面的跳转问题,由于代码的隔离,代码之间有时候会无法互相访问。因此需要一个**大门管理员**, Router 就此实现。\n+\n+它负责将传入的 HTTP 请求**映射(map)** 到相应的处理函数上。简单来说,路由决定了当用户访问一个特定的 URL 时,服务器应该执行哪些代码来处理这个请求。\n+\n+类似下面这样:\n+```go\n+type router struct {\n+ // map Handler function\n+ handlers map[string]HandlerFunc\n+}\n+```\n+\n+因此,路由要满足一下功能:\n+1. **URL匹配**:路由框架能够识别和匹配传入请求的URL,根据URL的不同部分(如路径、查询参数等)来决定调用哪个处理函数。\n+```go\n+func (r *router) handle(ctx *Context) {\n+ key := ctx.Method + \"-\" + ctx.Path\n+ if handler, ok := r.handlers[key]; ok {\n+ handler(ctx.Res, ctx.Req)\n+ } else {\n+ ctx.String(http.StatusNotFound, \"404 NOT FOUND: %s\\n\", ctx.Path)\n+ }\n+}\n+```\n+\n+2. **处理函数映射**:每个 URL 模式(pattern)都会被**映射**到一个或多个处理函数。当请求的 URL 匹配到某个模式时,相应的处理函数就会被调用。\n+```go\n+func (router *router) addRoute(method string, pattern string, handler HandlerFunc) {\n+ log.Printf(\"Route %4s - %s\", method, pattern)\n+ key := method + \"-\" + pattern\n+ router.handlers[key] = handler\n+}\n+```\n+\n+3. **参数提取**:对于**动态路由**,如 `/user/:id`,路由框架能够从 URL 中提取参数(如 `:id`),并将这些参数传递给处理函数。\n+4. **中间件支持**:路由框架通常支持中间件,这些中间件可以在请求到达**处理函数之前或之后**执行一些操作,如身份验证、日志记录等。\n+\n+### 主要点\n+\n+#### Query\n+\n+在HTTP请求的上下文中,`query` 通常指的是URL中的查询参数。查询参数是URL中`?`后面的键值对,它们用于向服务器传递额外的信息。例如,在URL `http://example.com/search?q=golang` 中,`q=golang` 就是一个查询参数,其中`q`是参数名,`golang`是参数值。\n+\n+#### Handler\n+\n+`Handler` 或 `Request Handler` 是指处理HTTP请求的函数或方法。在大多数后端框架中,包括Go语言的许多Web框架(如Gin、Echo、net/http等),`handler` 是一个函数,它接收HTTP请求并返回HTTP**响应**。\n+\n+### 封装\n+\n+在 Web 服务中,封装可以用来简化 HTTP**请求**和**响应**的处理。对于原始的方式需要手动设置 *HTTP Header*、*状态码*和*消息体* 等等,而封装后的方法则提供了一个更简洁的接口,只需调用一个函数就可以完成所有这些设置。\n+#### Context 结构\n+\n+在Web框架中,Context通常是一个结构体,它包含了处理HTTP请求和响应所需的所有信息。\n+\n+- **统一接口**:通过Context,可以将所有与请求相关的信息集中管理,使得处理函数和中间件可以方便地访问这些信息。\n+- **动态路由支持**:Context 可以存储动态路由解析后的参数,使得这些参数可以在处理函数中直接使用。[[#动态路由]]\n+- **中间件支持**:中间件可以在Context中添加或修改信息,这些信息可以被后续的处理函数使用。\n+\n+Context 随着每一个请求的出现而产生,请求的结束而销毁,和当前请求强相关的信息都应由 Context 承载。\n+\n+```go\n+// Context 结构体用于封装HTTP请求和响应的相关信息\n+type Context struct {\n+ Res http.ResponseWriter\n+ Req *http.Request\n+\n+ Path string\n+ Method string\n+ StatusCode int\n+}\n+```\n+在 Go 中的Context\n+#### API 设计\n+\n+🚧🚧🚧🚧🚧🚧🚧🚧🚧\n+### 动态路由\n+\n+动态路由是指路由中的某些部分是可变的,例如 `/hello/:name` 中的 `:name` 部分。当请求匹配到这个路由时,`:name` 会被替换为实际的值。在 Context 结构中,这些动态参数通常会被存储起来,以便在处理函数中使用。\n+\n+为了保存这些 `pattern` 我们有许多的协议和数据结构,常用 `Trie-Tree` 来作 pattern 的底层结构。\n+\n+\n+\n+了解 `pattern` 参数,其中 pattern 就是在路由器中预先定义的一组规则**模式** ,用来和用户输入的 URL 匹配。\n+\n+一般有三种模糊匹配路由规则:\n+1. `:name` ---- **命名匹配规则**\n+2. `*any` ---- **模糊匹配规**\n+3. `{field}` ---- **字段匹配规则**\n+\n+```go\n+type node struct {\n+\t//待匹配路由\n+\tpattern string\n+\t// important fields\n+\tpart string\n+\tchildren []*node\n+\t// node color (isKey)\n+\t// *any | :xxx\n+\tisWildcard bool\n+}\n+\n+type PatRoot struct {\n+    root *node\n+}\n+```\n+\n+#### 要点\n+1. **Pattern(模式)**:\n+ - 模式是指在路由器中预先定义的一组规则,用于匹配传入的HTTP请求的URL路径。这些模式通常包含静态路径部分和动态路径部分(如参数或通配符)。例如,模式 `/user/:id` 表示一个用户详情页,其中 `:id` 是一个参数,可以匹配任何用户ID。\n+ - 在您的代码中,`pattern` 是 `router` 结构体中的一个字段,用于存储每个HTTP方法对应的路由树(`PatRoot`)。这些路由树是根据预定义的模式构建的,用于快速匹配传入的请求路径。\n+\n+2. **URL(统一资源定位符)**:\n+ - URL 是客户端(如浏览器)发送给服务器的实际请求路径。它是一个具体的字符串,指定了请求的资源在服务器上的位置。例如,`/user/123` 是一个URL,它请求ID为123的用户详情页。\n+ - 在您的代码中,`URL` 是通过 `Context` 对象传递的,它是处理HTTP请求时的一个关键部分。`getRoute` 方法使用这个URL来在路由树中查找匹配的模式\n+\n+\n+第一种是对 httpRouter 进行简单的封装,然后提供定制的中间件和一些简单的小工具集成比如 gin,主打轻量,易学,高性能。第二种是借鉴其它语言的编程风格的一些 MVC 类框架,例如 beego,方便从其它语言迁移过来的程序员快速上手,快速开发。还有一些框架功能更为强大,除了数据库 schema 设计,大部分代码直接生成,例如 goa。不管哪种框架,适合开发者背景的就是最好的。\n+\n+\n+\n+根据我们的经验,简单地来说,只要你的路由带有参数,并且这个项目的 API 数目超过了 10,就尽量不要使用 `net/http` 中默认的路由。\n+\n+\n+## 外部链接\n+\n+[router 请求路由](https://chai2010.cn/advanced-go-programming-book/ch5-web/ch5-02-router.html#52-router-%E8%AF%B7%E6%B1%82%E8%B7%AF%E7%94%B1)\n+\n" - }, - { - "date": 1718117747771, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"Go Web的学习2\"\n date: 2024-06-11T22:45:30+08:00\n draft: false\n-taps: ['web']\n+taps: ['web', '']\n categories: ['Golang', 'Web']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n@@ -140,5 +140,4 @@\n \n ## 外部链接\n \n [router 请求路由](https://chai2010.cn/advanced-go-programming-book/ch5-web/ch5-02-router.html#52-router-%E8%AF%B7%E6%B1%82%E8%B7%AF%E7%94%B1)\n-\n" - }, - { - "date": 1718117757378, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"Go Web的学习2\"\n date: 2024-06-11T22:45:30+08:00\n draft: false\n-taps: ['web', '']\n+taps: ['web', 'router']\n categories: ['Golang', 'Web']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n@@ -18,8 +18,9 @@\n \n 它负责将传入的 HTTP 请求**映射(map)** 到相应的处理函数上。简单来说,路由决定了当用户访问一个特定的 URL 时,服务器应该执行哪些代码来处理这个请求。\n \n 类似下面这样:\n+\n ```go\n type router struct {\n // map Handler function\n handlers map[string]HandlerFunc\n@@ -27,8 +28,9 @@\n ```\n \n 因此,路由要满足一下功能:\n 1. **URL匹配**:路由框架能够识别和匹配传入请求的URL,根据URL的不同部分(如路径、查询参数等)来决定调用哪个处理函数。\n+\n ```go\n func (r *router) handle(ctx *Context) {\n key := ctx.Method + \"-\" + ctx.Path\n if handler, ok := r.handlers[key]; ok {\n@@ -39,8 +41,9 @@\n }\n ```\n \n 2. **处理函数映射**:每个 URL 模式(pattern)都会被**映射**到一个或多个处理函数。当请求的 URL 匹配到某个模式时,相应的处理函数就会被调用。\n+\n ```go\n func (router *router) addRoute(method string, pattern string, handler HandlerFunc) {\n log.Printf(\"Route %4s - %s\", method, pattern)\n key := method + \"-\" + pattern\n@@ -84,8 +87,9 @@\n Method string\n StatusCode int\n }\n ```\n+\n 在 Go 中的Context\n #### API 设计\n \n 🚧🚧🚧🚧🚧🚧🚧🚧🚧\n" - }, - { - "date": 1718117817780, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -11,10 +11,13 @@\n readingTime: true\n ---\n \n ## Router 框架\n+>\n > 大门管理员\n+>\n ### 路由功能\n+\n 为了将代码模块化,而随之带来的另外一个问题是关于前端页面的跳转问题,由于代码的隔离,代码之间有时候会无法互相访问。因此需要一个**大门管理员**, Router 就此实现。\n \n 它负责将传入的 HTTP 请求**映射(map)** 到相应的处理函数上。简单来说,路由决定了当用户访问一个特定的 URL 时,服务器应该执行哪些代码来处理这个请求。\n \n@@ -27,8 +30,9 @@\n }\n ```\n \n 因此,路由要满足一下功能:\n+\n 1. **URL匹配**:路由框架能够识别和匹配传入请求的URL,根据URL的不同部分(如路径、查询参数等)来决定调用哪个处理函数。\n \n ```go\n func (r *router) handle(ctx *Context) {\n@@ -66,8 +70,9 @@\n \n ### 封装\n \n 在 Web 服务中,封装可以用来简化 HTTP**请求**和**响应**的处理。对于原始的方式需要手动设置 *HTTP Header*、*状态码*和*消息体* 等等,而封装后的方法则提供了一个更简洁的接口,只需调用一个函数就可以完成所有这些设置。\n+\n #### Context 结构\n \n 在Web框架中,Context通常是一个结构体,它包含了处理HTTP请求和响应所需的所有信息。\n \n@@ -89,59 +94,57 @@\n }\n ```\n \n 在 Go 中的Context\n+\n #### API 设计\n \n 🚧🚧🚧🚧🚧🚧🚧🚧🚧\n+\n ### 动态路由\n \n 动态路由是指路由中的某些部分是可变的,例如 `/hello/:name` 中的 `:name` 部分。当请求匹配到这个路由时,`:name` 会被替换为实际的值。在 Context 结构中,这些动态参数通常会被存储起来,以便在处理函数中使用。\n \n 为了保存这些 `pattern` 我们有许多的协议和数据结构,常用 `Trie-Tree` 来作 pattern 的底层结构。\n \n-\n-\n 了解 `pattern` 参数,其中 pattern 就是在路由器中预先定义的一组规则**模式** ,用来和用户输入的 URL 匹配。\n \n 一般有三种模糊匹配路由规则:\n-1. `:name` ---- **命名匹配规则**\n+\n+1. `:name` ---- **命名匹配规则**\n 2. `*any` ---- **模糊匹配规**\n 3. `{field}` ---- **字段匹配规则**\n \n ```go\n type node struct {\n-\t//待匹配路由\n-\tpattern string\n-\t// important fields\n-\tpart string\n-\tchildren []*node\n-\t// node color (isKey)\n-\t// *any | :xxx\n-\tisWildcard bool\n+ //待匹配路由\n+ pattern string\n+ // important fields\n+ part string\n+ children []*node\n+ // node color (isKey)\n+ // *any | :xxx\n+ isWildcard bool\n }\n \n type PatRoot struct {\n     root *node\n }\n ```\n \n #### 要点\n+\n 1. **Pattern(模式)**:\n - 模式是指在路由器中预先定义的一组规则,用于匹配传入的HTTP请求的URL路径。这些模式通常包含静态路径部分和动态路径部分(如参数或通配符)。例如,模式 `/user/:id` 表示一个用户详情页,其中 `:id` 是一个参数,可以匹配任何用户ID。\n - 在您的代码中,`pattern` 是 `router` 结构体中的一个字段,用于存储每个HTTP方法对应的路由树(`PatRoot`)。这些路由树是根据预定义的模式构建的,用于快速匹配传入的请求路径。\n \n 2. **URL(统一资源定位符)**:\n - URL 是客户端(如浏览器)发送给服务器的实际请求路径。它是一个具体的字符串,指定了请求的资源在服务器上的位置。例如,`/user/123` 是一个URL,它请求ID为123的用户详情页。\n - 在您的代码中,`URL` 是通过 `Context` 对象传递的,它是处理HTTP请求时的一个关键部分。`getRoute` 方法使用这个URL来在路由树中查找匹配的模式\n \n-\n 第一种是对 httpRouter 进行简单的封装,然后提供定制的中间件和一些简单的小工具集成比如 gin,主打轻量,易学,高性能。第二种是借鉴其它语言的编程风格的一些 MVC 类框架,例如 beego,方便从其它语言迁移过来的程序员快速上手,快速开发。还有一些框架功能更为强大,除了数据库 schema 设计,大部分代码直接生成,例如 goa。不管哪种框架,适合开发者背景的就是最好的。\n \n-\n-\n 根据我们的经验,简单地来说,只要你的路由带有参数,并且这个项目的 API 数目超过了 10,就尽量不要使用 `net/http` 中默认的路由。\n \n-\n ## 外部链接\n \n [router 请求路由](https://chai2010.cn/advanced-go-programming-book/ch5-web/ch5-02-router.html#52-router-%E8%AF%B7%E6%B1%82%E8%B7%AF%E7%94%B1)\n" - }, - { - "date": 1718117828094, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -44,9 +44,9 @@\n }\n }\n ```\n \n-2. **处理函数映射**:每个 URL 模式(pattern)都会被**映射**到一个或多个处理函数。当请求的 URL 匹配到某个模式时,相应的处理函数就会被调用。\n+2.**处理函数映射**:每个 URL 模式(pattern)都会被**映射**到一个或多个处理函数。当请求的 URL 匹配到某个模式时,相应的处理函数就会被调用。\n \n ```go\n func (router *router) addRoute(method string, pattern string, handler HandlerFunc) {\n log.Printf(\"Route %4s - %s\", method, pattern)\n" - }, - { - "date": 1718117834380, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -43,11 +43,10 @@\n ctx.String(http.StatusNotFound, \"404 NOT FOUND: %s\\n\", ctx.Path)\n }\n }\n ```\n+2. **处理函数映射**:每个 URL 模式(pattern)都会被**映射**到一个或多个处理函数。当请求的 URL 匹配到某个模式时,相应的处理函数就会被调用。\n \n-2.**处理函数映射**:每个 URL 模式(pattern)都会被**映射**到一个或多个处理函数。当请求的 URL 匹配到某个模式时,相应的处理函数就会被调用。\n-\n ```go\n func (router *router) addRoute(method string, pattern string, handler HandlerFunc) {\n log.Printf(\"Route %4s - %s\", method, pattern)\n key := method + \"-\" + pattern\n" - } - ], - "date": 1718117713199, - "name": "Commit-0", - "content": "---\ntitle: \"Go Web的学习1\"\ndate: 2024-06-11T22:45:30+08:00\ndraft: false\ntaps: ['web']\ncategories: ['Golang', 'Web']\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb3/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb3/index.zh-cn.md.json deleted file mode 100644 index aa622dc..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb3/index.zh-cn.md.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb3/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 5, - "patches": [ - { - "date": 1718117718817, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1718117858915, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: \"Go Web的学习1\"\n+title: \"Go Web的学习3\"\n date: 2024-06-11T22:45:30+08:00\n draft: false\n taps: ['web']\n categories: ['Golang', 'Web']\n@@ -9,4 +9,40 @@\n weight:\n math: false\n readingTime: true\n ---\n+\n+## 分组控制 (Group)\n+\n+说到 **GROUP** 我就想起来 MySQL 中的 SQL 语句 `GROUP BY`,他们本质上不一样但其实想做的事情就是分组,这里的分组是路由分组。\n+\n+### 意义-为什么需要分组\n+\n+分组是在 Web 框架中组织和管理路由的技术之一。比如当我有 `/hello/x` 、`/hello/y` 、`/hello/z` 三个不同的 pattern 时,我不想写三个不同的 handler 来处理(假设 handler 也是做相似的),你会发现他们的前缀路由相同,在这样的一种情况下,我需要复用 handler,你会想不如打包在一起组织起来一同管理。\n+这种技术它允许开发者将相关的路由分组在一起,以便更好地**组织代码**、**共享中间件**、**统一处理路径前缀**等。也可以提高代码的可读性、可维护性和可扩展性。\n+\n+### 更好的管理\n+\n+例如 `/hello` 是一个分组,`/hello/a` 和 `/hello/b` 可以是该分组下的**子分组 (Subgroup)**。作用在 `/hello` 分组上的中间件(middleware),也都会作用在子分组,子分组还可以应用自己特有的中间件。\n+\n+🚧🚧🚧\n+\n+\n+## 中间件 (Middleware)\n+\n+中间件(Middleware)是一个**软件层**,是一些技术类组件的统称,它位于应用程序和底层服务(如操作系统、网络协议栈或数据库)之间,也允许用户自己定义功能,嵌入到框架服务中,提供通用服务。中间件的主要目的是简化应用程序开发,通过提供可重用的、跨应用程序的功能来减少开发工作量。\n+\n+中间件可以提供多种服务,包括但不限于:\n+1. **通信服务**:允许不同的应用程序或组件通过网络进行通信。\n+2. **数据管理**:提供数据存储、检索和管理的抽象层,如数据库中间件。\n+3. **消息传递**:支持异步消息传递,如消息队列或发布/订阅系统。\n+4. **事务处理**:确保分布式系统中的事务完整性和一致性。\n+5. **安全性**:提供认证、授权、加密和审计等安全功能。\n+6. **集成**:帮助不同的应用程序和系统集成,如企业服务总线(ESB)。\n+7. **应用服务器**:提供运行时环境和支持服务,如Java EE应用服务器。\n+8. **API网关**:作为微服务架构中的单一入口点,处理请求路由、组合和协议转换。\n+9. **缓存**:提供数据缓存服务以提高性能。\n+10. **日志和监控**:收集和分析应用程序的日志和性能数据。\n+\n+怎么使用中间件需要考虑2个比较关键的点:\n+- **插入点在哪合适**\n+- **中间件的参数**\n" - }, - { - "date": 1718117868259, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -25,14 +25,14 @@\n 例如 `/hello` 是一个分组,`/hello/a` 和 `/hello/b` 可以是该分组下的**子分组 (Subgroup)**。作用在 `/hello` 分组上的中间件(middleware),也都会作用在子分组,子分组还可以应用自己特有的中间件。\n \n 🚧🚧🚧\n \n-\n ## 中间件 (Middleware)\n \n 中间件(Middleware)是一个**软件层**,是一些技术类组件的统称,它位于应用程序和底层服务(如操作系统、网络协议栈或数据库)之间,也允许用户自己定义功能,嵌入到框架服务中,提供通用服务。中间件的主要目的是简化应用程序开发,通过提供可重用的、跨应用程序的功能来减少开发工作量。\n \n 中间件可以提供多种服务,包括但不限于:\n+\n 1. **通信服务**:允许不同的应用程序或组件通过网络进行通信。\n 2. **数据管理**:提供数据存储、检索和管理的抽象层,如数据库中间件。\n 3. **消息传递**:支持异步消息传递,如消息队列或发布/订阅系统。\n 4. **事务处理**:确保分布式系统中的事务完整性和一致性。\n@@ -43,6 +43,7 @@\n 9. **缓存**:提供数据缓存服务以提高性能。\n 10. **日志和监控**:收集和分析应用程序的日志和性能数据。\n \n 怎么使用中间件需要考虑2个比较关键的点:\n+\n - **插入点在哪合适**\n - **中间件的参数**\n" - }, - { - "date": 1718117873611, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"Go Web的学习3\"\n date: 2024-06-11T22:45:30+08:00\n draft: false\n-taps: ['web']\n+taps: ['web', ]\n categories: ['Golang', 'Web']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - }, - { - "date": 1718117879960, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"Go Web的学习3\"\n date: 2024-06-11T22:45:30+08:00\n draft: false\n-taps: ['web', ]\n+taps: ['web', 'router', ]\n categories: ['Golang', 'Web']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - }, - { - "date": 1718117885312, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"Go Web的学习3\"\n date: 2024-06-11T22:45:30+08:00\n draft: false\n-taps: ['web', 'router', 'middleware']\n+taps: ['web', 'GROUP', 'middleware']\n categories: ['Golang', 'Web']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - } - ], - "date": 1718117718817, - "name": "Commit-0", - "content": "---\ntitle: \"Go Web的学习1\"\ndate: 2024-06-11T22:45:30+08:00\ndraft: false\ntaps: ['web']\ncategories: ['Golang', 'Web']\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb4/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb4/index.zh-cn.md.json deleted file mode 100644 index 711524c..0000000 --- a/YBlog/.lh/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb4/index.zh-cn.md.json +++ /dev/null @@ -1,30 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb4/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 3, - "patches": [ - { - "date": 1718117955481, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1718117963480, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n-title: \"Goweb4\"\n-date: 2024-06-11T22:58:47+08:00\n-draft: true\n-taps: []\n-categories: []\n+title: \"Go Web的学习3\"\n+date: 2024-06-11T22:45:30+08:00\n+draft: false\n+taps: ['web', 'group', 'middleware']\n+categories: ['Golang', 'Web']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1718117970429, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n-title: \"Go Web的学习3\"\n+title: \"Go Web的学习4\"\n date: 2024-06-11T22:45:30+08:00\n draft: false\n-taps: ['web', 'group', 'middleware']\n+taps: ['web', 'tem', 'middleware']\n categories: ['Golang', 'Web']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - }, - { - "date": 1718117983260, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"Go Web的学习4\"\n date: 2024-06-11T22:45:30+08:00\n draft: false\n-taps: ['web', 'tem', 'middleware']\n+taps: ['web', 'template']\n categories: ['Golang', 'Web']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n@@ -19,4 +19,6 @@\n \n ### 静态资源文件\n \n ### HTML 文件\n+\n+🚧🚧🚧\n" - } - ], - "date": 1718117955481, - "name": "Commit-0", - "content": "---\ntitle: \"Goweb4\"\ndate: 2024-06-11T22:58:47+08:00\ndraft: true\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n\n## 模板 (Template)\n\n模板是在 Web 框架后端对支持服务端渲染的技术\n\n学习这个需要对前端有一点的认识\n\n### 静态资源文件\n\n### HTML 文件\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/2.DataStructures/GolangDS/_index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/2.DataStructures/GolangDS/_index.zh-cn.md.json deleted file mode 100644 index 66b8dbb..0000000 --- a/YBlog/.lh/content/post/Gohh/2.DataStructures/GolangDS/_index.zh-cn.md.json +++ /dev/null @@ -1,18 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/2.DataStructures/GolangDS/_index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 0, - "patches": [ - { - "date": 1718116706732, - "content": "Index: \n===================================================================\n--- \n+++ \n" - } - ], - "date": 1718116706732, - "name": "Commit-0", - "content": "---\ntitle: \"数据结构\"\ndate: 2024-03-14T21:43:01+08:00\ndraft: false\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/3.Architecture/CSAPP/CSAPP00/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/3.Architecture/CSAPP/CSAPP00/index.zh-cn.md.json deleted file mode 100644 index 4a03414..0000000 --- a/YBlog/.lh/content/post/Gohh/3.Architecture/CSAPP/CSAPP00/index.zh-cn.md.json +++ /dev/null @@ -1,18 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/3.Architecture/CSAPP/CSAPP00/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 0, - "patches": [ - { - "date": 1715560915458, - "content": "Index: \n===================================================================\n--- \n+++ \n" - } - ], - "date": 1715560915458, - "name": "Commit-0", - "content": "---\ntitle: \"零.深入理解计算机系统(CSAPP)\"\ndate: 2023-03-12T21:46:39+08:00\ndraft: false\ntags: [CSAPP]\ncategories: [\"CSAPP\",\"CS\"]\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nreadingTime: true\n---\n\n## 前言\n\n>### 有志,有识,有恒,则断无不成之事\n\n我自己在2022年学习过`CS61c`,这门课主要是讲解了计算机的体系结构,终于踏入了计算机的门槛。计算机体系结构,这是一个计算机十分难啃的一门知识,内容之多、范围之广,无论里面的`数的表示、编译原理、CPU的基本架构、内存、虚拟内存、流水线、线程级并行、I/O、OS、网络等等`,每个方面都可以单独拎出来成为一门课程。而想要精通这些知识需要耗费大量的时间和精力,即使学习十年也不嫌少。哈哈哈。\n\n我对计算机的热爱促使我非正式地学习了 `CS61c`(可惜我不是伯克利的学子)过后,我发现,它给我的是课堂上没有的一些思想,比如:为什么?通过已经有的事实发出提问(即存在有缘由,而不是想当然的存在即真理)。\n\n在我上大学的时候我就知道一本`神书`《深入理解计算机系统》(即:***《Computer Systems: A Programmer’s Perspective》***),可是一直没有机会读一读(也看不懂 😂 ,也正是在有CS61c的基础上我想去好好的通读一遍它。\n\n这本书好在哪里?它是一本以程序员的视角来看计算机的底层机制,不需要你对物理,电子层面有多么高的水准来看计算机,如果有的话更好的(在这里就不得不吐槽国内的教学了)。它里面的内容也是十分的丰富,结合了计算机组成与体系结构,链接与装载,程序优化,内存存储层次,操作系统,网络等基础知识。\n\n好的,说那么多,我也想把我在学习的过程写下来这也不失成为我的一场回忆。\n\n## 学习目的\n> 知其然而不知其所以然\n\n在看这本书的时候问问自己,这本书可以给我带来什么?我为什么要学习这本书?正如上面的这句话一样,况且我也不想做一个”代码的搬运工“。\n\n### 学到什么?\n\n> - 可以对计算机底层系统有一个更加全面且深入的认识。\n> - 系统的理解计算机系统底层的工作原理。\n> - 写出更加健壮的、安全的代码。\n> - 走向现实层面的计算机。\n> - 打下编译原理、操作系统的基础。\n> - 等等\n\n学习是要你静下心来,认真思考,积极动手的,用我的话来说就是:事无巨细\n\n## 计算机系统漫游\n\n接下来就看看我们要学什么。\n\n### 信息`bit`化\n\n人类与机器交互最大的问题是`语言不通`。让我们回到五六十年代,那时没有像现在这样方便的手机、iPad和电脑操作方式。那个\"古老时代\"没有图像、键盘或字符,只有打孔器、巨型电子管和满屋子的电线......我们唯一能与计算机交流的方法就是通过电流和“疯狂”的思维。\n\n而随着物理学和数学的发展,计算机得以快速发展,并且我们开始使用二进制来与机器进行交互,这比以前好多了。\n\n但仍然存在一个问题:“为什么要使用二进制?”因为它适用于我们的电路(高/低电压)和逻辑门(0/1),似乎所有事情都变成了二进制。 我们在这里已经迈出了很大的步伐。\n\n在计算机领域里面,我们叫一个可以正常显示0/1的位叫`bit`,而后续的研究证明了一次性对8bit进行操作是十分成功的,因此**1 Byte = 8 bit**(注意大小写),在后面我们的位越来越多,我们使用了`十六进制`。由此来看,人类是很富有想象力的种族。\n\n在后面的学习中,数值的表示是很重要的知识点,计算机就是为精准,快速计算这些数值,特别是浮点数(float)的计算而发展的。\n\n### 编译系统\n\n```c\n\n    int main()\n\n    {\n\n        printf(\"Hello World\\n\");\n\n        return 0;\n\n    }\n\n```\n\n上面是一个简单的C语言程序,打印一个\"Hello World\"(并且换行),但是,它要经过好几个步骤才能打印在你的屏幕上,分别是:编译(Compiler),汇编(Assembler),装载器(Loader),链接器(Linker)。\n\n我们在这一部分将要学到从 `高级语言 --> 汇编语言 --> 机器语言` 这一过程的具体实现,这使我们能够更深入地了解系统的底层。。\n\n### CPU基本结构\n\nCPU(中央处理器),可以说是本世纪最伟大的发明了,一个小小的芯片装载着人类的智慧,这一部分我们要了解 CPU 的内部构造,下面是一张 CPU 的大致图片:\n\n![cpu8085.png](https://s2.loli.net/2023/07/24/sU86Dw3jgNBOoV2.png)\n\n这是一个复杂但十分有趣的部分,相信我,你会体会它的魅力的。\n\n### 操作系统\n\n操作系统(***Operating System***),是来控制电脑的执行硬件、软件资源,控制**I/O**操作,提供基本的用户互动等。\n\n它也负责加载程序、处理服务(如网络堆栈和文件系统)以及为多个程序复用资源,但它实际上是要负责隔离各个程序,使得一个给定的程序不会干扰另一个程序的内存或执行。\n\n### 网络通信\n\n\n这一部分我也写了自己的[学习笔记](https://clever-klepon-d14cb6.netlify.app/posts/internet-0/)\n\n## 外部链接\n\n[Computer Science from the Bottom Up](https://www.bottomupcs.com/index.html)\n\n[小土刀博主的『读薄』](https://wdxtub.com/)\n\n[fengmuzi2003up主的计算机系统漫游](https://fengmuzi2003.gitbook.io/csapp3e/)\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/3.Architecture/CSAPP/CSAPP01/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/3.Architecture/CSAPP/CSAPP01/index.zh-cn.md.json deleted file mode 100644 index 08ec8da..0000000 --- a/YBlog/.lh/content/post/Gohh/3.Architecture/CSAPP/CSAPP01/index.zh-cn.md.json +++ /dev/null @@ -1,18 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/3.Architecture/CSAPP/CSAPP01/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 0, - "patches": [ - { - "date": 1715560918203, - "content": "Index: \n===================================================================\n--- \n+++ \n" - } - ], - "date": 1715560918203, - "name": "Commit-0", - "content": "---\ntitle: \"一.数的表示(CSAPP)\"\ndate: 2023-03-19T20:13:06+08:00\ndraft: false\ntags: [CSAPP]\ncategories: [\"CSAPP\",\"CS\"]\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nreadingTime: true\n---\n\n# 二进制系统的核心---bit\n\n众所周知,在计算机里面的所以数据都是由**bit**表示的,可能这与我们日常使用的十进制来说是十分不方便的,而要想从现实世界的十进制到二进制的过程需要一点点的改变。\n\n\n正如我们所想的一样,bit的表示符合物理的形式,更加的底层,也与数学上的息息相关。当我们终究是要从程序员的看发来看bit的,对我们来说,计算机就是通过对**bit**进行不同方式的编码和描述,来完成和执行不同的任务。\n\n## 信息存储\n\n### 二进制和十六进制\n\n下面是各个进制的转换:\n\n| 二进制 | 十进制 | 十六进制 | 二进制 | 十进制 | 十六进制 |\n| :---: | :---: | :---: | :---: | :---: | :---: |\n| 0000 | 0 | 0 | 1000 | 8 | 8 |\n| 0001 | 1 | 1 | 1001 | 9 | 9 |\n| 0010 | 2 | 2 | 1010 | 10 | A |\n| 0011 | 3 | 3 | 1011 | 11 | B |\n| 0100 | 4 | 4 | 1100 | 12 | C |\n| 0101 | 5 | 5 | 1101 | 13 | D |\n| 0110 | 6 | 6 | 1110 | 14 | E |\n| 0111 | 7 | 7 | 1111 | 15 | F |\n\n这是一个十分重要的表格,我们要记得它。\n\n### 位, 字节, 字(bit, Byte, word)\n\n我们的一个位就是一bit, 一个字节就是8个bit, 一般32位字长机器一个字就是4个bit。\n\n如果你问我为什么要这么规定的话,我可以告诉你我也不知道,笑,可以去看看历史,我猜是这样的设计符合机器的一些特性。\n\n在C语言里面,所有的数据类型都有分配好的字节数,`char:1字节、short:2字节、int:4字节、long: 4字节、float:4字节、double:8字节`(均在32位机器上)等等。\n\n分配成这样:\n\n- 有规范,可以在不同的机器程序可以运行。\n- 机器没有无限大的内存。\n\n### 寻址和字节顺序\n\n在内存里,我们把它们抽象成一个一定大的数组块,为每一均匀分布的地址块编上编号(图片),因此我们要知道多字节的存储顺序,这对于我们在进行网络数据的发送/接收格式,阅读反汇编的时候等等有关系。\n\n大小端的判定:\n\n以下是我使用书中的代码看我的电脑是大端还是小端:\n\n```c\n\ntypedef unsigned char *byte_pointer;\nvoid show_bytes(byte_pointer start, size_t len)\n{\n    size_t i;\n    for (size_t i = 0; i < len; i++)\n    {\n        printf(\"%.2x \", start[i]);\n    }\n    printf(\"\\n\");\n}\n\nvoid show_int(int x)\n{\n    show_bytes((byte_pointer)&x, sizeof(int));\n}\n\nint main(int argc, char const *argv[])\n\n{\n    short a = -12345;\n    unsigned short ua = a;\n    printf(\"number = %d\\n\", a);\n    show_int(a);\n    printf(\"number = %d\\n\", ua);\n    show_int(ua);\n    return 0;\n}\n\n==========================>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>\n$ ./byte\nnumber = -12345\nc7 cf ff ff\nnumber = 53191\nc7 cf 00 00\n\n// 我的电脑是小端的\n// 系统Linux: Alpine apk-tools 2.12.9, compiled for x86_64.\n\n```\n\n### 位的Boolean Algebras\n\n位的布尔运算可以看我的[这一篇](https://clever-klepon-d14cb6.netlify.app/posts/bitsoperation/)\n\n#### 左移和右移的计算\n\n这里我想着重的记下来:\n对于左移`<<`& 右移`>>` 是对于位的计算,相比于右移来说左移比较简单,在移动的同时往最低位右边补 0 即可。右移的话有两种类型,一种是`逻辑右移`(左边补 0),另一种是`算术右移`(左边补符号位)。为什么会有这两种,因为对应无符号数和有符号数的运算是不同的计算方法。\n\n### C语言上的logic计算\n\n不必多言,做题:\n\n```c\n// P76 练习题2.44\nint x = foo();\nint y = bar();\n\nunsigned ux = x;\nunsigned uy = y;\n\nx < 0 => ((x * 2) < 0)\nux >= 0\nx & 7 == 7 => (x<<30) < 0\nux > -1\nx > y => -x < -y\n\n```\n\n## 整数表示\n\n### 无符号表示\n\n无符号数(unsigned),就是在`0~2[^w] - 1`范围的数,w是表示字长。有一个重要的特性,就是每个介于0~2[^w]-1 之间的数都有唯一的一个w位的值编码。\n\n- UMin = 0;\n- UMax = 2[^w]−1;\n\n### 补码表示\n\n补码(Two' s Complement), 就是在`-2[^w-1] ~ 2[^w-1] - 1`范围的数,补码的出现使得数据的表示得到最好的利用,在运算上和我们的计算自觉一样了,只有一个0没正负之分。\n\n- TMin = -2[^w-1]\n- TMax = 2[^w-1] - 1\n\n我们可以从上面得到一些特性:\n\n- |TMin| = |TMax| + 1\n- UMax = 2 *|TMax| + 1 = 2* |TMin| - 1\n\n![B2Tx.png](https://s2.loli.net/2023/04/24/ZcUXbMrG2T4OJhP.png)\n\n## 整数运算\n\n### 加法\n\n考虑两个非负整数x 和y, 满足0 < x, y < 2[^w] 。每个数都能表示为w位无符号数字。然而,\n如果计算它们的和,我们就有一个可能的范围0 < x+y < 2[^w+1]-2 。我们需要`w+1`位\n\n| 8 | 11 | 3(19) |\n|:---:| :---: |:---:|\n|1000 | + 1011 |= 10011|\n\n我们来想想补码的形式,两个数x,y满足-2[^w-1] < x, y < 2[^w-1]-1, 计算它们的和,我们就有一个可能的范围-2[^w] < x + y < 2[^w-1]-2。\n\n| 8 | 11 | 3(19) |\n|:---:| :---: |:---:|\n|1000 | + 1011 |= 10011|\n\n### 乘法\n\n无符号数的乘法就是`UMul(x,y) = x * y mod 2[^w]`\n\n补码的乘法`TMul(x,y) = U2T(x * y mod 2[^w])`\n\n### 溢出\n\n在我们的运算中(特别是很大的数)不仅仅只考虑算不算的对,还要考虑有没有溢出,一旦我需要的位变成`w+1`的十分你要十分注意了。\n\n[![Two](https://s2.loli.net/2023/04/21/5iVANckMR9qseoZ.png)\n\n此时我们要用上扩展与截取:\n\n扩展:\n\n- 对于无符号数,用x位向量表示[xn-1,...,x0] ->[0,0,0,0,xn-1,...,x0],用0把剩下的位补齐\n- 对于补码, 用x位向量表示[xn-1,...,x0] ->[ xn-1,xn-1,xn-1,xn-1,...,x0],用`最高位xn-1`把剩下的位补齐\n截取:\n- 对于无符号数,UAdd(u,v) = u+v mod 2[^w], UMult(u,v) = u * v mod 2[^w]\n- 对于补码,先把数转换成无符号数再模运算最后再转换补码, TAdd(u,v) = U2T(u+v mod 2[^w]), TMult(u,v) = U2T(u * v mod 2[^w])\n\n### 类型转换\n\n无符号数和补码的转换是对位的表示不同来达到转换的过程。\n\n## 浮点数(floating point)\n\n关于浮点数,本质上就是我们如何使用二进制来表达一个很大或者很小的数 (类似科学计数法,但是编码上有显著的区别)。\n\n由于二进制的数值系统在表达能力上存在一定的限制 (位数的限制),我们实际上没有办法表示所有的数,因此浮点数的设计需要认真的权衡和折中,既要考虑能够表达的范围,也要考虑表达的精度。\n\n浮点数是一种近似的数,和我们十进制中的小数(或分数)一样,比如:3/10 = 0.333!。所以浮点数在不论大小项目里面都是要十分小心的地方。\n\n### IEEE 浮点表示\n\nIEEE 浮点标准用V=(-1)[^s] *M* 2[^E]的形式来表示一个数:\n\n- 符号(sign) s 决定这数是负数(s=1) 还是正数(s=0), 而对于数值0的符号位解释\n作为特殊情况处理(-0.0 = +0.0)。\n- 尾数(significand) M 是一个二进制小数,它的范围是1~2-£, 或者是0~1 - £。\n- 阶码(exponent) E 的作用是对浮点数加权,这个权重是2 的E 次幕(可能是负数) 。\n将浮点数的位表示划分为三个字段,分别对这些值进行编码:\n- 一个单独的符号位s 直接编码符号s 。\n- k 位的阶码字段exp=ek - 1 … e1,e0 编码阶码E 。\n- n 位小数字段frac= fn-1 ... f1,f0 编码尾数M, 但是编码出来的值也依赖于阶码字\n段的值是否等千0 。\n\n![float.png](https://s2.loli.net/2023/04/24/TYMtb2kBysG6maf.png)\n\n在开始时记住一些值的来源:E = exp - Bias;M = 1/0 + f\n\n#### 规格化的值\n\n当阶数 `exp ≠ 000…0`和 `exp ≠ 111…1`时,表示的其实都是规范化的值,这里只需要大概知道因为实数轴上原来连续的值会被规范到有限的定值上并且这些定值之间的间距也是不一样的,具体可以通过后面给出的例子来理解。\n\n当 exp 的位模式既不全为0(数值0), 也不全为(32位的255,64位的2047)的时候,frac可以随意取值;\n\n- E = exp - Bias(2[^w-1] - 1)\n- M = 1 + f;\n\n例子:\n\n```\n 12345 = 0b0011.0000.0011.1001 = 1.1000000111001 * 2[^13]\n\n E = 13 = exp - 127 -> exp = 140;\n M = 1 + f = 1.1000000111001 -> f = 1000000111001;\n```\n\n|s(1)|exp(8)|frac(23)|\n|-|---|---|\n|0|10001100|10000001110010000000000|\n\n![Normalized](https://s2.loli.net/2023/04/24/FvmEjJeDSVWkQtH.jpg)\n\n#### 非规格化的值\n\n当exp每一位都为0的时候,可以想象到这时候的数无限的接近数值0,可画个数轴来看,此时的 `E = 1 - Bias`而且M没有隐含的1表示了,`M = f`\n\n第一个功能就是表示0,0的时候exp位为0,frac位为0,符号位的不同使得-0/+0有相同的地方何不同的地方。\n\n非规格化数的另外一个功能是表示那些非常接近于0.0 的数。它们提供了一种属性,称为逐渐溢出(gradual underflow), 其中,可能的数值分布均匀地接近于0.0 。\n\n![Denormalized](https://s2.loli.net/2023/04/24/ZmftLThWNq5kD4p.jpg)\n\n#### 无穷大和NaN\n\n最后一类数值是当指阶码全为1 的时候出现的。当小数域全为0时,得到的值表示无穷,当 s=O 时是 +∞ 或者是 s=1 时是 -∞ 。当我们把两个非常大的数相乘,或者除以零时,无穷能够表示溢出的结果。当小数域为非零时,结果值被称为\"NaN\", 即“不是一个数(**Not a Number**)\" 的缩写。一些运算的结果不能是实数或无穷,就会返回这样的NaN值,比如当计算sqrt(-1)或 (∞-∞) 时。在某些应用中,表示未初始化的数据时,它们也很有用处。\n\n![inf](https://s2.loli.net/2023/04/24/iYnoLHDCwqASEyg.jpg)\n![NaN](https://s2.loli.net/2023/04/24/15xlfajNMHpnrwG.jpg)\n\n#### 练习\n\n假设一个基于IEEE 浮点格式的5 位浮点表示,有1 个符号位、2 个阶 码位(k=Z) 和两个小数位(n=2) 。阶码偏置量是2[2-1] - 1 = 1 。下表中列举了这个5 位浮点表示的全部非负取值范围。使用下面的条件,填写表格中的空白项:\n\ne: 假定阶码字段是一个无符号整数所表示的值。\n\nE: 偏置之后的阶码值。\n\n2[^E]: 阶码的权重。\n\nf: 小数值。\n\nM: 尾数的值。\n\n2[^E] * M: 该数(未归约的)小数值。\n\nV: 该数归约后的小数值。\n\n十进制:该数的十进制表示。\n\n| 位 | e | E | 2[^E] | f | M | 2[^E]*M | V | 十进制 |\n|----|---|---|-------|---|---|---------|---|-------|\n|0 00 00 | 0 | 0 | 1 | 0/4 | 0/4 | 0/4 | 0 | 0.0 |\n|0 00 01 | 0 | 0 | 1 | 1/4 | 1/4 | 1/4 | 1/4 | 0.25 |\n|0 00 10 | 0 | 0 | 1 | 2/4 | 2/4 | 2/4 | 1/2 | 0.5 |\n|0 00 11 | 0 | 0 | 1 | 3/4 | 3/4 | 3/4 | 3/4 | 0.75 |\n|0 01 00 | 1 | 0 | 1 | 0/4 | 4/4 | 4/4 | 1 | 1.0 |\n|0 01 01 | 1 | 0 | 1 | 1/4 | 5/4 | 5/4 | 5/4 | 1.25 |\n|0 01 10 | 1 | 0 | 1 | 2/4 | 6/4 | 6/4 | 3/2 | 1.5 |\n|0 01 11 | 1 | 0 | 1 | 3/4 | 7/4 | 7/4 | 7/4 | 1.75 |\n|0 10 00 | 2 | 1 | 2 | 0/4 | 4/4 | 8/4 | 2 | 2.0 |\n|0 10 01 | 2 | 1 | 2 | 1/4 | 5/4 | 10/4 | 5/2 | 2.5 |\n|0 10 10 | 2 | 1 | 2 | 2/4 | 6/4 | 12/4 | 3 | 3.0 |\n|0 10 11 | 2 | 1 | 2 | 3/4 | 7/4 | 14/4 | 7/2 | 3.5 |\n|0 11 00 | - | - | - | - | - | - | ∞ | - |\n|0 11 01 | - | - | - | - | - | - | NaN | - |\n|0 11 10 | - | - | - | - | - | - | NaN | - |\n|0 11 11 | - | - | - | - | - | - | NaN | - |\n\n### 浮点数的舍入\n\n### 溢出\n\n```c\nprintf(\"浮点数的溢出:\\n\\t\");\nprintf(\"(1e20 + (-1e20)) + 3.14 = %lf\\n\\t\", 1e20 + (-1e20) + 3.14);\nprintf(\"1e20 + (-1e20 + 3.14) = %lf\\n\", 1e20 + (-1e20 + 3.14));\n   \n```\n\n### 浮点数的加乘法\n\n浮点数的加乘法是和我们想的不一样的,它不满足结合律,交换律的,如下:\n\n```c\nx = a + b + c;\ny = b + c + d;\n\n// 编译器可能试图通过产生下列代码来省去一个浮点加法\nt = b + c;\nx = a + t;\ny = t + d;\n// 但是对x来说,这个计算可能会产生于原始值不同的值,因为它使用了加法运算的不同结合方式\n\n//浮点数的溢出:\n (1e20 + (-1e20)) + 3.14 = 3.140000\n 1e20 + (-1e20 + 3.14) = 0.000000\n```\n\n## 总结\n\n这一章我们具体的学习了在机器上数的表示,我们用无符号数和补码来表示我的数值,用浮点数表示二进制的科学计数法,数与数的计算,它们是会有溢出的,用模运算来截断防止位溢出。\n大多数C 语言实现遵循的原则是底层的位模式不变。在补码机器上,对于一个w 位的值,这种行为是由函数T2Uw 和U2Tw来描述的。C 语言隐式的强制类型转换会出现许多程序员无法预计的结果,常常导致程序错误。\n\n```c\n\nint y = (int)(double)y;\n\n```\n\n我的建议是通读一遍课本,课本比我写的好很多,我想表达的写不出来那个`味道`,而后再去看看视频会更加的理解。\n\n## 外部链接\n\n[IEEE754---wiki](https://en.wikipedia.org/wiki/IEEE_754)\n[浮点数---wiki](https://zh.wikipedia.org/wiki/%E6%B5%AE%E7%82%B9%E6%95%B0)\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/3.Architecture/CSAPP/CSAPP02/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/3.Architecture/CSAPP/CSAPP02/index.zh-cn.md.json deleted file mode 100644 index 8c70b88..0000000 --- a/YBlog/.lh/content/post/Gohh/3.Architecture/CSAPP/CSAPP02/index.zh-cn.md.json +++ /dev/null @@ -1,18 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/3.Architecture/CSAPP/CSAPP02/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 0, - "patches": [ - { - "date": 1715560920627, - "content": "Index: \n===================================================================\n--- \n+++ \n" - } - ], - "date": 1715560920627, - "name": "Commit-0", - "content": "---\ntitle: \"二.程序的机器级表示(CSAPP)\"\ndate: 2023-04-09T20:13:06+08:00\ndraft: false\ntags: [CSAPP]\ncategories: [\"CSAPP\",\"CS\"]\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nreadingTime: true\n---\n\n# 入门\n\n## 微处理器历史\n\n### Intel的x86\n\n在这里我想来简单的说道说道微处理器的历史发展,特此说明一下我不是专业的🙄,因此我没有详细的`深入研究`,如果有任何的错误请告诉我,谢谢。\n\n自从1971年的Intel4004既第一款微处理器,也是全球第一款微处理器开始,我们人类社会标志着进入微芯片时代,在这个时代有三个主要的趋势:\n\n- 处理器的位长的倍增\n- 指令集的快速发展\n- 时钟频率的快速增加\n\nIntel也逐步发布了`Intel 8008`一个8位的,`Intel 8086` 一个16位的,至此,Intel的x86`帝国`开始了。在1985年,Intel的32位处理器`IA32`问世,而随着摩尔定律等的种种限制,单核的处理器已经遇到瓶颈了,各大公司继而转向了高频率、低功耗的多核处理器,处理器进入多核/多线程时代(2005)。\n\n在一些无论是竞争关系,还是研究关系,导致目前的市场上出现了两种**指令集计算机**\n\n- CISC(*Complex instruction set computer*)\n- RISC(*Reduced instruction set computer*)\n\n在后面我会再提到的。\n\n我不知道未来的处理器向哪个方向发展,也不知道Intel是否一直在前沿(AMD:呵呵),但我相信,人类的智慧使得世界自第二次工业革命以来史无前例的大发展,在未来一定有着不一样的发展。\n\n## 基本概念\n\n>嗯嗯,回来回来,不去想未来,做好当下。\n\n在了解具体的体系系统前,我们来了解基本的一些东西:\n\n![CS61cCS](https://s2.loli.net/2023/04/24/Jp2IxPhfSWjHNZz.png)\n\n上面是来自CS61c的图片,我们现在要了解就是整个软件到硬件的过程,也可以说是抽象到具体的过程。\n\n**Instructure Set Architecture**:指令集架构 (包括指令规格,不同规则寄存器等),简称ISA,它是软硬件之间的`桥梁`。\n\n**Processor**、**Memory**、**I/O system**:这是由OS进行控制的。\n\n我们这章主要的是学习ISA,CSAPP主要是x86-64的CISC指令集,CS61c主要是RISC-V的RISC指令集,没错,它们是不同的指令集,在我的笔记里面我也会不时的写上RISC-V的一些表示来证明我学习过了(笑)。\n\n### 什么是编译\n\n```txt\n\n高级语言 --> 汇编语言 --> 机器语言\n\n```\n\n在我们的零章的时候我说过一个*.c文件如何变成的一个可执行的程序的一个主要过程,它有一个步骤是**编译**,这是一个我们需要细细品味的步骤。\n\n编译过程是一个由某个高级语言(比如c文件)经过编译器的一系列的处理成为可读性低的汇编语言。换而言之,就是把我们十分清楚明白的抽象语言转换成机器语言(值得注意的是,此时机器也不知道汇编语言),在经历汇编译器**翻译**成二进制代码,真正的机器语言,机器可以读懂了,但我们看不懂(除了某些黑客)。\n\n![CALL](https://s2.loli.net/2023/04/24/ARQExTsuyrhdgYO.png)\n\n\n上面是cs61c中的*从C到机器语言*的完整过程,十分的详细了。程序的运行就是想像是一个**翻译**过程,用上一些我们明文规定的语法规则,使用编译器(GCC等)来当我们程序员和机器之间的**翻译官**。\n\n现在来看一看从 `C语言` 到`机器代码`(一个整型加法计算的汇编代码)\n\n```c\n  // filename: clcyle_one\n \n#include \nint main(int argc, char const *argv[])\n{\n    int sum = 0;\n    for (int i = 0; i < 10; ++i)\n    {\n        sum += i;\n    }\n    return 0;\n}\n```\n\n经过gcc的编译,在自己的Linux机器上使用以下的代码\n\n```shell\n$ gcc -Og -S clcyle_one.c\n```\n\n```asm\n    .file   \"clcyle_one.c\"\n    .text\n    .globl  main\n    .type   main, @function\nmain:\n.LFB7:\n    .cfi_startproc\n    movl    $0, %eax\n    jmp .L2\n.L3:\n    addl    $1, %eax\n.L2:\n    cmpl    $9, %eax\n    jle .L3\n    movl    $0, %eax\n    ret\n    #(不用在意类似 .file 的指令,它们是伪指令, 要从main看起)\n```\n\n两者相互比较一下我们可以发现,C 语言代码被处理成统一格式的汇编代码,在汇编代码中,第一个字符串叫做操作符,后面的是源和目的`寄存器`(这是一个大玩意😣)。操作和操作数明确,在下面我们会到不同的操作符分类分析(我想把RISC-V的加入作比较),记住一个条件,`读取`/`运算操作`是一个**线性逐句逐次**的操作,PC指令是有现态和次态之分。\n\n## 处理器的工作\n\n在我们对操作指令分类讨论之前我们来认识处理器是怎么工作的,\n\n![x86-64](https://s2.loli.net/2023/04/24/3isvAmjMY8E9IgP.jpg)\n\n\n\n![cs61c cpu](https://s2.loli.net/2023/04/24/Fzb3uHQBLTlqOgD.png)\n\n\n\n上面的图片(分别来自CSapp和CS61c)十分清楚的展示了处理器对于存放在主存里面的指令有着什么样的操作,主要的就两点**存、读取值**和**计算**。在x86-64里面还有一个叫作**条件码**的东东,我会在下面说到因为我也第一次看见这个。\n\n\n\n这是一个**CPU到Memory**的一个过程,具体的是一个处理器从内存某个地址取值(有数据和指令)拿到**CPU**里的**寄存器**通过**ALU**计算,再根据**PC**选择下一步。\n\n\n\n- **程序计数器**(PC, Program counter) - 存着下一条指令的地址,在 x86-64 中称为 RIP。\n\n- **寄存器**(Register) - 用来存储数据以便操作。\n\n- **条件代码**(Codition codes) - 通常保存最近的算术或逻辑操作后的信息,用来做条件跳转的条件。\n\n## 什么是ISA\n\n**Instruction Set Architecture** (指令集框架) 是包含了针对某个特定处理器执行的基本操作码(*opcode*),里面是基本命令,在我们学习的`x86-64`、`RISC-V`都有不同的ISA。\n\n为了学习方便,我们一般要把ISA根据使用的方法不同进行不同的分类。\n\n- 资料处理与访问操作\n- 算术逻辑操作\n- 控制过程操作\n\n\n在下面我会一一分析。\n\n## CISC&RISC区别\n\nCISC(*Complex instruction set computer*)\n\n> 兼容性性强,指令繁多,长度可变,由微程序实现。\n> 代表:x86-64\n\nRISC(*Reduced instruction set computer*)\n\n> 指令少,使用频率接近,主要是依靠硬件实现(通用寄存器、硬布线逻辑控制)。\n> 代表:RISC-V\n\n\n# 开始快乐的汇编\n\n## 整型寄存器\n\n![Reg](https://s2.loli.net/2023/04/24/pYIjkJMEBKc413b.png)\n\n在x86-64上有16个64位的**通用寄存器**;对于每个寄存器的低32、16和8位可以独立地通过其他不同指令名称访问,原则上,几乎任何寄存器都可以用于保存几乎任何逻辑和算术操作的操作数,但有些具有特殊或受限制的用途。\n\n一个寄存器有着64位、32位、16位、8位这可以对以前的低位程序向下兼容。\n\n按照惯例,%rsp被保留作为堆栈指针,并且因为一些指令(例如push、pop、call)隐含使用它。%rsp指向最低占用的堆栈位置(而不是下一个要使用的位置)。\n\n寄存器%rbp有时被用作帧指针,即当前堆栈帧的基址。指令计数器寄存器(%rip) 指向要执行的下一条命令; 程序员无法直接访问它, 但是大量地被用作基于位置无关代码寻址的基础。还有一些其他指令隐含地使用某些寄存器;例如,整数乘法和除法指令需要%rax和%rdx。\n\n## 数据类型\n\n既然我们的寄存器有着不同位的表示,那就是说处理器在操作不同的数据时使用着不同位数的寄存器来提高速率。\n\n我们针对不同的数据类型使用不同的**suffix**和**size**:\n\n| Data type | suffix | size | word|\n| :---: | :---: | :---: | :---: |\n| char | b | 1B | Byet |\n| short | w | 2B | 1word |\n| int | l | 4B | 2word |\n| long | q | 8B | 4word |\n| char* | q | 8B | 4word |\n| float | s | 4B | 2word |\n| double | l | 8B | 4word |\n\n上面的**suffix**列显示了在 GNU 汇编程序用来指定适当大小的变体的字母指示。\n\n而一个新单位**word**是相等于2个字节的大小。\n\n## 操作数指示符\n\n### 操作数基本\n\n以下的都是在操作数里面主要数值表达的意思:\n\n- **Imm**   refers to a constant value, e.g. 0x8048d8e or 48\n- **r**     refers to a register.  e.g. %rax or %edi\n- **R[r]**  refers to the value stored in register address r.\n- **M[i]**  refers to the value stored at memory address i .\n\n不同的格式表示不同的类型。\n\n### 寻址\n\n> 很重要!!!\n\n对于寻址来说,比较通用的格式是:` Imm(Rb, Ri, S) -> M[R[Rb] + S*R[Ri]+ Imm] `,其中:\n\n- **Imm** - 常数偏移量\n- **Rb** - 基寄存器\n- **Ri** - 索引寄存器,不能是 %rsp\n- **S** - 系数\n\n![OperandSpecifiers](https://s2.loli.net/2023/04/24/LPK7kRoNwmFVfi2.png)\n\n## 指令\n\n接下来我们就来看看不同分类的指令格式,我按书上的顺序来说的,它也是按我们在平时使用的频率顺序来教的。\n\n大多数的指令都是使用上文提过的 **suffix** 来显示操作数的大小的。\n\n### 数据移动指令\n\n对于 **mov** 指令来说,需要**源操作数**和**目标操作数**。指令的具体格式可以这样写 `mov? Src, Dest`,第一个是源操作数,第二个是目标操作数\n\n```asm\nmov[b|w|l|q] Src, Dest                             # 将src移动到dest\nmovs[bw|bl|bq|wl|wq|lq] Src, Dest                  # 带符号扩展的移动\nmovz[bw|bl|bq|wl|wq] Src, Dest                     # 带零扩展的移动\nmovabsq imm, r                                     # 移动绝对四字(imm为64位)\n\ncltq Src, Dest                                     # 把%eax 符号扩展到%rax\n```\n\n在使用 **mov** 指令的时候需要值得注意的是我们的源值和目的值的选址是有标准的, 源操作数可以是立即数、寄存器值或内存值的任意一种,但目标操作数只能是寄存器值或内存值\n\n|Src| Dest |\n| :--: | :--: |\n| imm | Rag |\n| imm | Mem |\n|Reg| Reg |\n|Reg|Mem|\n|Mem|Reg|\n\n> 只有这五种的选择 , 如果要把Mem -> Mem 的值移动,需要两步 Mem -> Reg -> Mem\n\n\n### 程序栈指令\n\n这一部分就只有两个主要的指令,但是无比的重要。可以把数据压入程序栈中,以及在栈中弹出,程序栈在过程调用中起至关重要的作用。\n\n```asm\npushq  Src                    # 将4word的数据压入栈,并把%rsp - 8 -> %rsp\npopq  Dest                    # 将4word的数据弹入栈,并把%rsp + 8 -> %rsp\n```\n\n对于程序栈指令十分重要的一点是我们对内存的变化要注意。在程序员的眼里内存是一个有限的数组,我们在把寄存器里面的数据 `push` 进内存的时候栈指针(%rsp)要向着地址减小的方向移动,这就是 `%rsp - 8` 的原因。\n\n图片\n\n### 算术与逻辑指令\n\n对于算术指令我们想起CPU中最重要的部件 `ALU` 算术逻辑单元,基本上所有的这些指令通过\n `opcode` 来在多路选择上 `指挥` ALU正确的使用算术。\n\n > 注:下面的所有指令都可以根据数据类型加 suffix (b/w/l/q)\n\n#### Unary Operation(一元操作)\n\n```asm\ninc Deat         Deat+1->Deat           # 按1递增\ndec Deat         Deat-1->Deat           # 按1递减\nneg Deat         -Deat->Deat    (取反)  # 算术取反\nnot Deat         ~Deat-1->Deat (取补) # 按位取反\n```\n\n一元操作只有一个操作数,即做源也是目的。可以是`Reg or Mem` 。\n\n#### Binary Operation(二元操作)\n\n```asm\nleaq S,D      &S -> D        # 将源地址的有效地址加载到目标中\nadd S,D      D + S -> D      # 将源加到目标中\nsub S,D      D - S -> D      # 将源从目标中减去\nimul S,D     D * S -> D      # 目标乘以源\nxor S,D      D ^ S -> D      # 按位异或目标和来源\nor S,D       D | S -> D      # 按位或目标和来源\nand S, D      D & S -> D      # 按位与目标和来源\n```\n\n对于第二个到最后一个不需要再说了,都是字面意思。主要来说一说 `leaq` 这个指令。\n\nLoad effective address(加载有效地址) , leaq 有两个作用:\n\n> - 将其源操作数的有效地址(而不是该地址处的数据)加载到其目标寄存器中\n>   在 C语言里面就是 `&S` , 这样的好处是可以给下面的内存产生指针。\n> - 也可用于执行与寻址无关的算术运算。(eg: `leaq (%rdi, %rsi, 4), %rax` 相同与 `x + 4*y ` )\n\n#### Shift Operations(移位操作)\n\n```asm\nsal[b|w|l|q] imm,d   d = d << imm   # 左移imm位\nsar[b|w|l|q] imm,d   d = d >> imm   # 算术右移imm位\nshr[b|w|l|q] imm,d   d = d >> imm   # 逻辑右移imm位\n```\n\n#### Special Arithmetic Operations(特殊算术操作)\n\n```asm\nimulq S                  # 有符号全乘法   四字到八字\nmulq S                   # 无符号全乘法   四字到八字\nidivq S                  # 有符号全除法   八字到四字\ndivq S                   # 无符号全除法   八字到四字\ncltd                     # sign extend %eax into %edx::%eax\ncqto                     # sign extend %rax into %rdx::%rax\n```\n\n在特殊算术里面,这样的设计是为了补码的乘除有扩展。由两个64位的到全128位的乘积和整数除法的截断。\n\n除法需要特殊的安排:`idiv(有符号)` 和 `div(无符号)` 操作在2n字节被除数和n字节除数上,产生一个n字节商和n字节余数。被除数总是存在于一对固定寄存器中(32位情况下为%edx和%eax;64位情况下为%rdx和%rax);除数作为指令中的源操作数来指定。商放在%eax(resp. %rax)中; 余数放在%edx(resp. %rdx)中。对于有符号的除法,使用cltd(resp.ctqo)指令来准备%edx(resp.%rdx),并将其与%eax(resp.%rax)的符号扩展配合使用。例如,如果a、b、c是保存四个字长的内存位置,则可以使用以下序列设置c = a / b:\n\n```asm\n    movq a(%rip), %rax\n    ctqo\n    idivq b(%rip)\n    movq %rax, c(%rip)\n```\n\n上文来自文档)\n\n\n### 控制指令\n\n到目前为止,我们看到的都是顺序一条接着一条的操作的,但是在我们的c语言里面还有条件语句(if)、循环语句(while)、分支语句(switch)等,很明显都不是顺序的,要进行某种**跳转**,而这种跳转是由机器代码来实现的,根据测试数据值来判断机器此时是否改变控制流。\n\n#### 条件码\n\n好了,到我们心心念的**条件码**了,条件码在CPU中是有单独的**条件码寄存器**,但是它只有单个位,它们描述的是距离最近的算术和逻辑操作的某些属性,CPU根据条件码寄存器来断定是否执行分支跳转。以下是四种条件码:\n\n- **ZF** result was Zero\n- **CF** result caused Carry out of most significant bit (unsigned)\n- **SF** result was negative (Sign bit was set)\n- **OF** result caused (**signed**) Overflow (negative overflow, positive overflow)\n\n> leaq 指令不改变任何的条件码。而不是所有的指令都要改变,如**xor**对于CF、OF会设置为0。\n\n指令集中也有专门来设置条件码的指令,它们不会改变任何的其他寄存器,只会改变条件码:\n\n```asm\n\ncmp[b|w|l|q]  s2,s1                         # 比较两个值,S1 - S2 用减法的方法来比较\n\ntest[b|w|l|q] s2,s1                         # 测试两个值,S1 & S2 可以来检查是负or正,也可以比较具体位的值\n\n```\n\n其实cmp和test有时是十分好用的测试指令,比如在对(x == 0)的时候,可以用 `cmpl %eax, %eax` 或者 `testl %eax, %eax` 来与自己比较来设置**ZF**条件码,也用来判断 `%eax` 是正数或负数。\n\n#### 访问条件码\n\n条件码通常是不会直接读取的,在x86中采用三种使用方式:\n\n- 可以根据条件码的某种位逻辑组合,将一个字节设置为0 或1。\n- 可以条件跳转到程序的某个其他的部分。\n- 可以有条件地传送数据。\n\n\n> 这里会发现用了位的逻辑计算来确认大于或小于等情况。(需要好好看看第二章)\n\n1. 第一点的实现 **SET指令**\n\n```asm\nsete / setz   D        Set if equal/zero                               ZF\nsetne / setnz D        Set if not equal/nonzero                      ~ ZF\nsets          D        Set if negative                                 SF\nsetns         D        Set if nonnegative                            ~ SF\nsetg / setnle D        Set if greater (signed)                 ~ (SF ^ 0F)& ~ ZF\nsetge / setnl D        Set if greater or equal (signed)           ~ (SF ^ 0F)\nsetl / setnge D        Set if less (signed)                           SF^0F\nsetle / setng D        Set if less or equal                       (SF ^ OF)|ZF\nseta / setnbe D        Set if above (unsigned)                     ~ CF& ~ ZF\nsetae / setnb D        Set if above or equal (unsigned)              ~ CF\nsetb / setnae D        Set if below (unsigned)                         CF\nsetbe / setna D        Set if below or equal (unsigned)               CF|ZF\n```\n\nSET指令,每条指令根据条件码的各种组合将一个字节设置为 **0或1**。\n\n2. 第二点的实现 **Jump指令**\n\n```asm\njmp Label             Jump to label                                   true\njmp *Operand          Jump to specified location                      true\nje / jz Label         Jump if equal/zero                               ZF\njne / jnz Label       Jump if not equal/nonzero                       ~ ZF\njs Label              Jump if negative                                 SF\njns Label             Jump if nonnegative                             ~ SF\njg / jnle Label       Jump if greater (signed)                ~ (SF ^ 0F)& ~ ZF\njge / jnl Label       Jump if greater or equal (signed)           ~ (SF ^ 0F)\njl / jnge Label       Jump if less (signed)                           SF^0F\njle / jng Label       Jump if less or equal                       (SF ^ OF)|ZF\nja / jnbe Label       Jump if above (unsigned)                    ~ CF& ~ ZF\njae / jnb Label       Jump if above or equal (unsigned)               ~ CF\njb / jnae Label       Jump if below (unsigned)                         CF\njbe / jna Label       Jump if below or equal (unsigned)              CF|ZF\n```\n\n跳转(jump) 指令会导致执行切换到程序中一个全新的位置。在汇编代码中,这些跳转的目的地通常用一个标号(**Label**) 指明。在下一个标题再继续深入jump指令。\n\n3. 第三点的实现 **cmove指令**\n\n```asm\ncmove / cmovz   S, D   Move if equal/zero                               ZF\ncmovne / cmovnz S, D   Move if not equal/nonzero                       ~ ZF\ncmovs           S, D   Move if negative                                 SF\ncmovns          S, D   Move if nonnegative                             ~ SF\ncmovg / cmovnle S, D   Move if greater                (signed)    ~ (SF ^ 0F)& ~ ZF\ncmovge / cmovnl S, D   Move if greater or equal       (signed)      ~ (SF ^ 0F)\ncmovl / cmovnge S, D   Move if less (signed)                           SF^0F\ncmovle / cmovng S, D   Move if less or equal                       (SF ^ OF)|ZF\ncmova / cmovnbe S, D   Move if above (unsigned)                     ~ CF& ~ ZF\ncmovae / cmovnb S, D   Move if above or equal        (unsigned)        ~ CF\ncmovb / cmovnae S, D   Move if below                 (unsigned)         CF\ncmovbe / cmovna S, D   Move if below or equal        (unsigned)        CF|ZF\n```\n\n条件传送指令, 但传送条件满足的时候,指令把`S`复制到`D`中。\n\n#### C语言中的条件分支\n\n现在来进行对C语言中一些常见的分支跳转操作来看看翻译后的机器代码。\n\n##### if-else\n\nC 语言中的江-else 语旬的通用形式模板如下:\n\n```c\nif (test-expr)\n    then-statement\nelse\n    els-statement\n```\n\n汇编器工作是为 `then-statement` 和 `else-statement` 产生各自的代码块。它会插入条件和无条件分支,以保证能执行正确的代码块。\n\n看一个例子\n\n```c\n\nlong absdiff(long x, long y)\n{\n  long result;\n    if (x < y)\n        result = y-x;\n    else\n        result = x-y;\n    return result;\n}\n\n```\n\n```c\n\nlong absdiff_es(long x, long y)\n{\n    long result;\n    if (x > y)\n        result = x-y;\n    else\n        result = y-x;\n    return result;\n}\n\n```\n\n分别产生的汇编代码\n\n```asm\n# x in %rdi, y in %rai\nabsdiff :\n    movq %rsi, %rax\n    subq %rdi, %rax          rval = y-x\n    movq %rdi, %rdx\n    subq %rsi, %rdx          eval = x-y\n    cmpq %rsi, %rdi          比较 x:y\n    cmovge %rdx, %rax       If >=, rval = eval\n    ret                      Return tval\n\n```\n\n```asm\n\nabsdiff_es:\n    cmpq    %rsi, %rdi\n    jle     .L4\n    movq    %rdi, %rax\n    subq    %rsi, %rax\n    ret\n.L4:    # x <= y\n    movq    %rsi, %rax\n    subq    %rdi, %rax\n    ret\n```\n\n> [为什么基于条件数据传送(1)的代码会比基于条件控制转移(2)的代码性能要好?]\n\n##### while\n\nwhile 语句的通用形式如下:\n\n```c\nwhile (test-expr)\n    body-statement\n```\n\n例子\n\n```c\nlong fact_while(long n)\n{\n    long result = 1;\n    while (n > 1) {\n        result *= n;\n        n = n-1;\n    }\n    return result;\n}\n```\n\n##### do-while\n\ndo-while 语句的通用形式如下:\n\n```c\ndo\n    body-statement\n    while (test-expr);\n```\n\n例子\n\n```c\n\n// Do While 的 C 语言代码\nlong pcount_do(unsigned long x)\n\n{\n    long result = 0;\n    do {\n        result += x & 0x1;\n        x >>= 1;\n    } while (x);\n    return result;\n}\n```\n\n产生的汇编代码\n\n```asm\n\n    movl    $0, %eax    # result = 0\n.L2:                    # loop:\n    movq    %rdi, %rdx\n    andl    $1, %edx    # t = x & 0x1\n    addq    %rdx, %rax  # result += t\n    shrq    %rdi        # x >>= 1\n    jne     .L2         # if (x) goto loop\n    rep                 # ret\n```\n\n##### for\n\nfor 循环的通用形式如下:\n\n```c\nfor (init-expr; test-expr; update-expr)\n    body-statement\n```\n\n#### switch\n\nswitch 循环的通用形式如下:\n\n```c\nswitch(n){\n    case test-expr:\n        body-statement\n        break;\n    case test-expr:\n        body-statement\n        break;\n}\n\n```\n\n对于C语言的这些语法我只是在这里举出例子来,最好看看书上的讲解。\n\n### 分支跳转(RISC-V)\n\n对于这个分类其实我分给了RISC-V, 主要是在x86-64中的控制指令和RISC-V的分支跳转其实是一回事,主要区别是否使用的条件码(其实在我看来RISC-V也用了条件码,但是是隐式的使用)。\n\nRISC-V的 **Branch Instruction**\n\n```asm\n\n(施工中🚧)\n\n```\n\n## 过程调用\n\n过程是软件中一种很重要的抽象。它提供了一种封装代码的方式,用一组指定的参数和一个可选的返回值实现了某种功能。然后,可以在程序中不同的地方调用这个函数。设计良好的软件用过程作为抽象机制,隐藏某个行为的具体实现,同时又提供清晰简洁的接口定义,说明要计算的是哪些值,过程会对程序状态产生什么样的影响。不同编程语言中,过程的形式多样:函数(function) 、方法(method) 、子例(subroutine) 、处理函数(handler) 等等,但是它们有一些共有的特性。\n\n过程调用主要有三个机制:\n\n1. **控制传递**。包括如何开始执行过程代码,以及如何返回到开始的地方。本质上是代码执行地址的改变和切换。\n\n2. **数据传递**。调用函数时要传给函数一些参数,在返回函数时也可能会将一些函数计算结果以返回值形式返回给原函数。本质上是数据传入新过程,又传回原过程。\n\n3. **内存管理**。在过程进行时,如何分配内存空间;在过程返回后,如何销毁内存中存储的局部变量。\n\n![callsk](https://s2.loli.net/2023/05/07/iWSVILyRpxh63Dl.jpg)\n\n## 数据存储分配\n\n## 外部链接\n\n[摩尔定律---Wiki](https://zh.wikipedia.org/wiki/%E6%91%A9%E5%B0%94%E5%AE%9A%E5%BE%8B)\n\n[微处理器---Wiki](https://zh.wikipedia.org/wiki/%E5%BE%AE%E5%A4%84%E7%90%86%E5%99%A8)\n\n[*The 50 Year History of the Microprocessor*](https://zhuanlan.zhihu.com/p/511271401)\n\n[芯片相关-- Cpu历史--AMD系列](https://zhuanlan.zhihu.com/p/464721330)\n\n[芯片相关-- Cpu历史--intel系列](https://zhuanlan.zhihu.com/p/464413953)\n\n[【读薄 CSAPP】贰 机器指令与程序优化](https://wdxtub.com/csapp/thin-csapp-2/2016/04/16/)\n\n[RISC-V手册](http://riscvbook.com/chinese/RISC-V-Reader-Chinese-v2p1.pdf)\n\n[RISC-V基本指令集概述](https://www.sunnychen.top/archives/riscvbasic)\n\n[过程调用](https://segmentfault.com/a/1190000022161796)\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/3.Architecture/CSAPP/CSAPP03/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/3.Architecture/CSAPP/CSAPP03/index.zh-cn.md.json deleted file mode 100644 index 3be5218..0000000 --- a/YBlog/.lh/content/post/Gohh/3.Architecture/CSAPP/CSAPP03/index.zh-cn.md.json +++ /dev/null @@ -1,22 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/3.Architecture/CSAPP/CSAPP03/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 1, - "patches": [ - { - "date": 1715560923228, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1715560939684, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -9,4 +9,5 @@\n math: false\n weight:\n readingTime: true\n ---\n+\n" - } - ], - "date": 1715560923228, - "name": "Commit-0", - "content": "---\ntitle: \"三.处理器设计(CSAPP)\"\ndate: 2023-04-09T20:13:06+08:00\ndraft: True\ntags: [CSAPP]\ncategories: [\"CSAPP\",\"CS\"]\nauthor: [\"Yeelight\"]\nshowtoc: true\nmath: false\nweight:\nreadingTime: true\n---\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/3.OS/LinuxLearn/Notes/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/3.OS/LinuxLearn/Notes/index.zh-cn.md.json deleted file mode 100644 index 0403bba..0000000 --- a/YBlog/.lh/content/post/Gohh/3.OS/LinuxLearn/Notes/index.zh-cn.md.json +++ /dev/null @@ -1,22 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/3.OS/LinuxLearn/Notes/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 1, - "patches": [ - { - "date": 1712581746119, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1712581763717, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -26,14 +26,14 @@\n \n ## 个人 Linux 的学习\n \n [Linux个人学习记录]({{< relref \"\" >}})\n-[命令行的魅力]({{< relref \"post/CS/3.OS/LinuxLearn/Line/index.zh-cn.md\" >}})\n+[命令行的魅力]({{< relref \"post/Gohh/3.OS/LinuxLearn/Line/index.zh-cn.md\" >}})\n \n ### 分类\n \n-[文件描述符]({{< relref \"post/CS/3.OS/LinuxLearn/FD/index.zh-cn.md\" >}})\n-\n+[文件描述符]({{< relref \"post/Gohh/3.OS/LinuxLearn/FD/index.zh-cn.md\" >}})\n+\n [进程(Process)和 线程(Thread)]()\n \n ### 在 XV 6 中 Syscall 函数\n \n" - } - ], - "date": 1712581746119, - "name": "Commit-0", - "content": "---\ntitle: \"操作系统的具体学习\"\ndate: 2024-03-10T16:34:18+08:00\ndraft: false\ntaps: ['OS']\ncategories: ['linux', 'OS', 'xv6', 'learning']\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nreadingTime: true\n---\n\n## 通过 XV6 了解操作系统\n\n我希望通过 6. S081 的学习来学习操作系统的强大,以下的是我在学习中的笔记:\n[通过 XV6 来学习操作系统(OSTEP)]({{< relref \"post/CS/3.OS/S6.081/xv6_learn/index.zh-cn.md\" >}})\n\n- [XV6的gdb调试]({{< relref \"post/CS/3.OS/S6.081/xv6_gdb_debug/index.zh-cn.md\" >}})\n- [XV6的源码解析]({{< relref \"post/CS/3.OS/S6.081/xv6_src/index.zh-cn.md\" >}})\n\n- [XV6中的trap]({{< relref \"post/CS/3.OS/S6.081/xv6_trap/index.zh-cn.md\" >}})\n- [XV6的中断]({{< relref \"post/CS/3.OS/S6.081/xv6_interrupt/index.zh-cn.md\" >}})\n- [XV6的锁和并行]({{< relref \"post/CS/3.OS/S6.081/xv6_lock/index.zh-cn.md\" >}})\n- [XV6的进程和线程]({{< relref \"post/Gohh/3.OS/S6.081/xv6_process/index.zh-cn.md\" >}})\n- [XV6的文件系统]({{< relref \"post/Gohh/3.OS/S6.081/xv6_file_system/index.zh-cn.md\" >}})\n\n## 个人 Linux 的学习\n\n[Linux个人学习记录]({{< relref \"\" >}})\n[命令行的魅力]({{< relref \"post/CS/3.OS/LinuxLearn/Line/index.zh-cn.md\" >}})\n\n### 分类\n\n[文件描述符]({{< relref \"post/CS/3.OS/LinuxLearn/FD/index.zh-cn.md\" >}})\n\n[进程(Process)和 线程(Thread)]()\n\n### 在 XV 6 中 Syscall 函数\n\n|**系统调用**|**描述**|\n|---|---|\n|`int fork()`|创建一个进程,返回子进程的PID|\n|`int exit(int status)`|终止当前进程,并将状态报告给wait()函数。无返回|\n| `int wait(int *status)` |等待一个子进程退出; 将退出状态存入 `*status`; 返回子进程 PID。|\n|`int kill(int pid)`|终止对应PID的进程,返回0,或返回-1表示错误|\n|`int getpid()`|返回当前进程的PID|\n|`int sleep(int n)`|暂停n个时钟节拍|\n|`int exec(char *file, char *argv[])`|加载一个文件并使用参数执行它; 只有在出错时才返回|\n|`char *sbrk(int n)`|按n 字节增长进程的内存。返回新内存的开始|\n|`int open(char *file, int flags)`|打开一个文件;flags表示read/write;返回一个fd(文件描述符)|\n|`int write(int fd, char *buf, int n)`|从buf 写n 个字节到文件描述符fd; 返回n|\n|`int read(int fd, char *buf, int n)`|将n 个字节读入buf;返回读取的字节数;如果文件结束,返回0|\n|`int close(int fd)`|释放打开的文件fd|\n|`int dup(int fd)`|返回一个新的文件描述符,指向与fd 相同的文件|\n|`int pipe(int p[])`|创建一个管道,把read/write文件描述符放在p[0]和p[1]中|\n|`int chdir(char *dir)`|改变当前的工作目录|\n|`int mkdir(char *dir)`|创建一个新目录|\n|`int mknod(char *file, int, int)`|创建一个设备文件|\n|`int fstat(int fd, struct stat *st)`|将打开文件fd的信息放入*st|\n|`int stat(char *file, struct stat *st)`|将指定名称的文件信息放入*st|\n|`int link(char *file1, char *file2)`|为文件file1创建另一个名称(file2)|\n|`int unlink(char *file)`|删除一个文件|\n\n​ 来自表1.2:xv6系统调用(除非另外声明,这些系统调用返回0表示无误,返回-1表示出错)\n\n[fork() 函数]({{< relref \"\" >}})\n[exec() 函数]({{< relref \"\" >}})\n[exit() 函数]({{< relref \"\" >}})\n\n## 课程教材\n\nbook-riscv-rev2\n\n操作系统-三个简单的部分-ostep\n\n鸟哥的Linux私房菜 基础学习篇 第四版 (鸟哥)\n\n## MIT6.S081 的实验记录\n\n[MIT6.S081 的实验问题]({{< relref \"\" >}})\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/4.OS/LinuxLearn/Notes/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/4.OS/LinuxLearn/Notes/index.zh-cn.md.json deleted file mode 100644 index 0eebfa8..0000000 --- a/YBlog/.lh/content/post/Gohh/4.OS/LinuxLearn/Notes/index.zh-cn.md.json +++ /dev/null @@ -1,18 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/4.OS/LinuxLearn/Notes/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 0, - "patches": [ - { - "date": 1715567412571, - "content": "Index: \n===================================================================\n--- \n+++ \n" - } - ], - "date": 1715567412571, - "name": "Commit-0", - "content": "---\ntitle: \"操作系统的具体学习\"\ndate: 2024-03-10T16:34:18+08:00\ndraft: false\ntaps: ['OS']\ncategories: ['linux', 'OS', 'xv6', 'learning']\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nreadingTime: true\n---\n\n## 通过 XV6 了解操作系统\n\n我希望通过 6. S081 的学习来学习操作系统的强大,以下的是我在学习中的笔记:\n[通过 XV6 来学习操作系统(OSTEP)]({{< relref \"post/Gohh/4.OS/S6.081/xv6_learn/index.zh-cn.md\" >}})\n\n- [XV6的gdb调试]({{< relref \"post/Gohh/4.OS/S6.081/xv6_gdb_debug/index.zh-cn.md\" >}})\n- [XV6的源码解析]({{< relref \"post/Gohh/4.OS/S6.081/xv6_src/index.zh-cn.md\" >}})\n\n- [XV6中的trap]({{< relref \"post/Gohh/4.OS/S6.081/xv6_trap/index.zh-cn.md\" >}})\n- [XV6的中断]({{< relref \"post/Gohh/4.OS/S6.081/xv6_interrupt/index.zh-cn.md\" >}})\n- [XV6的锁和并行]({{< relref \"post/Gohh/4.OS/S6.081/xv6_lock/index.zh-cn.md\" >}})\n- [XV6的进程和线程]({{< relref \"post/Gohh/4.OS/S6.081/xv6_process/index.zh-cn.md\" >}})\n- [XV6的文件系统]({{< relref \"post/Gohh/4.OS/S6.081/xv6_file_system/index.zh-cn.md\" >}})\n\n## 个人 Linux 的学习\n\n[Linux个人学习记录]({{< relref \"\" >}})\n[命令行的魅力]({{< relref \"post/Gohh/4.OS/LinuxLearn/Line/index.zh-cn.md\" >}})\n\n### 分类\n\n[文件描述符]({{< relref \"post/Gohh/4.OS/LinuxLearn/FD/index.zh-cn.md\" >}})\n\n[进程(Process)和 线程(Thread)]()\n\n### 在 XV 6 中 Syscall 函数\n\n|**系统调用**|**描述**|\n|---|---|\n|`int fork()`|创建一个进程,返回子进程的PID|\n|`int exit(int status)`|终止当前进程,并将状态报告给wait()函数。无返回|\n| `int wait(int *status)` |等待一个子进程退出; 将退出状态存入 `*status`; 返回子进程 PID。|\n|`int kill(int pid)`|终止对应PID的进程,返回0,或返回-1表示错误|\n|`int getpid()`|返回当前进程的PID|\n|`int sleep(int n)`|暂停n个时钟节拍|\n|`int exec(char *file, char *argv[])`|加载一个文件并使用参数执行它; 只有在出错时才返回|\n|`char *sbrk(int n)`|按n 字节增长进程的内存。返回新内存的开始|\n|`int open(char *file, int flags)`|打开一个文件;flags表示read/write;返回一个fd(文件描述符)|\n|`int write(int fd, char *buf, int n)`|从buf 写n 个字节到文件描述符fd; 返回n|\n|`int read(int fd, char *buf, int n)`|将n 个字节读入buf;返回读取的字节数;如果文件结束,返回0|\n|`int close(int fd)`|释放打开的文件fd|\n|`int dup(int fd)`|返回一个新的文件描述符,指向与fd 相同的文件|\n|`int pipe(int p[])`|创建一个管道,把read/write文件描述符放在p[0]和p[1]中|\n|`int chdir(char *dir)`|改变当前的工作目录|\n|`int mkdir(char *dir)`|创建一个新目录|\n|`int mknod(char *file, int, int)`|创建一个设备文件|\n|`int fstat(int fd, struct stat *st)`|将打开文件fd的信息放入*st|\n|`int stat(char *file, struct stat *st)`|将指定名称的文件信息放入*st|\n|`int link(char *file1, char *file2)`|为文件file1创建另一个名称(file2)|\n|`int unlink(char *file)`|删除一个文件|\n\n​ 来自表1.2:xv6系统调用(除非另外声明,这些系统调用返回0表示无误,返回-1表示出错)\n\n[fork() 函数]({{< relref \"\" >}})\n[exec() 函数]({{< relref \"\" >}})\n[exit() 函数]({{< relref \"\" >}})\n\n## 课程教材\n\nbook-riscv-rev2\n\n操作系统-三个简单的部分-ostep\n\n鸟哥的Linux私房菜 基础学习篇 第四版 (鸟哥)\n\n## MIT6.S081 的实验记录\n\n[MIT6.S081 的实验问题]({{< relref \"\" >}})\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/5.Networking/http/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/5.Networking/http/index.zh-cn.md.json deleted file mode 100644 index 3fa2ff2..0000000 --- a/YBlog/.lh/content/post/Gohh/5.Networking/http/index.zh-cn.md.json +++ /dev/null @@ -1,66 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/5.Networking/http/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 12, - "patches": [ - { - "date": 1718117388278, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1718117393956, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: \"Http http 是什么\"\n+title: \"Http 是什么\"\n date: 2024-06-11T22:49:31+08:00\n draft: true\n taps: []\n categories: []\n@@ -9,4 +9,143 @@\n weight:\n math: false\n readingTime: true\n ---\n+\n+\t在这篇文章里,可以学习到现代网络的工作模式\n+\t比如:什么是http、Web...\n+## Why need network?\n+\n+军事方面、信息交换、跨地域传输、业务连接... ...\n+\n+**网络**已经成为现代社会不可或缺的基础设施,它极大地促进了信息的流通、资源的共享和全球化的进程。\n+\n+看来我们为了满足需要,我们要规范 **network** ,因此出现HTTP\n+\n+## What is HTTP?\n+\n+HTTP 是基于 **TCP/IP(传输层)** 的**应用层**通信协议,它标准化了客户端和服务器之间的**通信**方式。定义了如何通过互联网**请求(Requests)** 和 **传输(Transmissions)** 内容。\n+\n+通过应用层协议(客户端和服务器之间的通信方式抽象层),HTTP 本身依赖于 TCP/IP 来获取客户端和服务器之间的请求和响应。默认使用 TCP 端口 80。\n+\n+在 http 中的主要流程为:\n+> 浏览器 -> 服务器\n+\n+![[Pasted image 20240526132924.png]]\n+\n+## HTTP Version\n+\tHTTP 的历代版本\n+### HTTP/0.9\n+有史以来最简单的协议,只有一个名为 GET 的方法。\n+- 响应必须是 HTML 文件\n+- 只有 GET\n+### HTTP/1.0\n+\tHTTP 的大发展\n+可以处理其他响应格式,即**图像**、**视频文件**、**纯文本**或**任何其他内容**类型。它添加 `POST` 和 `HEAD` 方法、更改了请求/响应 **格式**、将 HTTP **标头**添加到请求和响应中、添加了**状态代码**来**标识响应**、还有引入了字符集支持、多部分类型、授权、缓存、内容编码等都包括在内。\n+\n+请求:\n+```http\n+GET / HTTP/1.0\n+```\n+\n+响应:\n+``` http\n+HTTP/1.0 200 OK\n+...\n+```\n+\n+HTTP/1.0 的主要缺点\n+- 无持久连接 --- [[Three-way Handshake(三次握手)]]\n+- 队头阻塞\n+- 请求方法有限\n+- 头部信息冗余\n+- 缓存有限\n+### HTTP/1.1\n+\n+相比于 HTTP/1.0\n+- ***持久连接*** --- 允许多个连续请求\n+- 添加了新的方法,其中引入了 `PUT`、`PATCH`、`OPTIONS`、`DELETE`\n+- 主机名**标识**在 HTTP/1.1 使其成为必要的\n+- **Pipelining** 管道化\n+- 更多的状态码\n+- 等等\n+> 更多 [RFC 2616](https://datatracker.ietf.org/doc/html/rfc2616)\n+\n+ 缺点:\n+\n+1. **队头阻塞(Head-of-line Blocking)**:虽然HTTP/1.1 支持管道化,但由于TCP的特性,如果前一个请求的响应延迟,后续请求仍然会被阻塞。\n+2. **性能瓶颈**:由于HTTP/1.1 仍然依赖于文本格式的头部信息,这可能导致较大的数据传输量和解析延迟。\n+3. **不支持服务器推送**:HTTP/1.1 不支持服务器主动向客户端推送资源,所有资源都需要客户端明确请求。\n+4. **头部冗余**:HTTP/1.1 的头部信息在每次请求中都会重复发送,尤其是在使用Cookie等机制时,增加了数据传输量。\n+5. **缺乏对现代Web应用的支持**:随着Web应用变得越来越复杂,HTTP/1.1 在处理大量并发请求、实时数据传输等方面显得力不从心。\n+### SPDY (from Google)\n+> SPDY也就是[HTTP/2](https://zh.wikipedia.org/wiki/HTTP/2 \"HTTP/2\")的前身\n+\n+### HTTP/2\n+\n+优点:\n+\n+1. **二进制分帧**(Frames and Streams)\n+\tHTTP/2 将数据分割成更小的**二进制**帧,每个帧都有自己的类型和流标识符。这种分帧机制使得数据传输更加高效,并且可以实现多路复用。\n+2. **I/O多路复用**:\n+\tHTTP/2 允许在单个连接上**并行**处理多个请求和响应,消除了 HTTP/1.x 中的队头阻塞问题,提高了页面加载速度\n+3. **头部压缩**:\n+\tHTTP/2 使用 **HPACK** 算法压缩头部信息,减少了数据传输量,降低了延迟。(Huffman Code ?)\n+\t[RFC7541](https://datatracker.ietf.org/doc/html/rfc7541)\n+4. **服务器推送**:\n+\tHTTP/2 支持服务器**主动**向客户端推送资源,即服务器可以在客户端请求之前发送客户端可能需要的资源,提高了页面加载效率。\n+5. **优先级和依赖**:\n+\tHTTP/2 允许客户端指定请求的优先级,服务器可以根据这些信息优化资源的传输顺序。\n+6. **保持连接**:\n+\t HTTP/2 默认使用持久连接,减少了连接建立和断开的开销。\n+7. **兼容性**:\n+\tHTTP/2 保持了与 HTTP/1.x 的语义兼容性,现有的应用可以无需修改或只需少量修改即可迁移到 HTTP/2。\n+\n+缺点:\n+1. **实现复杂性**:HTTP/2 的二进制分帧和多路复用机制增加了协议实现的复杂性,对服务器和客户端的实现提出了更高的要求。\n+2. **安全依赖**:虽然 HTTP/2 本身不强制要求使用加密,但大多数浏览器和服务器实现都要求使用 HTTPS,这增加了部署的复杂性和成本。\n+3. **队头阻塞问题**:虽然 HTTP/2 在应用层解决了队头阻塞问题,但在TCP层仍然存在队头阻塞,因为TCP协议本身是按顺序传输数据的。\n+4. **服务器推送的挑战**:服务器推送虽然可以提高性能,但如果不当使用,可能会导致资源浪费或客户端缓存问题。\n+5. **兼容性问题**:虽然HTTP/2 与 HTTP/1.x 语义兼容,但在实际部署中可能会遇到一些兼容性问题,尤其是在旧的网络设备和中间件上。\n+6. **性能提升有限**:对于一些优化良好的HTTP/1.x 网站,迁移到 HTTP/2 可能不会带来显著的性能提升。\n+\n+## SSL、TLS、HTTPS\n+\n+?\n+- **SSL/TLS**:这两个协议位于应用层和传输层之间,为上层协议提供加密服务。它们负责在客户端和服务器之间建立安全的通信通道。\n+- **HTTPS**:这是一个应用层协议,它使用SSL/TLS来保护HTTP通信的安全。HTTPS是HTTP和SSL/TLS的结合体,它使得Web浏览器和服务器之间的通信变得安全。\n+\n+## 继续学习 HTTP 的详解\n+\n+### HTTP 请求包\n+### HTTP 响应包\n+\n+**响应头**(Response Headers)是在 HTTP 响应中发送的一组**键值对(key-value pair)**,它们提供了关于响应的**元数据信息**,如**内容类型**、**内容长度**、**缓存控制**、**服务器信息**等。响应头位于 HTTP 响应的起始行(状态行)之后,响应体之前,并且以空行(CRLF)与响应体分隔。\n+\n+```HTTP\n+HTTP/1.1 200 OK\n+Content-Type: text/html; charset=UTF-8\n+Content-Length: 1234\n+Date: Mon, 21 Oct 2019 07:28:00 GMT\n+Server: Apache\n+```\n+\n+### HTTP 的方法\n+\n+### HTTP 的状态码\n+\n+- 1 XX 提示信息 - 表示请求已被成功接收,继续处理\n+- 2 XX 成功 - 表示请求已被成功接收,理解,接受\n+- 3 XX 重定向 - 要完成请求必须进行更进一步的处理\n+- 4 XX 客户端错误 - 请求有语法错误或请求无法实现\n+- 5 XX 服务器端错误 - 服务器未能实现合法的请求\n+\n+\n+\n+\n+## 外部链接\n+\n+[什么是HTTP](https://cs.fyi/guide/http-in-depth)\n+\n+[SPDY](https://en.wikipedia.org/wiki/SPDY)\n+\n+[HTTP docs](https://developer.mozilla.org/en-US/docs/Web/HTTP)\n" - }, - { - "date": 1718117404498, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -10,10 +10,11 @@\n math: false\n readingTime: true\n ---\n \n-\t在这篇文章里,可以学习到现代网络的工作模式\n-\t比如:什么是http、Web...\n+ 在这篇文章里,可以学习到现代网络的工作模式\n+ 比如:什么是http、Web...\n+\n ## Why need network?\n \n 军事方面、信息交换、跨地域传输、业务连接... ...\n \n@@ -32,43 +33,55 @@\n \n ![[Pasted image 20240526132924.png]]\n \n ## HTTP Version\n+\n \tHTTP 的历代版本\n+\n ### HTTP/0.9\n+\n 有史以来最简单的协议,只有一个名为 GET 的方法。\n+\n - 响应必须是 HTML 文件\n - 只有 GET\n+\n ### HTTP/1.0\n+\n \tHTTP 的大发展\n 可以处理其他响应格式,即**图像**、**视频文件**、**纯文本**或**任何其他内容**类型。它添加 `POST` 和 `HEAD` 方法、更改了请求/响应 **格式**、将 HTTP **标头**添加到请求和响应中、添加了**状态代码**来**标识响应**、还有引入了字符集支持、多部分类型、授权、缓存、内容编码等都包括在内。\n \n 请求:\n+\n ```http\n GET / HTTP/1.0\n ```\n \n 响应:\n+\n ``` http\n HTTP/1.0 200 OK\n ...\n ```\n \n HTTP/1.0 的主要缺点\n+\n - 无持久连接 --- [[Three-way Handshake(三次握手)]]\n - 队头阻塞\n - 请求方法有限\n - 头部信息冗余\n - 缓存有限\n+\n ### HTTP/1.1\n \n 相比于 HTTP/1.0\n+\n - ***持久连接*** --- 允许多个连续请求\n - 添加了新的方法,其中引入了 `PUT`、`PATCH`、`OPTIONS`、`DELETE`\n - 主机名**标识**在 HTTP/1.1 使其成为必要的\n - **Pipelining** 管道化\n - 更多的状态码\n - 等等\n+\n > 更多 [RFC 2616](https://datatracker.ietf.org/doc/html/rfc2616)\n \n 缺点:\n \n@@ -76,32 +89,35 @@\n 2. **性能瓶颈**:由于HTTP/1.1 仍然依赖于文本格式的头部信息,这可能导致较大的数据传输量和解析延迟。\n 3. **不支持服务器推送**:HTTP/1.1 不支持服务器主动向客户端推送资源,所有资源都需要客户端明确请求。\n 4. **头部冗余**:HTTP/1.1 的头部信息在每次请求中都会重复发送,尤其是在使用Cookie等机制时,增加了数据传输量。\n 5. **缺乏对现代Web应用的支持**:随着Web应用变得越来越复杂,HTTP/1.1 在处理大量并发请求、实时数据传输等方面显得力不从心。\n+\n ### SPDY (from Google)\n+>\n > SPDY也就是[HTTP/2](https://zh.wikipedia.org/wiki/HTTP/2 \"HTTP/2\")的前身\n \n ### HTTP/2\n \n 优点:\n \n 1. **二进制分帧**(Frames and Streams)\n-\tHTTP/2 将数据分割成更小的**二进制**帧,每个帧都有自己的类型和流标识符。这种分帧机制使得数据传输更加高效,并且可以实现多路复用。\n+ HTTP/2 将数据分割成更小的**二进制**帧,每个帧都有自己的类型和流标识符。这种分帧机制使得数据传输更加高效,并且可以实现多路复用。\n 2. **I/O多路复用**:\n-\tHTTP/2 允许在单个连接上**并行**处理多个请求和响应,消除了 HTTP/1.x 中的队头阻塞问题,提高了页面加载速度\n+ HTTP/2 允许在单个连接上**并行**处理多个请求和响应,消除了 HTTP/1.x 中的队头阻塞问题,提高了页面加载速度\n 3. **头部压缩**:\n-\tHTTP/2 使用 **HPACK** 算法压缩头部信息,减少了数据传输量,降低了延迟。(Huffman Code ?)\n-\t[RFC7541](https://datatracker.ietf.org/doc/html/rfc7541)\n+ HTTP/2 使用 **HPACK** 算法压缩头部信息,减少了数据传输量,降低了延迟。(Huffman Code ?)\n+ [RFC7541](https://datatracker.ietf.org/doc/html/rfc7541)\n 4. **服务器推送**:\n-\tHTTP/2 支持服务器**主动**向客户端推送资源,即服务器可以在客户端请求之前发送客户端可能需要的资源,提高了页面加载效率。\n+ HTTP/2 支持服务器**主动**向客户端推送资源,即服务器可以在客户端请求之前发送客户端可能需要的资源,提高了页面加载效率。\n 5. **优先级和依赖**:\n-\tHTTP/2 允许客户端指定请求的优先级,服务器可以根据这些信息优化资源的传输顺序。\n+ HTTP/2 允许客户端指定请求的优先级,服务器可以根据这些信息优化资源的传输顺序。\n 6. **保持连接**:\n-\t HTTP/2 默认使用持久连接,减少了连接建立和断开的开销。\n+ HTTP/2 默认使用持久连接,减少了连接建立和断开的开销。\n 7. **兼容性**:\n-\tHTTP/2 保持了与 HTTP/1.x 的语义兼容性,现有的应用可以无需修改或只需少量修改即可迁移到 HTTP/2。\n+ HTTP/2 保持了与 HTTP/1.x 的语义兼容性,现有的应用可以无需修改或只需少量修改即可迁移到 HTTP/2。\n \n 缺点:\n+\n 1. **实现复杂性**:HTTP/2 的二进制分帧和多路复用机制增加了协议实现的复杂性,对服务器和客户端的实现提出了更高的要求。\n 2. **安全依赖**:虽然 HTTP/2 本身不强制要求使用加密,但大多数浏览器和服务器实现都要求使用 HTTPS,这增加了部署的复杂性和成本。\n 3. **队头阻塞问题**:虽然 HTTP/2 在应用层解决了队头阻塞问题,但在TCP层仍然存在队头阻塞,因为TCP协议本身是按顺序传输数据的。\n 4. **服务器推送的挑战**:服务器推送虽然可以提高性能,但如果不当使用,可能会导致资源浪费或客户端缓存问题。\n@@ -110,14 +126,16 @@\n \n ## SSL、TLS、HTTPS\n \n ?\n+\n - **SSL/TLS**:这两个协议位于应用层和传输层之间,为上层协议提供加密服务。它们负责在客户端和服务器之间建立安全的通信通道。\n - **HTTPS**:这是一个应用层协议,它使用SSL/TLS来保护HTTP通信的安全。HTTPS是HTTP和SSL/TLS的结合体,它使得Web浏览器和服务器之间的通信变得安全。\n \n ## 继续学习 HTTP 的详解\n \n ### HTTP 请求包\n+\n ### HTTP 响应包\n \n **响应头**(Response Headers)是在 HTTP 响应中发送的一组**键值对(key-value pair)**,它们提供了关于响应的**元数据信息**,如**内容类型**、**内容长度**、**缓存控制**、**服务器信息**等。响应头位于 HTTP 响应的起始行(状态行)之后,响应体之前,并且以空行(CRLF)与响应体分隔。\n \n@@ -138,11 +156,8 @@\n - 3 XX 重定向 - 要完成请求必须进行更进一步的处理\n - 4 XX 客户端错误 - 请求有语法错误或请求无法实现\n - 5 XX 服务器端错误 - 服务器未能实现合法的请求\n \n-\n-\n-\n ## 外部链接\n \n [什么是HTTP](https://cs.fyi/guide/http-in-depth)\n \n" - }, - { - "date": 1718117410525, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -34,9 +34,9 @@\n ![[Pasted image 20240526132924.png]]\n \n ## HTTP Version\n \n-\tHTTP 的历代版本\n+ HTTP 的历代版本\n \n ### HTTP/0.9\n \n 有史以来最简单的协议,只有一个名为 GET 的方法。\n@@ -45,9 +45,9 @@\n - 只有 GET\n \n ### HTTP/1.0\n \n-\tHTTP 的大发展\n+ HTTP 的大发展\n 可以处理其他响应格式,即**图像**、**视频文件**、**纯文本**或**任何其他内容**类型。它添加 `POST` 和 `HEAD` 方法、更改了请求/响应 **格式**、将 HTTP **标头**添加到请求和响应中、添加了**状态代码**来**标识响应**、还有引入了字符集支持、多部分类型、授权、缓存、内容编码等都包括在内。\n \n 请求:\n \n" - }, - { - "date": 1718117415871, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -50,9 +50,9 @@\n 可以处理其他响应格式,即**图像**、**视频文件**、**纯文本**或**任何其他内容**类型。它添加 `POST` 和 `HEAD` 方法、更改了请求/响应 **格式**、将 HTTP **标头**添加到请求和响应中、添加了**状态代码**来**标识响应**、还有引入了字符集支持、多部分类型、授权、缓存、内容编码等都包括在内。\n \n 请求:\n \n-```http\n+``` http\n GET / HTTP/1.0\n ```\n \n 响应:\n" - }, - { - "date": 1718117421616, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -2,9 +2,9 @@\n title: \"Http 是什么\"\n date: 2024-06-11T22:49:31+08:00\n draft: true\n taps: []\n-categories: []\n+categories: ['']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1718117432662, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n title: \"Http 是什么\"\n date: 2024-06-11T22:49:31+08:00\n draft: true\n-taps: []\n-categories: ['']\n+taps: ['net']\n+categories: ['Networking', 'HTTP']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1718117437973, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n title: \"Http 是什么\"\n date: 2024-06-11T22:49:31+08:00\n draft: true\n-taps: ['net']\n-categories: ['Networking', 'HTTP']\n+taps: ['network''HTTP']\n+categories: ['Networking', ]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1718117444618, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n title: \"Http 是什么\"\n date: 2024-06-11T22:49:31+08:00\n-draft: true\n-taps: ['network''HTTP']\n-categories: ['Networking', ]\n+draft: false\n+taps: ['network', 'HTTP']\n+categories: ['Networking']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1718117537444, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -63,8 +63,9 @@\n ```\n \n HTTP/1.0 的主要缺点\n \n+\n - 无持久连接 --- [[Three-way Handshake(三次握手)]]\n - 队头阻塞\n - 请求方法有限\n - 头部信息冗余\n" - }, - { - "date": 1718117570294, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -63,9 +63,9 @@\n ```\n \n HTTP/1.0 的主要缺点\n \n-\n+\n - 无持久连接 --- [[Three-way Handshake(三次握手)]]\n - 队头阻塞\n - 请求方法有限\n - 头部信息冗余\n@@ -134,9 +134,9 @@\n \n ## 继续学习 HTTP 的详解\n \n ### HTTP 请求包\n-\n+🎙️🚧🚧🚧\n ### HTTP 响应包\n \n **响应头**(Response Headers)是在 HTTP 响应中发送的一组**键值对(key-value pair)**,它们提供了关于响应的**元数据信息**,如**内容类型**、**内容长度**、**缓存控制**、**服务器信息**等。响应头位于 HTTP 响应的起始行(状态行)之后,响应体之前,并且以空行(CRLF)与响应体分隔。\n \n" - }, - { - "date": 1718117578013, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -134,11 +134,14 @@\n \n ## 继续学习 HTTP 的详解\n \n ### HTTP 请求包\n-🎙️🚧🚧🚧\n+\n+🚧🚧🚧\n+\n ### HTTP 响应包\n \n+🚧🚧🚧\n **响应头**(Response Headers)是在 HTTP 响应中发送的一组**键值对(key-value pair)**,它们提供了关于响应的**元数据信息**,如**内容类型**、**内容长度**、**缓存控制**、**服务器信息**等。响应头位于 HTTP 响应的起始行(状态行)之后,响应体之前,并且以空行(CRLF)与响应体分隔。\n \n ```HTTP\n HTTP/1.1 200 OK\n" - }, - { - "date": 1718117585871, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -64,8 +64,9 @@\n \n HTTP/1.0 的主要缺点\n \n \n+🚧🚧🚧\n - 无持久连接 --- [[Three-way Handshake(三次握手)]]\n - 队头阻塞\n - 请求方法有限\n - 头部信息冗余\n" - } - ], - "date": 1718117388278, - "name": "Commit-0", - "content": "---\ntitle: \"Http http 是什么\"\ndate: 2024-06-11T22:49:31+08:00\ndraft: true\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/Algorithms/backtrack/index.md.json b/YBlog/.lh/content/post/Gohh/Algorithms/backtrack/index.md.json deleted file mode 100644 index 07f469d..0000000 --- a/YBlog/.lh/content/post/Gohh/Algorithms/backtrack/index.md.json +++ /dev/null @@ -1,46 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/Algorithms/backtrack/index.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 7, - "patches": [ - { - "date": 1718116804884, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1718116810168, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: \"Backtrack\"\n+title: \"回溯算法\"\n date: 2024-06-11T22:39:52+08:00\n draft: true\n taps: []\n categories: []\n" - }, - { - "date": 1718116817578, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -10,5 +10,30 @@\n math: false\n readingTime: true\n ---\n \n+> 有组合就要回溯\n+## 问题\n \n+先想一个问题:\n+怎么利用计算机算法去计算关于排序组合等的数学问题?\n+\n+这些数学问题有个最大的特点他们都要根据数字多少来进去匹配,然后再来判断是否合题意\n+\n+接下来我从两个方面图像逻辑和数学角度来讨论\n+### 从图像逻辑上来看\n+\n+我依稀记得我在计算组合的时候我喜欢画图,画一幅 N 树形图来找组合的数量,像下面这个图:\n+\n+其实这个图向右转 90 度就是一副树图,从横向看和纵向看\n+\n+### 从数学角度来看\n+\n+\n+\n+一层的递归就是一次遍历\n+\n+\n+递归\n+1. 确立终止条件\n+2. 参数和返回值\n+3. 主体逻辑\n" - }, - { - "date": 1718116823417, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -28,12 +28,11 @@\n \n ### 从数学角度来看\n \n \n-\n 一层的递归就是一次遍历\n \n+递归\n \n-递归\n 1. 确立终止条件\n 2. 参数和返回值\n 3. 主体逻辑\n" - }, - { - "date": 1718116844946, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -2,34 +2,35 @@\n title: \"回溯算法\"\n date: 2024-06-11T22:39:52+08:00\n draft: true\n taps: []\n-categories: []\n+categories: ['']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n readingTime: true\n ---\n \n > 有组合就要回溯\n+>\n ## 问题\n \n 先想一个问题:\n 怎么利用计算机算法去计算关于排序组合等的数学问题?\n \n 这些数学问题有个最大的特点他们都要根据数字多少来进去匹配,然后再来判断是否合题意\n \n 接下来我从两个方面图像逻辑和数学角度来讨论\n+\n ### 从图像逻辑上来看\n \n 我依稀记得我在计算组合的时候我喜欢画图,画一幅 N 树形图来找组合的数量,像下面这个图:\n \n 其实这个图向右转 90 度就是一副树图,从横向看和纵向看\n \n ### 从数学角度来看\n \n-\n 一层的递归就是一次遍历\n \n 递归\n \n" - }, - { - "date": 1718116850992, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -2,9 +2,9 @@\n title: \"回溯算法\"\n date: 2024-06-11T22:39:52+08:00\n draft: true\n taps: []\n-categories: ['']\n+categories: ['Algorithms', 'backtrack']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1718118213693, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,8 +1,8 @@\n ---\n title: \"回溯算法\"\n date: 2024-06-11T22:39:52+08:00\n-draft: true\n+draft: false\n taps: []\n categories: ['Algorithms', 'backtrack']\n author: [\"Yeelight\"]\n showtoc: true\n" - }, - { - "date": 1718118221389, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"回溯算法\"\n date: 2024-06-11T22:39:52+08:00\n draft: false\n-taps: []\n+taps: ['ba']\n categories: ['Algorithms', 'backtrack']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - } - ], - "date": 1718116804884, - "name": "Commit-0", - "content": "---\ntitle: \"Backtrack\"\ndate: 2024-06-11T22:39:52+08:00\ndraft: true\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n\n\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/Algorithms/sort/index.md.json b/YBlog/.lh/content/post/Gohh/Algorithms/sort/index.md.json deleted file mode 100644 index dbf6eb1..0000000 --- a/YBlog/.lh/content/post/Gohh/Algorithms/sort/index.md.json +++ /dev/null @@ -1,58 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/Algorithms/sort/index.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 10, - "patches": [ - { - "date": 1718118440879, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1718118449030, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n ---\n-title: \"\"\n+title: \"排序算法da'q\"\n date: 2024-06-11T23:07:13+08:00\n draft: true\n taps: []\n categories: []\n" - }, - { - "date": 1718118455234, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n-title: \"排序算法da'q\"\n+title: \"排序算法大全\"\n date: 2024-06-11T23:07:13+08:00\n draft: true\n taps: []\n-categories: []\n+categories: ['']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1718118460868, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n title: \"排序算法大全\"\n date: 2024-06-11T23:07:13+08:00\n draft: true\n-taps: []\n-categories: ['']\n+taps: ['']\n+categories: ['Algorithms', 'sort']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1718118472725, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"排序算法大全\"\n date: 2024-06-11T23:07:13+08:00\n draft: true\n-taps: ['']\n+taps: ['sort']\n categories: ['Algorithms', 'sort']\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - }, - { - "date": 1718118480104, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -9,4 +9,6 @@\n weight:\n math: false\n readingTime: true\n ---\n+\n+## mao\n" - }, - { - "date": 1718118487887, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -10,5 +10,7 @@\n math: false\n readingTime: true\n ---\n \n-## mao\n+## 冒泡排序\n+## 选择排序\n+## \n" - }, - { - "date": 1718118493251, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -12,5 +12,6 @@\n ---\n \n ## 冒泡排序\n ## 选择排序\n-## \n+## 插入排序\n+## 希尔排序\n" - }, - { - "date": 1718118498412, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -14,4 +14,6 @@\n ## 冒泡排序\n ## 选择排序\n ## 插入排序\n ## 希尔排序\n+## 归并排序\n+## \n" - }, - { - "date": 1718118503676, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -15,5 +15,7 @@\n ## 选择排序\n ## 插入排序\n ## 希尔排序\n ## 归并排序\n+## 快速排序\n+## 堆排序\n ## \n" - }, - { - "date": 1718118511311, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -17,5 +17,7 @@\n ## 希尔排序\n ## 归并排序\n ## 快速排序\n ## 堆排序\n-## \n+## 计数排序\n+## 桶排序\n+## 基数排序\n" - } - ], - "date": 1718118440879, - "name": "Commit-0", - "content": "---\ntitle: \"\"\ndate: 2024-06-11T23:07:13+08:00\ndraft: true\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/CS61c/cache/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/CS61c/cache/index.zh-cn.md.json deleted file mode 100644 index e9aa25f..0000000 --- a/YBlog/.lh/content/post/Gohh/CS61c/cache/index.zh-cn.md.json +++ /dev/null @@ -1,42 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/CS61c/cache/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 6, - "patches": [ - { - "date": 1715560768088, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1715560774389, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -9,4 +9,139 @@\n weight:\n math: false\n readingTime: true\n ---\n+\n+\n+*资料来源: cs 61 c*\n+\n+> Cache 可以说是计算机技术革命中最伟大的想法了\n+\n+想一个问题:在我们的电脑里,指令是怎么控制内存里的东西的?因为我们要运行电脑除了 CPU 以外我们要向外 `拿取` 数据才能执行一系列的指令,这样电脑才算运行起来。\n+\n+让我们来看下面的这张图,这是十分完整的计算机组成结构:\n+\n+## Components of a Computer\n+\n+![Components of a Computer](https://s2.loli.net/2023/04/24/Fzb3uHQBLTlqOgD.png)\n+\n+我们可以从中看到在 CPU 需要运行一个进程的时候,首先会将指令告诉主存(main memory), 然后开始在主存中找地址(Address)找到后加载到在 CPU 内部通用寄存器(register)然后开始执行\n+执行完后再写入主存中。\n+> 在这里面还有一个步骤,memory 要先向 disk 中读取数据\n+\n+其实现实中,CPU 通用寄存器的速度和主存之间存在着太大的差异。两者之间的速度大致如下关系:\n+![memory-steep](https://s2.loli.net/2023/04/24/KtvMSR7QmrXpjbl.png)\n+\n+Oh!!! 它们相差 1,000 倍左右,这是无法想像的,就比如当我前 1 ns 的时候 CPU 已经做完了,而我还要等 1000 ns 的 memory 的时间,因此在我们看来 CPU 此时是空闲的,大大的浪费了。\n+\n+因此,如果我们可以提升主存的速度,那么对于系统来说将会获得很大的性能提升。但我们试图提升主存的速度和容量,又期望其成本很低,这就有点难为人了。因此,我们有一种折中的方法,那就是制作一块速度极快但是容量极小的存储设备。那么其成本也不会太高。这块存储设备我们称之为 `cache`。在硬件上,我们将 `cache` 放置在 `CPU` 和 `主存` 之间,作为主存数据的缓存。当 CPU 试图从主存中 load/store 数据的时候, CPU 会首先从 cache 中查找对应地址的数据是否缓存在 cache 中。如果其数据缓存在 cache 中,直接从 cache 中拿到数据并返回给 CPU。\n+\n+![add-cache.png](https://s2.loli.net/2023/04/24/qLhOmsTV2IE9S8p.png)\n+\n+\n+其实类比的话,我蛮喜欢 CS 61 c 里面的 Library Analogy,而我自己的想法是有点像现在的物流运输:对一些物品都有一个 `主要的仓库`,而也有一些 `本地仓`,当我要送东西的时候我先去看看 `本地仓` 有没有,没有就再去 `主仓` 去看看,但时间上就没有本地仓的快\n+\n+> [[2. Areas/01 Blog/03-ComputerSystems/cs61c/SRAM vs. DRAM vs. Disk]]\n+\n+## Memory Hierarchy\n+\n+好的现在我们知道了 `cache` 的出现了,而下面的图是说明了对于不同的内存级别\n+![Cache-line.png](https://s2.loli.net/2023/04/24/3anw1UgNoWDZBsq.png)\n+\n+## Cache\n+\n+### Cache 的级别\n+> 每一级的 cache 就是每一个下级内存的副本\n+\n+Cahe 的速度在一定程度上同样影响着系统的性能. 当 cache 中没有缓存我们想要的数据的时候,依然需要漫长的等待从主存中 load 数据。为了进一步提升性能,引入多级 cache。前面提到的 cache,称之为 L 1 cache(第一级 cache)。我们在 L 1 cache 后面连接 L 2 cache,在 L 2 cache 和主存之间连接 L 3 cache。等级越高,速度越慢,容量越大。\n+\n+### Temporal Locality (时间局部性)\n+> If a memory location is referenced then it will tend to be referenced again soon\n+\n+比如说我用过一次这个地址, 我保存起来以防我下次使用\n+\n+### Spatial Locality (空间局部性)\n+> If a memory location is referenced, the locations with nearby addresses will\n+ Tend to be referenced soon\n+\n+比如一个数组,在我读取的时候它会把数组左右的都读取了\n+\n+### Cache Hit vs Cache Miss\n+\n+在我要对数据进行查找的时候会出现两种情况 `Cache Hit` & `Cache Miss`.\n+\n+#### Cache hit\n+你要查找的数据 `在缓存中` 从缓存中检索数据并将其带到处理器.\n+\n+#### Cache miss\n+你要查找的数据 `不在缓存中` 去内存中找数据,把数据放到缓存中,带到处理器中\n+\n+## Cache 的工作原理\n+\n+现在我们来继续说一些快取的工作原理, 在此之前先来说一下的一些名词\n+\t什么是 `line/tag/index/offset/valid`\n+\n+- **line:** 我们将 cache 平均分成相等的很多块,每一个块大小称之为 `cache line` 也可以叫 `cache block`,其大小是 `cache line size`。\n+- **tag:** Used to identify the data (用于识别数据)。每条 Cache Line 前都会有一个独立分配的内存来存 tag,其就是内存地址的前 Nbits。\n+$$ addressbits - offsetbits $$\n+- **offset:** Identifies the byte offset (标识字节偏移量)。一般是低位后几位。\n+$$ offset = log_2(line size) $$\n+- **index:** 内存地址后续的 bits 则是在这--Way 的是 Cache Line 索引,可以索引 Cache Line。\n+- **Valid bit:** Tells you if the data stored at a given cache line is valid (告诉您存储在给定缓存行中的数据是否有效)\n+\n+\n+> 一个地址访问要映射到 Cache 中,地址被分成三个字段:tag,set index, block offset。这样,通过一个物理地址就可以获取数据或指令在缓存中的位置 (set, way, byte))\n+\n+\n+![line-block.png](https://s2.loli.net/2023/04/24/mHdMoveGWXkiNL4.png)\n+\n+### Direct mapped cache (直接映射缓存)\n+\n+优点:直接映射缓存在硬件设计上会更加简单,因此成本上也会较低。\n+> 一句话, 我一个个的加载进入 cache, 当我的 cache 满了我就转头再来一遍\n+\n+>只适合于**大容量**Cache\n+\n+缺点: 继续访问下面的地址时,依然会 cache 缺失。这就相当于每次访问数据都要从主存中读取,所以 cache 的存在并没有对性能提升有效, 有 `cache颠簸` (每个主存块只有一个固定位置可存放,容易产生冲突)\n+\n+![Direct Mapped.png](https://s2.loli.net/2023/04/24/xeav7mlIDAyOwqK.png)\n+\n+![Direct Mapped-cache.png](https://s2.loli.net/2023/04/24/4EYI7Va1S5lKgow.png)\n+\n+### Two-way set associative cache (两路组相连缓存)\n+**Cache 分了 2 组**\n+\n+优点: 减少 cache 颠簸出现频率\n+> 组相联映射实际上是直接映射和全相联映射的折中方案\n+\n+缺点: 增加硬件设计复杂读、成本较高 (需要比较多个 cache line 的 TAG)\n+\n+![set associative-cache.png](https://s2.loli.net/2023/04/24/yXE8J6RMo9F3Vxq.png)\n+\n+\n+### Fully Associative Cache (全相连缓存)\n+\n+优点: 最大程度的降低 cache 颠簸的频率\n+>只适合于**小容量**Cache\n+\n+缺点: 增加硬件设计复杂读、成本较高 (需要比较多个 cache line 的 TAG)\n+\n+扩展:[[More Eviction Policies]]\n+![](https://s2.loli.net/2023/07/10/TRUdXNBPsveZS7D.png)\n+\n+\n+![Fully Associative.png](https://s2.loli.net/2023/04/24/76uSATyrPno1eYf.png)\n+\n+寻找 Hit 的电路\n+\n+![Required to Check for Hit](https://s2.loli.net/2023/04/24/3VYzGo9dkgHwcrS.png)\n+\n+[[Types of Misses]]\n+\n+![](https://s2.loli.net/2023/04/24/M4Fc1g6k5OrfBpj.png)\n+\n+### Comparisons\n+\n+三个 cache 的区别之分\n+![Comparisons](https://s2.loli.net/2023/04/24/iICnWkpOMcFtKZH.png)\n+**需补充**\n+\n" - }, - { - "date": 1715560781438, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -19,9 +19,9 @@\n 想一个问题:在我们的电脑里,指令是怎么控制内存里的东西的?因为我们要运行电脑除了 CPU 以外我们要向外 `拿取` 数据才能执行一系列的指令,这样电脑才算运行起来。\n \n 让我们来看下面的这张图,这是十分完整的计算机组成结构:\n \n-## Components of a Computer\n+## Components of a Computer\n \n ![Components of a Computer](https://s2.loli.net/2023/04/24/Fzb3uHQBLTlqOgD.png)\n \n 我们可以从中看到在 CPU 需要运行一个进程的时候,首先会将指令告诉主存(main memory), 然后开始在主存中找地址(Address)找到后加载到在 CPU 内部通用寄存器(register)然后开始执行\n@@ -36,9 +36,8 @@\n 因此,如果我们可以提升主存的速度,那么对于系统来说将会获得很大的性能提升。但我们试图提升主存的速度和容量,又期望其成本很低,这就有点难为人了。因此,我们有一种折中的方法,那就是制作一块速度极快但是容量极小的存储设备。那么其成本也不会太高。这块存储设备我们称之为 `cache`。在硬件上,我们将 `cache` 放置在 `CPU` 和 `主存` 之间,作为主存数据的缓存。当 CPU 试图从主存中 load/store 数据的时候, CPU 会首先从 cache 中查找对应地址的数据是否缓存在 cache 中。如果其数据缓存在 cache 中,直接从 cache 中拿到数据并返回给 CPU。\n \n ![add-cache.png](https://s2.loli.net/2023/04/24/qLhOmsTV2IE9S8p.png)\n \n-\n 其实类比的话,我蛮喜欢 CS 61 c 里面的 Library Analogy,而我自己的想法是有点像现在的物流运输:对一些物品都有一个 `主要的仓库`,而也有一些 `本地仓`,当我要送东西的时候我先去看看 `本地仓` 有没有,没有就再去 `主仓` 去看看,但时间上就没有本地仓的快\n \n > [[2. Areas/01 Blog/03-ComputerSystems/cs61c/SRAM vs. DRAM vs. Disk]]\n \n@@ -49,18 +48,21 @@\n \n ## Cache\n \n ### Cache 的级别\n+>\n > 每一级的 cache 就是每一个下级内存的副本\n \n Cahe 的速度在一定程度上同样影响着系统的性能. 当 cache 中没有缓存我们想要的数据的时候,依然需要漫长的等待从主存中 load 数据。为了进一步提升性能,引入多级 cache。前面提到的 cache,称之为 L 1 cache(第一级 cache)。我们在 L 1 cache 后面连接 L 2 cache,在 L 2 cache 和主存之间连接 L 3 cache。等级越高,速度越慢,容量越大。\n \n ### Temporal Locality (时间局部性)\n+>\n > If a memory location is referenced then it will tend to be referenced again soon\n \n 比如说我用过一次这个地址, 我保存起来以防我下次使用\n \n ### Spatial Locality (空间局部性)\n+>\n > If a memory location is referenced, the locations with nearby addresses will\n Tend to be referenced soon\n \n 比如一个数组,在我读取的时候它会把数组左右的都读取了\n@@ -69,17 +71,19 @@\n \n 在我要对数据进行查找的时候会出现两种情况 `Cache Hit` & `Cache Miss`.\n \n #### Cache hit\n+\n 你要查找的数据 `在缓存中` 从缓存中检索数据并将其带到处理器.\n \n #### Cache miss\n+\n 你要查找的数据 `不在缓存中` 去内存中找数据,把数据放到缓存中,带到处理器中\n \n ## Cache 的工作原理\n \n 现在我们来继续说一些快取的工作原理, 在此之前先来说一下的一些名词\n-\t什么是 `line/tag/index/offset/valid`\n+ 什么是 `line/tag/index/offset/valid`\n \n - **line:** 我们将 cache 平均分成相等的很多块,每一个块大小称之为 `cache line` 也可以叫 `cache block`,其大小是 `cache line size`。\n - **tag:** Used to identify the data (用于识别数据)。每条 Cache Line 前都会有一个独立分配的内存来存 tag,其就是内存地址的前 Nbits。\n $$ addressbits - offsetbits $$\n@@ -87,12 +91,10 @@\n $$ offset = log_2(line size) $$\n - **index:** 内存地址后续的 bits 则是在这--Way 的是 Cache Line 索引,可以索引 Cache Line。\n - **Valid bit:** Tells you if the data stored at a given cache line is valid (告诉您存储在给定缓存行中的数据是否有效)\n \n-\n > 一个地址访问要映射到 Cache 中,地址被分成三个字段:tag,set index, block offset。这样,通过一个物理地址就可以获取数据或指令在缓存中的位置 (set, way, byte))\n \n-\n ![line-block.png](https://s2.loli.net/2023/04/24/mHdMoveGWXkiNL4.png)\n \n ### Direct mapped cache (直接映射缓存)\n \n@@ -107,8 +109,9 @@\n \n ![Direct Mapped-cache.png](https://s2.loli.net/2023/04/24/4EYI7Va1S5lKgow.png)\n \n ### Two-way set associative cache (两路组相连缓存)\n+\n **Cache 分了 2 组**\n \n 优点: 减少 cache 颠簸出现频率\n > 组相联映射实际上是直接映射和全相联映射的折中方案\n@@ -116,9 +119,8 @@\n 缺点: 增加硬件设计复杂读、成本较高 (需要比较多个 cache line 的 TAG)\n \n ![set associative-cache.png](https://s2.loli.net/2023/04/24/yXE8J6RMo9F3Vxq.png)\n \n-\n ### Fully Associative Cache (全相连缓存)\n \n 优点: 最大程度的降低 cache 颠簸的频率\n >只适合于**小容量**Cache\n@@ -127,9 +129,8 @@\n \n 扩展:[[More Eviction Policies]]\n ![](https://s2.loli.net/2023/07/10/TRUdXNBPsveZS7D.png)\n \n-\n ![Fully Associative.png](https://s2.loli.net/2023/04/24/76uSATyrPno1eYf.png)\n \n 寻找 Hit 的电路\n \n@@ -143,5 +144,4 @@\n \n 三个 cache 的区别之分\n ![Comparisons](https://s2.loli.net/2023/04/24/iICnWkpOMcFtKZH.png)\n **需补充**\n-\n" - }, - { - "date": 1715560844542, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,8 +1,8 @@\n ---\n title: \"Cache Notes\"\n date: 2024-05-13T08:39:14+08:00\n-draft: true\n+draft: false\n taps: []\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n@@ -11,9 +11,9 @@\n readingTime: true\n ---\n \n \n-*资料来源: cs 61 c*\n+*资料来源: cs61c*\n \n > Cache 可以说是计算机技术革命中最伟大的想法了\n \n 想一个问题:在我们的电脑里,指令是怎么控制内存里的东西的?因为我们要运行电脑除了 CPU 以外我们要向外 `拿取` 数据才能执行一系列的指令,这样电脑才算运行起来。\n" - }, - { - "date": 1715560849824, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,9 +1,9 @@\n ---\n title: \"Cache Notes\"\n date: 2024-05-13T08:39:14+08:00\n draft: false\n-taps: []\n+taps: [cache]\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n" - }, - { - "date": 1715560855874, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,10 +1,10 @@\n ---\n title: \"Cache Notes\"\n date: 2024-05-13T08:39:14+08:00\n draft: false\n-taps: [cache]\n-categories: []\n+taps: ['cache']\n+categories: [\"\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - }, - { - "date": 1715560872949, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -2,9 +2,9 @@\n title: \"Cache Notes\"\n date: 2024-05-13T08:39:14+08:00\n draft: false\n taps: ['cache']\n-categories: [\"\"]\n+categories: [\"CS\"]\n author: [\"Yeelight\"]\n showtoc: true\n weight:\n math: false\n" - } - ], - "date": 1715560768088, - "name": "Commit-0", - "content": "---\ntitle: \"Cache Notes\"\ndate: 2024-05-13T08:39:14+08:00\ndraft: true\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Gohh/Personal/update/index.zh-cn.md.json b/YBlog/.lh/content/post/Gohh/Personal/update/index.zh-cn.md.json deleted file mode 100644 index 46ccbd9..0000000 --- a/YBlog/.lh/content/post/Gohh/Personal/update/index.zh-cn.md.json +++ /dev/null @@ -1,22 +0,0 @@ -{ - "sourceFile": "content/post/Gohh/Personal/update/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 1, - "patches": [ - { - "date": 1712581672340, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1712581678273, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -8,11 +8,11 @@\n showtoc: true\n weight: -110\n math: false\n readingTime: true\n-image: 'pexels-andreea-ch-1166643.jpg'\n+image: 'https://s2.loli.net/2024/04/08/bN8h1ZycAzF5MHu.jpg'\n ---\n-![](https://s2.loli.net/2024/04/08/bN8h1ZycAzF5MHu.jpg)\n+![]()\n ## Hello\n \n 你好,这是,这里面是记录我对自己的博客 web 更新的日记。\n \n" - } - ], - "date": 1712581672340, - "name": "Commit-0", - "content": "---\ntitle: '博客搭建更新日记✨'\ndate: 2023-03-08T19:56:58+08:00\ndraft: false\ntaps: ['update']\ncategories: ['update']\nauthor: ['Yeelight']\nshowtoc: true\nweight: -110\nmath: false\nreadingTime: true\nimage: 'pexels-andreea-ch-1166643.jpg'\n---\n![](https://s2.loli.net/2024/04/08/bN8h1ZycAzF5MHu.jpg)\n## Hello\n\n你好,这是,这里面是记录我对自己的博客 web 更新的日记。\n\n## March 10,2023\n\n博客使用 hugo 了\n\n## April 20, 2023\n\n我使用了图床,蛮好用的 😁\n\n## April 25, 2023\n\n我更新了一些社交方式\n\n更新一下我的博客的配置\n\n## Mar 10,2024\n\n好久不见了,这一次我把近一年的笔记进行一个整理,然后更新到了博客上。\n也做了许多的计划和之后的规划\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/Personal/update/index.zh-cn.md.json b/YBlog/.lh/content/post/Personal/update/index.zh-cn.md.json deleted file mode 100644 index 28bbc65..0000000 --- a/YBlog/.lh/content/post/Personal/update/index.zh-cn.md.json +++ /dev/null @@ -1,58 +0,0 @@ -{ - "sourceFile": "content/post/Personal/update/index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 10, - "patches": [ - { - "date": 1712579214179, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1712579219340, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -10,4 +10,38 @@\n math: false\n readingTime: true\n ---\n \n+---\n+title: \"博客搭建更新日记✨\"\n+description: \"\"\n+date: 2023-03-08T19:56:58+08:00\n+draft: false\n+weight: 1\n+showtoc: true\n+tags: [Blog]\n+categories: [\"Blog\"]\n+disableShare: true\n+---\n+\n+## Hello\n+\n+你好,这是,这里面是记录我对自己的博客web更新的日记。\n+\n+## March 10,2023\n+\n+博客使用hugo了\n+\n+## April 20, 2023\n+\n+我使用了图床,蛮好用的 😁\n+\n+## April 25, 2023\n+\n+我更新了一些社交方式\n+\n+更新一下我的博客的配置\n+\n+## Mar 10,2024\n+\n+好久不见了,这一次我把近一年的笔记进行一个整理,然后更新到了博客上。\n+也做了许多的计划和之后的规划\n" - }, - { - "date": 1712579225517, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -10,20 +10,8 @@\n math: false\n readingTime: true\n ---\n \n----\n-title: \"博客搭建更新日记✨\"\n-description: \"\"\n-date: 2023-03-08T19:56:58+08:00\n-draft: false\n-weight: 1\n-showtoc: true\n-tags: [Blog]\n-categories: [\"Blog\"]\n-disableShare: true\n----\n-\n ## Hello\n \n 你好,这是,这里面是记录我对自己的博客web更新的日记。\n \n" - }, - { - "date": 1712579231002, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,13 +1,13 @@\n ---\n title: \"Update\"\n date: 2024-04-08T20:26:47+08:00\n-draft: true\n+draft: false\n taps: []\n categories: []\n author: [\"Yeelight\"]\n showtoc: true\n-weight:\n+weight: -\n math: false\n readingTime: true\n ---\n \n" - }, - { - "date": 1712579262229, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,24 +1,24 @@\n ---\n-title: \"Update\"\n+title: '博客搭建更新日记✨'\n date: 2024-04-08T20:26:47+08:00\n draft: false\n taps: []\n categories: []\n-author: [\"Yeelight\"]\n+author: ['Yeelight']\n showtoc: true\n-weight: -\n+weight: -110\n math: false\n readingTime: true\n ---\n \n ## Hello\n \n-你好,这是,这里面是记录我对自己的博客web更新的日记。\n+你好,这是,这里面是记录我对自己的博客 web 更新的日记。\n \n ## March 10,2023\n \n-博客使用hugo了\n+博客使用 hugo 了\n \n ## April 20, 2023\n \n 我使用了图床,蛮好用的 😁\n" - }, - { - "date": 1712579267803, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,7 +1,7 @@\n ---\n title: '博客搭建更新日记✨'\n-date: 2024-04-08T20:26:47+08:00\n+date: 2023-03-08T19:56:58+08:00\n draft: false\n taps: []\n categories: []\n author: ['Yeelight']\n" - }, - { - "date": 1712579535383, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -8,8 +8,9 @@\n showtoc: true\n weight: -110\n math: false\n readingTime: true\n+im\n ---\n \n ## Hello\n \n" - }, - { - "date": 1712579541412, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -8,9 +8,9 @@\n showtoc: true\n weight: -110\n math: false\n readingTime: true\n-im\n+image: \"content/post/Personal/update/photo_2024-04-08_20-31-53.jpg\n ---\n \n ## Hello\n \n" - }, - { - "date": 1712579547360, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -8,9 +8,9 @@\n showtoc: true\n weight: -110\n math: false\n readingTime: true\n-image: \"content/post/Personal/update/photo_2024-04-08_20-31-53.jpg\n+image: 'content/post/Personal/update/photo_2024-04-08_20-31-53.jpg'\n ---\n \n ## Hello\n \n" - }, - { - "date": 1712579563348, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -8,9 +8,9 @@\n showtoc: true\n weight: -110\n math: false\n readingTime: true\n-image: 'content/post/Personal/update/photo_2024-04-08_20-31-53.jpg'\n+image: 'photo_2024-04-08_20-31-53.jpg'\n ---\n \n ## Hello\n \n" - }, - { - "date": 1712579882169, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -8,9 +8,9 @@\n showtoc: true\n weight: -110\n math: false\n readingTime: true\n-image: 'photo_2024-04-08_20-31-53.jpg'\n+image: 'content/post/Personal/update/pexels-andreea-ch-1166643.jpg'\n ---\n \n ## Hello\n \n" - } - ], - "date": 1712579214179, - "name": "Commit-0", - "content": "---\ntitle: \"Update\"\ndate: 2024-04-08T20:26:47+08:00\ndraft: true\ntaps: []\ncategories: []\nauthor: [\"Yeelight\"]\nshowtoc: true\nweight:\nmath: false\nreadingTime: true\n---\n\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/content/post/_index.zh-cn.md.json b/YBlog/.lh/content/post/_index.zh-cn.md.json deleted file mode 100644 index a659fe6..0000000 --- a/YBlog/.lh/content/post/_index.zh-cn.md.json +++ /dev/null @@ -1,22 +0,0 @@ -{ - "sourceFile": "content/post/_index.zh-cn.md", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 1, - "patches": [ - { - "date": 1712581232400, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1712581240141, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,1 +1,9 @@\n-\n+---\n+menu:\n+ main:\n+ name: 主页\n+ weight: -110\n+ url: /\n+ params:\n+ icon: home\n+---\n" - } - ], - "date": 1712581232400, - "name": "Commit-0", - "content": "\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/.lh/hugo.yaml.json b/YBlog/.lh/hugo.yaml.json deleted file mode 100644 index 58314c2..0000000 --- a/YBlog/.lh/hugo.yaml.json +++ /dev/null @@ -1,106 +0,0 @@ -{ - "sourceFile": "hugo.yaml", - "activeCommit": 0, - "commits": [ - { - "activePatchIndex": 22, - "patches": [ - { - "date": 1712580625532, - "content": "Index: \n===================================================================\n--- \n+++ \n" - }, - { - "date": 1712580632126, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -210,11 +210,9 @@\n ### Custom menu\n ### See https://docs.stack.jimmycai.com/configuration/custom-menu.html\n ### To remove about, archive and search page menu item, remove `menu` field from their FrontMatter\n menu:\n- main: [\n- \n- ]\n+ main: []\n \n social:\n - identifier: github\n name: GitHub\n" - }, - { - "date": 1712580725313, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -219,13 +219,13 @@\n url: https://github.com/FeiNiaoBF\n params:\n icon: brand-github\n \n- - identifier: twitter\n- name: Twitter\n- url: https://twitter.com\n- params:\n- icon: brand-twitter\n+ # - identifier: twitter\n+ # name: Twitter\n+ # url: https://twitter.com\n+ # params:\n+ # icon: brand-twitter\n \n # - identifier: youTube\n # name: YouTube\n # url: https://www.youtube.com/channel/UCZsE4g_WIh-KRpjCeF4cABA\n" - }, - { - "date": 1712580730673, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -218,9 +218,9 @@\n name: GitHub\n url: https://github.com/FeiNiaoBF\n params:\n icon: brand-github\n-\n+ \n # - identifier: twitter\n # name: Twitter\n # url: https://twitter.com\n # params:\n" - }, - { - "date": 1712580741428, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -218,9 +218,9 @@\n name: GitHub\n url: https://github.com/FeiNiaoBF\n params:\n icon: brand-github\n- \n+ - id\n # - identifier: twitter\n # name: Twitter\n # url: https://twitter.com\n # params:\n" - }, - { - "date": 1712580749310, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -218,9 +218,9 @@\n name: GitHub\n url: https://github.com/FeiNiaoBF\n params:\n icon: brand-github\n- - id\n+ \n # - identifier: twitter\n # name: Twitter\n # url: https://twitter.com\n # params:\n" - }, - { - "date": 1712580860825, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -210,17 +210,25 @@\n ### Custom menu\n ### See https://docs.stack.jimmycai.com/configuration/custom-menu.html\n ### To remove about, archive and search page menu item, remove `menu` field from their FrontMatter\n menu:\n- main: []\n+ main:\n+ - identifier: cs\n+ name: CS\n+ url: /post/cs/\n+ weight: 10\n+ - identifier: personal\n+ name: Personal\n+ url: /post/personal/\n+ weight: 20\n \n social:\n - identifier: github\n name: GitHub\n url: https://github.com/FeiNiaoBF\n params:\n icon: brand-github\n- \n+\n # - identifier: twitter\n # name: Twitter\n # url: https://twitter.com\n # params:\n" - }, - { - "date": 1712580866529, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -211,9 +211,9 @@\n ### See https://docs.stack.jimmycai.com/configuration/custom-menu.html\n ### To remove about, archive and search page menu item, remove `menu` field from their FrontMatter\n menu:\n main:\n- - identifier: cs\n+ - identifier: cs\n name: CS\n url: /post/cs/\n weight: 10\n - identifier: personal\n" - }, - { - "date": 1712580893308, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -213,9 +213,9 @@\n menu:\n main:\n - identifier: cs\n name: CS\n- url: /post/cs/\n+ url: /post/CS/\n weight: 10\n - identifier: personal\n name: Personal\n url: /post/personal/\n" - }, - { - "date": 1712580922613, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -213,13 +213,13 @@\n menu:\n main:\n - identifier: cs\n name: CS\n- url: /post/CS/\n+ url: /posts/CS/\n weight: 10\n - identifier: personal\n name: Personal\n- url: /post/personal/\n+ url: /posts/Personal/\n weight: 20\n \n social:\n - identifier: github\n" - }, - { - "date": 1712580927782, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -213,9 +213,9 @@\n menu:\n main:\n - identifier: cs\n name: CS\n- url: /posts/CS/\n+ url: /post/CS/\n weight: 10\n - identifier: personal\n name: Personal\n url: /posts/Personal/\n" - }, - { - "date": 1712580979187, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -213,13 +213,13 @@\n menu:\n main:\n - identifier: cs\n name: CS\n- url: /post/CS/\n+ url: \n weight: 10\n - identifier: personal\n name: Personal\n- url: /posts/Personal/\n+ url: /post/Personal/\n weight: 20\n \n social:\n - identifier: github\n" - }, - { - "date": 1712580985788, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -213,13 +213,13 @@\n menu:\n main:\n - identifier: cs\n name: CS\n- url: \n+ url: /post/CS/\n weight: 10\n - identifier: personal\n name: Personal\n- url: /post/Personal/\n+ url: /\n weight: 20\n \n social:\n - identifier: github\n" - }, - { - "date": 1712580994580, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -217,9 +217,9 @@\n url: /post/CS/\n weight: 10\n - identifier: personal\n name: Personal\n- url: /\n+ url: /post/Personal/\n weight: 20\n \n social:\n - identifier: github\n" - }, - { - "date": 1712581130565, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -211,16 +211,12 @@\n ### See https://docs.stack.jimmycai.com/configuration/custom-menu.html\n ### To remove about, archive and search page menu item, remove `menu` field from their FrontMatter\n menu:\n main:\n- - identifier: cs\n- name: CS\n- url: /post/CS/\n- weight: 10\n- - identifier: personal\n- name: Personal\n- url: /post/Personal/\n- weight: 20\n+ name: title (optional)\n+ weight: -90\n+ params:\n+ icon: icon-name\n \n social:\n - identifier: github\n name: GitHub\n" - }, - { - "date": 1712581138893, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -213,11 +213,11 @@\n menu:\n main:\n name: title (optional)\n weight: -90\n- params:\n- icon: icon-name\n+ \n \n+\n social:\n - identifier: github\n name: GitHub\n url: https://github.com/FeiNiaoBF\n" - }, - { - "date": 1712581144495, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -211,13 +211,13 @@\n ### See https://docs.stack.jimmycai.com/configuration/custom-menu.html\n ### To remove about, archive and search page menu item, remove `menu` field from their FrontMatter\n menu:\n main:\n- name: title (optional)\n+ name: CS\n weight: -90\n- \n \n \n+\n social:\n - identifier: github\n name: GitHub\n url: https://github.com/FeiNiaoBF\n" - }, - { - "date": 1712581154846, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -211,13 +211,10 @@\n ### See https://docs.stack.jimmycai.com/configuration/custom-menu.html\n ### To remove about, archive and search page menu item, remove `menu` field from their FrontMatter\n menu:\n main:\n- name: CS\n- weight: -90\n \n \n-\n social:\n - identifier: github\n name: GitHub\n url: https://github.com/FeiNiaoBF\n" - }, - { - "date": 1712581161025, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -210,9 +210,14 @@\n ### Custom menu\n ### See https://docs.stack.jimmycai.com/configuration/custom-menu.html\n ### To remove about, archive and search page menu item, remove `menu` field from their FrontMatter\n menu:\n- main:\n+ main: [\n+ {identifier: \"home\", name: \"Home\", url: \"/\", icon: \"home\"},\n+ {identifier: \"about\", name: \"About\", url: \"/about/\", icon: \"user\"},\n+ {identifier: \"archive\", name: \"Archive\", url: \"/archive/\", icon: \"archive\"},\n+ {identifier: \"search\", name: \"Search\", url: \"/search/\", icon: \"search\"},\n+ ]\n \n \n social:\n - identifier: github\n" - }, - { - "date": 1712581178549, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -210,14 +210,9 @@\n ### Custom menu\n ### See https://docs.stack.jimmycai.com/configuration/custom-menu.html\n ### To remove about, archive and search page menu item, remove `menu` field from their FrontMatter\n menu:\n- main: [\n- {identifier: \"home\", name: \"Home\", url: \"/\", icon: \"home\"},\n- {identifier: \"about\", name: \"About\", url: \"/about/\", icon: \"user\"},\n- {identifier: \"archive\", name: \"Archive\", url: \"/archive/\", icon: \"archive\"},\n- {identifier: \"search\", name: \"Search\", url: \"/search/\", icon: \"search\"},\n- ]\n+ main: [ ]\n \n \n social:\n - identifier: github\n" - }, - { - "date": 1715565269915, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -1,6 +1,6 @@\n baseurl: https://FeiNiaoBF.github.io/\n-languageCode: en\n+languageCode: zh-cn\n theme: hugo-theme-stack\n paginate: 5\n title: Yeelight の 小屋\n copyright: Example Person. All rights reserved.\n@@ -17,260 +17,258 @@\n enableEmoji: true # 允许使用 Emoji 表情,建议 true\n enableRobotsTXT: true # 允许爬虫抓取到搜索引擎,建议 true\n \n languages:\n- en:\n- disabled: false\n- languageCode: \"\"\n- languageDirection: \"\"\n- languageName: English\n- title: Yeelight's Home\n- weight: 1\n- params:\n- description: A hut where we talk about learning\n- zh-cn:\n- disabled: false\n- languageCode: \"\"\n- languageDirection: \"\"\n- languageName: 中文\n- title: Yeelight の 小屋\n- weight: 2\n- params:\n- description: 一个谈学习的小屋\n+ en:\n+ disabled: false\n+ languageCode: ''\n+ languageDirection: ''\n+ languageName: English\n+ title: Yeelight's Home\n+ weight: 1\n+ params:\n+ description: A hut where we talk about learning\n+ zh-cn:\n+ disabled: false\n+ languageCode: ''\n+ languageDirection: ''\n+ languageName: 中文\n+ title: Yeelight の 小屋\n+ weight: 2\n+ params:\n+ description: 一个谈学习的小屋\n \n services:\n- # Change it to your Disqus shortname before using\n- disqus:\n- shortname: \"hugo-theme-stack\"\n- # GA Tracking ID\n- googleAnalytics:\n- id:\n+ # Change it to your Disqus shortname before using\n+ disqus:\n+ shortname: 'hugo-theme-stack'\n+ # GA Tracking ID\n+ googleAnalytics:\n+ id:\n \n permalinks:\n- post: /p/:slug/\n- page: /:slug/\n+ post: /p/:slug/\n+ page: /:slug/\n \n params:\n- mainSections:\n- - post\n- featuredImageField: image\n- # Output page's full content in RSS.\n- rssFullContent: true\n- favicon: favicon.ico # e.g.: favicon placed in `static/favicon.ico` of your site folder, then set this field to `/favicon.ico` (`/` is necessary)\n+ mainSections:\n+ - post\n+ featuredImageField: image\n+ # Output page's full content in RSS.\n+ rssFullContent: true\n+ favicon: favicon.ico # e.g.: favicon placed in `static/favicon.ico` of your site folder, then set this field to `/favicon.ico` (`/` is necessary)\n \n- footer:\n- since: 2023\n- customText:\n+ footer:\n+ since: 2023\n+ customText:\n \n- dateFormat:\n- published: Jan 02, 2006\n- lastUpdated: Jan 02, 2006 15:04 CST\n+ dateFormat:\n+ published: Jan 02, 2006\n+ lastUpdated: Jan 02, 2006 15:04 CST\n \n- sidebar:\n- emoji: 🌞 # 🍥\n- subtitle: \"简单是稳定的前提( •̀ ω •́ )✧\"\n- avatar:\n- enabled: true\n- local: true\n- src: img/avatar.png\n+ sidebar:\n+ emoji: 🌞 # 🍥\n+ subtitle: '简单是稳定的前提( •̀ ω •́ )✧'\n+ avatar:\n+ enabled: true\n+ local: true\n+ src: img/avatar.png\n \n- article:\n- math: false\n- toc: true\n- readingTime: true\n- license:\n- enabled: true\n- default: Licensed under CC BY-NC-SA 4.0\n+ article:\n+ math: false\n+ toc: true\n+ readingTime: true\n+ license:\n+ enabled: true\n+ default: Licensed under CC BY-NC-SA 4.0\n \n- comments:\n- enabled: true\n- provider: disqus\n+ comments:\n+ enabled: true\n+ provider: disqus\n \n- disqusjs:\n- shortname:\n- apiUrl:\n- apiKey:\n- admin:\n- adminLabel:\n+ disqusjs:\n+ shortname:\n+ apiUrl:\n+ apiKey:\n+ admin:\n+ adminLabel:\n \n- utterances:\n- repo:\n- issueTerm: pathname\n- label:\n+ utterances:\n+ repo:\n+ issueTerm: pathname\n+ label:\n \n- beaudar:\n- repo:\n- issueTerm: pathname\n- label:\n- theme:\n+ beaudar:\n+ repo:\n+ issueTerm: pathname\n+ label:\n+ theme:\n \n- remark42:\n- host:\n- site:\n- locale:\n+ remark42:\n+ host:\n+ site:\n+ locale:\n \n- vssue:\n- platform:\n- owner:\n- repo:\n- clientId:\n- clientSecret:\n- autoCreateIssue: false\n+ vssue:\n+ platform:\n+ owner:\n+ repo:\n+ clientId:\n+ clientSecret:\n+ autoCreateIssue: false\n \n- # Waline client configuration see: https://waline.js.org/en/reference/component.html\n- waline:\n- serverURL:\n- lang:\n- pageview:\n- emoji:\n- - https://unpkg.com/@waline/emojis@1.0.1/weibo\n- requiredMeta:\n- - name\n- - email\n- - url\n- locale:\n- admin: Yeelight\n- placeholder:\n+ # Waline client configuration see: https://waline.js.org/en/reference/component.html\n+ waline:\n+ serverURL:\n+ lang:\n+ pageview:\n+ emoji:\n+ - https://unpkg.com/@waline/emojis@1.0.1/weibo\n+ requiredMeta:\n+ - name\n+ - email\n+ - url\n+ locale:\n+ admin: Yeelight\n+ placeholder:\n \n- twikoo:\n- envId:\n- region:\n- path:\n- lang:\n+ twikoo:\n+ envId:\n+ region:\n+ path:\n+ lang:\n \n- # See https://cactus.chat/docs/reference/web-client/#configuration for description of the various options\n- cactus:\n- defaultHomeserverUrl: \"https://matrix.cactus.chat:8448\"\n- serverName: \"cactus.chat\"\n- siteName: \"\" # You must insert a unique identifier here matching the one you registered (See https://cactus.chat/docs/getting-started/quick-start/#register-your-site)\n+ # See https://cactus.chat/docs/reference/web-client/#configuration for description of the various options\n+ cactus:\n+ defaultHomeserverUrl: 'https://matrix.cactus.chat:8448'\n+ serverName: 'cactus.chat'\n+ siteName: '' # You must insert a unique identifier here matching the one you registered (See https://cactus.chat/docs/getting-started/quick-start/#register-your-site)\n \n- giscus:\n- repo:\n- repoID:\n- category:\n- categoryID:\n- mapping:\n- lightTheme:\n- darkTheme:\n- reactionsEnabled: 1\n- emitMetadata: 0\n+ giscus:\n+ repo:\n+ repoID:\n+ category:\n+ categoryID:\n+ mapping:\n+ lightTheme:\n+ darkTheme:\n+ reactionsEnabled: 1\n+ emitMetadata: 0\n \n- gitalk:\n- owner:\n- admin:\n- repo:\n- clientID:\n- clientSecret:\n+ gitalk:\n+ owner:\n+ admin:\n+ repo:\n+ clientID:\n+ clientSecret:\n \n- cusdis:\n- host:\n- id:\n- widgets:\n- homepage:\n- - type: bolg\n- - type: search\n- - type: archives\n- params:\n- limit: 10\n- - type: categories\n- params:\n- limit: 10\n- - type: tag-cloud\n- params:\n- limit: 10\n- page:\n- - type: toc\n+ cusdis:\n+ host:\n+ id:\n+ widgets:\n+ homepage:\n+ - type: bolg\n+ - type: search\n+ - type: archives\n+ params:\n+ limit: 10\n+ - type: categories\n+ params:\n+ limit: 10\n+ - type: tag-cloud\n+ params:\n+ limit: 10\n+ page:\n+ - type: toc\n \n- opengraph:\n- twitter:\n- # Your Twitter username\n- site:\n+ opengraph:\n+ twitter:\n+ # Your Twitter username\n+ site:\n \n- # Available values: summary, summary_large_image\n- card: summary_large_image\n+ # Available values: summary, summary_large_image\n+ card: summary_large_image\n \n- defaultImage:\n- opengraph:\n- enabled: false\n- local: false\n- src:\n+ defaultImage:\n+ opengraph:\n+ enabled: false\n+ local: false\n+ src:\n \n- colorScheme:\n- # Display toggle\n- toggle: true\n+ colorScheme:\n+ # Display toggle\n+ toggle: true\n \n- # Available values: auto, light, dark\n- default: auto\n+ # Available values: auto, light, dark\n+ default: auto\n \n- imageProcessing:\n- cover:\n- enabled: true\n- content:\n- enabled: true\n+ imageProcessing:\n+ cover:\n+ enabled: true\n+ content:\n+ enabled: true\n \n ### Custom menu\n ### See https://docs.stack.jimmycai.com/configuration/custom-menu.html\n ### To remove about, archive and search page menu item, remove `menu` field from their FrontMatter\n menu:\n- main: [ ]\n+ main: []\n \n+ social:\n+ - identifier: github\n+ name: GitHub\n+ url: https://github.com/FeiNiaoBF\n+ params:\n+ icon: brand-github\n \n- social:\n- - identifier: github\n- name: GitHub\n- url: https://github.com/FeiNiaoBF\n- params:\n- icon: brand-github\n+ # - identifier: twitter\n+ # name: Twitter\n+ # url: https://twitter.com\n+ # params:\n+ # icon: brand-twitter\n \n- # - identifier: twitter\n- # name: Twitter\n- # url: https://twitter.com\n- # params:\n- # icon: brand-twitter\n+ # - identifier: youTube\n+ # name: YouTube\n+ # url: https://www.youtube.com/channel/UCZsE4g_WIh-KRpjCeF4cABA\n+ # params:\n+ # icon: brand-twitter\n \n- # - identifier: youTube\n- # name: YouTube\n- # url: https://www.youtube.com/channel/UCZsE4g_WIh-KRpjCeF4cABA\n- # params:\n- # icon: brand-twitter\n+ # - identifier: bilibili\n+ # name: Bilibili\n+ # url: https://space.bilibili.com/592367582?spm_id_from=333.1007.0.0\n+ # params:\n+ # icon: brand-twitter\n \n- # - identifier: bilibili\n- # name: Bilibili\n- # url: https://space.bilibili.com/592367582?spm_id_from=333.1007.0.0\n- # params:\n- # icon: brand-twitter\n+ # - identifier: steam\n+ # name: Steam\n+ # url: https://store.steampowered.com/\n+ # params:\n+ # icon: brand-twitter\n \n- # - identifier: steam\n- # name: Steam\n- # url: https://store.steampowered.com/\n- # params:\n- # icon: brand-twitter\n-\n-\n related:\n- includeNewer: true\n- threshold: 60\n- toLower: false\n- indices:\n- - name: tags\n- weight: 100\n+ includeNewer: true\n+ threshold: 60\n+ toLower: false\n+ indices:\n+ - name: tags\n+ weight: 100\n \n- - name: categories\n- weight: 200\n+ - name: categories\n+ weight: 200\n \n markup:\n- goldmark:\n- renderer:\n- ## Set to true if you have HTML content inside Markdown\n- unsafe: true\n- tableOfContents:\n- endLevel: 4\n- ordered: true\n- startLevel: 2\n- highlight:\n- noClasses: false\n- codeFences: true\n- guessSyntax: true\n- lineNoStart: 1\n- lineNos: true\n- lineNumbersInTable: true\n- tabWidth: 4\n+ goldmark:\n+ renderer:\n+ ## Set to true if you have HTML content inside Markdown\n+ unsafe: true\n+ tableOfContents:\n+ endLevel: 4\n+ ordered: true\n+ startLevel: 2\n+ highlight:\n+ noClasses: false\n+ codeFences: true\n+ guessSyntax: true\n+ lineNoStart: 1\n+ lineNos: true\n+ lineNumbersInTable: true\n+ tabWidth: 4\n" - }, - { - "date": 1715565327183, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -165,9 +165,9 @@\n host:\n id:\n widgets:\n homepage:\n- - type: bolg\n+ - type: blog\n - type: search\n - type: archives\n params:\n limit: 10\n" - }, - { - "date": 1715566644184, - "content": "Index: \n===================================================================\n--- \n+++ \n@@ -165,9 +165,9 @@\n host:\n id:\n widgets:\n homepage:\n- - type: blog\n+ # - type: blog\n - type: search\n - type: archives\n params:\n limit: 10\n" - } - ], - "date": 1712580625532, - "name": "Commit-0", - "content": "baseurl: https://FeiNiaoBF.github.io/\nlanguageCode: en\ntheme: hugo-theme-stack\npaginate: 5\ntitle: Yeelight の 小屋\ncopyright: Example Person. All rights reserved.\n\n# Theme i18n support\n# Available values: ar, bn, ca, de, el, en, es, fr, hu, id, it, ja, ko, nl, pt-br, th, uk, zh-cn, zh-hk, zh-tw\nDefaultContentLanguage: zh-cn\nDefaultContentLanguageInSubdir: true\n# Set hasCJKLanguage to true if DefaultContentLanguage is in [zh-cn ja ko]\n# This will make .Summary and .WordCount behave correctly for CJK languages.\nhasCJKLanguage: true\n\nenableInlineShortcodes: true #允许内联短码\nenableEmoji: true # 允许使用 Emoji 表情,建议 true\nenableRobotsTXT: true # 允许爬虫抓取到搜索引擎,建议 true\n\nlanguages:\n en:\n disabled: false\n languageCode: \"\"\n languageDirection: \"\"\n languageName: English\n title: Yeelight's Home\n weight: 1\n params:\n description: A hut where we talk about learning\n zh-cn:\n disabled: false\n languageCode: \"\"\n languageDirection: \"\"\n languageName: 中文\n title: Yeelight の 小屋\n weight: 2\n params:\n description: 一个谈学习的小屋\n\nservices:\n # Change it to your Disqus shortname before using\n disqus:\n shortname: \"hugo-theme-stack\"\n # GA Tracking ID\n googleAnalytics:\n id:\n\npermalinks:\n post: /p/:slug/\n page: /:slug/\n\nparams:\n mainSections:\n - post\n featuredImageField: image\n # Output page's full content in RSS.\n rssFullContent: true\n favicon: favicon.ico # e.g.: favicon placed in `static/favicon.ico` of your site folder, then set this field to `/favicon.ico` (`/` is necessary)\n\n footer:\n since: 2023\n customText:\n\n dateFormat:\n published: Jan 02, 2006\n lastUpdated: Jan 02, 2006 15:04 CST\n\n sidebar:\n emoji: 🌞 # 🍥\n subtitle: \"简单是稳定的前提( •̀ ω •́ )✧\"\n avatar:\n enabled: true\n local: true\n src: img/avatar.png\n\n article:\n math: false\n toc: true\n readingTime: true\n license:\n enabled: true\n default: Licensed under CC BY-NC-SA 4.0\n\n comments:\n enabled: true\n provider: disqus\n\n disqusjs:\n shortname:\n apiUrl:\n apiKey:\n admin:\n adminLabel:\n\n utterances:\n repo:\n issueTerm: pathname\n label:\n\n beaudar:\n repo:\n issueTerm: pathname\n label:\n theme:\n\n remark42:\n host:\n site:\n locale:\n\n vssue:\n platform:\n owner:\n repo:\n clientId:\n clientSecret:\n autoCreateIssue: false\n\n # Waline client configuration see: https://waline.js.org/en/reference/component.html\n waline:\n serverURL:\n lang:\n pageview:\n emoji:\n - https://unpkg.com/@waline/emojis@1.0.1/weibo\n requiredMeta:\n - name\n - email\n - url\n locale:\n admin: Yeelight\n placeholder:\n\n twikoo:\n envId:\n region:\n path:\n lang:\n\n # See https://cactus.chat/docs/reference/web-client/#configuration for description of the various options\n cactus:\n defaultHomeserverUrl: \"https://matrix.cactus.chat:8448\"\n serverName: \"cactus.chat\"\n siteName: \"\" # You must insert a unique identifier here matching the one you registered (See https://cactus.chat/docs/getting-started/quick-start/#register-your-site)\n\n giscus:\n repo:\n repoID:\n category:\n categoryID:\n mapping:\n lightTheme:\n darkTheme:\n reactionsEnabled: 1\n emitMetadata: 0\n\n gitalk:\n owner:\n admin:\n repo:\n clientID:\n clientSecret:\n\n cusdis:\n host:\n id:\n widgets:\n homepage:\n - type: bolg\n - type: search\n - type: archives\n params:\n limit: 10\n - type: categories\n params:\n limit: 10\n - type: tag-cloud\n params:\n limit: 10\n page:\n - type: toc\n\n opengraph:\n twitter:\n # Your Twitter username\n site:\n\n # Available values: summary, summary_large_image\n card: summary_large_image\n\n defaultImage:\n opengraph:\n enabled: false\n local: false\n src:\n\n colorScheme:\n # Display toggle\n toggle: true\n\n # Available values: auto, light, dark\n default: auto\n\n imageProcessing:\n cover:\n enabled: true\n content:\n enabled: true\n\n### Custom menu\n### See https://docs.stack.jimmycai.com/configuration/custom-menu.html\n### To remove about, archive and search page menu item, remove `menu` field from their FrontMatter\nmenu:\n main: [\n \n ]\n\n social:\n - identifier: github\n name: GitHub\n url: https://github.com/FeiNiaoBF\n params:\n icon: brand-github\n\n - identifier: twitter\n name: Twitter\n url: https://twitter.com\n params:\n icon: brand-twitter\n\n # - identifier: youTube\n # name: YouTube\n # url: https://www.youtube.com/channel/UCZsE4g_WIh-KRpjCeF4cABA\n # params:\n # icon: brand-twitter\n\n # - identifier: bilibili\n # name: Bilibili\n # url: https://space.bilibili.com/592367582?spm_id_from=333.1007.0.0\n # params:\n # icon: brand-twitter\n\n # - identifier: steam\n # name: Steam\n # url: https://store.steampowered.com/\n # params:\n # icon: brand-twitter\n\n\nrelated:\n includeNewer: true\n threshold: 60\n toLower: false\n indices:\n - name: tags\n weight: 100\n\n - name: categories\n weight: 200\n\nmarkup:\n goldmark:\n renderer:\n ## Set to true if you have HTML content inside Markdown\n unsafe: true\n tableOfContents:\n endLevel: 4\n ordered: true\n startLevel: 2\n highlight:\n noClasses: false\n codeFences: true\n guessSyntax: true\n lineNoStart: 1\n lineNos: true\n lineNumbersInTable: true\n tabWidth: 4\n" - } - ] -} \ No newline at end of file diff --git a/YBlog/public b/YBlog/public deleted file mode 160000 index 2800180..0000000 --- a/YBlog/public +++ /dev/null @@ -1 +0,0 @@ -Subproject commit 2800180780689ece84651c468fc483b71e88d81b diff --git a/YBlog/themes/hugo-theme-stack b/YBlog/themes/hugo-theme-stack deleted file mode 160000 index 5a8607e..0000000 --- a/YBlog/themes/hugo-theme-stack +++ /dev/null @@ -1 +0,0 @@ -Subproject commit 5a8607e4a88fd2c0f488ff56cef2356c2471a5c4 diff --git a/YBlog/archetypes/categories.md b/archetypes/categories.md similarity index 100% rename from YBlog/archetypes/categories.md rename to archetypes/categories.md diff --git a/YBlog/archetypes/default.md b/archetypes/default.md similarity index 100% rename from YBlog/archetypes/default.md rename to archetypes/default.md diff --git a/YBlog/archetypes/tags.md b/archetypes/tags.md similarity index 100% rename from YBlog/archetypes/tags.md rename to archetypes/tags.md diff --git a/YBlog/assets/icons/archives.svg b/assets/icons/archives.svg similarity index 100% rename from YBlog/assets/icons/archives.svg rename to assets/icons/archives.svg diff --git a/YBlog/assets/icons/arrow-back.svg b/assets/icons/arrow-back.svg similarity index 100% rename from YBlog/assets/icons/arrow-back.svg rename to assets/icons/arrow-back.svg diff --git a/YBlog/assets/icons/back.svg b/assets/icons/back.svg similarity index 100% rename from YBlog/assets/icons/back.svg rename to assets/icons/back.svg diff --git a/YBlog/assets/icons/blog.svg b/assets/icons/blog.svg similarity index 100% rename from YBlog/assets/icons/blog.svg rename to assets/icons/blog.svg diff --git a/YBlog/assets/icons/brand-github.svg b/assets/icons/brand-github.svg similarity index 100% rename from YBlog/assets/icons/brand-github.svg rename to assets/icons/brand-github.svg diff --git a/YBlog/assets/icons/brand-twitter.svg b/assets/icons/brand-twitter.svg similarity index 100% rename from YBlog/assets/icons/brand-twitter.svg rename to assets/icons/brand-twitter.svg diff --git a/YBlog/assets/icons/categories.svg b/assets/icons/categories.svg similarity index 100% rename from YBlog/assets/icons/categories.svg rename to assets/icons/categories.svg diff --git a/YBlog/assets/icons/clock.svg b/assets/icons/clock.svg similarity index 100% rename from YBlog/assets/icons/clock.svg rename to assets/icons/clock.svg diff --git a/YBlog/assets/icons/copyright.svg b/assets/icons/copyright.svg similarity index 100% rename from YBlog/assets/icons/copyright.svg rename to assets/icons/copyright.svg diff --git a/YBlog/assets/icons/date.svg b/assets/icons/date.svg similarity index 100% rename from YBlog/assets/icons/date.svg rename to assets/icons/date.svg diff --git a/YBlog/assets/icons/hash.svg b/assets/icons/hash.svg similarity index 100% rename from YBlog/assets/icons/hash.svg rename to assets/icons/hash.svg diff --git a/YBlog/assets/icons/home.svg b/assets/icons/home.svg similarity index 100% rename from YBlog/assets/icons/home.svg rename to assets/icons/home.svg diff --git a/YBlog/assets/icons/infinity.svg b/assets/icons/infinity.svg similarity index 100% rename from YBlog/assets/icons/infinity.svg rename to assets/icons/infinity.svg diff --git a/YBlog/assets/icons/language.svg b/assets/icons/language.svg similarity index 100% rename from YBlog/assets/icons/language.svg rename to assets/icons/language.svg diff --git a/YBlog/assets/icons/link.svg b/assets/icons/link.svg similarity index 100% rename from YBlog/assets/icons/link.svg rename to assets/icons/link.svg diff --git a/YBlog/assets/icons/messages.svg b/assets/icons/messages.svg similarity index 100% rename from YBlog/assets/icons/messages.svg rename to assets/icons/messages.svg diff --git a/YBlog/assets/icons/rss.svg b/assets/icons/rss.svg similarity index 100% rename from YBlog/assets/icons/rss.svg rename to assets/icons/rss.svg diff --git a/YBlog/assets/icons/search.svg b/assets/icons/search.svg similarity index 100% rename from YBlog/assets/icons/search.svg rename to assets/icons/search.svg diff --git a/YBlog/assets/icons/tag.svg b/assets/icons/tag.svg similarity index 100% rename from YBlog/assets/icons/tag.svg rename to assets/icons/tag.svg diff --git a/YBlog/assets/icons/toggle-left.svg b/assets/icons/toggle-left.svg similarity index 100% rename from YBlog/assets/icons/toggle-left.svg rename to assets/icons/toggle-left.svg diff --git a/YBlog/assets/icons/toggle-right.svg b/assets/icons/toggle-right.svg similarity index 100% rename from YBlog/assets/icons/toggle-right.svg rename to assets/icons/toggle-right.svg diff --git a/YBlog/assets/icons/user.svg b/assets/icons/user.svg similarity index 100% rename from YBlog/assets/icons/user.svg rename to assets/icons/user.svg diff --git a/YBlog/assets/img/avatar.png b/assets/img/avatar.png similarity index 100% rename from YBlog/assets/img/avatar.png rename to assets/img/avatar.png diff --git a/YBlog/assets/jsconfig.json b/assets/jsconfig.json similarity index 100% rename from YBlog/assets/jsconfig.json rename to assets/jsconfig.json diff --git a/YBlog/assets/scss/breakpoints.scss b/assets/scss/breakpoints.scss similarity index 100% rename from YBlog/assets/scss/breakpoints.scss rename to assets/scss/breakpoints.scss diff --git a/YBlog/assets/scss/custom.scss b/assets/scss/custom.scss similarity index 100% rename from YBlog/assets/scss/custom.scss rename to assets/scss/custom.scss diff --git a/YBlog/assets/scss/external/normalize.scss b/assets/scss/external/normalize.scss similarity index 100% rename from YBlog/assets/scss/external/normalize.scss rename to assets/scss/external/normalize.scss diff --git a/YBlog/assets/scss/general.scss b/assets/scss/general.scss similarity index 100% rename from YBlog/assets/scss/general.scss rename to assets/scss/general.scss diff --git a/YBlog/assets/scss/grid.scss b/assets/scss/grid.scss similarity index 100% rename from YBlog/assets/scss/grid.scss rename to assets/scss/grid.scss diff --git a/YBlog/assets/scss/partials/article.scss b/assets/scss/partials/article.scss similarity index 100% rename from YBlog/assets/scss/partials/article.scss rename to assets/scss/partials/article.scss diff --git a/YBlog/assets/scss/partials/base.scss b/assets/scss/partials/base.scss similarity index 100% rename from YBlog/assets/scss/partials/base.scss rename to assets/scss/partials/base.scss diff --git a/YBlog/assets/scss/partials/comments/disqusjs.scss b/assets/scss/partials/comments/disqusjs.scss similarity index 100% rename from YBlog/assets/scss/partials/comments/disqusjs.scss rename to assets/scss/partials/comments/disqusjs.scss diff --git a/YBlog/assets/scss/partials/footer.scss b/assets/scss/partials/footer.scss similarity index 100% rename from YBlog/assets/scss/partials/footer.scss rename to assets/scss/partials/footer.scss diff --git a/YBlog/assets/scss/partials/highlight/common.scss b/assets/scss/partials/highlight/common.scss similarity index 100% rename from YBlog/assets/scss/partials/highlight/common.scss rename to assets/scss/partials/highlight/common.scss diff --git a/YBlog/assets/scss/partials/highlight/dark.scss b/assets/scss/partials/highlight/dark.scss similarity index 100% rename from YBlog/assets/scss/partials/highlight/dark.scss rename to assets/scss/partials/highlight/dark.scss diff --git a/YBlog/assets/scss/partials/highlight/light.scss b/assets/scss/partials/highlight/light.scss similarity index 100% rename from YBlog/assets/scss/partials/highlight/light.scss rename to assets/scss/partials/highlight/light.scss diff --git a/YBlog/assets/scss/partials/layout/404.scss b/assets/scss/partials/layout/404.scss similarity index 100% rename from YBlog/assets/scss/partials/layout/404.scss rename to assets/scss/partials/layout/404.scss diff --git a/YBlog/assets/scss/partials/layout/article.scss b/assets/scss/partials/layout/article.scss similarity index 100% rename from YBlog/assets/scss/partials/layout/article.scss rename to assets/scss/partials/layout/article.scss diff --git a/YBlog/assets/scss/partials/layout/list.scss b/assets/scss/partials/layout/list.scss similarity index 100% rename from YBlog/assets/scss/partials/layout/list.scss rename to assets/scss/partials/layout/list.scss diff --git a/YBlog/assets/scss/partials/layout/search.scss b/assets/scss/partials/layout/search.scss similarity index 100% rename from YBlog/assets/scss/partials/layout/search.scss rename to assets/scss/partials/layout/search.scss diff --git a/YBlog/assets/scss/partials/menu.scss b/assets/scss/partials/menu.scss similarity index 100% rename from YBlog/assets/scss/partials/menu.scss rename to assets/scss/partials/menu.scss diff --git a/YBlog/assets/scss/partials/pagination.scss b/assets/scss/partials/pagination.scss similarity index 100% rename from YBlog/assets/scss/partials/pagination.scss rename to assets/scss/partials/pagination.scss diff --git a/YBlog/assets/scss/partials/sidebar.scss b/assets/scss/partials/sidebar.scss similarity index 100% rename from YBlog/assets/scss/partials/sidebar.scss rename to assets/scss/partials/sidebar.scss diff --git a/YBlog/assets/scss/partials/widgets.scss b/assets/scss/partials/widgets.scss similarity index 100% rename from YBlog/assets/scss/partials/widgets.scss rename to assets/scss/partials/widgets.scss diff --git a/YBlog/assets/scss/style.scss b/assets/scss/style.scss similarity index 100% rename from YBlog/assets/scss/style.scss rename to assets/scss/style.scss diff --git a/YBlog/assets/scss/variables.scss b/assets/scss/variables.scss similarity index 100% rename from YBlog/assets/scss/variables.scss rename to assets/scss/variables.scss diff --git a/YBlog/assets/ts/color.ts b/assets/ts/color.ts similarity index 100% rename from YBlog/assets/ts/color.ts rename to assets/ts/color.ts diff --git a/YBlog/assets/ts/colorScheme.ts b/assets/ts/colorScheme.ts similarity index 100% rename from YBlog/assets/ts/colorScheme.ts rename to assets/ts/colorScheme.ts diff --git a/YBlog/assets/ts/createElement.ts b/assets/ts/createElement.ts similarity index 100% rename from YBlog/assets/ts/createElement.ts rename to assets/ts/createElement.ts diff --git a/YBlog/assets/ts/gallery.ts b/assets/ts/gallery.ts similarity index 100% rename from YBlog/assets/ts/gallery.ts rename to assets/ts/gallery.ts diff --git a/YBlog/assets/ts/main.ts b/assets/ts/main.ts similarity index 100% rename from YBlog/assets/ts/main.ts rename to assets/ts/main.ts diff --git a/YBlog/assets/ts/menu.ts b/assets/ts/menu.ts similarity index 100% rename from YBlog/assets/ts/menu.ts rename to assets/ts/menu.ts diff --git a/YBlog/assets/ts/scrollspy.ts b/assets/ts/scrollspy.ts similarity index 100% rename from YBlog/assets/ts/scrollspy.ts rename to assets/ts/scrollspy.ts diff --git a/YBlog/assets/ts/search.tsx b/assets/ts/search.tsx similarity index 100% rename from YBlog/assets/ts/search.tsx rename to assets/ts/search.tsx diff --git a/YBlog/assets/ts/smoothAnchors.ts b/assets/ts/smoothAnchors.ts similarity index 100% rename from YBlog/assets/ts/smoothAnchors.ts rename to assets/ts/smoothAnchors.ts diff --git a/YBlog/content/categories/Test/_index.en.md b/content/categories/Test/_index.en.md similarity index 100% rename from YBlog/content/categories/Test/_index.en.md rename to content/categories/Test/_index.en.md diff --git a/YBlog/content/categories/Test/_index.zh-cn.md b/content/categories/Test/_index.zh-cn.md similarity index 100% rename from YBlog/content/categories/Test/_index.zh-cn.md rename to content/categories/Test/_index.zh-cn.md diff --git a/YBlog/content/categories/Test/hutomo-abrianto-l2jk-uxb1BY-unsplash.jpg b/content/categories/Test/hutomo-abrianto-l2jk-uxb1BY-unsplash.jpg similarity index 100% rename from YBlog/content/categories/Test/hutomo-abrianto-l2jk-uxb1BY-unsplash.jpg rename to content/categories/Test/hutomo-abrianto-l2jk-uxb1BY-unsplash.jpg diff --git a/YBlog/content/page/about/index.en.md b/content/page/about/index.en.md similarity index 100% rename from YBlog/content/page/about/index.en.md rename to content/page/about/index.en.md diff --git a/YBlog/content/page/about/index.zh-cn.md b/content/page/about/index.zh-cn.md similarity index 100% rename from YBlog/content/page/about/index.zh-cn.md rename to content/page/about/index.zh-cn.md diff --git a/YBlog/content/page/archives/index.en.md b/content/page/archives/index.en.md similarity index 100% rename from YBlog/content/page/archives/index.en.md rename to content/page/archives/index.en.md diff --git a/YBlog/content/page/archives/index.zh-cn.md b/content/page/archives/index.zh-cn.md similarity index 100% rename from YBlog/content/page/archives/index.zh-cn.md rename to content/page/archives/index.zh-cn.md diff --git a/YBlog/content/page/blog/index.en.md b/content/page/blog/index.en.md similarity index 100% rename from YBlog/content/page/blog/index.en.md rename to content/page/blog/index.en.md diff --git a/YBlog/content/page/blog/index.zh-cn.md b/content/page/blog/index.zh-cn.md similarity index 100% rename from YBlog/content/page/blog/index.zh-cn.md rename to content/page/blog/index.zh-cn.md diff --git a/YBlog/content/page/links/index.en.md b/content/page/links/index.en.md similarity index 100% rename from YBlog/content/page/links/index.en.md rename to content/page/links/index.en.md diff --git a/YBlog/content/page/links/index.zh-cn.md b/content/page/links/index.zh-cn.md similarity index 100% rename from YBlog/content/page/links/index.zh-cn.md rename to content/page/links/index.zh-cn.md diff --git a/YBlog/content/page/links/ts-logo-128.jpg b/content/page/links/ts-logo-128.jpg similarity index 100% rename from YBlog/content/page/links/ts-logo-128.jpg rename to content/page/links/ts-logo-128.jpg diff --git a/YBlog/content/page/search/index.en.md b/content/page/search/index.en.md similarity index 100% rename from YBlog/content/page/search/index.en.md rename to content/page/search/index.en.md diff --git a/YBlog/content/page/search/index.zh-cn.md b/content/page/search/index.zh-cn.md similarity index 100% rename from YBlog/content/page/search/index.zh-cn.md rename to content/page/search/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/0.CS-Learning-Plan/index.zh-cn.md b/content/post/Gohh/0.CS-Learning-Plan/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/0.CS-Learning-Plan/index.zh-cn.md rename to content/post/Gohh/0.CS-Learning-Plan/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/0.CS-Learning-Plan/matt-le-SJSpo9hQf7s-unsplash.jpg b/content/post/Gohh/0.CS-Learning-Plan/matt-le-SJSpo9hQf7s-unsplash.jpg similarity index 100% rename from YBlog/content/post/Gohh/0.CS-Learning-Plan/matt-le-SJSpo9hQf7s-unsplash.jpg rename to content/post/Gohh/0.CS-Learning-Plan/matt-le-SJSpo9hQf7s-unsplash.jpg diff --git a/YBlog/content/post/Gohh/0.CS-Learning-Plan/photo_2024-04-08_20-31-47.jpg b/content/post/Gohh/0.CS-Learning-Plan/photo_2024-04-08_20-31-47.jpg similarity index 100% rename from YBlog/content/post/Gohh/0.CS-Learning-Plan/photo_2024-04-08_20-31-47.jpg rename to content/post/Gohh/0.CS-Learning-Plan/photo_2024-04-08_20-31-47.jpg diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/BitwiseOperationsNotes/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/BitwiseOperationsNotes/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/BitwiseOperationsNotes/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/BitwiseOperationsNotes/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/_index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/conclusion/GoReader/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/conclusion/GoReader/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/conclusion/GoReader/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/conclusion/GoReader/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/conclusion/_index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/conclusion/_index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/conclusion/_index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/conclusion/_index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/InterviewQuestions/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/InterviewQuestions/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/InterviewQuestions/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/InterviewQuestions/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/Problem/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/Problem/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/Problem/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/Problem/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/_index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/_index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/_index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/development/_index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/DataType/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/LearningPath/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Map/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Resource/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/Strings/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/_index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/_index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/_index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/_index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/bitop/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/bitop/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/bitop/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/bitop/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/image.png b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/image.png similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/image.png rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/image.png diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/keyword/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/keyword/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/keyword/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/start/keyword/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/Concurrency/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/Concurrency/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/Concurrency/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/Concurrency/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/GC/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/GC/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/GC/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/GC/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/GMP_Model/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/GMP_Model/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/GMP_Model/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/GMP_Model/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/Map/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/Map/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/Map/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/Map/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/_index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/_index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/_index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/_index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb1/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb1/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb1/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb1/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb2/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb2/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb2/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb2/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb3/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb3/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb3/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb3/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb4/index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb4/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb4/index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/Golang/transition/goweb4/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/_index.zh-cn.md b/content/post/Gohh/1.ComputerBasics/CSLanguages/_index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/1.ComputerBasics/CSLanguages/_index.zh-cn.md rename to content/post/Gohh/1.ComputerBasics/CSLanguages/_index.zh-cn.md diff --git a/YBlog/content/post/Gohh/2.DataStructures/GolangDS/Array/index.zh-cn.md b/content/post/Gohh/2.DataStructures/GolangDS/Array/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/2.DataStructures/GolangDS/Array/index.zh-cn.md rename to content/post/Gohh/2.DataStructures/GolangDS/Array/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/2.DataStructures/GolangDS/Link/index.zh-cn.md b/content/post/Gohh/2.DataStructures/GolangDS/Link/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/2.DataStructures/GolangDS/Link/index.zh-cn.md rename to content/post/Gohh/2.DataStructures/GolangDS/Link/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/2.DataStructures/GolangDS/Stack/index.zh-cn.md b/content/post/Gohh/2.DataStructures/GolangDS/Stack/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/2.DataStructures/GolangDS/Stack/index.zh-cn.md rename to content/post/Gohh/2.DataStructures/GolangDS/Stack/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/2.DataStructures/GolangDS/_index.zh-cn.md b/content/post/Gohh/2.DataStructures/GolangDS/_index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/2.DataStructures/GolangDS/_index.zh-cn.md rename to content/post/Gohh/2.DataStructures/GolangDS/_index.zh-cn.md diff --git a/YBlog/content/post/Gohh/3.Architecture/CS61c/_index.zh-cn.md b/content/post/Gohh/3.Architecture/CS61c/_index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/3.Architecture/CS61c/_index.zh-cn.md rename to content/post/Gohh/3.Architecture/CS61c/_index.zh-cn.md diff --git a/YBlog/content/post/Gohh/3.Architecture/CSAPP/CSAPP00/index.zh-cn.md b/content/post/Gohh/3.Architecture/CSAPP/CSAPP00/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/3.Architecture/CSAPP/CSAPP00/index.zh-cn.md rename to content/post/Gohh/3.Architecture/CSAPP/CSAPP00/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/3.Architecture/CSAPP/CSAPP01/index.zh-cn.md b/content/post/Gohh/3.Architecture/CSAPP/CSAPP01/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/3.Architecture/CSAPP/CSAPP01/index.zh-cn.md rename to content/post/Gohh/3.Architecture/CSAPP/CSAPP01/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/3.Architecture/CSAPP/CSAPP02/index.zh-cn.md b/content/post/Gohh/3.Architecture/CSAPP/CSAPP02/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/3.Architecture/CSAPP/CSAPP02/index.zh-cn.md rename to content/post/Gohh/3.Architecture/CSAPP/CSAPP02/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/3.Architecture/CSAPP/CSAPP03/index.zh-cn.md b/content/post/Gohh/3.Architecture/CSAPP/CSAPP03/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/3.Architecture/CSAPP/CSAPP03/index.zh-cn.md rename to content/post/Gohh/3.Architecture/CSAPP/CSAPP03/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/3.Architecture/CSAPP/_index.zh-cn.md b/content/post/Gohh/3.Architecture/CSAPP/_index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/3.Architecture/CSAPP/_index.zh-cn.md rename to content/post/Gohh/3.Architecture/CSAPP/_index.zh-cn.md diff --git a/YBlog/content/post/Gohh/4.OS/LinuxLearn/FD/index.zh-cn.md b/content/post/Gohh/4.OS/LinuxLearn/FD/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/4.OS/LinuxLearn/FD/index.zh-cn.md rename to content/post/Gohh/4.OS/LinuxLearn/FD/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/4.OS/LinuxLearn/Line/index.zh-cn.md b/content/post/Gohh/4.OS/LinuxLearn/Line/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/4.OS/LinuxLearn/Line/index.zh-cn.md rename to content/post/Gohh/4.OS/LinuxLearn/Line/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/4.OS/LinuxLearn/Notes/index.zh-cn.md b/content/post/Gohh/4.OS/LinuxLearn/Notes/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/4.OS/LinuxLearn/Notes/index.zh-cn.md rename to content/post/Gohh/4.OS/LinuxLearn/Notes/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/4.OS/LinuxLearn/_index.zh-cn.md b/content/post/Gohh/4.OS/LinuxLearn/_index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/4.OS/LinuxLearn/_index.zh-cn.md rename to content/post/Gohh/4.OS/LinuxLearn/_index.zh-cn.md diff --git a/YBlog/content/post/Gohh/4.OS/LinuxLearn/pipe/index.zh-cn.md b/content/post/Gohh/4.OS/LinuxLearn/pipe/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/4.OS/LinuxLearn/pipe/index.zh-cn.md rename to content/post/Gohh/4.OS/LinuxLearn/pipe/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/4.OS/S6.081/_index.zh-cn.md b/content/post/Gohh/4.OS/S6.081/_index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/4.OS/S6.081/_index.zh-cn.md rename to content/post/Gohh/4.OS/S6.081/_index.zh-cn.md diff --git a/YBlog/content/post/Gohh/4.OS/S6.081/xv6_file_system/index.zh-cn.md b/content/post/Gohh/4.OS/S6.081/xv6_file_system/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/4.OS/S6.081/xv6_file_system/index.zh-cn.md rename to content/post/Gohh/4.OS/S6.081/xv6_file_system/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/4.OS/S6.081/xv6_gdb_debug/index.zh-cn.md b/content/post/Gohh/4.OS/S6.081/xv6_gdb_debug/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/4.OS/S6.081/xv6_gdb_debug/index.zh-cn.md rename to content/post/Gohh/4.OS/S6.081/xv6_gdb_debug/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/4.OS/S6.081/xv6_interrupt/index.zh-cn.md b/content/post/Gohh/4.OS/S6.081/xv6_interrupt/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/4.OS/S6.081/xv6_interrupt/index.zh-cn.md rename to content/post/Gohh/4.OS/S6.081/xv6_interrupt/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/4.OS/S6.081/xv6_learn/index.zh-cn.md b/content/post/Gohh/4.OS/S6.081/xv6_learn/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/4.OS/S6.081/xv6_learn/index.zh-cn.md rename to content/post/Gohh/4.OS/S6.081/xv6_learn/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/4.OS/S6.081/xv6_lock/index.zh-cn.md b/content/post/Gohh/4.OS/S6.081/xv6_lock/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/4.OS/S6.081/xv6_lock/index.zh-cn.md rename to content/post/Gohh/4.OS/S6.081/xv6_lock/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/4.OS/S6.081/xv6_process/index.zh-cn.md b/content/post/Gohh/4.OS/S6.081/xv6_process/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/4.OS/S6.081/xv6_process/index.zh-cn.md rename to content/post/Gohh/4.OS/S6.081/xv6_process/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/4.OS/S6.081/xv6_src/index.zh-cn.md b/content/post/Gohh/4.OS/S6.081/xv6_src/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/4.OS/S6.081/xv6_src/index.zh-cn.md rename to content/post/Gohh/4.OS/S6.081/xv6_src/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/4.OS/S6.081/xv6_trap/index.zh-cn.md b/content/post/Gohh/4.OS/S6.081/xv6_trap/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/4.OS/S6.081/xv6_trap/index.zh-cn.md rename to content/post/Gohh/4.OS/S6.081/xv6_trap/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/4.OS/S6.081/xv6_vmem/index.zh-cn.md b/content/post/Gohh/4.OS/S6.081/xv6_vmem/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/4.OS/S6.081/xv6_vmem/index.zh-cn.md rename to content/post/Gohh/4.OS/S6.081/xv6_vmem/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/5.Networking/Internet0/index.zh-cn.md b/content/post/Gohh/5.Networking/Internet0/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/5.Networking/Internet0/index.zh-cn.md rename to content/post/Gohh/5.Networking/Internet0/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/5.Networking/Internet1/index.zh-cn.md b/content/post/Gohh/5.Networking/Internet1/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/5.Networking/Internet1/index.zh-cn.md rename to content/post/Gohh/5.Networking/Internet1/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/5.Networking/_index.zh-cn.md b/content/post/Gohh/5.Networking/_index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/5.Networking/_index.zh-cn.md rename to content/post/Gohh/5.Networking/_index.zh-cn.md diff --git a/YBlog/content/post/Gohh/5.Networking/http/index.zh-cn.md b/content/post/Gohh/5.Networking/http/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/5.Networking/http/index.zh-cn.md rename to content/post/Gohh/5.Networking/http/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/6.Distribut/MIT6.824/01/index.zh-cn.md b/content/post/Gohh/6.Distribut/MIT6.824/01/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/6.Distribut/MIT6.824/01/index.zh-cn.md rename to content/post/Gohh/6.Distribut/MIT6.824/01/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/6.Distribut/MIT6.824/01lab/index.zh-cn.md b/content/post/Gohh/6.Distribut/MIT6.824/01lab/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/6.Distribut/MIT6.824/01lab/index.zh-cn.md rename to content/post/Gohh/6.Distribut/MIT6.824/01lab/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/6.Distribut/MIT6.824/_index.zh-cn.md b/content/post/Gohh/6.Distribut/MIT6.824/_index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/6.Distribut/MIT6.824/_index.zh-cn.md rename to content/post/Gohh/6.Distribut/MIT6.824/_index.zh-cn.md diff --git a/YBlog/content/post/Gohh/88.Tools/GDB/index.zh-cn.md b/content/post/Gohh/88.Tools/GDB/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/88.Tools/GDB/index.zh-cn.md rename to content/post/Gohh/88.Tools/GDB/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/88.Tools/Makefile/index.zh-cn.md b/content/post/Gohh/88.Tools/Makefile/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/88.Tools/Makefile/index.zh-cn.md rename to content/post/Gohh/88.Tools/Makefile/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/99.Problems/_index.zh-cn.md b/content/post/Gohh/99.Problems/_index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/99.Problems/_index.zh-cn.md rename to content/post/Gohh/99.Problems/_index.zh-cn.md diff --git a/YBlog/content/post/Gohh/99.Problems/issue/index.zh-cn.md b/content/post/Gohh/99.Problems/issue/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/99.Problems/issue/index.zh-cn.md rename to content/post/Gohh/99.Problems/issue/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/Algorithms/backtrack/index.md b/content/post/Gohh/Algorithms/backtrack/index.md similarity index 100% rename from YBlog/content/post/Gohh/Algorithms/backtrack/index.md rename to content/post/Gohh/Algorithms/backtrack/index.md diff --git a/YBlog/content/post/Gohh/Algorithms/sort/index.md b/content/post/Gohh/Algorithms/sort/index.md similarity index 100% rename from YBlog/content/post/Gohh/Algorithms/sort/index.md rename to content/post/Gohh/Algorithms/sort/index.md diff --git a/YBlog/content/post/Gohh/CS61c/cache/index.zh-cn.md b/content/post/Gohh/CS61c/cache/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/CS61c/cache/index.zh-cn.md rename to content/post/Gohh/CS61c/cache/index.zh-cn.md diff --git a/YBlog/content/post/Gohh/Personal/update/index.zh-cn.md b/content/post/Gohh/Personal/update/index.zh-cn.md similarity index 100% rename from YBlog/content/post/Gohh/Personal/update/index.zh-cn.md rename to content/post/Gohh/Personal/update/index.zh-cn.md diff --git a/YBlog/content/post/_index.en.md b/content/post/_index.en.md similarity index 100% rename from YBlog/content/post/_index.en.md rename to content/post/_index.en.md diff --git a/YBlog/content/post/_index.zh-cn.md b/content/post/_index.zh-cn.md similarity index 100% rename from YBlog/content/post/_index.zh-cn.md rename to content/post/_index.zh-cn.md diff --git a/YBlog/data/external.yaml b/data/external.yaml similarity index 100% rename from YBlog/data/external.yaml rename to data/external.yaml diff --git a/YBlog/hugo.yaml b/hugo.yaml similarity index 100% rename from YBlog/hugo.yaml rename to hugo.yaml diff --git a/YBlog/i18n/ar.yaml b/i18n/ar.yaml similarity index 100% rename from YBlog/i18n/ar.yaml rename to i18n/ar.yaml diff --git a/YBlog/i18n/be.yaml b/i18n/be.yaml similarity index 100% rename from YBlog/i18n/be.yaml rename to i18n/be.yaml diff --git a/YBlog/i18n/bn.yaml b/i18n/bn.yaml similarity index 100% rename from YBlog/i18n/bn.yaml rename to i18n/bn.yaml diff --git a/YBlog/i18n/ca.yaml b/i18n/ca.yaml similarity index 100% rename from YBlog/i18n/ca.yaml rename to i18n/ca.yaml diff --git a/YBlog/i18n/cs.yaml b/i18n/cs.yaml similarity index 100% rename from YBlog/i18n/cs.yaml rename to i18n/cs.yaml diff --git a/YBlog/i18n/de.yaml b/i18n/de.yaml similarity index 100% rename from YBlog/i18n/de.yaml rename to i18n/de.yaml diff --git a/YBlog/i18n/el.yaml b/i18n/el.yaml similarity index 100% rename from YBlog/i18n/el.yaml rename to i18n/el.yaml diff --git a/YBlog/i18n/en.yaml b/i18n/en.yaml similarity index 100% rename from YBlog/i18n/en.yaml rename to i18n/en.yaml diff --git a/YBlog/i18n/es.yaml b/i18n/es.yaml similarity index 100% rename from YBlog/i18n/es.yaml rename to i18n/es.yaml diff --git a/YBlog/i18n/fa.yaml b/i18n/fa.yaml similarity index 100% rename from YBlog/i18n/fa.yaml rename to i18n/fa.yaml diff --git a/YBlog/i18n/fr.yaml b/i18n/fr.yaml similarity index 100% rename from YBlog/i18n/fr.yaml rename to i18n/fr.yaml diff --git a/YBlog/i18n/hi.yaml b/i18n/hi.yaml similarity index 100% rename from YBlog/i18n/hi.yaml rename to i18n/hi.yaml diff --git a/YBlog/i18n/hu.yaml b/i18n/hu.yaml similarity index 100% rename from YBlog/i18n/hu.yaml rename to i18n/hu.yaml diff --git a/YBlog/i18n/id.yaml b/i18n/id.yaml similarity index 100% rename from YBlog/i18n/id.yaml rename to i18n/id.yaml diff --git a/YBlog/i18n/it.yaml b/i18n/it.yaml similarity index 100% rename from YBlog/i18n/it.yaml rename to i18n/it.yaml diff --git a/YBlog/i18n/ja.yaml b/i18n/ja.yaml similarity index 100% rename from YBlog/i18n/ja.yaml rename to i18n/ja.yaml diff --git a/YBlog/i18n/ko.yaml b/i18n/ko.yaml similarity index 100% rename from YBlog/i18n/ko.yaml rename to i18n/ko.yaml diff --git a/YBlog/i18n/nl.yaml b/i18n/nl.yaml similarity index 100% rename from YBlog/i18n/nl.yaml rename to i18n/nl.yaml diff --git a/YBlog/i18n/pl.yaml b/i18n/pl.yaml similarity index 100% rename from YBlog/i18n/pl.yaml rename to i18n/pl.yaml diff --git a/YBlog/i18n/pt-br.yaml b/i18n/pt-br.yaml similarity index 100% rename from YBlog/i18n/pt-br.yaml rename to i18n/pt-br.yaml diff --git a/YBlog/i18n/pt-pt.yaml b/i18n/pt-pt.yaml similarity index 100% rename from YBlog/i18n/pt-pt.yaml rename to i18n/pt-pt.yaml diff --git a/YBlog/i18n/ru.yaml b/i18n/ru.yaml similarity index 100% rename from YBlog/i18n/ru.yaml rename to i18n/ru.yaml diff --git a/YBlog/i18n/sk.yaml b/i18n/sk.yaml similarity index 100% rename from YBlog/i18n/sk.yaml rename to i18n/sk.yaml diff --git a/YBlog/i18n/th.yaml b/i18n/th.yaml similarity index 100% rename from YBlog/i18n/th.yaml rename to i18n/th.yaml diff --git a/YBlog/i18n/tr.yaml b/i18n/tr.yaml similarity index 100% rename from YBlog/i18n/tr.yaml rename to i18n/tr.yaml diff --git a/YBlog/i18n/uk.yaml b/i18n/uk.yaml similarity index 100% rename from YBlog/i18n/uk.yaml rename to i18n/uk.yaml diff --git a/YBlog/i18n/vi.yaml b/i18n/vi.yaml similarity index 100% rename from YBlog/i18n/vi.yaml rename to i18n/vi.yaml diff --git a/YBlog/i18n/zh-cn.yaml b/i18n/zh-cn.yaml similarity index 100% rename from YBlog/i18n/zh-cn.yaml rename to i18n/zh-cn.yaml diff --git a/YBlog/i18n/zh-hk.yaml b/i18n/zh-hk.yaml similarity index 100% rename from YBlog/i18n/zh-hk.yaml rename to i18n/zh-hk.yaml diff --git a/YBlog/i18n/zh-tw.yaml b/i18n/zh-tw.yaml similarity index 100% rename from YBlog/i18n/zh-tw.yaml rename to i18n/zh-tw.yaml diff --git a/YBlog/layouts/404.html b/layouts/404.html similarity index 100% rename from YBlog/layouts/404.html rename to layouts/404.html diff --git a/YBlog/layouts/_default/_markup/render-image.html b/layouts/_default/_markup/render-image.html similarity index 100% rename from YBlog/layouts/_default/_markup/render-image.html rename to layouts/_default/_markup/render-image.html diff --git a/YBlog/layouts/_default/_markup/render-link.html b/layouts/_default/_markup/render-link.html similarity index 100% rename from YBlog/layouts/_default/_markup/render-link.html rename to layouts/_default/_markup/render-link.html diff --git a/YBlog/layouts/_default/archives.html b/layouts/_default/archives.html similarity index 100% rename from YBlog/layouts/_default/archives.html rename to layouts/_default/archives.html diff --git a/YBlog/layouts/_default/baseof.html b/layouts/_default/baseof.html similarity index 100% rename from YBlog/layouts/_default/baseof.html rename to layouts/_default/baseof.html diff --git a/YBlog/layouts/_default/list.html b/layouts/_default/list.html similarity index 100% rename from YBlog/layouts/_default/list.html rename to layouts/_default/list.html diff --git a/YBlog/layouts/_default/rss.xml b/layouts/_default/rss.xml similarity index 100% rename from YBlog/layouts/_default/rss.xml rename to layouts/_default/rss.xml diff --git a/YBlog/layouts/_default/single.html b/layouts/_default/single.html similarity index 100% rename from YBlog/layouts/_default/single.html rename to layouts/_default/single.html diff --git a/YBlog/layouts/index.html b/layouts/index.html similarity index 100% rename from YBlog/layouts/index.html rename to layouts/index.html diff --git a/YBlog/layouts/page/search.html b/layouts/page/search.html similarity index 100% rename from YBlog/layouts/page/search.html rename to layouts/page/search.html diff --git a/YBlog/layouts/page/search.json b/layouts/page/search.json similarity index 100% rename from YBlog/layouts/page/search.json rename to layouts/page/search.json diff --git a/YBlog/layouts/partials/article-list/compact.html b/layouts/partials/article-list/compact.html similarity index 100% rename from YBlog/layouts/partials/article-list/compact.html rename to layouts/partials/article-list/compact.html diff --git a/YBlog/layouts/partials/article-list/default.html b/layouts/partials/article-list/default.html similarity index 100% rename from YBlog/layouts/partials/article-list/default.html rename to layouts/partials/article-list/default.html diff --git a/YBlog/layouts/partials/article-list/tile.html b/layouts/partials/article-list/tile.html similarity index 100% rename from YBlog/layouts/partials/article-list/tile.html rename to layouts/partials/article-list/tile.html diff --git a/YBlog/layouts/partials/article/article.html b/layouts/partials/article/article.html similarity index 100% rename from YBlog/layouts/partials/article/article.html rename to layouts/partials/article/article.html diff --git a/YBlog/layouts/partials/article/components/content.html b/layouts/partials/article/components/content.html similarity index 100% rename from YBlog/layouts/partials/article/components/content.html rename to layouts/partials/article/components/content.html diff --git a/YBlog/layouts/partials/article/components/details.html b/layouts/partials/article/components/details.html similarity index 100% rename from YBlog/layouts/partials/article/components/details.html rename to layouts/partials/article/components/details.html diff --git a/YBlog/layouts/partials/article/components/footer.html b/layouts/partials/article/components/footer.html similarity index 100% rename from YBlog/layouts/partials/article/components/footer.html rename to layouts/partials/article/components/footer.html diff --git a/YBlog/layouts/partials/article/components/header.html b/layouts/partials/article/components/header.html similarity index 100% rename from YBlog/layouts/partials/article/components/header.html rename to layouts/partials/article/components/header.html diff --git a/YBlog/layouts/partials/article/components/links.html b/layouts/partials/article/components/links.html similarity index 100% rename from YBlog/layouts/partials/article/components/links.html rename to layouts/partials/article/components/links.html diff --git a/YBlog/layouts/partials/article/components/math.html b/layouts/partials/article/components/math.html similarity index 100% rename from YBlog/layouts/partials/article/components/math.html rename to layouts/partials/article/components/math.html diff --git a/YBlog/layouts/partials/article/components/photoswipe.html b/layouts/partials/article/components/photoswipe.html similarity index 100% rename from YBlog/layouts/partials/article/components/photoswipe.html rename to layouts/partials/article/components/photoswipe.html diff --git a/YBlog/layouts/partials/article/components/related-content.html b/layouts/partials/article/components/related-content.html similarity index 100% rename from YBlog/layouts/partials/article/components/related-content.html rename to layouts/partials/article/components/related-content.html diff --git a/YBlog/layouts/partials/article/components/tags.html b/layouts/partials/article/components/tags.html similarity index 100% rename from YBlog/layouts/partials/article/components/tags.html rename to layouts/partials/article/components/tags.html diff --git a/YBlog/layouts/partials/comments/include.html b/layouts/partials/comments/include.html similarity index 100% rename from YBlog/layouts/partials/comments/include.html rename to layouts/partials/comments/include.html diff --git a/YBlog/layouts/partials/comments/provider/beaudar.html b/layouts/partials/comments/provider/beaudar.html similarity index 100% rename from YBlog/layouts/partials/comments/provider/beaudar.html rename to layouts/partials/comments/provider/beaudar.html diff --git a/YBlog/layouts/partials/comments/provider/cactus.html b/layouts/partials/comments/provider/cactus.html similarity index 100% rename from YBlog/layouts/partials/comments/provider/cactus.html rename to layouts/partials/comments/provider/cactus.html diff --git a/YBlog/layouts/partials/comments/provider/cusdis.html b/layouts/partials/comments/provider/cusdis.html similarity index 100% rename from YBlog/layouts/partials/comments/provider/cusdis.html rename to layouts/partials/comments/provider/cusdis.html diff --git a/YBlog/layouts/partials/comments/provider/disqus.html b/layouts/partials/comments/provider/disqus.html similarity index 100% rename from YBlog/layouts/partials/comments/provider/disqus.html rename to layouts/partials/comments/provider/disqus.html diff --git a/YBlog/layouts/partials/comments/provider/disqusjs.html b/layouts/partials/comments/provider/disqusjs.html similarity index 100% rename from YBlog/layouts/partials/comments/provider/disqusjs.html rename to layouts/partials/comments/provider/disqusjs.html diff --git a/YBlog/layouts/partials/comments/provider/giscus.html b/layouts/partials/comments/provider/giscus.html similarity index 100% rename from YBlog/layouts/partials/comments/provider/giscus.html rename to layouts/partials/comments/provider/giscus.html diff --git a/YBlog/layouts/partials/comments/provider/gitalk.html b/layouts/partials/comments/provider/gitalk.html similarity index 100% rename from YBlog/layouts/partials/comments/provider/gitalk.html rename to layouts/partials/comments/provider/gitalk.html diff --git a/YBlog/layouts/partials/comments/provider/remark42.html b/layouts/partials/comments/provider/remark42.html similarity index 100% rename from YBlog/layouts/partials/comments/provider/remark42.html rename to layouts/partials/comments/provider/remark42.html diff --git a/YBlog/layouts/partials/comments/provider/twikoo.html b/layouts/partials/comments/provider/twikoo.html similarity index 100% rename from YBlog/layouts/partials/comments/provider/twikoo.html rename to layouts/partials/comments/provider/twikoo.html diff --git a/YBlog/layouts/partials/comments/provider/utterances.html b/layouts/partials/comments/provider/utterances.html similarity index 100% rename from YBlog/layouts/partials/comments/provider/utterances.html rename to layouts/partials/comments/provider/utterances.html diff --git a/YBlog/layouts/partials/comments/provider/vssue.html b/layouts/partials/comments/provider/vssue.html similarity index 100% rename from YBlog/layouts/partials/comments/provider/vssue.html rename to layouts/partials/comments/provider/vssue.html diff --git a/YBlog/layouts/partials/comments/provider/waline.html b/layouts/partials/comments/provider/waline.html similarity index 100% rename from YBlog/layouts/partials/comments/provider/waline.html rename to layouts/partials/comments/provider/waline.html diff --git a/YBlog/layouts/partials/data/description.html b/layouts/partials/data/description.html similarity index 100% rename from YBlog/layouts/partials/data/description.html rename to layouts/partials/data/description.html diff --git a/YBlog/layouts/partials/data/title.html b/layouts/partials/data/title.html similarity index 100% rename from YBlog/layouts/partials/data/title.html rename to layouts/partials/data/title.html diff --git a/YBlog/layouts/partials/footer/components/custom-font.html b/layouts/partials/footer/components/custom-font.html similarity index 100% rename from YBlog/layouts/partials/footer/components/custom-font.html rename to layouts/partials/footer/components/custom-font.html diff --git a/YBlog/layouts/partials/footer/components/script.html b/layouts/partials/footer/components/script.html similarity index 100% rename from YBlog/layouts/partials/footer/components/script.html rename to layouts/partials/footer/components/script.html diff --git a/YBlog/layouts/partials/footer/custom.html b/layouts/partials/footer/custom.html similarity index 100% rename from YBlog/layouts/partials/footer/custom.html rename to layouts/partials/footer/custom.html diff --git a/YBlog/layouts/partials/footer/footer.html b/layouts/partials/footer/footer.html similarity index 100% rename from YBlog/layouts/partials/footer/footer.html rename to layouts/partials/footer/footer.html diff --git a/YBlog/layouts/partials/footer/include.html b/layouts/partials/footer/include.html similarity index 100% rename from YBlog/layouts/partials/footer/include.html rename to layouts/partials/footer/include.html diff --git a/YBlog/layouts/partials/head/colorScheme.html b/layouts/partials/head/colorScheme.html similarity index 100% rename from YBlog/layouts/partials/head/colorScheme.html rename to layouts/partials/head/colorScheme.html diff --git a/YBlog/layouts/partials/head/custom.html b/layouts/partials/head/custom.html similarity index 100% rename from YBlog/layouts/partials/head/custom.html rename to layouts/partials/head/custom.html diff --git a/YBlog/layouts/partials/head/head.html b/layouts/partials/head/head.html similarity index 100% rename from YBlog/layouts/partials/head/head.html rename to layouts/partials/head/head.html diff --git a/YBlog/layouts/partials/head/opengraph/include.html b/layouts/partials/head/opengraph/include.html similarity index 100% rename from YBlog/layouts/partials/head/opengraph/include.html rename to layouts/partials/head/opengraph/include.html diff --git a/YBlog/layouts/partials/head/opengraph/provider/base.html b/layouts/partials/head/opengraph/provider/base.html similarity index 100% rename from YBlog/layouts/partials/head/opengraph/provider/base.html rename to layouts/partials/head/opengraph/provider/base.html diff --git a/YBlog/layouts/partials/head/opengraph/provider/twitter.html b/layouts/partials/head/opengraph/provider/twitter.html similarity index 100% rename from YBlog/layouts/partials/head/opengraph/provider/twitter.html rename to layouts/partials/head/opengraph/provider/twitter.html diff --git a/YBlog/layouts/partials/head/script.html b/layouts/partials/head/script.html similarity index 100% rename from YBlog/layouts/partials/head/script.html rename to layouts/partials/head/script.html diff --git a/YBlog/layouts/partials/head/style.html b/layouts/partials/head/style.html similarity index 100% rename from YBlog/layouts/partials/head/style.html rename to layouts/partials/head/style.html diff --git a/YBlog/layouts/partials/helper/external.html b/layouts/partials/helper/external.html similarity index 100% rename from YBlog/layouts/partials/helper/external.html rename to layouts/partials/helper/external.html diff --git a/YBlog/layouts/partials/helper/icon.html b/layouts/partials/helper/icon.html similarity index 100% rename from YBlog/layouts/partials/helper/icon.html rename to layouts/partials/helper/icon.html diff --git a/YBlog/layouts/partials/helper/image.html b/layouts/partials/helper/image.html similarity index 100% rename from YBlog/layouts/partials/helper/image.html rename to layouts/partials/helper/image.html diff --git a/YBlog/layouts/partials/pagination.html b/layouts/partials/pagination.html similarity index 100% rename from YBlog/layouts/partials/pagination.html rename to layouts/partials/pagination.html diff --git a/YBlog/layouts/partials/sidebar/left.html b/layouts/partials/sidebar/left.html similarity index 100% rename from YBlog/layouts/partials/sidebar/left.html rename to layouts/partials/sidebar/left.html diff --git a/YBlog/layouts/partials/sidebar/right.html b/layouts/partials/sidebar/right.html similarity index 100% rename from YBlog/layouts/partials/sidebar/right.html rename to layouts/partials/sidebar/right.html diff --git a/YBlog/layouts/partials/widget/archives.html b/layouts/partials/widget/archives.html similarity index 100% rename from YBlog/layouts/partials/widget/archives.html rename to layouts/partials/widget/archives.html diff --git a/YBlog/layouts/partials/widget/categories.html b/layouts/partials/widget/categories.html similarity index 100% rename from YBlog/layouts/partials/widget/categories.html rename to layouts/partials/widget/categories.html diff --git a/YBlog/layouts/partials/widget/search.html b/layouts/partials/widget/search.html similarity index 100% rename from YBlog/layouts/partials/widget/search.html rename to layouts/partials/widget/search.html diff --git a/YBlog/layouts/partials/widget/tag-cloud.html b/layouts/partials/widget/tag-cloud.html similarity index 100% rename from YBlog/layouts/partials/widget/tag-cloud.html rename to layouts/partials/widget/tag-cloud.html diff --git a/YBlog/layouts/partials/widget/toc.html b/layouts/partials/widget/toc.html similarity index 100% rename from YBlog/layouts/partials/widget/toc.html rename to layouts/partials/widget/toc.html diff --git a/YBlog/layouts/shortcodes/bilibili.html b/layouts/shortcodes/bilibili.html similarity index 100% rename from YBlog/layouts/shortcodes/bilibili.html rename to layouts/shortcodes/bilibili.html diff --git a/YBlog/layouts/shortcodes/gitlab.html b/layouts/shortcodes/gitlab.html similarity index 100% rename from YBlog/layouts/shortcodes/gitlab.html rename to layouts/shortcodes/gitlab.html diff --git a/YBlog/layouts/shortcodes/quote.html b/layouts/shortcodes/quote.html similarity index 100% rename from YBlog/layouts/shortcodes/quote.html rename to layouts/shortcodes/quote.html diff --git a/YBlog/layouts/shortcodes/tencent.html b/layouts/shortcodes/tencent.html similarity index 100% rename from YBlog/layouts/shortcodes/tencent.html rename to layouts/shortcodes/tencent.html diff --git a/YBlog/layouts/shortcodes/video.html b/layouts/shortcodes/video.html similarity index 100% rename from YBlog/layouts/shortcodes/video.html rename to layouts/shortcodes/video.html diff --git a/YBlog/layouts/shortcodes/youtube.html b/layouts/shortcodes/youtube.html similarity index 100% rename from YBlog/layouts/shortcodes/youtube.html rename to layouts/shortcodes/youtube.html diff --git a/YBlog/resources/_gen/assets/scss/style.scss_511aa33e99371f93fbf403479ebfd32e.content b/resources/_gen/assets/scss/style.scss_511aa33e99371f93fbf403479ebfd32e.content similarity index 100% rename from YBlog/resources/_gen/assets/scss/style.scss_511aa33e99371f93fbf403479ebfd32e.content rename to resources/_gen/assets/scss/style.scss_511aa33e99371f93fbf403479ebfd32e.content diff --git a/YBlog/resources/_gen/assets/scss/style.scss_511aa33e99371f93fbf403479ebfd32e.json b/resources/_gen/assets/scss/style.scss_511aa33e99371f93fbf403479ebfd32e.json similarity index 100% rename from YBlog/resources/_gen/assets/scss/style.scss_511aa33e99371f93fbf403479ebfd32e.json rename to resources/_gen/assets/scss/style.scss_511aa33e99371f93fbf403479ebfd32e.json diff --git a/resources/_gen/assets/scss/style.scss_77b10c8e87ff110a62c52933fe3f7f11.content b/resources/_gen/assets/scss/style.scss_77b10c8e87ff110a62c52933fe3f7f11.content new file mode 100644 index 0000000..37dfd39 --- /dev/null +++ b/resources/_gen/assets/scss/style.scss_77b10c8e87ff110a62c52933fe3f7f11.content @@ -0,0 +1,10 @@ +/*!* Hugo Theme Stack +* +* @author: Jimmy Cai +* @website: https://jimmycai.com +* @link: https://github.com/CaiJimmy/hugo-theme-stack*/:root{--main-top-padding:35px;--body-background:#f5f5fa;--accent-color:#34495e;--accent-color-darker:#2c3e50;--accent-color-text:#fff;--body-text-color:#707070;--tag-border-radius:4px;--section-separation:40px;--scrollbar-thumb:hsl(0, 0%, 85%);--scrollbar-track:var(--body-background)}@media(min-width:1280px){:root{--main-top-padding:50px}}:root[data-scheme=dark]{--body-background:#303030;--accent-color:#ecf0f1;--accent-color-darker:#bdc3c7;--accent-color-text:#000;--body-text-color:rgba(255, 255, 255, 0.7);--scrollbar-thumb:hsl(0, 0%, 40%);--scrollbar-track:var(--body-background)}:root{--sys-font-family:-apple-system, BlinkMacSystemFont, "Segoe UI", "Droid Sans", "Helvetica Neue";--zh-font-family:"PingFang SC", "Hiragino Sans GB", "Droid Sans Fallback", "Microsoft YaHei";--base-font-family:"Lato", var(--sys-font-family), var(--zh-font-family), sans-serif;--code-font-family:Menlo, Monaco, Consolas, "Courier New", var(--zh-font-family), monospace}:root{--card-background:#fff;--card-background-selected:#eaeaea;--card-text-color-main:#000;--card-text-color-secondary:#747474;--card-text-color-tertiary:#767676;--card-separator-color:rgba(218, 218, 218, 0.5);--card-border-radius:10px;--card-padding:20px;--small-card-padding:25px 20px}@media(min-width:768px){:root{--card-padding:25px}}@media(min-width:1280px){:root{--card-padding:30px}}@media(min-width:768px){:root{--small-card-padding:25px}}:root[data-scheme=dark]{--card-background:#424242;--card-background-selected:rgba(255, 255, 255, 0.16);--card-text-color-main:rgba(255, 255, 255, 0.9);--card-text-color-secondary:rgba(255, 255, 255, 0.7);--card-text-color-tertiary:rgba(255, 255, 255, 0.5);--card-separator-color:rgba(255, 255, 255, 0.12)}:root{--article-font-family:var(--base-font-family);--article-font-size:1.6rem;--article-line-height:1.85}@media(min-width:768px){:root{--article-font-size:1.7rem}}:root{--blockquote-border-size:4px;--blockquote-background-color:rgb(248 248 248);--heading-border-size:4px;--link-background-color:189, 195, 199;--link-background-opacity:0.5;--link-background-opacity-hover:0.7;--pre-background-color:#272822;--pre-text-color:#f8f8f2;--code-background-color:rgba(0, 0, 0, 0.12);--code-text-color:#808080;--table-border-color:#dadada;--tr-even-background-color:#efefee;--kbd-border-color:#dadada}:root[data-scheme=dark]{--code-background-color:#272822;--code-text-color:rgba(255, 255, 255, 0.9);--table-border-color:#717171;--tr-even-background-color:#545454;--blockquote-background-color:rgb(75 75 75)}:root{--shadow-l1:0px 4px 8px rgba(0, 0, 0, 0.04), 0px 0px 2px rgba(0, 0, 0, 0.06), 0px 0px 1px rgba(0, 0, 0, 0.04);--shadow-l2:0px 10px 20px rgba(0, 0, 0, 0.04), 0px 2px 6px rgba(0, 0, 0, 0.04), 0px 0px 1px rgba(0, 0, 0, 0.04);--shadow-l3:0px 10px 20px rgba(0, 0, 0, 0.04), 0px 2px 6px rgba(0, 0, 0, 0.04), 0px 0px 1px rgba(0, 0, 0, 0.04);--shadow-l4:0px 24px 32px rgba(0, 0, 0, 0.04), 0px 16px 24px rgba(0, 0, 0, 0.04), 0px 4px 8px rgba(0, 0, 0, 0.04), + 0px 0px 1px rgba(0, 0, 0, 0.04)}[data-scheme=light]{--pre-text-color:#272822;--pre-background-color:#fafafa}[data-scheme=light] .chroma{color:#272822;background-color:#fafafa}[data-scheme=light] .chroma .err{color:#960050}[data-scheme=light] .chroma .lntd{vertical-align:top;padding:0;margin:0;border:0}[data-scheme=light] .chroma .lntable{border-spacing:0;padding:0;margin:0;border:0;width:100%;display:block}[data-scheme=light] .chroma .lntable>tbody{display:block;width:100%}[data-scheme=light] .chroma .lntable>tbody>tr{display:flex;width:100%}[data-scheme=light] .chroma .lntable>tbody>tr>td:last-child{overflow-x:auto}[data-scheme=light] .chroma .hl{display:block;width:100%;background-color:#ffc}[data-scheme=light] .chroma .lnt{margin-right:.4em;padding:0 .4em;color:#7f7f7f;display:block}[data-scheme=light] .chroma .ln{margin-right:.4em;padding:0 .4em;color:#7f7f7f}[data-scheme=light] .chroma .k{color:#00a8c8}[data-scheme=light] .chroma .kc{color:#00a8c8}[data-scheme=light] .chroma .kd{color:#00a8c8}[data-scheme=light] .chroma .kn{color:#f92672}[data-scheme=light] .chroma .kp{color:#00a8c8}[data-scheme=light] .chroma .kr{color:#00a8c8}[data-scheme=light] .chroma .kt{color:#00a8c8}[data-scheme=light] .chroma .n{color:#111}[data-scheme=light] .chroma .na{color:#75af00}[data-scheme=light] .chroma .nb{color:#111}[data-scheme=light] .chroma .bp{color:#111}[data-scheme=light] .chroma .nc{color:#75af00}[data-scheme=light] .chroma .no{color:#00a8c8}[data-scheme=light] .chroma .nd{color:#75af00}[data-scheme=light] .chroma .ni{color:#111}[data-scheme=light] .chroma .ne{color:#75af00}[data-scheme=light] .chroma .nf{color:#75af00}[data-scheme=light] .chroma .fm{color:#111}[data-scheme=light] .chroma .nl{color:#111}[data-scheme=light] .chroma .nn{color:#111}[data-scheme=light] .chroma .nx{color:#75af00}[data-scheme=light] .chroma .py{color:#111}[data-scheme=light] .chroma .nt{color:#f92672}[data-scheme=light] .chroma .nv{color:#111}[data-scheme=light] .chroma .vc{color:#111}[data-scheme=light] .chroma .vg{color:#111}[data-scheme=light] .chroma .vi{color:#111}[data-scheme=light] .chroma .vm{color:#111}[data-scheme=light] .chroma .l{color:#ae81ff}[data-scheme=light] .chroma .ld{color:#d88200}[data-scheme=light] .chroma .s{color:#d88200}[data-scheme=light] .chroma .sa{color:#d88200}[data-scheme=light] .chroma .sb{color:#d88200}[data-scheme=light] .chroma .sc{color:#d88200}[data-scheme=light] .chroma .dl{color:#d88200}[data-scheme=light] .chroma .sd{color:#d88200}[data-scheme=light] .chroma .s2{color:#d88200}[data-scheme=light] .chroma .se{color:#ae81ff}[data-scheme=light] .chroma .sh{color:#d88200}[data-scheme=light] .chroma .si{color:#d88200}[data-scheme=light] .chroma .sx{color:#d88200}[data-scheme=light] .chroma .sr{color:#d88200}[data-scheme=light] .chroma .s1{color:#d88200}[data-scheme=light] .chroma .ss{color:#d88200}[data-scheme=light] .chroma .m{color:#ae81ff}[data-scheme=light] .chroma .mb{color:#ae81ff}[data-scheme=light] .chroma .mf{color:#ae81ff}[data-scheme=light] .chroma .mh{color:#ae81ff}[data-scheme=light] .chroma .mi{color:#ae81ff}[data-scheme=light] .chroma .il{color:#ae81ff}[data-scheme=light] .chroma .mo{color:#ae81ff}[data-scheme=light] .chroma .o{color:#f92672}[data-scheme=light] .chroma .ow{color:#f92672}[data-scheme=light] .chroma .p{color:#111}[data-scheme=light] .chroma .c{color:#75715e}[data-scheme=light] .chroma .ch{color:#75715e}[data-scheme=light] .chroma .cm{color:#75715e}[data-scheme=light] .chroma .c1{color:#75715e}[data-scheme=light] .chroma .cs{color:#75715e}[data-scheme=light] .chroma .cp{color:#75715e}[data-scheme=light] .chroma .cpf{color:#75715e}[data-scheme=light] .chroma .gd{color:#f92672}[data-scheme=light] .chroma .ge{font-style:italic}[data-scheme=light] .chroma .gi{color:#75af00}[data-scheme=light] .chroma .gs{font-weight:700}[data-scheme=light] .chroma .gu{color:#75715e}[data-scheme=dark]{--pre-text-color:#f8f8f2;--pre-background-color:#272822}[data-scheme=dark] .chroma{color:#f8f8f2;background-color:#272822}[data-scheme=dark] .chroma .err{color:#bb0064}[data-scheme=dark] .chroma .lntd{vertical-align:top;padding:0;margin:0;border:0}[data-scheme=dark] .chroma .lntable{border-spacing:0;padding:0;margin:0;border:0;width:100%;display:block}[data-scheme=dark] .chroma .lntable>tbody{display:block;width:100%}[data-scheme=dark] .chroma .lntable>tbody>tr{display:flex;width:100%}[data-scheme=dark] .chroma .lntable>tbody>tr>td:last-child{overflow-x:auto}[data-scheme=dark] .chroma .hl{display:block;width:100%;background-color:#ffc}[data-scheme=dark] .chroma .lnt{margin-right:.4em;padding:0 .4em;color:#7f7f7f;display:block}[data-scheme=dark] .chroma .ln{margin-right:.4em;padding:0 .4em;color:#7f7f7f}[data-scheme=dark] .chroma .k{color:#66d9ef}[data-scheme=dark] .chroma .kc{color:#66d9ef}[data-scheme=dark] .chroma .kd{color:#66d9ef}[data-scheme=dark] .chroma .kn{color:#f92672}[data-scheme=dark] .chroma .kp{color:#66d9ef}[data-scheme=dark] .chroma .kr{color:#66d9ef}[data-scheme=dark] .chroma .kt{color:#66d9ef}[data-scheme=dark] .chroma .n{color:#f8f8f2}[data-scheme=dark] .chroma .na{color:#a6e22e}[data-scheme=dark] .chroma .nb{color:#f8f8f2}[data-scheme=dark] .chroma .bp{color:#f8f8f2}[data-scheme=dark] .chroma .nc{color:#a6e22e}[data-scheme=dark] .chroma .no{color:#66d9ef}[data-scheme=dark] .chroma .nd{color:#a6e22e}[data-scheme=dark] .chroma .ni{color:#f8f8f2}[data-scheme=dark] .chroma .ne{color:#a6e22e}[data-scheme=dark] .chroma .nf{color:#a6e22e}[data-scheme=dark] .chroma .fm{color:#f8f8f2}[data-scheme=dark] .chroma .nl{color:#f8f8f2}[data-scheme=dark] .chroma .nn{color:#f8f8f2}[data-scheme=dark] .chroma .nx{color:#a6e22e}[data-scheme=dark] .chroma .py{color:#f8f8f2}[data-scheme=dark] .chroma .nt{color:#f92672}[data-scheme=dark] .chroma .nv{color:#f8f8f2}[data-scheme=dark] .chroma .vc{color:#f8f8f2}[data-scheme=dark] .chroma .vg{color:#f8f8f2}[data-scheme=dark] .chroma .vi{color:#f8f8f2}[data-scheme=dark] .chroma .vm{color:#f8f8f2}[data-scheme=dark] .chroma .l{color:#ae81ff}[data-scheme=dark] .chroma .ld{color:#e6db74}[data-scheme=dark] .chroma .s{color:#e6db74}[data-scheme=dark] .chroma .sa{color:#e6db74}[data-scheme=dark] .chroma .sb{color:#e6db74}[data-scheme=dark] .chroma .sc{color:#e6db74}[data-scheme=dark] .chroma .dl{color:#e6db74}[data-scheme=dark] .chroma .sd{color:#e6db74}[data-scheme=dark] .chroma .s2{color:#e6db74}[data-scheme=dark] .chroma .se{color:#ae81ff}[data-scheme=dark] .chroma .sh{color:#e6db74}[data-scheme=dark] .chroma .si{color:#e6db74}[data-scheme=dark] .chroma .sx{color:#e6db74}[data-scheme=dark] .chroma .sr{color:#e6db74}[data-scheme=dark] .chroma .s1{color:#e6db74}[data-scheme=dark] .chroma .ss{color:#e6db74}[data-scheme=dark] .chroma .m{color:#ae81ff}[data-scheme=dark] .chroma .mb{color:#ae81ff}[data-scheme=dark] .chroma .mf{color:#ae81ff}[data-scheme=dark] .chroma .mh{color:#ae81ff}[data-scheme=dark] .chroma .mi{color:#ae81ff}[data-scheme=dark] .chroma .il{color:#ae81ff}[data-scheme=dark] .chroma .mo{color:#ae81ff}[data-scheme=dark] .chroma .o{color:#f92672}[data-scheme=dark] .chroma .ow{color:#f92672}[data-scheme=dark] .chroma .p{color:#f8f8f2}[data-scheme=dark] .chroma .c{color:#75715e}[data-scheme=dark] .chroma .ch{color:#75715e}[data-scheme=dark] .chroma .cm{color:#75715e}[data-scheme=dark] .chroma .c1{color:#75715e}[data-scheme=dark] .chroma .cs{color:#75715e}[data-scheme=dark] .chroma .cp{color:#75715e}[data-scheme=dark] .chroma .cpf{color:#75715e}[data-scheme=dark] .chroma .gd{color:#f92672}[data-scheme=dark] .chroma .ge{font-style:italic}[data-scheme=dark] .chroma .gi{color:#a6e22e}[data-scheme=dark] .chroma .gs{font-weight:700}[data-scheme=dark] .chroma .gu{color:#75715e}:root{--menu-icon-separation:40px;--container-padding:15px;--widget-separation:var(--section-separation)}.container{margin-left:auto;margin-right:auto}.container .left-sidebar{order:-3;max-width:var(--left-sidebar-max-width)}.container .right-sidebar{order:-1;max-width:var(--right-sidebar-max-width)}@media(min-width:1024px){.container .right-sidebar{display:flex}}@media(min-width:768px){.container.extended{max-width:1024px;--left-sidebar-max-width:25%;--right-sidebar-max-width:30%}}@media(min-width:1024px){.container.extended{max-width:1280px;--left-sidebar-max-width:20%;--right-sidebar-max-width:30%}}@media(min-width:1280px){.container.extended{max-width:1536px;--left-sidebar-max-width:15%;--right-sidebar-max-width:25%}}@media(min-width:768px){.container.compact{--left-sidebar-max-width:25%;max-width:768px}}@media(min-width:1024px){.container.compact{max-width:1024px;--left-sidebar-max-width:20%}}@media(min-width:1280px){.container.compact{max-width:1280px}}.flex{display:flex;flex-direction:row}.flex.column{flex-direction:column}.flex.on-phone--column{flex-direction:column}@media(min-width:768px){.flex.on-phone--column{flex-direction:unset}}.flex .full-width{width:100%}main.main{order:-2;min-width:0;max-width:100%;flex-grow:1;display:flex;flex-direction:column;gap:var(--section-separation)}@media(min-width:768px){main.main{padding-top:var(--main-top-padding)}}.main-container{min-height:100vh;align-items:flex-start;padding:0 15px;gap:var(--section-separation);padding-top:var(--main-top-padding)}@media(min-width:768px){.main-container{padding:0 20px}}/*!normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css*/html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}/*!* Hamburgers +* @description Tasty CSS-animated hamburgers +* @author Jonathan Suh @jonsuh +* @site https://jonsuh.com/hamburgers +* @link https://github.com/jonsuh/hamburgers*/.hamburger{padding-top:10px;display:inline-block;cursor:pointer;transition-property:opacity,filter;transition-duration:.15s;transition-timing-function:linear;font:inherit;color:inherit;text-transform:none;background-color:transparent;border:0;margin:0;overflow:visible}.hamburger:hover{opacity:.7}.hamburger.is-active:hover{opacity:.7}.hamburger.is-active .hamburger-inner,.hamburger.is-active .hamburger-inner::before,.hamburger.is-active .hamburger-inner::after{background-color:#000}.hamburger-box{width:30px;height:24px;display:inline-block;position:relative}.hamburger-inner{display:block;top:50%;margin-top:-2px}.hamburger-inner,.hamburger-inner::before,.hamburger-inner::after{width:30px;height:2px;background-color:var(--card-text-color-main);border-radius:4px;position:absolute;transition-property:transform;transition-duration:.15s;transition-timing-function:ease}.hamburger-inner::before,.hamburger-inner::after{content:"";display:block}.hamburger-inner::before{top:-10px}.hamburger-inner::after{bottom:-10px}.hamburger--spin .hamburger-inner{transition-duration:.22s;transition-timing-function:cubic-bezier(.55,.055,.675,.19)}.hamburger--spin .hamburger-inner::before{transition:top .1s .25s ease-in,opacity .1s ease-in}.hamburger--spin .hamburger-inner::after{transition:bottom .1s .25s ease-in,transform .22s cubic-bezier(.55,.055,.675,.19)}.hamburger--spin.is-active .hamburger-inner{transform:rotate(225deg);transition-delay:.12s;transition-timing-function:cubic-bezier(.215,.61,.355,1)}.hamburger--spin.is-active .hamburger-inner::before{top:0;opacity:0;transition:top .1s ease-out,opacity .1s .12s ease-out}.hamburger--spin.is-active .hamburger-inner::after{bottom:0;transform:rotate(-90deg);transition:bottom .1s ease-out,transform .22s .12s cubic-bezier(.215,.61,.355,1)}#toggle-menu{background:0 0;border:none;position:absolute;right:0;top:0;z-index:2;cursor:pointer;outline:none}[dir=rtl] #toggle-menu{left:0;right:auto}@media(min-width:768px){#toggle-menu{display:none}}#toggle-menu.is-active .hamburger-inner,#toggle-menu.is-active .hamburger-inner::before,#toggle-menu.is-active .hamburger-inner::after{background-color:var(--accent-color)}#main-menu{list-style:none;overflow-y:auto;flex-grow:1;font-size:1.4rem;background-color:var(--card-background);box-shadow:var(--shadow-l1);display:none;margin:0 calc(var(--container-padding) * -1);padding:30px}@media(min-width:1280px){#main-menu{padding:15px 0}}#main-menu,#main-menu .menu-bottom-section ol{flex-direction:column;gap:30px}@media(min-width:1280px){#main-menu,#main-menu .menu-bottom-section ol{gap:25px}}#main-menu.show{display:flex}@media(min-width:768px){#main-menu{align-items:flex-end;display:flex;background-color:transparent;padding:0;box-shadow:none;margin:0}}#main-menu li{position:relative;vertical-align:middle;padding:0}@media(min-width:768px){#main-menu li{width:100%}}#main-menu li svg{stroke:currentColor;stroke-width:1.33;width:20px;height:20px}#main-menu li a{height:100%;display:inline-flex;align-items:center;color:var(--body-text-color);gap:var(--menu-icon-separation)}#main-menu li span{flex:1}#main-menu li.current a{color:var(--accent-color);font-weight:700}#main-menu li.menu-bottom-section{margin-top:auto}#main-menu li.menu-bottom-section ol{display:flex;padding-left:0}.social-menu{list-style:none;padding:0;margin:0;display:flex;flex-direction:row;gap:10px}.social-menu svg{width:24px;height:24px;stroke:var(--body-text-color);stroke-width:1.33}.article-list{display:flex;flex-direction:column;gap:var(--section-separation)}.article-list article{display:flex;flex-direction:column;background-color:var(--card-background);box-shadow:var(--shadow-l1);border-radius:var(--card-border-radius);overflow:hidden;transition:box-shadow .3s ease}.article-list article:hover{box-shadow:var(--shadow-l2)}.article-list article .article-image img{width:100%;height:150px;object-fit:cover}@media(min-width:768px){.article-list article .article-image img{height:200px}}@media(min-width:1280px){.article-list article .article-image img{height:250px}}.article-list article:nth-child(5n+1) .article-category a{background:#8ea885;color:#fff}.article-list article:nth-child(5n+2) .article-category a{background:#df7988;color:#fff}.article-list article:nth-child(5n+3) .article-category a{background:#0177b8;color:#fff}.article-list article:nth-child(5n+4) .article-category a{background:#ffb900;color:#fff}.article-list article:nth-child(5n+5) .article-category a{background:#6b69d6;color:#fff}.article-details{display:flex;flex-direction:column;justify-content:center;padding:var(--card-padding);gap:15px}.article-title{font-family:var(--article-font-family);font-weight:600;margin:0;color:var(--card-text-color-main);font-size:2.2rem}@media(min-width:1280px){.article-title{font-size:2.4rem}}.article-title a{color:var(--card-text-color-main)}.article-title a:hover{color:var(--card-text-color-main)}.article-subtitle{font-weight:400;color:var(--card-text-color-secondary);line-height:1.5;margin:0;font-size:1.75rem}@media(min-width:1280px){.article-subtitle{font-size:2rem}}.article-title-wrapper{display:flex;flex-direction:column;gap:8px}.article-time,.article-translations{display:flex;color:var(--card-text-color-tertiary);gap:15px}.article-time svg,.article-translations svg{vertical-align:middle;width:20px;height:20px;stroke-width:1.33;flex-shrink:0}.article-time time,.article-time a,.article-translations time,.article-translations a{font-size:1.4rem;color:var(--card-text-color-tertiary)}.article-time>div,.article-translations>div{display:inline-flex;align-items:center;gap:15px}.article-time{flex-wrap:wrap}.article-translations>div{flex-wrap:wrap}.article-category,.article-tags{display:flex;gap:10px}.article-category a,.article-tags a{color:var(--accent-color-text);background-color:var(--accent-color);padding:8px 16px;border-radius:var(--tag-border-radius);display:inline-block;font-size:1.4rem;transition:background-color .5s ease}.article-category a:hover,.article-tags a:hover{color:var(--accent-color-text);background-color:var(--accent-color-darker)}.article-list--compact{border-radius:var(--card-border-radius);box-shadow:var(--shadow-l1);background-color:var(--card-background);--image-size:50px}@media(min-width:768px){.article-list--compact{--image-size:60px}}.article-list--compact article>a{display:flex;align-items:center;padding:var(--small-card-padding);gap:15px}.article-list--compact article:not(:last-of-type){border-bottom:1.5px solid var(--card-separator-color)}.article-list--compact article .article-details{flex-grow:1;padding:0;min-height:var(--image-size);gap:10px}.article-list--compact article .article-title{margin:0;font-size:1.6rem}@media(min-width:768px){.article-list--compact article .article-title{font-size:1.8rem}}.article-list--compact article .article-image img{width:var(--image-size);height:var(--image-size);object-fit:cover}.article-list--compact article .article-time{font-size:1.4rem}.article-list--compact article .article-preview{font-size:1.4rem;color:var(--card-text-color-tertiary);margin-top:10px;line-height:1.5}.article-list--tile article{border-radius:var(--card-border-radius);overflow:hidden;position:relative;height:350px;width:250px;box-shadow:var(--shadow-l1);transition:box-shadow .3s ease;background-color:var(--card-background)}.article-list--tile article:hover{box-shadow:var(--shadow-l2)}.article-list--tile article.has-image .article-details{background-color:rgba(0,0,0,.25)}.article-list--tile article.has-image .article-title{color:#fff}.article-list--tile article .article-image{position:absolute;top:0;left:0;width:100%;height:100%}.article-list--tile article .article-image img{width:100%;height:100%;object-fit:cover}.article-list--tile article .article-details{border-radius:var(--card-border-radius);position:relative;height:100%;width:100%;display:flex;flex-direction:column;justify-content:flex-end;z-index:2;padding:15px}@media(min-width:640px){.article-list--tile article .article-details{padding:20px}}.article-list--tile article .article-title{font-size:2rem;font-weight:500;color:var(--card-text-color-main)}@media(min-width:640px){.article-list--tile article .article-title{font-size:2.2rem}}.widget{display:flex;flex-direction:column}.widget .widget-icon svg{width:32px;height:32px;stroke-width:1.6;color:var(--body-text-color)}.tagCloud .tagCloud-tags{display:flex;flex-wrap:wrap;gap:10px}.tagCloud .tagCloud-tags a{background:var(--card-background);box-shadow:var(--shadow-l1);border-radius:var(--tag-border-radius);padding:8px 20px;color:var(--card-text-color-main);font-size:1.4rem;transition:box-shadow .3s ease}.tagCloud .tagCloud-tags a:hover{box-shadow:var(--shadow-l2)}.widget.archives .widget-archive--list{border-radius:var(--card-border-radius);box-shadow:var(--shadow-l1);background-color:var(--card-background)}.widget.archives .archives-year:not(:last-of-type){border-bottom:1.5px solid var(--card-separator-color)}.widget.archives .archives-year a{font-size:1.4rem;padding:18px 25px;display:flex}.widget.archives .archives-year a span.year{flex:1;color:var(--card-text-color-main);font-weight:700}.widget.archives .archives-year a span.count{color:var(--card-text-color-tertiary)}footer.site-footer{padding:20px 0 var(--section-separation);font-size:1.4rem;line-height:1.75}footer.site-footer:before{content:"";display:block;height:3px;width:50px;background:var(--body-text-color);margin-bottom:20px}footer.site-footer .copyright{color:var(--accent-color);font-weight:700;margin-bottom:5px}footer.site-footer .powerby{color:var(--body-text-color);font-weight:400;font-size:1.2rem}footer.site-footer .powerby a{color:var(--body-text-color)}.pagination{display:flex;background-color:var(--card-background);box-shadow:var(--shadow-l1);border-radius:var(--card-border-radius);overflow:hidden;flex-wrap:wrap}.pagination .page-link{padding:16px 32px;display:inline-flex;color:var(--card-text-color-secondary)}.pagination .page-link.current{font-weight:700;background-color:var(--card-background-selected);color:var(--card-text-color-main)}@media(min-width:768px){.sidebar.sticky{position:sticky}}.left-sidebar{display:flex;flex-direction:column;flex-shrink:0;align-self:stretch;gap:var(--sidebar-element-separation);max-width:none;width:100%;position:relative;--sidebar-avatar-size:100px;--sidebar-element-separation:20px;--emoji-size:40px;--emoji-font-size:20px}@media(min-width:768px){.left-sidebar{width:auto;padding-top:var(--main-top-padding);padding-bottom:var(--main-top-padding);max-height:100vh}}@media(min-width:1536px){.left-sidebar{--sidebar-avatar-size:120px;--sidebar-element-separation:25px;--emoji-size:40px}}.left-sidebar.sticky{top:0}.left-sidebar.compact{--sidebar-avatar-size:80px;--emoji-size:30px;--emoji-font-size:15px}@media(min-width:1024px){.left-sidebar.compact header{flex-direction:row}}.left-sidebar.compact header .site-meta{gap:5px}.left-sidebar.compact header .site-name{font-size:1.4rem}@media(min-width:1536px){.left-sidebar.compact header .site-name{font-size:1.75rem}}.left-sidebar.compact header .site-description{font-size:1.4rem}.right-sidebar{width:100%;display:none;flex-direction:column;gap:var(--widget-separation)}.right-sidebar.sticky{top:0}@media(min-width:1024px){.right-sidebar{padding-top:var(--main-top-padding);padding-bottom:var(--main-top-padding)}}.sidebar header{z-index:1;transition:box-shadow .5s ease;display:flex;flex-direction:column;gap:var(--sidebar-element-separation)}@media(min-width:768px){.sidebar header{padding:0}}.sidebar header .site-avatar{position:relative;margin:0;width:var(--sidebar-avatar-size);height:var(--sidebar-avatar-size);flex-shrink:0}.sidebar header .site-avatar .site-logo{width:100%;height:100%;border-radius:100%;box-shadow:var(--shadow-l1)}.sidebar header .site-avatar .emoji{position:absolute;width:var(--emoji-size);height:var(--emoji-size);line-height:var(--emoji-size);border-radius:100%;bottom:0;right:0;text-align:center;font-size:var(--emoji-font-size);background-color:var(--card-background);box-shadow:var(--shadow-l2)}.sidebar header .site-meta{display:flex;flex-direction:column;gap:10px;justify-content:center}.sidebar header .site-name{color:var(--accent-color);margin:0;font-size:1.6rem}@media(min-width:1536px){.sidebar header .site-name{font-size:1.8rem}}.sidebar header .site-description{color:var(--body-text-color);font-weight:400;margin:0;font-size:1.4rem}@media(min-width:1536px){.sidebar header .site-description{font-size:1.6rem}}[data-scheme=dark] #dark-mode-toggle{color:var(--accent-color);font-weight:700}[data-scheme=dark] #dark-mode-toggle .icon-tabler-toggle-left{display:none}[data-scheme=dark] #dark-mode-toggle .icon-tabler-toggle-right{display:unset}#dark-mode-toggle{margin-top:auto;color:var(--body-text-color);display:flex;align-items:center;cursor:pointer;gap:var(--menu-icon-separation)}#dark-mode-toggle .icon-tabler-toggle-right{display:none}#i18n-switch{color:var(--body-text-color);display:inline-flex;align-content:center;gap:var(--menu-icon-separation)}#i18n-switch select{border:0;background-color:transparent;color:var(--body-text-color)}#i18n-switch select option{color:var(--card-text-color-main);background-color:var(--card-background)}html{font-size:62.5%;overflow-y:scroll}*{box-sizing:border-box}body{background:var(--body-background);margin:0;font-family:var(--base-font-family);font-size:1.6rem;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{scrollbar-width:auto;scrollbar-color:var(--scrollbar-thumb)transparent}::-webkit-scrollbar{height:auto}::-webkit-scrollbar-thumb{background-color:var(--scrollbar-thumb)}::-webkit-scrollbar-track{background-color:transparent}.article-page.hide-sidebar-sm .left-sidebar{display:none}@media(min-width:768px){.article-page.hide-sidebar-sm .left-sidebar{display:inherit}}.article-page .main-article{background:var(--card-background);border-radius:var(--card-border-radius);box-shadow:var(--shadow-l1);overflow:hidden}.article-page .main-article .article-header .article-image img{height:auto;width:100%;max-height:50vh;object-fit:cover}.article-page .main-article .article-header .article-details{padding:var(--card-padding);padding-bottom:0}.article-page .main-article .article-content{margin:var(--card-padding)0;color:var(--card-text-color-main)}.article-page .main-article .article-content .footnotes{font-family:var(--base-font-family)}.article-page .main-article .article-content img{max-width:100%;height:auto}.article-page .main-article .article-footer{margin:var(--card-padding);margin-top:0}.article-page .main-article .article-footer section:not(:first-child){margin-top:var(--card-padding)}.article-page .main-article .article-footer section{color:var(--card-text-color-tertiary);text-transform:uppercase;display:flex;align-items:center;font-size:1.4rem;gap:15px}.article-page .main-article .article-footer section svg{width:20px;height:20px;stroke-width:1.33}.article-page .main-article .article-footer .article-tags{flex-wrap:wrap;text-transform:unset}.article-page .main-article .article-footer .article-copyright a,.article-page .main-article .article-footer .article-lastmod a{color:var(--body-text-color)}.article-page .main-article .article-footer .article-copyright a.link,.article-page .main-article .article-footer .article-lastmod a.link{box-shadow:unset}.widget--toc{background-color:var(--card-background);border-radius:var(--card-border-radius);box-shadow:var(--shadow-l1);display:flex;flex-direction:column;color:var(--card-text-color-main);overflow:hidden}.widget--toc ::-webkit-scrollbar-thumb{background-color:var(--card-separator-color)}.widget--toc #TableOfContents{overflow-x:auto;max-height:75vh}.widget--toc #TableOfContents ol,.widget--toc #TableOfContents ul{margin:0;padding:0}.widget--toc #TableOfContents ol{list-style-type:none;counter-reset:item}.widget--toc #TableOfContents ol li a:first-of-type::before{counter-increment:item;content:counters(item,".")". ";font-weight:700;margin-right:5px}.widget--toc #TableOfContents>ul{padding:0 1em}.widget--toc #TableOfContents li{margin:15px 0 15px 20px;padding:5px}.widget--toc #TableOfContents li>ol,.widget--toc #TableOfContents li>ul{margin-top:10px;padding-left:10px;margin-bottom:-5px}.widget--toc #TableOfContents li>ol>li:last-child,.widget--toc #TableOfContents li>ul>li:last-child{margin-bottom:0}.widget--toc #TableOfContents li.active-class>a{border-left:var(--heading-border-size)solid var(--accent-color);font-weight:700}.widget--toc #TableOfContents ul li.active-class>a{display:block}.widget--toc #TableOfContents>ul>li.active-class>a{margin-left:calc(-25px - 1em);padding-left:calc(25px + 1em - var(--heading-border-size))}.widget--toc #TableOfContents>ol>li.active-class>a{margin-left:calc(-9px - 1em);padding-left:calc(9px + 1em - var(--heading-border-size));display:block}.widget--toc #TableOfContents>ul>li>ul>li.active-class>a{margin-left:calc(-60px - 1em);padding-left:calc(60px + 1em - var(--heading-border-size))}.widget--toc #TableOfContents>ol>li>ol>li.active-class>a{margin-left:calc(-44px - 1em);padding-left:calc(44px + 1em - var(--heading-border-size));display:block}.widget--toc #TableOfContents>ul>li>ul>li>ul>li.active-class>a{margin-left:calc(-95px - 1em);padding-left:calc(95px + 1em - var(--heading-border-size))}.widget--toc #TableOfContents>ol>li>ol>li>ol>li.active-class>a{margin-left:calc(-79px - 1em);padding-left:calc(79px + 1em - var(--heading-border-size));display:block}.widget--toc #TableOfContents>ul>li>ul>li>ul>li>ul>li.active-class>a{margin-left:calc(-130px - 1em);padding-left:calc(130px + 1em - var(--heading-border-size))}.widget--toc #TableOfContents>ol>li>ol>li>ol>li>ol>li.active-class>a{margin-left:calc(-114px - 1em);padding-left:calc(114px + 1em - var(--heading-border-size));display:block}.widget--toc #TableOfContents>ul>li>ul>li>ul>li>ul>li>ul>li.active-class>a{margin-left:calc(-165px - 1em);padding-left:calc(165px + 1em - var(--heading-border-size))}.widget--toc #TableOfContents>ol>li>ol>li>ol>li>ol>li>ol>li.active-class>a{margin-left:calc(-149px - 1em);padding-left:calc(149px + 1em - var(--heading-border-size));display:block}.related-content{overflow-x:auto;padding-bottom:15px}.related-content>.flex{float:left}.related-content article{margin-right:15px;flex-shrink:0;overflow:hidden;width:250px;height:150px}.related-content article .article-title{font-size:1.8rem;margin:0}.related-content article.has-image .article-details{padding:20px;background:linear-gradient(0deg,rgba(0,0,0,.25) 0%,rgba(0,0,0,.75) 100%)}.article-content{font-family:var(--article-font-family);font-size:var(--article-font-size);padding:0 var(--card-padding);line-height:var(--article-line-height)}.article-content>p{margin:1.5em 0}.article-content h1,.article-content h2,.article-content h3,.article-content h4,.article-content h5,.article-content h6{margin-inline-start:calc((var(--card-padding)) * -1);padding-inline-start:calc(var(--card-padding) - var(--heading-border-size));border-inline-start:var(--heading-border-size)solid var(--accent-color)}.article-content figure{text-align:center}.article-content figure figcaption{font-size:1.4rem;color:var(--card-text-color-secondary)}.article-content blockquote{position:relative;margin:1.5em 0;border-inline-start:var(--blockquote-border-size)solid var(--card-separator-color);padding:15px calc(var(--card-padding) - var(--blockquote-border-size));background-color:var(--blockquote-background-color)}.article-content blockquote .cite{display:block;text-align:right;font-size:.75em}.article-content blockquote .cite a{text-decoration:underline}.article-content hr{width:100px;margin:40px auto;background:var(--card-text-color-tertiary);height:2px;border:0;opacity:.55}.article-content code{color:var(--code-text-color);background-color:var(--code-background-color);padding:2px 4px;border-radius:var(--tag-border-radius);font-family:var(--code-font-family)}.article-content a,.article-content code{word-break:break-word}.article-content .gallery{position:relative;display:flex;flex-direction:row;justify-content:center;margin:1.5em 0;gap:10px}.article-content .gallery figure{margin:0}.article-content pre{overflow-x:auto;display:block;background-color:var(--pre-background-color);color:var(--pre-text-color);font-family:var(--code-font-family);line-height:1.428571429;word-break:break-all;padding:var(--card-padding)}[dir=rtl] .article-content pre{direction:ltr}.article-content pre code{color:unset;border:none;background:0 0;padding:0}.article-content .highlight{background-color:var(--pre-background-color);padding:var(--card-padding);position:relative}.article-content .highlight:hover .copyCodeButton{opacity:1}[dir=rtl] .article-content .highlight{direction:ltr}.article-content .highlight pre{margin:initial;padding:0;margin:0;width:auto}.article-content .copyCodeButton{position:absolute;top:calc(var(--card-padding));right:calc(var(--card-padding));background:var(--card-background);border:none;box-shadow:var(--shadow-l2);border-radius:var(--tag-border-radius);padding:8px 16px;color:var(--card-text-color-main);cursor:pointer;font-size:14px;opacity:0;transition:opacity .3s ease}.article-content .table-wrapper{padding:0 var(--card-padding);overflow-x:auto;display:block}.article-content table{width:100%;border-collapse:collapse;border-spacing:0;margin-bottom:1.5em;font-size:.96em}.article-content th,.article-content td{text-align:left;padding:4px 8px 4px 10px;border:1px solid var(--table-border-color)}.article-content td{vertical-align:top}.article-content tr:nth-child(even){background-color:var(--tr-even-background-color)}.article-content .twitter-tweet{color:var(--card-text-color-main)}.article-content .video-wrapper{position:relative;width:100%;height:0;padding-bottom:56.25%;overflow:hidden}.article-content .video-wrapper>iframe,.article-content .video-wrapper>video{position:absolute;width:100%;height:100%;left:0;top:0;border:0}.article-content .gitlab-embed-snippets{margin:0!important}.article-content .gitlab-embed-snippets .file-holder.snippet-file-content{margin-block-end:0!important;margin-block-start:0!important;margin-left:calc((var(--card-padding)) * -1)!important;margin-right:calc((var(--card-padding)) * -1)!important;padding:0 var(--card-padding)!important}.article-content blockquote,.article-content figure,.article-content .highlight,.article-content pre,.article-content .gallery,.article-content .video-wrapper,.article-content .table-wrapper,.article-content .s_video_simple{margin-left:calc((var(--card-padding)) * -1);margin-right:calc((var(--card-padding)) * -1);width:calc(100% + var(--card-padding) * 2)}.article-content .katex-display>.katex{overflow-x:auto;overflow-y:hidden}.article-content kbd{border:1px solid var(--kbd-border-color);font-weight:700;font-size:.9em;line-height:1;padding:2px 4px;border-radius:4px;display:inline-block}.section-card{border-radius:var(--card-border-radius);background-color:var(--card-background);padding:var(--small-card-padding);box-shadow:var(--shadow-l1);display:flex;align-items:center;gap:20px;--separation:15px}.section-card .section-term{font-size:2.2rem;margin:0;color:var(--card-text-color-main)}.section-card .section-description{font-weight:400;color:var(--card-text-color-secondary);font-size:1.6rem;margin:0}.section-card .section-details{flex-grow:1;display:flex;flex-direction:column;gap:8px}.section-card .section-image img{width:60px;height:60px}.section-card .section-count{color:var(--card-text-color-tertiary);font-size:1.4rem;margin:0;font-weight:700;text-transform:uppercase}.subsection-list{overflow-x:auto}.subsection-list .article-list--tile{display:flex;padding-bottom:15px}.subsection-list .article-list--tile article{width:250px;height:150px;margin-right:20px;flex-shrink:0}.subsection-list .article-list--tile article .article-title{margin:0;font-size:1.8rem}.subsection-list .article-list--tile article .article-details{padding:20px}.not-found-card{background-color:var(--card-background);box-shadow:var(--shadow-l1);border-radius:var(--card-border-radius);padding:var(--card-padding)}.search-form{position:relative;--button-size:80px}.search-form.widget{--button-size:60px}.search-form.widget label{font-size:1.3rem;top:10px}.search-form.widget input{font-size:1.5rem;padding:30px 20px 15px}.search-form p{position:relative;margin:0}.search-form label{position:absolute;top:15px;inset-inline-start:20px;font-size:1.4rem;color:var(--card-text-color-tertiary)}.search-form input{padding:40px 20px 20px;border-radius:var(--card-border-radius);background-color:var(--card-background);box-shadow:var(--shadow-l1);color:var(--card-text-color-main);width:100%;border:0;-webkit-appearance:none;transition:box-shadow .3s ease;font-size:1.8rem}.search-form input:focus{outline:0;box-shadow:var(--shadow-l2)}.search-form button{position:absolute;inset-inline-end:0;top:0;height:100%;width:var(--button-size);cursor:pointer;background-color:transparent;border:0;padding:0 10px}.search-form button:focus{outline:0}.search-form button:focus svg{stroke-width:2;color:var(--accent-color)}.search-form button svg{color:var(--card-text-color-secondary);stroke-width:1.33;transition:all .3s ease;width:20px;height:20px}a{text-decoration:none;color:var(--accent-color)}a:hover{color:var(--accent-color-darker)}a.link{box-shadow:0 -2px rgba(var(--link-background-color),var(--link-background-opacity))inset;transition:all .3s ease}a.link:hover{box-shadow:0 calc(-1rem * var(--article-line-height))rgba(var(--link-background-color),var(--link-background-opacity-hover))inset}.section-title{text-transform:uppercase;margin-top:0;margin-bottom:10px;display:block;font-size:1.6rem;font-weight:700;color:var(--body-text-color)}.section-title a{color:var(--body-text-color)} \ No newline at end of file diff --git a/resources/_gen/assets/scss/style.scss_77b10c8e87ff110a62c52933fe3f7f11.json b/resources/_gen/assets/scss/style.scss_77b10c8e87ff110a62c52933fe3f7f11.json new file mode 100644 index 0000000..850270a --- /dev/null +++ b/resources/_gen/assets/scss/style.scss_77b10c8e87ff110a62c52933fe3f7f11.json @@ -0,0 +1 @@ +{"Target":"/scss/style.min.d8118f156935b64eca93aca758476adca858d2c47354971654d9bd2933a0e45f.css","MediaType":"text/css","Data":{"Integrity":"sha256-2BGPFWk1tk7Kk6ynWEdq3KhY0sRzVJcWVNm9KTOg5F8="}} \ No newline at end of file diff --git a/YBlog/resources/_gen/images/img/avatar_hu22c762c923636fe3e0f29f976348b4e1_4912_300x0_resize_box_3.png b/resources/_gen/images/img/avatar_hu10384529077158532367.png similarity index 100% rename from YBlog/resources/_gen/images/img/avatar_hu22c762c923636fe3e0f29f976348b4e1_4912_300x0_resize_box_3.png rename to resources/_gen/images/img/avatar_hu10384529077158532367.png diff --git a/resources/_gen/images/img/avatar_hu22c762c923636fe3e0f29f976348b4e1_4912_300x0_resize_box_3.png b/resources/_gen/images/img/avatar_hu22c762c923636fe3e0f29f976348b4e1_4912_300x0_resize_box_3.png new file mode 100644 index 0000000000000000000000000000000000000000..bb3a617a8425433de22e226ee551117db593cf50 GIT binary patch literal 5752 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 ZK+U5odh13~EKcOEn%E~M`55Z#e*k2j+N}Tp literal 0 HcmV?d00001 diff --git a/YBlog/resources/_gen/images/zh-cn/categories/test/hutomo-abrianto-l2jk-uxb1BY-unsplash_hu8102ac0a5989befdf52fa5096a373f78_52927_120x120_fill_q75_box_smart1.jpg b/resources/_gen/images/zh-cn/categories/test/hutomo-abrianto-l2jk-uxb1BY-unsplash_hu13714511474273067689.jpg similarity index 100% rename from YBlog/resources/_gen/images/zh-cn/categories/test/hutomo-abrianto-l2jk-uxb1BY-unsplash_hu8102ac0a5989befdf52fa5096a373f78_52927_120x120_fill_q75_box_smart1.jpg rename to resources/_gen/images/zh-cn/categories/test/hutomo-abrianto-l2jk-uxb1BY-unsplash_hu13714511474273067689.jpg diff --git a/resources/_gen/images/zh-cn/categories/test/hutomo-abrianto-l2jk-uxb1BY-unsplash_hu8102ac0a5989befdf52fa5096a373f78_52927_120x120_fill_q75_box_smart1.jpg b/resources/_gen/images/zh-cn/categories/test/hutomo-abrianto-l2jk-uxb1BY-unsplash_hu8102ac0a5989befdf52fa5096a373f78_52927_120x120_fill_q75_box_smart1.jpg new file mode 100644 index 0000000000000000000000000000000000000000..1c73a8ac415141ab51c199fa82b2b67570015657 GIT binary patch literal 2500 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 literal 0 HcmV?d00001 diff --git "a/YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/matt-le-SJSpo9hQf7s-unsplash_hu958d513eeefe5556a31d065479ecc5ac_14205_120x120_fill_q75_box_smart1.jpg" "b/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/matt-le-SJSpo9hQf7s-unsplash_hu958d513eeefe5556a31d065479ecc5ac_14205_120x120_fill_q75_box_smart1.jpg" similarity index 100% rename from "YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/matt-le-SJSpo9hQf7s-unsplash_hu958d513eeefe5556a31d065479ecc5ac_14205_120x120_fill_q75_box_smart1.jpg" rename to "resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/matt-le-SJSpo9hQf7s-unsplash_hu958d513eeefe5556a31d065479ecc5ac_14205_120x120_fill_q75_box_smart1.jpg" diff --git "a/YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/matt-le-SJSpo9hQf7s-unsplash_hu958d513eeefe5556a31d065479ecc5ac_14205_1600x0_resize_q75_box.jpg" "b/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/matt-le-SJSpo9hQf7s-unsplash_hu958d513eeefe5556a31d065479ecc5ac_14205_1600x0_resize_q75_box.jpg" similarity index 100% rename from "YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/matt-le-SJSpo9hQf7s-unsplash_hu958d513eeefe5556a31d065479ecc5ac_14205_1600x0_resize_q75_box.jpg" rename to "resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/matt-le-SJSpo9hQf7s-unsplash_hu958d513eeefe5556a31d065479ecc5ac_14205_1600x0_resize_q75_box.jpg" diff --git "a/YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/matt-le-SJSpo9hQf7s-unsplash_hu958d513eeefe5556a31d065479ecc5ac_14205_800x0_resize_q75_box.jpg" "b/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/matt-le-SJSpo9hQf7s-unsplash_hu958d513eeefe5556a31d065479ecc5ac_14205_800x0_resize_q75_box.jpg" similarity index 100% rename from "YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/matt-le-SJSpo9hQf7s-unsplash_hu958d513eeefe5556a31d065479ecc5ac_14205_800x0_resize_q75_box.jpg" rename to "resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/matt-le-SJSpo9hQf7s-unsplash_hu958d513eeefe5556a31d065479ecc5ac_14205_800x0_resize_q75_box.jpg" diff --git "a/YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-47_hu5dad4d9514f270d8c1798d204b1d3615_152725_120x120_fill_q75_box_smart1.jpg" "b/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-47_hu5dad4d9514f270d8c1798d204b1d3615_152725_120x120_fill_q75_box_smart1.jpg" similarity index 100% rename from "YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-47_hu5dad4d9514f270d8c1798d204b1d3615_152725_120x120_fill_q75_box_smart1.jpg" rename to "resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-47_hu5dad4d9514f270d8c1798d204b1d3615_152725_120x120_fill_q75_box_smart1.jpg" diff --git "a/YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-47_hu5dad4d9514f270d8c1798d204b1d3615_152725_1600x0_resize_q75_box.jpg" "b/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-47_hu5dad4d9514f270d8c1798d204b1d3615_152725_1600x0_resize_q75_box.jpg" similarity index 100% rename from "YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-47_hu5dad4d9514f270d8c1798d204b1d3615_152725_1600x0_resize_q75_box.jpg" rename to "resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-47_hu5dad4d9514f270d8c1798d204b1d3615_152725_1600x0_resize_q75_box.jpg" diff --git "a/YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-47_hu5dad4d9514f270d8c1798d204b1d3615_152725_800x0_resize_q75_box.jpg" "b/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-47_hu5dad4d9514f270d8c1798d204b1d3615_152725_800x0_resize_q75_box.jpg" similarity index 100% rename from "YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-47_hu5dad4d9514f270d8c1798d204b1d3615_152725_800x0_resize_q75_box.jpg" rename to "resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-47_hu5dad4d9514f270d8c1798d204b1d3615_152725_800x0_resize_q75_box.jpg" diff --git "a/YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_120x120_fill_q75_box_smart1.jpg" "b/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_120x120_fill_q75_box_smart1.jpg" similarity index 100% rename from "YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_120x120_fill_q75_box_smart1.jpg" rename to "resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_120x120_fill_q75_box_smart1.jpg" diff --git "a/YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_1600x0_resize_q75_box.jpg" "b/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_1600x0_resize_q75_box.jpg" similarity index 100% rename from "YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_1600x0_resize_q75_box.jpg" rename to "resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_1600x0_resize_q75_box.jpg" diff --git "a/YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_800x0_resize_q75_box.jpg" "b/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_800x0_resize_q75_box.jpg" similarity index 100% rename from "YBlog/resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_800x0_resize_q75_box.jpg" rename to "resources/_gen/images/zh-cn/p/cs\345\255\246\344\271\240\350\256\241\345\210\222/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_800x0_resize_q75_box.jpg" diff --git "a/YBlog/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/pexels-andreea-ch-1166643_hu5459c0360c2b0cb7a147d2df0eb350ca_602824_120x120_fill_q75_box_smart1.jpg" "b/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/pexels-andreea-ch-1166643_hu5459c0360c2b0cb7a147d2df0eb350ca_602824_120x120_fill_q75_box_smart1.jpg" similarity index 100% rename from "YBlog/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/pexels-andreea-ch-1166643_hu5459c0360c2b0cb7a147d2df0eb350ca_602824_120x120_fill_q75_box_smart1.jpg" rename to "resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/pexels-andreea-ch-1166643_hu5459c0360c2b0cb7a147d2df0eb350ca_602824_120x120_fill_q75_box_smart1.jpg" diff --git "a/YBlog/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/pexels-andreea-ch-1166643_hu5459c0360c2b0cb7a147d2df0eb350ca_602824_1600x0_resize_q75_box.jpg" "b/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/pexels-andreea-ch-1166643_hu5459c0360c2b0cb7a147d2df0eb350ca_602824_1600x0_resize_q75_box.jpg" similarity index 100% rename from "YBlog/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/pexels-andreea-ch-1166643_hu5459c0360c2b0cb7a147d2df0eb350ca_602824_1600x0_resize_q75_box.jpg" rename to "resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/pexels-andreea-ch-1166643_hu5459c0360c2b0cb7a147d2df0eb350ca_602824_1600x0_resize_q75_box.jpg" diff --git "a/YBlog/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/pexels-andreea-ch-1166643_hu5459c0360c2b0cb7a147d2df0eb350ca_602824_800x0_resize_q75_box.jpg" "b/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/pexels-andreea-ch-1166643_hu5459c0360c2b0cb7a147d2df0eb350ca_602824_800x0_resize_q75_box.jpg" similarity index 100% rename from "YBlog/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/pexels-andreea-ch-1166643_hu5459c0360c2b0cb7a147d2df0eb350ca_602824_800x0_resize_q75_box.jpg" rename to "resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/pexels-andreea-ch-1166643_hu5459c0360c2b0cb7a147d2df0eb350ca_602824_800x0_resize_q75_box.jpg" diff --git "a/YBlog/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_120x120_fill_q75_box_smart1.jpg" "b/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_120x120_fill_q75_box_smart1.jpg" similarity index 100% rename from "YBlog/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_120x120_fill_q75_box_smart1.jpg" rename to "resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_120x120_fill_q75_box_smart1.jpg" diff --git "a/YBlog/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_1600x0_resize_q75_box.jpg" "b/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_1600x0_resize_q75_box.jpg" similarity index 100% rename from "YBlog/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_1600x0_resize_q75_box.jpg" rename to "resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_1600x0_resize_q75_box.jpg" diff --git "a/YBlog/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_800x0_resize_q75_box.jpg" "b/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_800x0_resize_q75_box.jpg" similarity index 100% rename from "YBlog/resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_800x0_resize_q75_box.jpg" rename to "resources/_gen/images/zh-cn/p/\345\215\232\345\256\242\346\220\255\345\273\272\346\233\264\346\226\260\346\227\245\350\256\260/photo_2024-04-08_20-31-53_hud03833d022cc8116a82b7d9cf733c7cb_138328_800x0_resize_q75_box.jpg" diff --git a/YBlog/static/favicon.ico b/static/favicon.ico similarity index 100% rename from YBlog/static/favicon.ico rename to static/favicon.ico diff --git a/themes/hugo-theme-stack/.devcontainer/Dockerfile b/themes/hugo-theme-stack/.devcontainer/Dockerfile new file mode 100644 index 0000000..b601136 --- /dev/null +++ b/themes/hugo-theme-stack/.devcontainer/Dockerfile @@ -0,0 +1,31 @@ +# Update the NODE_VERSION arg in docker-compose.yml to pick a Node version: 10, 12, 14 +ARG NODE_VERSION=14 +FROM mcr.microsoft.com/vscode/devcontainers/javascript-node:0-${NODE_VERSION} + +# VARIANT can be either 'hugo' for the standard version or 'hugo_extended' for the extended version. +ARG VARIANT=hugo +# VERSION can be either 'latest' or a specific version number +ARG VERSION=latest + +# Download Hugo +RUN apt-get update && apt-get install -y ca-certificates openssl git curl && \ + rm -rf /var/lib/apt/lists/* && \ + case ${VERSION} in \ + latest) \ + export VERSION=$(curl -s https://api.github.com/repos/gohugoio/hugo/releases/latest | grep "tag_name" | awk '{print substr($2, 3, length($2)-4)}') ;;\ + esac && \ + echo ${VERSION} && \ + wget -O ${VERSION}.tar.gz https://github.com/gohugoio/hugo/releases/download/v${VERSION}/${VARIANT}_${VERSION}_Linux-64bit.tar.gz && \ + tar xf ${VERSION}.tar.gz && \ + mv hugo /usr/bin/hugo + +# Hugo dev server port +EXPOSE 1313 + +# [Optional] Uncomment this section to install additional OS packages you may want. +# +# RUN apt-get update && export DEBIAN_FRONTEND=noninteractive \ +# && apt-get -y install --no-install-recommends + +# [Optional] Uncomment if you want to install more global node packages +# RUN sudo -u node npm install -g diff --git a/themes/hugo-theme-stack/.devcontainer/devcontainer.json b/themes/hugo-theme-stack/.devcontainer/devcontainer.json new file mode 100644 index 0000000..4bf8a19 --- /dev/null +++ b/themes/hugo-theme-stack/.devcontainer/devcontainer.json @@ -0,0 +1,45 @@ +// For format details, see https://aka.ms/devcontainer.json. For config options, see the README at: +// https://github.com/microsoft/vscode-dev-containers/tree/v0.202.3/containers/hugo +{ + "name": "Hugo (Community)", + "build": { + "dockerfile": "Dockerfile", + "args": { + // Update VARIANT to pick hugo variant. + // Example variants: hugo, hugo_extended + // Rebuild the container if it already exists to update. + "VARIANT": "hugo_extended", + // Update VERSION to pick a specific hugo version. + // Example versions: latest, 0.73.0, 0,71.1 + // Rebuild the container if it already exists to update. + "VERSION": "latest", + // Update NODE_VERSION to pick the Node.js version: 12, 14 + "NODE_VERSION": "14", + } + }, + + // Set *default* container specific settings.json values on container create. + "settings": { + "html.format.templating": true, + }, + + // Add the IDs of extensions you want installed when the container is created. + "extensions": [ + "bungcip.better-toml", + "davidanson.vscode-markdownlint" + ], + + // Use 'forwardPorts' to make a list of ports inside the container available locally. + "forwardPorts": [ + 1313 + ], + + // Use 'postCreateCommand' to run commands after the container is created. + // "postCreateCommand": "uname -a", + + // Comment out connect as root instead. More info: https://aka.ms/vscode-remote/containers/non-root. + "remoteUser": "node", + "features": { + "golang": "latest" + } +} diff --git a/themes/hugo-theme-stack/.github/FUNDING.yml b/themes/hugo-theme-stack/.github/FUNDING.yml new file mode 100644 index 0000000..95f0c18 --- /dev/null +++ b/themes/hugo-theme-stack/.github/FUNDING.yml @@ -0,0 +1,2 @@ +ko_fi: jimmycai +github: CaiJimmy diff --git a/themes/hugo-theme-stack/.github/ISSUE_TEMPLATE/bug_report.yml b/themes/hugo-theme-stack/.github/ISSUE_TEMPLATE/bug_report.yml new file mode 100644 index 0000000..81f8833 --- /dev/null +++ b/themes/hugo-theme-stack/.github/ISSUE_TEMPLATE/bug_report.yml @@ -0,0 +1,65 @@ +name: Bug Report +description: File a bug report +body: + - type: markdown + attributes: + value: | + Thanks for taking the time to fill out this bug report! Please provide as much information as possible and make sure you have checked the [documentation](https://stack.jimmycai.com/guide/). + - type: textarea + id: what-happened + attributes: + label: What happened? + description: Also tell us, what did you expect to happen? Please be as detailed as possible, including screenshots and any other information that might help us reproduce the problem. + placeholder: Tell us what you see! + validations: + required: true + - type: input + id: hugo-version + attributes: + label: Hugo version + description: "What is the version of Hugo you are using? (Note: this theme does not support non-extended version of Hugo)" + placeholder: ex. 0.100.0 + validations: + required: true + - type: input + id: theme-version + attributes: + label: Theme version + description: "What is the version of Stack theme you are using?" + placeholder: ex. 3.12.0 + validations: + required: true + - type: dropdown + id: browsers + attributes: + label: What browsers are you seeing the problem on? + multiple: true + options: + - Firefox + - Chrome + - Safari + - Microsoft Edge + - type: input + id: browser-info + attributes: + label: More information about the browser + description: "E.g: Browser version, OS version, etc." + placeholder: ex. Chrome 104, Windows 11 + validations: + required: false + - type: textarea + id: logs + attributes: + label: Relevant log output + description: Please copy and paste any relevant log output. This will be automatically formatted into code, so no need for backticks. + render: shell + - type: input + id: minimal-reproduction-url + attributes: + label: Link to Minimal Reproducible Example + description: | + Use [CaiJimmy/hugo-theme-stack-starter](https://github.com/CaiJimmy/hugo-theme-stack-starter) to create a minimal reproduction of the problem. + A minimal reproduction is required so that others can help debug your issue. If a report is vague (e.g. just a generic error message) and has no reproduction, it may be auto-closed. + placeholder: https://github.com/username/your-repository + validations: + required: true diff --git a/themes/hugo-theme-stack/.github/ISSUE_TEMPLATE/config.yml b/themes/hugo-theme-stack/.github/ISSUE_TEMPLATE/config.yml new file mode 100644 index 0000000..f120c04 --- /dev/null +++ b/themes/hugo-theme-stack/.github/ISSUE_TEMPLATE/config.yml @@ -0,0 +1,5 @@ +blank_issues_enabled: false +contact_links: + - name: Discussions + url: https://github.com/CaiJimmy/hugo-theme-stack/discussions + about: Please ask and answer questions here. diff --git a/themes/hugo-theme-stack/.gitignore b/themes/hugo-theme-stack/.gitignore new file mode 100644 index 0000000..9ff142d --- /dev/null +++ b/themes/hugo-theme-stack/.gitignore @@ -0,0 +1,4 @@ +public +resources +assets/jsconfig.json +.hugo_build.lock \ No newline at end of file diff --git a/themes/hugo-theme-stack/LICENSE b/themes/hugo-theme-stack/LICENSE new file mode 100644 index 0000000..e72bfdd --- /dev/null +++ b/themes/hugo-theme-stack/LICENSE @@ -0,0 +1,674 @@ + GNU GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The GNU General Public License is a free, copyleft license for +software and other kinds of works. + + The licenses for most software and other practical works are designed +to take away your freedom to share and change the works. By contrast, +the GNU General Public License is intended to guarantee your freedom to +share and change all versions of a program--to make sure it remains free +software for all its users. We, the Free Software Foundation, use the +GNU General Public License for most of our software; it applies also to +any other work released this way by its authors. You can apply it to +your programs, too. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +them if you wish), that you receive source code or can get it if you +want it, that you can change the software or use pieces of it in new +free programs, and that you know you can do these things. + + To protect your rights, we need to prevent others from denying you +these rights or asking you to surrender the rights. Therefore, you have +certain responsibilities if you distribute copies of the software, or if +you modify it: responsibilities to respect the freedom of others. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must pass on to the recipients the same +freedoms that you received. You must make sure that they, too, receive +or can get the source code. And you must show them these terms so they +know their rights. + + Developers that use the GNU GPL protect your rights with two steps: +(1) assert copyright on the software, and (2) offer you this License +giving you legal permission to copy, distribute and/or modify it. + + For the developers' and authors' protection, the GPL clearly explains +that there is no warranty for this free software. For both users' and +authors' sake, the GPL requires that modified versions be marked as +changed, so that their problems will not be attributed erroneously to +authors of previous versions. + + Some devices are designed to deny users access to install or run +modified versions of the software inside them, although the manufacturer +can do so. This is fundamentally incompatible with the aim of +protecting users' freedom to change the software. The systematic +pattern of such abuse occurs in the area of products for individuals to +use, which is precisely where it is most unacceptable. Therefore, we +have designed this version of the GPL to prohibit the practice for those +products. If such problems arise substantially in other domains, we +stand ready to extend this provision to those domains in future versions +of the GPL, as needed to protect the freedom of users. + + Finally, every program is threatened constantly by software patents. +States should not allow patents to restrict development and use of +software on general-purpose computers, but in those that do, we wish to +avoid the special danger that patents applied to a free program could +make it effectively proprietary. To prevent this, the GPL assures that +patents cannot be used to render the program non-free. + + The precise terms and conditions for copying, distribution and +modification follow. + + TERMS AND CONDITIONS + + 0. Definitions. + + "This License" refers to version 3 of the GNU General Public License. + + "Copyright" also means copyright-like laws that apply to other kinds of +works, such as semiconductor masks. + + "The Program" refers to any copyrightable work licensed under this +License. Each licensee is addressed as "you". "Licensees" and +"recipients" may be individuals or organizations. + + To "modify" a work means to copy from or adapt all or part of the work +in a fashion requiring copyright permission, other than the making of an +exact copy. The resulting work is called a "modified version" of the +earlier work or a work "based on" the earlier work. + + A "covered work" means either the unmodified Program or a work based +on the Program. + + To "propagate" a work means to do anything with it that, without +permission, would make you directly or secondarily liable for +infringement under applicable copyright law, except executing it on a +computer or modifying a private copy. Propagation includes copying, +distribution (with or without modification), making available to the +public, and in some countries other activities as well. + + To "convey" a work means any kind of propagation that enables other +parties to make or receive copies. Mere interaction with a user through +a computer network, with no transfer of a copy, is not conveying. + + An interactive user interface displays "Appropriate Legal Notices" +to the extent that it includes a convenient and prominently visible +feature that (1) displays an appropriate copyright notice, and (2) +tells the user that there is no warranty for the work (except to the +extent that warranties are provided), that licensees may convey the +work under this License, and how to view a copy of this License. If +the interface presents a list of user commands or options, such as a +menu, a prominent item in the list meets this criterion. + + 1. Source Code. + + The "source code" for a work means the preferred form of the work +for making modifications to it. "Object code" means any non-source +form of a work. + + A "Standard Interface" means an interface that either is an official +standard defined by a recognized standards body, or, in the case of +interfaces specified for a particular programming language, one that +is widely used among developers working in that language. + + The "System Libraries" of an executable work include anything, other +than the work as a whole, that (a) is included in the normal form of +packaging a Major Component, but which is not part of that Major +Component, and (b) serves only to enable use of the work with that +Major Component, or to implement a Standard Interface for which an +implementation is available to the public in source code form. A +"Major Component", in this context, means a major essential component +(kernel, window system, and so on) of the specific operating system +(if any) on which the executable work runs, or a compiler used to +produce the work, or an object code interpreter used to run it. + + The "Corresponding Source" for a work in object code form means all +the source code needed to generate, install, and (for an executable +work) run the object code and to modify the work, including scripts to +control those activities. However, it does not include the work's +System Libraries, or general-purpose tools or generally available free +programs which are used unmodified in performing those activities but +which are not part of the work. For example, Corresponding Source +includes interface definition files associated with source files for +the work, and the source code for shared libraries and dynamically +linked subprograms that the work is specifically designed to require, +such as by intimate data communication or control flow between those +subprograms and other parts of the work. + + The Corresponding Source need not include anything that users +can regenerate automatically from other parts of the Corresponding +Source. + + The Corresponding Source for a work in source code form is that +same work. + + 2. Basic Permissions. + + All rights granted under this License are granted for the term of +copyright on the Program, and are irrevocable provided the stated +conditions are met. This License explicitly affirms your unlimited +permission to run the unmodified Program. The output from running a +covered work is covered by this License only if the output, given its +content, constitutes a covered work. This License acknowledges your +rights of fair use or other equivalent, as provided by copyright law. + + You may make, run and propagate covered works that you do not +convey, without conditions so long as your license otherwise remains +in force. You may convey covered works to others for the sole purpose +of having them make modifications exclusively for you, or provide you +with facilities for running those works, provided that you comply with +the terms of this License in conveying all material for which you do +not control copyright. Those thus making or running the covered works +for you must do so exclusively on your behalf, under your direction +and control, on terms that prohibit them from making any copies of +your copyrighted material outside their relationship with you. + + Conveying under any other circumstances is permitted solely under +the conditions stated below. Sublicensing is not allowed; section 10 +makes it unnecessary. + + 3. Protecting Users' Legal Rights From Anti-Circumvention Law. + + No covered work shall be deemed part of an effective technological +measure under any applicable law fulfilling obligations under article +11 of the WIPO copyright treaty adopted on 20 December 1996, or +similar laws prohibiting or restricting circumvention of such +measures. + + When you convey a covered work, you waive any legal power to forbid +circumvention of technological measures to the extent such circumvention +is effected by exercising rights under this License with respect to +the covered work, and you disclaim any intention to limit operation or +modification of the work as a means of enforcing, against the work's +users, your or third parties' legal rights to forbid circumvention of +technological measures. + + 4. Conveying Verbatim Copies. + + You may convey verbatim copies of the Program's source code as you +receive it, in any medium, provided that you conspicuously and +appropriately publish on each copy an appropriate copyright notice; +keep intact all notices stating that this License and any +non-permissive terms added in accord with section 7 apply to the code; +keep intact all notices of the absence of any warranty; and give all +recipients a copy of this License along with the Program. + + You may charge any price or no price for each copy that you convey, +and you may offer support or warranty protection for a fee. + + 5. Conveying Modified Source Versions. + + You may convey a work based on the Program, or the modifications to +produce it from the Program, in the form of source code under the +terms of section 4, provided that you also meet all of these conditions: + + a) The work must carry prominent notices stating that you modified + it, and giving a relevant date. + + b) The work must carry prominent notices stating that it is + released under this License and any conditions added under section + 7. This requirement modifies the requirement in section 4 to + "keep intact all notices". + + c) You must license the entire work, as a whole, under this + License to anyone who comes into possession of a copy. This + License will therefore apply, along with any applicable section 7 + additional terms, to the whole of the work, and all its parts, + regardless of how they are packaged. This License gives no + permission to license the work in any other way, but it does not + invalidate such permission if you have separately received it. + + d) If the work has interactive user interfaces, each must display + Appropriate Legal Notices; however, if the Program has interactive + interfaces that do not display Appropriate Legal Notices, your + work need not make them do so. + + A compilation of a covered work with other separate and independent +works, which are not by their nature extensions of the covered work, +and which are not combined with it such as to form a larger program, +in or on a volume of a storage or distribution medium, is called an +"aggregate" if the compilation and its resulting copyright are not +used to limit the access or legal rights of the compilation's users +beyond what the individual works permit. Inclusion of a covered work +in an aggregate does not cause this License to apply to the other +parts of the aggregate. + + 6. Conveying Non-Source Forms. + + You may convey a covered work in object code form under the terms +of sections 4 and 5, provided that you also convey the +machine-readable Corresponding Source under the terms of this License, +in one of these ways: + + a) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by the + Corresponding Source fixed on a durable physical medium + customarily used for software interchange. + + b) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by a + written offer, valid for at least three years and valid for as + long as you offer spare parts or customer support for that product + model, to give anyone who possesses the object code either (1) a + copy of the Corresponding Source for all the software in the + product that is covered by this License, on a durable physical + medium customarily used for software interchange, for a price no + more than your reasonable cost of physically performing this + conveying of source, or (2) access to copy the + Corresponding Source from a network server at no charge. + + c) Convey individual copies of the object code with a copy of the + written offer to provide the Corresponding Source. This + alternative is allowed only occasionally and noncommercially, and + only if you received the object code with such an offer, in accord + with subsection 6b. + + d) Convey the object code by offering access from a designated + place (gratis or for a charge), and offer equivalent access to the + Corresponding Source in the same way through the same place at no + further charge. You need not require recipients to copy the + Corresponding Source along with the object code. If the place to + copy the object code is a network server, the Corresponding Source + may be on a different server (operated by you or a third party) + that supports equivalent copying facilities, provided you maintain + clear directions next to the object code saying where to find the + Corresponding Source. Regardless of what server hosts the + Corresponding Source, you remain obligated to ensure that it is + available for as long as needed to satisfy these requirements. + + e) Convey the object code using peer-to-peer transmission, provided + you inform other peers where the object code and Corresponding + Source of the work are being offered to the general public at no + charge under subsection 6d. + + A separable portion of the object code, whose source code is excluded +from the Corresponding Source as a System Library, need not be +included in conveying the object code work. + + A "User Product" is either (1) a "consumer product", which means any +tangible personal property which is normally used for personal, family, +or household purposes, or (2) anything designed or sold for incorporation +into a dwelling. In determining whether a product is a consumer product, +doubtful cases shall be resolved in favor of coverage. For a particular +product received by a particular user, "normally used" refers to a +typical or common use of that class of product, regardless of the status +of the particular user or of the way in which the particular user +actually uses, or expects or is expected to use, the product. A product +is a consumer product regardless of whether the product has substantial +commercial, industrial or non-consumer uses, unless such uses represent +the only significant mode of use of the product. + + "Installation Information" for a User Product means any methods, +procedures, authorization keys, or other information required to install +and execute modified versions of a covered work in that User Product from +a modified version of its Corresponding Source. The information must +suffice to ensure that the continued functioning of the modified object +code is in no case prevented or interfered with solely because +modification has been made. + + If you convey an object code work under this section in, or with, or +specifically for use in, a User Product, and the conveying occurs as +part of a transaction in which the right of possession and use of the +User Product is transferred to the recipient in perpetuity or for a +fixed term (regardless of how the transaction is characterized), the +Corresponding Source conveyed under this section must be accompanied +by the Installation Information. But this requirement does not apply +if neither you nor any third party retains the ability to install +modified object code on the User Product (for example, the work has +been installed in ROM). + + The requirement to provide Installation Information does not include a +requirement to continue to provide support service, warranty, or updates +for a work that has been modified or installed by the recipient, or for +the User Product in which it has been modified or installed. Access to a +network may be denied when the modification itself materially and +adversely affects the operation of the network or violates the rules and +protocols for communication across the network. + + Corresponding Source conveyed, and Installation Information provided, +in accord with this section must be in a format that is publicly +documented (and with an implementation available to the public in +source code form), and must require no special password or key for +unpacking, reading or copying. + + 7. Additional Terms. + + "Additional permissions" are terms that supplement the terms of this +License by making exceptions from one or more of its conditions. +Additional permissions that are applicable to the entire Program shall +be treated as though they were included in this License, to the extent +that they are valid under applicable law. If additional permissions +apply only to part of the Program, that part may be used separately +under those permissions, but the entire Program remains governed by +this License without regard to the additional permissions. + + When you convey a copy of a covered work, you may at your option +remove any additional permissions from that copy, or from any part of +it. (Additional permissions may be written to require their own +removal in certain cases when you modify the work.) You may place +additional permissions on material, added by you to a covered work, +for which you have or can give appropriate copyright permission. + + Notwithstanding any other provision of this License, for material you +add to a covered work, you may (if authorized by the copyright holders of +that material) supplement the terms of this License with terms: + + a) Disclaiming warranty or limiting liability differently from the + terms of sections 15 and 16 of this License; or + + b) Requiring preservation of specified reasonable legal notices or + author attributions in that material or in the Appropriate Legal + Notices displayed by works containing it; or + + c) Prohibiting misrepresentation of the origin of that material, or + requiring that modified versions of such material be marked in + reasonable ways as different from the original version; or + + d) Limiting the use for publicity purposes of names of licensors or + authors of the material; or + + e) Declining to grant rights under trademark law for use of some + trade names, trademarks, or service marks; or + + f) Requiring indemnification of licensors and authors of that + material by anyone who conveys the material (or modified versions of + it) with contractual assumptions of liability to the recipient, for + any liability that these contractual assumptions directly impose on + those licensors and authors. + + All other non-permissive additional terms are considered "further +restrictions" within the meaning of section 10. If the Program as you +received it, or any part of it, contains a notice stating that it is +governed by this License along with a term that is a further +restriction, you may remove that term. If a license document contains +a further restriction but permits relicensing or conveying under this +License, you may add to a covered work material governed by the terms +of that license document, provided that the further restriction does +not survive such relicensing or conveying. + + If you add terms to a covered work in accord with this section, you +must place, in the relevant source files, a statement of the +additional terms that apply to those files, or a notice indicating +where to find the applicable terms. + + Additional terms, permissive or non-permissive, may be stated in the +form of a separately written license, or stated as exceptions; +the above requirements apply either way. + + 8. Termination. + + You may not propagate or modify a covered work except as expressly +provided under this License. Any attempt otherwise to propagate or +modify it is void, and will automatically terminate your rights under +this License (including any patent licenses granted under the third +paragraph of section 11). + + However, if you cease all violation of this License, then your +license from a particular copyright holder is reinstated (a) +provisionally, unless and until the copyright holder explicitly and +finally terminates your license, and (b) permanently, if the copyright +holder fails to notify you of the violation by some reasonable means +prior to 60 days after the cessation. + + Moreover, your license from a particular copyright holder is +reinstated permanently if the copyright holder notifies you of the +violation by some reasonable means, this is the first time you have +received notice of violation of this License (for any work) from that +copyright holder, and you cure the violation prior to 30 days after +your receipt of the notice. + + Termination of your rights under this section does not terminate the +licenses of parties who have received copies or rights from you under +this License. If your rights have been terminated and not permanently +reinstated, you do not qualify to receive new licenses for the same +material under section 10. + + 9. Acceptance Not Required for Having Copies. + + You are not required to accept this License in order to receive or +run a copy of the Program. Ancillary propagation of a covered work +occurring solely as a consequence of using peer-to-peer transmission +to receive a copy likewise does not require acceptance. However, +nothing other than this License grants you permission to propagate or +modify any covered work. These actions infringe copyright if you do +not accept this License. Therefore, by modifying or propagating a +covered work, you indicate your acceptance of this License to do so. + + 10. Automatic Licensing of Downstream Recipients. + + Each time you convey a covered work, the recipient automatically +receives a license from the original licensors, to run, modify and +propagate that work, subject to this License. You are not responsible +for enforcing compliance by third parties with this License. + + An "entity transaction" is a transaction transferring control of an +organization, or substantially all assets of one, or subdividing an +organization, or merging organizations. If propagation of a covered +work results from an entity transaction, each party to that +transaction who receives a copy of the work also receives whatever +licenses to the work the party's predecessor in interest had or could +give under the previous paragraph, plus a right to possession of the +Corresponding Source of the work from the predecessor in interest, if +the predecessor has it or can get it with reasonable efforts. + + You may not impose any further restrictions on the exercise of the +rights granted or affirmed under this License. For example, you may +not impose a license fee, royalty, or other charge for exercise of +rights granted under this License, and you may not initiate litigation +(including a cross-claim or counterclaim in a lawsuit) alleging that +any patent claim is infringed by making, using, selling, offering for +sale, or importing the Program or any portion of it. + + 11. Patents. + + A "contributor" is a copyright holder who authorizes use under this +License of the Program or a work on which the Program is based. The +work thus licensed is called the contributor's "contributor version". + + A contributor's "essential patent claims" are all patent claims +owned or controlled by the contributor, whether already acquired or +hereafter acquired, that would be infringed by some manner, permitted +by this License, of making, using, or selling its contributor version, +but do not include claims that would be infringed only as a +consequence of further modification of the contributor version. For +purposes of this definition, "control" includes the right to grant +patent sublicenses in a manner consistent with the requirements of +this License. + + Each contributor grants you a non-exclusive, worldwide, royalty-free +patent license under the contributor's essential patent claims, to +make, use, sell, offer for sale, import and otherwise run, modify and +propagate the contents of its contributor version. + + In the following three paragraphs, a "patent license" is any express +agreement or commitment, however denominated, not to enforce a patent +(such as an express permission to practice a patent or covenant not to +sue for patent infringement). To "grant" such a patent license to a +party means to make such an agreement or commitment not to enforce a +patent against the party. + + If you convey a covered work, knowingly relying on a patent license, +and the Corresponding Source of the work is not available for anyone +to copy, free of charge and under the terms of this License, through a +publicly available network server or other readily accessible means, +then you must either (1) cause the Corresponding Source to be so +available, or (2) arrange to deprive yourself of the benefit of the +patent license for this particular work, or (3) arrange, in a manner +consistent with the requirements of this License, to extend the patent +license to downstream recipients. "Knowingly relying" means you have +actual knowledge that, but for the patent license, your conveying the +covered work in a country, or your recipient's use of the covered work +in a country, would infringe one or more identifiable patents in that +country that you have reason to believe are valid. + + If, pursuant to or in connection with a single transaction or +arrangement, you convey, or propagate by procuring conveyance of, a +covered work, and grant a patent license to some of the parties +receiving the covered work authorizing them to use, propagate, modify +or convey a specific copy of the covered work, then the patent license +you grant is automatically extended to all recipients of the covered +work and works based on it. + + A patent license is "discriminatory" if it does not include within +the scope of its coverage, prohibits the exercise of, or is +conditioned on the non-exercise of one or more of the rights that are +specifically granted under this License. You may not convey a covered +work if you are a party to an arrangement with a third party that is +in the business of distributing software, under which you make payment +to the third party based on the extent of your activity of conveying +the work, and under which the third party grants, to any of the +parties who would receive the covered work from you, a discriminatory +patent license (a) in connection with copies of the covered work +conveyed by you (or copies made from those copies), or (b) primarily +for and in connection with specific products or compilations that +contain the covered work, unless you entered into that arrangement, +or that patent license was granted, prior to 28 March 2007. + + Nothing in this License shall be construed as excluding or limiting +any implied license or other defenses to infringement that may +otherwise be available to you under applicable patent law. + + 12. No Surrender of Others' Freedom. + + If conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot convey a +covered work so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you may +not convey it at all. For example, if you agree to terms that obligate you +to collect a royalty for further conveying from those to whom you convey +the Program, the only way you could satisfy both those terms and this +License would be to refrain entirely from conveying the Program. + + 13. Use with the GNU Affero General Public License. + + Notwithstanding any other provision of this License, you have +permission to link or combine any covered work with a work licensed +under version 3 of the GNU Affero General Public License into a single +combined work, and to convey the resulting work. The terms of this +License will continue to apply to the part which is the covered work, +but the special requirements of the GNU Affero General Public License, +section 13, concerning interaction through a network will apply to the +combination as such. + + 14. Revised Versions of this License. + + The Free Software Foundation may publish revised and/or new versions of +the GNU General Public License from time to time. Such new versions will +be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + + Each version is given a distinguishing version number. If the +Program specifies that a certain numbered version of the GNU General +Public License "or any later version" applies to it, you have the +option of following the terms and conditions either of that numbered +version or of any later version published by the Free Software +Foundation. If the Program does not specify a version number of the +GNU General Public License, you may choose any version ever published +by the Free Software Foundation. + + If the Program specifies that a proxy can decide which future +versions of the GNU General Public License can be used, that proxy's +public statement of acceptance of a version permanently authorizes you +to choose that version for the Program. + + Later license versions may give you additional or different +permissions. However, no additional obligations are imposed on any +author or copyright holder as a result of your choosing to follow a +later version. + + 15. Disclaimer of Warranty. + + THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY +APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT +HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY +OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, +THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR +PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM +IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF +ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. Limitation of Liability. + + IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS +THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY +GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE +USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF +DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD +PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), +EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF +SUCH DAMAGES. + + 17. Interpretation of Sections 15 and 16. + + If the disclaimer of warranty and limitation of liability provided +above cannot be given local legal effect according to their terms, +reviewing courts shall apply local law that most closely approximates +an absolute waiver of all civil liability in connection with the +Program, unless a warranty or assumption of liability accompanies a +copy of the Program in return for a fee. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +state the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see . + +Also add information on how to contact you by electronic and paper mail. + + If the program does terminal interaction, make it output a short +notice like this when it starts in an interactive mode: + + Copyright (C) + This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + +The hypothetical commands `show w' and `show c' should show the appropriate +parts of the General Public License. Of course, your program's commands +might be different; for a GUI interface, you would use an "about box". + + You should also get your employer (if you work as a programmer) or school, +if any, to sign a "copyright disclaimer" for the program, if necessary. +For more information on this, and how to apply and follow the GNU GPL, see +. + + The GNU General Public License does not permit incorporating your program +into proprietary programs. If your program is a subroutine library, you +may consider it more useful to permit linking proprietary applications with +the library. If this is what you want to do, use the GNU Lesser General +Public License instead of this License. But first, please read +. \ No newline at end of file diff --git a/themes/hugo-theme-stack/README.md b/themes/hugo-theme-stack/README.md new file mode 100644 index 0000000..b071761 --- /dev/null +++ b/themes/hugo-theme-stack/README.md @@ -0,0 +1,28 @@ +![image](https://user-images.githubusercontent.com/5889006/190859441-141b5f81-8483-40d2-bd96-ebf85616a46d.png) + +# Hugo Theme Stack + +logo + +Card-style Hugo theme designed for bloggers. + +## Quickstart + +Use this template: [CaiJimmy/hugo-theme-stack-starter](https://github.com/CaiJimmy/hugo-theme-stack-starter) + +## Demo + +* Starter template demo: [demo.stack.jimmycai.com](https://demo.stack.jimmycai.com) +* Dev build: [dev.stack.jimmycai.com](https://dev.stack.jimmycai.com) + +## Documentation + +Visit [stack.jimmycai.com](https://stack.jimmycai.com) + +## Copyright + +**Licensed under the GNU General Public License v3.0** + +Please do not remove the "*Theme Stack designed by Jimmy*" text and link. + +If you want to port this theme to another blogging platform, please let me know🙏. diff --git a/themes/hugo-theme-stack/archetypes/categories.md b/themes/hugo-theme-stack/archetypes/categories.md new file mode 100644 index 0000000..d771b29 --- /dev/null +++ b/themes/hugo-theme-stack/archetypes/categories.md @@ -0,0 +1,7 @@ +--- +title: "{{ replace .Name "-" " " | title }}" +image: +style: + background: "#2a9d8f" + color: "#fff" +--- \ No newline at end of file diff --git a/themes/hugo-theme-stack/archetypes/default.md b/themes/hugo-theme-stack/archetypes/default.md new file mode 100644 index 0000000..0556d3a --- /dev/null +++ b/themes/hugo-theme-stack/archetypes/default.md @@ -0,0 +1,11 @@ +--- +title: "{{ replace .Name "-" " " | title }}" +description: +date: {{ .Date }} +image: +math: +license: +hidden: false +comments: true +draft: true +--- \ No newline at end of file diff --git a/themes/hugo-theme-stack/archetypes/tags.md b/themes/hugo-theme-stack/archetypes/tags.md new file mode 100644 index 0000000..2fd2fd7 --- /dev/null +++ b/themes/hugo-theme-stack/archetypes/tags.md @@ -0,0 +1,5 @@ +--- +title: "{{ replace .Name "-" " " | title }}" +description: +image: +--- \ No newline at end of file diff --git a/themes/hugo-theme-stack/assets/icons/archives.svg b/themes/hugo-theme-stack/assets/icons/archives.svg new file mode 100644 index 0000000..cd96cbe --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/archives.svg @@ -0,0 +1,8 @@ + + + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/arrow-back.svg b/themes/hugo-theme-stack/assets/icons/arrow-back.svg new file mode 100644 index 0000000..0f7c5f4 --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/arrow-back.svg @@ -0,0 +1,6 @@ + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/back.svg b/themes/hugo-theme-stack/assets/icons/back.svg new file mode 100644 index 0000000..ee52db4 --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/back.svg @@ -0,0 +1,6 @@ + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/brand-github.svg b/themes/hugo-theme-stack/assets/icons/brand-github.svg new file mode 100644 index 0000000..1fe7e0b --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/brand-github.svg @@ -0,0 +1,6 @@ + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/brand-twitter.svg b/themes/hugo-theme-stack/assets/icons/brand-twitter.svg new file mode 100644 index 0000000..17ab1b1 --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/brand-twitter.svg @@ -0,0 +1,6 @@ + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/categories.svg b/themes/hugo-theme-stack/assets/icons/categories.svg new file mode 100644 index 0000000..e00ab1d --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/categories.svg @@ -0,0 +1,9 @@ + + + + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/clock.svg b/themes/hugo-theme-stack/assets/icons/clock.svg new file mode 100644 index 0000000..a7a8be6 --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/clock.svg @@ -0,0 +1,7 @@ + + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/copyright.svg b/themes/hugo-theme-stack/assets/icons/copyright.svg new file mode 100644 index 0000000..2ac45ff --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/copyright.svg @@ -0,0 +1,7 @@ + + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/date.svg b/themes/hugo-theme-stack/assets/icons/date.svg new file mode 100644 index 0000000..ed92a90 --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/date.svg @@ -0,0 +1,9 @@ + + + + + + + + + \ No newline at end of file diff --git a/themes/hugo-theme-stack/assets/icons/hash.svg b/themes/hugo-theme-stack/assets/icons/hash.svg new file mode 100644 index 0000000..e00ab1d --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/hash.svg @@ -0,0 +1,9 @@ + + + + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/home.svg b/themes/hugo-theme-stack/assets/icons/home.svg new file mode 100644 index 0000000..ed5fd53 --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/home.svg @@ -0,0 +1,8 @@ + + + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/infinity.svg b/themes/hugo-theme-stack/assets/icons/infinity.svg new file mode 100644 index 0000000..fb40b24 --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/infinity.svg @@ -0,0 +1,6 @@ + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/language.svg b/themes/hugo-theme-stack/assets/icons/language.svg new file mode 100644 index 0000000..66ede1c --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/language.svg @@ -0,0 +1,10 @@ + + + + + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/link.svg b/themes/hugo-theme-stack/assets/icons/link.svg new file mode 100644 index 0000000..3c87803 --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/link.svg @@ -0,0 +1,7 @@ + + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/messages.svg b/themes/hugo-theme-stack/assets/icons/messages.svg new file mode 100644 index 0000000..725d75c --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/messages.svg @@ -0,0 +1,7 @@ + + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/rss.svg b/themes/hugo-theme-stack/assets/icons/rss.svg new file mode 100644 index 0000000..b92ea8f --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/rss.svg @@ -0,0 +1,8 @@ + + + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/search.svg b/themes/hugo-theme-stack/assets/icons/search.svg new file mode 100644 index 0000000..a0b0ddc --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/search.svg @@ -0,0 +1,7 @@ + + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/tag.svg b/themes/hugo-theme-stack/assets/icons/tag.svg new file mode 100644 index 0000000..ef7a63d --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/tag.svg @@ -0,0 +1,7 @@ + + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/toggle-left.svg b/themes/hugo-theme-stack/assets/icons/toggle-left.svg new file mode 100644 index 0000000..c3048d4 --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/toggle-left.svg @@ -0,0 +1,7 @@ + + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/toggle-right.svg b/themes/hugo-theme-stack/assets/icons/toggle-right.svg new file mode 100644 index 0000000..d3edd63 --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/toggle-right.svg @@ -0,0 +1,7 @@ + + + + + + + diff --git a/themes/hugo-theme-stack/assets/icons/user.svg b/themes/hugo-theme-stack/assets/icons/user.svg new file mode 100644 index 0000000..9c92c87 --- /dev/null +++ b/themes/hugo-theme-stack/assets/icons/user.svg @@ -0,0 +1,7 @@ + + + + + + + diff --git a/themes/hugo-theme-stack/assets/img/avatar.png b/themes/hugo-theme-stack/assets/img/avatar.png new file mode 100644 index 0000000000000000000000000000000000000000..d90352c317e384c2209aac094ea7fee36c774e0c GIT binary patch literal 373 zcmeAS@N?(olHy`uVBq!ia0vp^(?FPo8AzVf&$$Ssqyv0HT+f_2Gi} div { + display: inline-flex; + align-items: center; + gap: 15px; + } +} + +.article-time { + flex-wrap: wrap; +} + +.article-translations { + & > div { + flex-wrap: wrap; + } +} + +.article-category, +.article-tags { + display: flex; + gap: 10px; + + a { + color: var(--accent-color-text); + background-color: var(--accent-color); + padding: 8px 16px; + border-radius: var(--tag-border-radius); + display: inline-block; + font-size: 1.4rem; + transition: background-color 0.5s ease; + + &:hover { + color: var(--accent-color-text); + background-color: var(--accent-color-darker); + } + } +} + +/* Compact style article list */ +.article-list--compact { + border-radius: var(--card-border-radius); + box-shadow: var(--shadow-l1); + background-color: var(--card-background); + --image-size: 50px; + + @include respond(md) { + --image-size: 60px; + } + + article { + & > a { + display: flex; + align-items: center; + padding: var(--small-card-padding); + gap: 15px; + } + + &:not(:last-of-type) { + border-bottom: 1.5px solid var(--card-separator-color); + } + + .article-details { + flex-grow: 1; + padding: 0; + min-height: var(--image-size); + gap: 10px; + } + + .article-title { + margin: 0; + font-size: 1.6rem; + + @include respond(md) { + font-size: 1.8rem; + } + } + + .article-image { + img { + width: var(--image-size); + height: var(--image-size); + object-fit: cover; + } + } + + .article-time { + font-size: 1.4rem; + } + + .article-preview { + font-size: 1.4rem; + color: var(--card-text-color-tertiary); + margin-top: 10px; + line-height: 1.5; + } + } +} + +/* Tile style article list */ +.article-list--tile { + article { + border-radius: var(--card-border-radius); + overflow: hidden; + position: relative; + height: 350px; + width: 250px; + box-shadow: var(--shadow-l1); + transition: box-shadow 0.3s ease; + background-color: var(--card-background); + + &:hover { + box-shadow: var(--shadow-l2); + } + + &.has-image { + .article-details { + background-color: rgba(#000, 0.25); + } + + .article-title { + color: #fff; + } + } + + .article-image { + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; + + img { + width: 100%; + height: 100%; + object-fit: cover; + } + } + + .article-details { + border-radius: var(--card-border-radius); + position: relative; + height: 100%; + width: 100%; + display: flex; + flex-direction: column; + justify-content: flex-end; + z-index: 2; + padding: 15px; + + @include respond(sm) { + padding: 20px; + } + } + + .article-title { + font-size: 2rem; + font-weight: 500; + color: var(--card-text-color-main); + + @include respond(sm) { + font-size: 2.2rem; + } + } + } +} diff --git a/themes/hugo-theme-stack/assets/scss/partials/base.scss b/themes/hugo-theme-stack/assets/scss/partials/base.scss new file mode 100644 index 0000000..efb4b8f --- /dev/null +++ b/themes/hugo-theme-stack/assets/scss/partials/base.scss @@ -0,0 +1,38 @@ +html { + font-size: 62.5%; + overflow-y: scroll; +} + +* { + box-sizing: border-box; +} + +body { + background: var(--body-background); + margin: 0; + font-family: var(--base-font-family); + font-size: 1.6rem; + -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; +} + +/* scrollbar styles for Firefox */ +* { + scrollbar-width: auto; + scrollbar-color: var(--scrollbar-thumb) transparent; +} +/**/ + +/* scrollbar styles for Chromium */ +::-webkit-scrollbar { + height: auto; +} + +::-webkit-scrollbar-thumb { + background-color: var(--scrollbar-thumb); +} + +::-webkit-scrollbar-track { + background-color: transparent; +} +/**/ \ No newline at end of file diff --git a/themes/hugo-theme-stack/assets/scss/partials/comments/disqusjs.scss b/themes/hugo-theme-stack/assets/scss/partials/comments/disqusjs.scss new file mode 100644 index 0000000..eb270e3 --- /dev/null +++ b/themes/hugo-theme-stack/assets/scss/partials/comments/disqusjs.scss @@ -0,0 +1,394 @@ +.disqus-container { + background-color: var(--card-background); + border-radius: var(--card-border-radius); + box-shadow: var(--shadow-l1); + padding: var(--card-padding); +} + +#dsqjs * { + margin: 0; + padding: 0 +} + +#dsqjs a { + text-decoration: none; + color: #076dd0 +} + +#dsqjs .dsqjs-hide { + display: none!important +} + +#dsqjs .dsqjs-disabled { + cursor: not-allowed; + opacity: .5 +} + +#dsqjs #dsqjs-msg { + text-align: center; + margin-top: 4px; + margin-bottom: 4px; + font-size: 14px +} + +#dsqjs #dsqjs-msg .dsqjs-msg-btn { + cursor: pointer +} + +#dsqjs .dsqjs-bullet { + line-height: 1.4; + margin: 0 2px +} + +#dsqjs .dsqjs-bullet:after { + color: #c2c6cc; + content: "·"; + font-weight: 700 +} + +#dsqjs .dsqjs-clearfix:after,#dsqjs .dsqjs-clearfix:before { + display: table; + content: ""; + line-height: 0; + clear: both +} + +#dsqjs .dsqjs-nav { + position: relative; + margin: 0 0 20px; + border-bottom: 2px solid #e7e9ee +} + +#dsqjs ol,#dsqjs ul { + list-style: none; + list-style-type: none +} + +#dsqjs .dsqjs-no-comment { + text-align: center; + font-size: 16px; + line-height: 1.5; + word-wrap: break-word; + overflow: hidden; + color: #2a2e2e; + margin-bottom: 6px +} + +#dsqjs .dsqjs-nav-tab { + float: left; + text-transform: capitalize; + font-size: 15px; + padding: 12px 8px; + color: #656c7a; + display: block; + margin: 0 15px 0 0; + font-weight: 700; + line-height: 1; + position: relative; + transition: all .2s ease-in-out +} + +#dsqjs .dsqjs-nav-tab:last-child { + margin: 0 +} + +#dsqjs .dsqjs-tab-active { + color: #2a2e2e +} + +#dsqjs .dsqjs-tab-active>span:after { + content: " "; + display: block; + height: 2px; + background-color: #076dd0!important; + position: absolute; + bottom: -5px; + left: 0; + right: 0 +} + +#dsqjs .dsqjs-post-list .dsqjs-post-item { + position: relative; + margin-bottom: 16px +} + +#dsqjs .dsqjs-post-list .dsqjs-post-avatar { + float: left; + margin-right: 10px; + position: relative; + background: #dbdfe4; + padding: 0; + display: block; + border-radius: 4px +} + +#dsqjs .dsqjs-post-list .dsqjs-post-avatar img { + width: 44px; + height: 44px; + display: block; + border-radius: 4px +} + +#dsqjs .dsqjs-post-list .dsqjs-post-header { + line-height: 1; + font-size: 14px; + margin-bottom: 3px +} + +#dsqjs .dsqjs-post-list .dsqjs-post-header .dsqjs-post-author { + color: #656c7a; + font-weight: 700 +} + +#dsqjs .dsqjs-post-list .dsqjs-post-header .dsqjs-admin-badge { + color: #fff; + background: #687a86; + padding: 1px 3px; + margin-left: 4px; + font-size: 12px; + line-height: 1; + font-weight: 700; + border-radius: 3px; + display: inline-block; + position: relative; + top: -1px; + left: 1px +} + +#dsqjs .dsqjs-post-list .dsqjs-post-header .dsqjs-meta { + display: inline-block; + font-size: 12px; + color: #656c7a +} + +#dsqjs .dsqjs-post-body { + font-size: 15px; + line-height: 1.5; + word-wrap: break-word; + overflow: hidden; + color: #2a2e2e +} + +#dsqjs .dsqjs-post-body code { + padding: .2em .4em; + margin: 0; + font-size: 85%; + background: #f5f5f5; + color: inherit; + border-radius: 3px +} + +#dsqjs .dsqjs-post-body pre { + padding: .5em; + overflow: auto; + font-size: 85%; + line-height: 1.45; + border-radius: 3px; + background: #f5f5f5; + margin: .5em 0 +} + +#dsqjs .dsqjs-post-body blockquote { + padding: 0 .8em; + margin: .5em 0; + color: #6a737d; + border-left: .25em solid #dfe2e5 +} + +#dsqjs .dsqjs-post-body p:last-child { + margin: 0 +} + +#dsqjs .dsqjs-post-list.dsqjs-children>li { + margin-left: 30px +} + +#dsqjs .dsqjs-post-list.dsqjs-children .dsqjs-post-avatar img { + width: 38px; + height: 38px +} + +#dsqjs .dsqjs-load-more { + font-size: 14px; + font-weight: 400; + display: block; + text-align: center; + padding: 11px 14px; + margin: 0 0 24px; + background: #687a86; + color: #fff; + cursor: pointer +} + +#dsqjs .dsqjs-load-more:hover { + opacity: .8 +} + +#dsqjs footer { + text-align: right; + line-height: 1.5; + padding-top: 10px; + padding-right: 10px; + border-top: 2px solid #e7e9ee; + margin-top: 12px; + font-weight: 700; + font-size: 16px; + color: #555 +} + +#dsqjs .dsqjs-disqus-logo { + background-image: url(https://c.disquscdn.com/next/embed/assets/img/sprite.654110a9206fd22f08cca0798e34a65e.png); + background-repeat: no-repeat; + display: inline-block; + background-size: 86px 40.5px; + height: 16.5px; + width: 86px; +} + +#dsqjs .dsqjs-order { + display: flex; + float: right; + align-items: center; + margin-top: 10px; + margin-bottom: 12px +} + +#dsqjs .dsqjs-order-radio { + display: none +} + +#dsqjs .dsqjs-order-radio:checked+.dsqjs-order-label { + color: #fff; + background-color: #888 +} + +#dsqjs .dsqjs-order-label { + display: block; + height: 20px; + line-height: 20px; + margin-right: 10px; + font-size: 12px; + border-radius: 2px; + padding: 0 5px; + background-color: #dcdcdc; + cursor: pointer +} + +#dsqjs p.dsqjs-has-more { + margin-bottom: 24px; + margin-left: 48px; + font-size: 13px; + line-height: 15px +} + +#dsqjs p.dsqjs-has-more a.dsqjs-has-more-btn { + color: #656c7a; + text-decoration: underline; + cursor: pointer +} + +@media (min-width: 768px) { + #dsqjs .dsqjs-post-list.dsqjs-children>li { + margin-left:48px + } + + #dsqjs .dsqjs-post-list .dsqjs-post-avatar { + margin-right: 12px + } + + #dsqjs .dsqjs-post-list .dsqjs-post-item { + margin-bottom: 20px + } +} + +@media (min-width: 1024px) { + #dsqjs .dsqjs-post-list.dsqjs-children>li { + margin-left:60px + } +} + +:root[data-scheme="light"] { + #dsqjs .dsqjs-disqus-logo { + background-position: 0 -7px; + } +} + +:root[data-scheme="dark"] { + #dsqjs { + --t-s: rgba(255,255,255,0.9); + --alt: #3e4b5e; + --link-hover: #47a2e0; + --hover-bg: #3e4b5e; + --tag: #3e4b5e; + --border: #435266; + --pre: #3c495b; + --c-bg: #2f3947; + --code: #c3c7cb; + --kbd: #4e5f77; + --hl: #abb2bf; + --hlc: #808895; + --hlk: #c678dd; + --hln: #e06c75; + --hll: #56b6c2; + --hls: #98c379; + --hlt: #e6c07b; + --hlv: #d19a66; + --bg: #181c27; + --main: #252d38; + --t: rgba(255,255,255,0.86); + --t-l: rgba(255,255,255,0.66); + --logo: #fff; + --link: #38a3fd; + --title: rgba(255,255,255,0.92); + --fab: #364151; + --shadow: none; + } + + #disqus_thread { + color: var(--body-text-color) + } + + #dsqjs #dsqjs-msg { + color: var(--t) + } + + #dsqjs a { + color:var(--link) + } + + #dsqjs a:focus,#dsqjs a:hover { + color: var(--link-hover) + } + + #dsqjs .dsqjs-disqus-logo { + background-position: 0 -24px; + } + + #dsqjs .dsqjs-nav,#dsqjs footer { + border-color: var(--hlc) + } + + #dsqjs .dsqjs-load-more,#dsqjs .dsqjs-load-more:hover,#dsqjs .dsqjs-nav-tab,#dsqjs .dsqjs-no-comment,#dsqjs .dsqjs-post-content { + color: var(--t) + } + + #dsqjs .dsqjs-order-label { + background-color: var(--hlc) + } + + #dsqjs .dsqjs-order-radio:checked+.dsqjs-order-label { + background-color: var(--kbd) + } + + #dsqjs .dsqjs-tab-active>span:after { + background-color: #2e9fff + } + + #dsqjs .dsqjs-footer,#dsqjs .dsqjs-meta { + color: var(--t-l) + } + + #dsqjs .dsqjs-post-body blockquote { + border-color: var(--border) + } +} diff --git a/themes/hugo-theme-stack/assets/scss/partials/footer.scss b/themes/hugo-theme-stack/assets/scss/partials/footer.scss new file mode 100644 index 0000000..ccb7394 --- /dev/null +++ b/themes/hugo-theme-stack/assets/scss/partials/footer.scss @@ -0,0 +1,30 @@ +footer.site-footer { + padding: 20px 0 var(--section-separation) 0; + font-size: 1.4rem; + line-height: 1.75; + + &:before { + content: ""; + display: block; + height: 3px; + width: 50px; + background: var(--body-text-color); + margin-bottom: 20px; + } + + .copyright { + color: var(--accent-color); + font-weight: bold; + margin-bottom: 5px; + } + + .powerby { + color: var(--body-text-color); + font-weight: normal; + font-size: 1.2rem; + + a { + color: var(--body-text-color); + } + } +} diff --git a/themes/hugo-theme-stack/assets/scss/partials/highlight/common.scss b/themes/hugo-theme-stack/assets/scss/partials/highlight/common.scss new file mode 100644 index 0000000..c680fa4 --- /dev/null +++ b/themes/hugo-theme-stack/assets/scss/partials/highlight/common.scss @@ -0,0 +1,428 @@ +/* Background */ +.chroma { + color: $color; + background-color: $background-color; +} + +/* Other */ +.chroma .x { +} + +/* Error */ +.chroma .err { + color: $error-color; +} + +/* LineTableTD */ +.chroma .lntd { + vertical-align: top; + padding: 0; + margin: 0; + border: 0; +} + +/* LineTable */ +.chroma .lntable { + border-spacing: 0; + padding: 0; + margin: 0; + border: 0; + width: 100%; + display: block; + + > tbody { + display: block; + width: 100%; + > tr { + display: flex; + width: 100%; + > td:last-child { + overflow-x: auto; + } + } + } +} + +/* LineHighlight */ +.chroma .hl { + display: block; + width: 100%; + background-color: #ffffcc; +} + +/* LineNumbersTable */ +.chroma .lnt { + margin-right: 0.4em; + padding: 0 0.4em 0 0.4em; + color: #7f7f7f; + display: block; +} + +/* LineNumbers */ +.chroma .ln { + margin-right: 0.4em; + padding: 0 0.4em 0 0.4em; + color: #7f7f7f; +} + +/* Keyword */ +.chroma .k { + color: $keyword-color; +} + +/* KeywordConstant */ +.chroma .kc { + color: $keyword-color; +} + +/* KeywordDeclaration */ +.chroma .kd { + color: $keyword-color; +} + +/* KeywordNamespace */ +.chroma .kn { + color: #f92672; +} + +/* KeywordPseudo */ +.chroma .kp { + color: $keyword-color; +} + +/* KeywordReserved */ +.chroma .kr { + color: $keyword-color; +} + +/* KeywordType */ +.chroma .kt { + color: $keyword-color; +} + +/* Name */ +.chroma .n { + color: $text-color; +} + +/* NameAttribute */ +.chroma .na { + color: $name-color; +} + +/* NameBuiltin */ +.chroma .nb { + color: $text-color; +} + +/* NameBuiltinPseudo */ +.chroma .bp { + color: $text-color; +} + +/* NameClass */ +.chroma .nc { + color: $name-color; +} + +/* NameConstant */ +.chroma .no { + color: $keyword-color; +} + +/* NameDecorator */ +.chroma .nd { + color: $name-color; +} + +/* NameEntity */ +.chroma .ni { + color: $text-color; +} + +/* NameException */ +.chroma .ne { + color: $name-color; +} + +/* NameFunction */ +.chroma .nf { + color: $name-color; +} + +/* NameFunctionMagic */ +.chroma .fm { + color: $text-color; +} + +/* NameLabel */ +.chroma .nl { + color: $text-color; +} + +/* NameNamespace */ +.chroma .nn { + color: $text-color; +} + +/* NameOther */ +.chroma .nx { + color: $name-color; +} + +/* NameProperty */ +.chroma .py { + color: $text-color; +} + +/* NameTag */ +.chroma .nt { + color: #f92672; +} + +/* NameVariable */ +.chroma .nv { + color: $text-color; +} + +/* NameVariableClass */ +.chroma .vc { + color: $text-color; +} + +/* NameVariableGlobal */ +.chroma .vg { + color: $text-color; +} + +/* NameVariableInstance */ +.chroma .vi { + color: $text-color; +} + +/* NameVariableMagic */ +.chroma .vm { + color: $text-color; +} + +/* Literal */ +.chroma .l { + color: #ae81ff; +} + +/* LiteralDate */ +.chroma .ld { + color: $literal-color; +} + +/* LiteralString */ +.chroma .s { + color: $literal-color; +} + +/* LiteralStringAffix */ +.chroma .sa { + color: $literal-color; +} + +/* LiteralStringBacktick */ +.chroma .sb { + color: $literal-color; +} + +/* LiteralStringChar */ +.chroma .sc { + color: $literal-color; +} + +/* LiteralStringDelimiter */ +.chroma .dl { + color: $literal-color; +} + +/* LiteralStringDoc */ +.chroma .sd { + color: $literal-color; +} + +/* LiteralStringDouble */ +.chroma .s2 { + color: $literal-color; +} + +/* LiteralStringEscape */ +.chroma .se { + color: #ae81ff; +} + +/* LiteralStringHeredoc */ +.chroma .sh { + color: $literal-color; +} + +/* LiteralStringInterpol */ +.chroma .si { + color: $literal-color; +} + +/* LiteralStringOther */ +.chroma .sx { + color: $literal-color; +} + +/* LiteralStringRegex */ +.chroma .sr { + color: $literal-color; +} + +/* LiteralStringSingle */ +.chroma .s1 { + color: $literal-color; +} + +/* LiteralStringSymbol */ +.chroma .ss { + color: $literal-color; +} + +/* LiteralNumber */ +.chroma .m { + color: #ae81ff; +} + +/* LiteralNumberBin */ +.chroma .mb { + color: #ae81ff; +} + +/* LiteralNumberFloat */ +.chroma .mf { + color: #ae81ff; +} + +/* LiteralNumberHex */ +.chroma .mh { + color: #ae81ff; +} + +/* LiteralNumberInteger */ +.chroma .mi { + color: #ae81ff; +} + +/* LiteralNumberIntegerLong */ +.chroma .il { + color: #ae81ff; +} + +/* LiteralNumberOct */ +.chroma .mo { + color: #ae81ff; +} + +/* Operator */ +.chroma .o { + color: #f92672; +} + +/* OperatorWord */ +.chroma .ow { + color: #f92672; +} + +/* Punctuation */ +.chroma .p { + color: $text-color; +} + +/* Comment */ +.chroma .c { + color: #75715e; +} + +/* CommentHashbang */ +.chroma .ch { + color: #75715e; +} + +/* CommentMultiline */ +.chroma .cm { + color: #75715e; +} + +/* CommentSingle */ +.chroma .c1 { + color: #75715e; +} + +/* CommentSpecial */ +.chroma .cs { + color: #75715e; +} + +/* CommentPreproc */ +.chroma .cp { + color: #75715e; +} + +/* CommentPreprocFile */ +.chroma .cpf { + color: #75715e; +} + +/* Generic */ +.chroma .g { +} + +/* GenericDeleted */ +.chroma .gd { + color: #f92672; +} + +/* GenericEmph */ +.chroma .ge { + font-style: italic; +} + +/* GenericError */ +.chroma .gr { +} + +/* GenericHeading */ +.chroma .gh { +} + +/* GenericInserted */ +.chroma .gi { + color: $name-color; +} + +/* GenericOutput */ +.chroma .go { +} + +/* GenericPrompt */ +.chroma .gp { +} + +/* GenericStrong */ +.chroma .gs { + font-weight: bold; +} + +/* GenericSubheading */ +.chroma .gu { + color: #75715e; +} + +/* GenericTraceback */ +.chroma .gt { +} + +/* GenericUnderline */ +.chroma .gl { +} + +/* TextWhitespace */ +.chroma .w { +} diff --git a/themes/hugo-theme-stack/assets/scss/partials/highlight/dark.scss b/themes/hugo-theme-stack/assets/scss/partials/highlight/dark.scss new file mode 100644 index 0000000..0d3f330 --- /dev/null +++ b/themes/hugo-theme-stack/assets/scss/partials/highlight/dark.scss @@ -0,0 +1,14 @@ +/* +* Style: monokai +* https://xyproto.github.io/splash/docs/monokai.html +*/ + +$color: #f8f8f2; +$background-color: #272822; +$error-color: #bb0064; +$keyword-color: #66d9ef; +$text-color: $color; +$name-color: #a6e22e; +$literal-color: #e6db74; + +@import "common.scss"; diff --git a/themes/hugo-theme-stack/assets/scss/partials/highlight/light.scss b/themes/hugo-theme-stack/assets/scss/partials/highlight/light.scss new file mode 100644 index 0000000..174b649 --- /dev/null +++ b/themes/hugo-theme-stack/assets/scss/partials/highlight/light.scss @@ -0,0 +1,14 @@ +/* +* Style: monokailight +* https://xyproto.github.io/splash/docs/monokailight.html +*/ + +$color: #272822; +$background-color: #fafafa; +$error-color: #960050; +$keyword-color: #00a8c8; +$text-color: #111111; +$name-color: #75af00; +$literal-color: #d88200; + +@import "common.scss"; diff --git a/themes/hugo-theme-stack/assets/scss/partials/layout/404.scss b/themes/hugo-theme-stack/assets/scss/partials/layout/404.scss new file mode 100644 index 0000000..d9d8752 --- /dev/null +++ b/themes/hugo-theme-stack/assets/scss/partials/layout/404.scss @@ -0,0 +1,6 @@ +.not-found-card { + background-color: var(--card-background); + box-shadow: var(--shadow-l1); + border-radius: var(--card-border-radius); + padding: var(--card-padding); +} diff --git a/themes/hugo-theme-stack/assets/scss/partials/layout/article.scss b/themes/hugo-theme-stack/assets/scss/partials/layout/article.scss new file mode 100644 index 0000000..2a61423 --- /dev/null +++ b/themes/hugo-theme-stack/assets/scss/partials/layout/article.scss @@ -0,0 +1,462 @@ +.article-page { + &.hide-sidebar-sm .left-sidebar { + display: none; + + @include respond(md) { + display: inherit; + } + } + + .main-article { + background: var(--card-background); + border-radius: var(--card-border-radius); + box-shadow: var(--shadow-l1); + overflow: hidden; + + .article-header { + .article-image { + img { + height: auto; + width: 100%; + max-height: 50vh; + object-fit: cover; + } + } + + .article-details { + padding: var(--card-padding); + padding-bottom: 0; + } + } + + .article-content { + margin: var(--card-padding) 0; + color: var(--card-text-color-main); + + .footnotes { + font-family: var(--base-font-family); + } + + img { + max-width: 100%; + height: auto; + } + } + + .article-footer { + margin: var(--card-padding); + margin-top: 0; + + section:not(:first-child) { + margin-top: var(--card-padding); + } + + section { + color: var(--card-text-color-tertiary); + text-transform: uppercase; + display: flex; + align-items: center; + font-size: 1.4rem; + gap: 15px; + + svg { + width: 20px; + height: 20px; + stroke-width: 1.33; + } + } + + .article-tags { + flex-wrap: wrap; + text-transform: unset; + } + + .article-copyright, + .article-lastmod { + a { + color: var(--body-text-color); + } + + a.link { + box-shadow: unset; + } + } + } + } +} + +.widget--toc { + background-color: var(--card-background); + border-radius: var(--card-border-radius); + box-shadow: var(--shadow-l1); + display: flex; + flex-direction: column; + color: var(--card-text-color-main); + overflow: hidden; + + ::-webkit-scrollbar-thumb { + background-color: var(--card-separator-color); + } + + #TableOfContents { + overflow-x: auto; + max-height: 75vh; + + ol, + ul { + margin: 0; + padding: 0; + } + + ol { + list-style-type: none; + counter-reset: item; + + li a:first-of-type::before { + counter-increment: item; + content: counters(item, ".") ". "; + font-weight: bold; + margin-right: 5px; + } + } + + & > ul { + padding: 0 1em; + } + + li { + margin: 15px 0 15px 20px; + padding: 5px; + + & > ol, + & > ul { + margin-top: 10px; + padding-left: 10px; + margin-bottom: -5px; + + & > li:last-child { + margin-bottom: 0; + } + } + } + li.active-class > a { + border-left: var(--heading-border-size) solid var(--accent-color); + font-weight: bold; + } + + ul li.active-class > a { + display: block; + } + + @function repeat($str, $n) { + $result: ""; + @for $_ from 0 to $n { + $result: $result + $str; + } + @return $result; + } + + // Support up to 6 levels of indentation for lists in ToCs + @for $i from 0 to 5 { + & > ul #{repeat("> li > ul", $i)} > li.active-class > a { + $n: 25 + $i * 35; + margin-left: calc(-#{$n}px - 1em); + padding-left: calc(#{$n}px + 1em - var(--heading-border-size)); + } + + & > ol #{repeat("> li > ol", $i)} > li.active-class > a { + $n: 9 + $i * 35; + margin-left: calc(-#{$n}px - 1em); + padding-left: calc(#{$n}px + 1em - var(--heading-border-size)); + display: block; + } + } + } +} + +.related-content { + overflow-x: auto; + padding-bottom: 15px; + + & > .flex { + float: left; + } + + article { + margin-right: 15px; + flex-shrink: 0; + overflow: hidden; + width: 250px; + height: 150px; + + .article-title { + font-size: 1.8rem; + margin: 0; + } + + &.has-image { + .article-details { + padding: 20px; + background: linear-gradient(0deg, rgba(0, 0, 0, 0.25) 0%, rgba(0, 0, 0, 0.75) 100%); + } + } + } +} + +.article-content { + font-family: var(--article-font-family); + font-size: var(--article-font-size); + padding: 0 var(--card-padding); + line-height: var(--article-line-height); + + & > p { + margin: 1.5em 0; + } + + h1, + h2, + h3, + h4, + h5, + h6 { + margin-inline-start: calc((var(--card-padding)) * -1); + padding-inline-start: calc(var(--card-padding) - var(--heading-border-size)); + border-inline-start: var(--heading-border-size) solid var(--accent-color); + position: relative; + + a.header-anchor { + transition: opacity 0.3s ease; + opacity: 0; + position: absolute; + left: 0; + width: var(--card-padding); + text-align: center; + color: var(--accent-color); + + &:before { + content: "#"; + } + } + + &:hover, + &:focus { + a.header-anchor { + opacity: 1; + } + } + } + + figure { + text-align: center; + + figcaption { + font-size: 1.4rem; + color: var(--card-text-color-secondary); + } + } + + blockquote { + position: relative; + margin: 1.5em 0; + border-inline-start: var(--blockquote-border-size) solid var(--card-separator-color); + padding: 15px calc(var(--card-padding) - var(--blockquote-border-size)); + background-color: var(--blockquote-background-color); + + .cite { + display: block; + text-align: right; + font-size: 0.75em; + + a { + text-decoration: underline; + } + } + } + + hr { + width: 100px; + margin: 40px auto; + background: var(--card-text-color-tertiary); + height: 2px; + border: 0; + opacity: 0.55; + } + + code { + color: var(--code-text-color); + background-color: var(--code-background-color); + padding: 2px 4px; + border-radius: var(--tag-border-radius); + font-family: var(--code-font-family); + } + + a, + code { + word-break: break-word; + } + + .gallery { + position: relative; + display: flex; + flex-direction: row; + justify-content: center; + margin: 1.5em 0; + gap: 10px; + + figure { + margin: 0; + } + } + + pre { + overflow-x: auto; + display: block; + background-color: var(--pre-background-color); + color: var(--pre-text-color); + font-family: var(--code-font-family); + line-height: 1.428571429; + word-break: break-all; + padding: var(--card-padding); + // keep Codeblocks LTR + [dir="rtl"] & { + direction: ltr; + } + code { + color: unset; + border: none; + background: none; + padding: 0; + } + } + + .highlight { + background-color: var(--pre-background-color); + padding: var(--card-padding); + position: relative; + + &:hover { + .copyCodeButton { + opacity: 1; + } + } + // keep Codeblocks LTR + [dir="rtl"] & { + direction: ltr; + } + pre { + margin: initial; + padding: 0; + margin: 0; + width: auto; + } + } + + .copyCodeButton { + position: absolute; + top: calc(var(--card-padding)); + right: calc(var(--card-padding)); + background: var(--card-background); + border: none; + box-shadow: var(--shadow-l2); + border-radius: var(--tag-border-radius); + padding: 8px 16px; + color: var(--card-text-color-main); + cursor: pointer; + font-size: 14px; + opacity: 0; + transition: opacity 0.3s ease; + } + + .table-wrapper { + padding: 0 var(--card-padding); + overflow-x: auto; + display: block; + } + + table { + width: 100%; + border-collapse: collapse; + border-spacing: 0; + margin-bottom: 1.5em; + font-size: 0.96em; + } + + th, + td { + text-align: left; + padding: 4px 8px 4px 10px; + border: 1px solid var(--table-border-color); + } + + td { + vertical-align: top; + } + + tr:nth-child(even) { + background-color: var(--tr-even-background-color); + } + + .twitter-tweet { + color: var(--card-text-color-main); + } + + .video-wrapper { + position: relative; + width: 100%; + height: 0; + padding-bottom: 56.25%; + overflow: hidden; + + & > iframe, + & > video { + position: absolute; + width: 100%; + height: 100%; + left: 0; + top: 0; + border: 0; + } + } + + .gitlab-embed-snippets { + margin: 0 !important; + + .file-holder.snippet-file-content { + margin-block-end: 0 !important; + margin-block-start: 0 !important; + margin-left: calc((var(--card-padding)) * -1) !important; + margin-right: calc((var(--card-padding)) * -1) !important; + padding: 0 var(--card-padding) !important; + } + } + + /// Negative margins + blockquote, + figure, + .highlight, + pre, + .gallery, + .video-wrapper, + .table-wrapper, + .s_video_simple { + margin-left: calc((var(--card-padding)) * -1); + margin-right: calc((var(--card-padding)) * -1); + width: calc(100% + var(--card-padding) * 2); + } + + /// Make long KaTeX equations scrollable in the x-axis + .katex-display > .katex { + overflow-x: auto; + overflow-y: hidden; + } + + kbd { + border: 1px solid var(--kbd-border-color); + font-weight: bold; + font-size: 0.9em; + line-height: 1; + padding: 2px 4px; + border-radius: 4px; + display: inline-block; + } +} diff --git a/themes/hugo-theme-stack/assets/scss/partials/layout/list.scss b/themes/hugo-theme-stack/assets/scss/partials/layout/list.scss new file mode 100644 index 0000000..d7815ca --- /dev/null +++ b/themes/hugo-theme-stack/assets/scss/partials/layout/list.scss @@ -0,0 +1,71 @@ +.section-card { + border-radius: var(--card-border-radius); + background-color: var(--card-background); + padding: var(--small-card-padding); + box-shadow: var(--shadow-l1); + display: flex; + align-items: center; + gap: 20px; + + --separation: 15px; + + .section-term { + font-size: 2.2rem; + margin: 0; + color: var(--card-text-color-main); + } + + .section-description { + font-weight: normal; + color: var(--card-text-color-secondary); + font-size: 1.6rem; + margin: 0; + } + + .section-details { + flex-grow: 1; + display: flex; + flex-direction: column; + gap: 8px; + } + + .section-image { + img { + width: 60px; + height: 60px; + } + } + + .section-count { + color: var(--card-text-color-tertiary); + font-size: 1.4rem; + margin: 0; + font-weight: bold; + text-transform: uppercase; + } +} + +.subsection-list { + overflow-x: auto; + + .article-list--tile { + display: flex; + padding-bottom: 15px; + + article { + width: 250px; + height: 150px; + margin-right: 20px; + flex-shrink: 0; + + .article-title { + margin: 0; + font-size: 1.8rem; + } + + .article-details { + padding: 20px; + } + } + } +} diff --git a/themes/hugo-theme-stack/assets/scss/partials/layout/search.scss b/themes/hugo-theme-stack/assets/scss/partials/layout/search.scss new file mode 100644 index 0000000..89cdcef --- /dev/null +++ b/themes/hugo-theme-stack/assets/scss/partials/layout/search.scss @@ -0,0 +1,82 @@ +.search-form { + position: relative; + --button-size: 80px; + + &.widget { + --button-size: 60px; + + label { + font-size: 1.3rem; + top: 10px; + } + + input { + font-size: 1.5rem; + padding: 30px 20px 15px 20px; + } + } + + p { + position: relative; + margin: 0; + } + + label { + position: absolute; + top: 15px; + inset-inline-start: 20px; + font-size: 1.4rem; + color: var(--card-text-color-tertiary); + } + + input { + padding: 40px 20px 20px; + border-radius: var(--card-border-radius); + background-color: var(--card-background); + box-shadow: var(--shadow-l1); + color: var(--card-text-color-main); + width: 100%; + border: 0; + -webkit-appearance: none; + + transition: box-shadow 0.3s ease; + + font-size: 1.8rem; + + &:focus { + outline: 0; + box-shadow: var(--shadow-l2); + } + } + + button { + position: absolute; + inset-inline-end: 0; + top: 0; + height: 100%; + width: var(--button-size); + cursor: pointer; + background-color: transparent; + border: 0; + + padding: 0 10px; + + &:focus { + outline: 0; + + svg { + stroke-width: 2; + color: var(--accent-color); + } + } + + svg { + color: var(--card-text-color-secondary); + stroke-width: 1.33; + transition: all 0.3s ease; + width: 20px; + height: 20px; + } + } + +} \ No newline at end of file diff --git a/themes/hugo-theme-stack/assets/scss/partials/menu.scss b/themes/hugo-theme-stack/assets/scss/partials/menu.scss new file mode 100644 index 0000000..5b6be17 --- /dev/null +++ b/themes/hugo-theme-stack/assets/scss/partials/menu.scss @@ -0,0 +1,229 @@ +/*! + * Hamburgers + * @description Tasty CSS-animated hamburgers + * @author Jonathan Suh @jonsuh + * @site https://jonsuh.com/hamburgers + * @link https://github.com/jonsuh/hamburgers + */ + +.hamburger { + padding-top: 10px; + display: inline-block; + cursor: pointer; + transition-property: opacity, filter; + transition-duration: 0.15s; + transition-timing-function: linear; + font: inherit; + color: inherit; + text-transform: none; + background-color: transparent; + border: 0; + margin: 0; + overflow: visible; +} +.hamburger:hover { + opacity: 0.7; +} +.hamburger.is-active:hover { + opacity: 0.7; +} +.hamburger.is-active .hamburger-inner, +.hamburger.is-active .hamburger-inner::before, +.hamburger.is-active .hamburger-inner::after { + background-color: #000; +} + +.hamburger-box { + width: 30px; + height: 24px; + display: inline-block; + position: relative; +} + +.hamburger-inner { + display: block; + top: 50%; + margin-top: -2px; +} + +.hamburger-inner, +.hamburger-inner::before, +.hamburger-inner::after { + width: 30px; + height: 2px; + background-color: var(--card-text-color-main); + border-radius: 4px; + position: absolute; + transition-property: transform; + transition-duration: 0.15s; + transition-timing-function: ease; +} +.hamburger-inner::before, +.hamburger-inner::after { + content: ""; + display: block; +} +.hamburger-inner::before { + top: -10px; +} +.hamburger-inner::after { + bottom: -10px; +} + +.hamburger--spin .hamburger-inner { + transition-duration: 0.22s; + transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); +} +.hamburger--spin .hamburger-inner::before { + transition: top 0.1s 0.25s ease-in, opacity 0.1s ease-in; +} +.hamburger--spin .hamburger-inner::after { + transition: bottom 0.1s 0.25s ease-in, transform 0.22s cubic-bezier(0.55, 0.055, 0.675, 0.19); +} + +.hamburger--spin.is-active .hamburger-inner { + transform: rotate(225deg); + transition-delay: 0.12s; + transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); +} +.hamburger--spin.is-active .hamburger-inner::before { + top: 0; + opacity: 0; + transition: top 0.1s ease-out, opacity 0.1s 0.12s ease-out; +} +.hamburger--spin.is-active .hamburger-inner::after { + bottom: 0; + transform: rotate(-90deg); + transition: bottom 0.1s ease-out, transform 0.22s 0.12s cubic-bezier(0.215, 0.61, 0.355, 1); +} + +#toggle-menu { + background: none; + border: none; + position: absolute; + right: 0; + top: 0; + z-index: 2; + cursor: pointer; + + [dir="rtl"] & { + left: 0; + right: auto; + } + + @include respond(md) { + display: none; + } + + outline: none; + + &.is-active { + .hamburger-inner, + .hamburger-inner::before, + .hamburger-inner::after { + background-color: var(--accent-color); + } + } +} + +/* Menu style */ +#main-menu { + list-style: none; + overflow-y: auto; + flex-grow: 1; + font-size: 1.4rem; + background-color: var(--card-background); + + box-shadow: var(--shadow-l1); + display: none; + margin: 0 calc(var(--container-padding) * -1); + + padding: 30px 30px; + + @include respond(xl) { + padding: 15px 0; + } + + &, .menu-bottom-section ol { + flex-direction: column; + gap: 30px; + + @include respond(xl) { + gap: 25px; + } + } + + &.show { + display: flex; + } + + @include respond(md) { + align-items: flex-end; + display: flex; + background-color: transparent; + padding: 0; + box-shadow: none; + margin: 0; + } + + li { + position: relative; + vertical-align: middle; + padding: 0; + + @include respond(md) { + width: 100%; + } + + svg { + stroke: currentColor; + stroke-width: 1.33; + width: 20px; + height: 20px; + } + + a { + height: 100%; + display: inline-flex; + align-items: center; + color: var(--body-text-color); + gap: var(--menu-icon-separation); + } + + span { + flex: 1; + } + + &.current { + a { + color: var(--accent-color); + font-weight: bold; + } + } + + &.menu-bottom-section { + margin-top: auto; + + ol { + display: flex; + padding-left: 0; + } + } + } +} + +.menu-social { + list-style: none; + padding: 0; + margin: 0; + display: flex; + flex-direction: row; + gap: 10px; + + svg { + width: 24px; + height: 24px; + stroke: var(--body-text-color); + stroke-width: 1.33; + } +} diff --git a/themes/hugo-theme-stack/assets/scss/partials/pagination.scss b/themes/hugo-theme-stack/assets/scss/partials/pagination.scss new file mode 100644 index 0000000..ca46780 --- /dev/null +++ b/themes/hugo-theme-stack/assets/scss/partials/pagination.scss @@ -0,0 +1,21 @@ +.pagination { + display: flex; + background-color: var(--card-background); + box-shadow: var(--shadow-l1); + border-radius: var(--card-border-radius); + overflow: hidden; + flex-wrap: wrap; + + .page-link { + padding: 16px 32px; + display: inline-flex; + + &.current { + font-weight: bold; + background-color: var(--card-background-selected); + color: var(--card-text-color-main); + } + + color: var(--card-text-color-secondary); + } +} diff --git a/themes/hugo-theme-stack/assets/scss/partials/sidebar.scss b/themes/hugo-theme-stack/assets/scss/partials/sidebar.scss new file mode 100644 index 0000000..a6a77c5 --- /dev/null +++ b/themes/hugo-theme-stack/assets/scss/partials/sidebar.scss @@ -0,0 +1,199 @@ +.sidebar { + &.sticky { + @include respond(md) { + position: sticky; + } + } +} + +.left-sidebar { + display: flex; + flex-direction: column; + flex-shrink: 0; + align-self: stretch; + gap: var(--sidebar-element-separation); + max-width: none; + width: 100%; + position: relative; + + --sidebar-avatar-size: 100px; + --sidebar-element-separation: 20px; + --emoji-size: 40px; + --emoji-font-size: 20px; + + @include respond(md) { + width: auto; + padding-top: var(--main-top-padding); + padding-bottom: var(--main-top-padding); + max-height: 100vh; + } + + @include respond(2xl) { + --sidebar-avatar-size: 120px; + --sidebar-element-separation: 25px; + --emoji-size: 40px; + } + + &.sticky { + top: 0; + } + + &.compact { + --sidebar-avatar-size: 80px; + --emoji-size: 30px; + --emoji-font-size: 15px; + + header { + @include respond(lg) { + flex-direction: row; + } + + .site-meta { + gap: 5px; + } + + .site-name { + font-size: 1.4rem; + + @include respond(2xl) { + font-size: 1.75rem; + } + } + + .site-description { + font-size: 1.4rem; + } + } + } +} + +.right-sidebar { + width: 100%; + display: none; + flex-direction: column; + gap: var(--widget-separation); + + &.sticky { + top: 0; + } + + @include respond(lg) { + padding-top: var(--main-top-padding); + padding-bottom: var(--main-top-padding); + } +} + +.sidebar header { + z-index: 1; + transition: box-shadow 0.5s ease; + display: flex; + flex-direction: column; + gap: var(--sidebar-element-separation); + + @include respond(md) { + padding: 0; + } + + .site-avatar { + position: relative; + margin: 0; + width: var(--sidebar-avatar-size); + height: var(--sidebar-avatar-size); + flex-shrink: 0; + + .site-logo { + width: 100%; + height: 100%; + border-radius: 100%; + box-shadow: var(--shadow-l1); + } + + .emoji { + position: absolute; + width: var(--emoji-size); + height: var(--emoji-size); + line-height: var(--emoji-size); + border-radius: 100%; + bottom: 0; + right: 0; + text-align: center; + font-size: var(--emoji-font-size); + background-color: var(--card-background); + box-shadow: var(--shadow-l2); + } + } + + .site-meta { + display: flex; + flex-direction: column; + gap: 10px; + justify-content: center; + } + + .site-name { + color: var(--accent-color); + margin: 0; + font-size: 1.6rem; + + @include respond(2xl) { + font-size: 1.8rem; + } + } + + .site-description { + color: var(--body-text-color); + font-weight: normal; + margin: 0; + font-size: 1.4rem; + + @include respond(2xl) { + font-size: 1.6rem; + } + } +} + +[data-scheme="dark"] { + #dark-mode-toggle { + color: var(--accent-color); + font-weight: 700; + + .icon-tabler-toggle-left { + display: none; + } + + .icon-tabler-toggle-right { + display: unset; + } + } +} + +#dark-mode-toggle { + margin-top: auto; + color: var(--body-text-color); + display: flex; + align-items: center; + cursor: pointer; + gap: var(--menu-icon-separation); + + .icon-tabler-toggle-right { + display: none; + } +} + +#i18n-switch { + color: var(--body-text-color); + display: inline-flex; + align-content: center; + gap: var(--menu-icon-separation); + + select { + border: 0; + background-color: transparent; + color: var(--body-text-color); + + option { + color: var(--card-text-color-main); + background-color: var(--card-background); + } + } +} diff --git a/themes/hugo-theme-stack/assets/scss/partials/widgets.scss b/themes/hugo-theme-stack/assets/scss/partials/widgets.scss new file mode 100644 index 0000000..42cfcc2 --- /dev/null +++ b/themes/hugo-theme-stack/assets/scss/partials/widgets.scss @@ -0,0 +1,67 @@ +.widget { + display: flex; + flex-direction: column; + + .widget-icon { + svg { + width: 32px; + height: 32px; + stroke-width: 1.6; + color: var(--body-text-color); + } + } +} + +/* Tag cloud widget */ +.tagCloud { + .tagCloud-tags { + display: flex; + flex-wrap: wrap; + gap: 10px; + + a { + background: var(--card-background); + box-shadow: var(--shadow-l1); + border-radius: var(--tag-border-radius); + padding: 8px 20px; + color: var(--card-text-color-main); + font-size: 1.4rem; + transition: box-shadow 0.3s ease; + + &:hover { + box-shadow: var(--shadow-l2); + } + } + } +} + +/* Archives widget */ +.widget.archives { + .widget-archive--list { + border-radius: var(--card-border-radius); + box-shadow: var(--shadow-l1); + background-color: var(--card-background); + } + + .archives-year { + &:not(:last-of-type) { + border-bottom: 1.5px solid var(--card-separator-color); + } + + a { + font-size: 1.4rem; + padding: 18px 25px; + display: flex; + + span.year { + flex: 1; + color: var(--card-text-color-main); + font-weight: bold; + } + + span.count { + color: var(--card-text-color-tertiary); + } + } + } +} diff --git a/themes/hugo-theme-stack/assets/scss/style.scss b/themes/hugo-theme-stack/assets/scss/style.scss new file mode 100644 index 0000000..e50d400 --- /dev/null +++ b/themes/hugo-theme-stack/assets/scss/style.scss @@ -0,0 +1,28 @@ +/*! +* Hugo Theme Stack +* +* @author: Jimmy Cai +* @website: https://jimmycai.com +* @link: https://github.com/CaiJimmy/hugo-theme-stack +*/ + +@import "breakpoints.scss"; +@import "variables.scss"; +@import "grid.scss"; + +@import "external/normalize.scss"; + +@import "partials/menu.scss"; +@import "partials/article.scss"; +@import "partials/widgets.scss"; +@import "partials/footer.scss"; +@import "partials/pagination.scss"; +@import "partials/sidebar.scss"; +@import "partials/base.scss"; +@import "partials/layout/article.scss"; +@import "partials/layout/list.scss"; +@import "partials/layout/404.scss"; +@import "partials/layout/search.scss"; + +@import "general.scss"; +@import "custom.scss"; diff --git a/themes/hugo-theme-stack/assets/scss/variables.scss b/themes/hugo-theme-stack/assets/scss/variables.scss new file mode 100644 index 0000000..97810a1 --- /dev/null +++ b/themes/hugo-theme-stack/assets/scss/variables.scss @@ -0,0 +1,167 @@ +$defaultTagBackgrounds: #8ea885, #df7988, #0177b8, #ffb900, #6b69d6; +$defaultTagColors: #fff, #fff, #fff, #fff, #fff; + +/* +* Global style +*/ +:root { + --main-top-padding: 35px; + + @include respond(xl) { + --main-top-padding: 50px; + } + + --body-background: #f5f5fa; + + --accent-color: #34495e; + --accent-color-darker: #2c3e50; + --accent-color-text: #fff; + --body-text-color: #707070; + + --tag-border-radius: 4px; + + --section-separation: 40px; + + --scrollbar-thumb: hsl(0, 0%, 85%); + --scrollbar-track: var(--body-background); + + &[data-scheme="dark"] { + --body-background: #303030; + --accent-color: #ecf0f1; + --accent-color-darker: #bdc3c7; + --accent-color-text: #000; + --body-text-color: rgba(255, 255, 255, 0.7); + --scrollbar-thumb: hsl(0, 0%, 40%); + --scrollbar-track: var(--body-background); + } +} + +/** +* Global font family +*/ +:root { + --sys-font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Droid Sans", "Helvetica Neue"; + --zh-font-family: "PingFang SC", "Hiragino Sans GB", "Droid Sans Fallback", "Microsoft YaHei"; + + --base-font-family: "Lato", var(--sys-font-family), var(--zh-font-family), sans-serif; + --code-font-family: Menlo, Monaco, Consolas, "Courier New", var(--zh-font-family), monospace; +} + +/* +* Card style +*/ +:root { + --card-background: #fff; + --card-background-selected: #eaeaea; + + --card-text-color-main: #000; + --card-text-color-secondary: #747474; + --card-text-color-tertiary: #767676; + --card-separator-color: rgba(218, 218, 218, 0.5); + + --card-border-radius: 10px; + + --card-padding: 20px; + + @include respond(md) { + --card-padding: 25px; + } + + @include respond(xl) { + --card-padding: 30px; + } + + --small-card-padding: 25px 20px; + + @include respond(md) { + --small-card-padding: 25px; + } + + &[data-scheme="dark"] { + --card-background: #424242; + --card-background-selected: rgba(255, 255, 255, 0.16); + --card-text-color-main: rgba(255, 255, 255, 0.9); + --card-text-color-secondary: rgba(255, 255, 255, 0.7); + --card-text-color-tertiary: rgba(255, 255, 255, 0.5); + --card-separator-color: rgba(255, 255, 255, 0.12); + } +} + +/** +* Article content font settings +*/ +:root { + --article-font-family: var(--base-font-family); + --article-font-size: 1.6rem; + + @include respond(md) { + --article-font-size: 1.7rem; + } + + --article-line-height: 1.85; +} + +/* +* Article content style +*/ +:root { + --blockquote-border-size: 4px; + --blockquote-background-color: rgb(248 248 248); + + --heading-border-size: 4px; + + --link-background-color: 189, 195, 199; + --link-background-opacity: 0.5; + --link-background-opacity-hover: 0.7; + + --pre-background-color: #272822; + --pre-text-color: #f8f8f2; + + --code-background-color: rgba(0, 0, 0, 0.12); + --code-text-color: #808080; + + --table-border-color: #dadada; + --tr-even-background-color: #efefee; + + --kbd-border-color: #dadada; + + &[data-scheme="dark"] { + --code-background-color: #272822; + --code-text-color: rgba(255, 255, 255, 0.9); + + --table-border-color: #717171; + --tr-even-background-color: #545454; + + --blockquote-background-color: rgb(75 75 75); + } +} + +/* +* Shadow style +* Thanks to https://www.figma.com/community/plugin/744987207861965946/Shadow-picker +*/ +:root { + --shadow-l1: 0px 4px 8px rgba(0, 0, 0, 0.04), 0px 0px 2px rgba(0, 0, 0, 0.06), 0px 0px 1px rgba(0, 0, 0, 0.04); + --shadow-l2: 0px 10px 20px rgba(0, 0, 0, 0.04), 0px 2px 6px rgba(0, 0, 0, 0.04), 0px 0px 1px rgba(0, 0, 0, 0.04); + --shadow-l3: 0px 10px 20px rgba(0, 0, 0, 0.04), 0px 2px 6px rgba(0, 0, 0, 0.04), 0px 0px 1px rgba(0, 0, 0, 0.04); + --shadow-l4: 0px 24px 32px rgba(0, 0, 0, 0.04), 0px 16px 24px rgba(0, 0, 0, 0.04), 0px 4px 8px rgba(0, 0, 0, 0.04), + 0px 0px 1px rgba(0, 0, 0, 0.04); +} + +[data-scheme="light"] { + --pre-text-color: #272822; + --pre-background-color: #fafafa; + @import "partials/highlight/light.scss"; +} + +[data-scheme="dark"] { + --pre-text-color: #f8f8f2; + --pre-background-color: #272822; + @import "partials/highlight/dark.scss"; +} + +:root { + --menu-icon-separation: 40px; + --container-padding: 15px; + --widget-separation: var(--section-separation); +} diff --git a/themes/hugo-theme-stack/assets/ts/color.ts b/themes/hugo-theme-stack/assets/ts/color.ts new file mode 100644 index 0000000..50581d1 --- /dev/null +++ b/themes/hugo-theme-stack/assets/ts/color.ts @@ -0,0 +1,63 @@ +interface colorScheme { + hash: string, /// Regenerate color scheme when the image hash is changed + DarkMuted: { + hex: string, + rgb: Number[], + bodyTextColor: string + }, + Vibrant: { + hex: string, + rgb: Number[], + bodyTextColor: string + } +} + +let colorsCache: { [key: string]: colorScheme } = {}; + +if (localStorage.hasOwnProperty('StackColorsCache')) { + try { + colorsCache = JSON.parse(localStorage.getItem('StackColorsCache')); + } + catch (e) { + colorsCache = {}; + } +} + +async function getColor(key: string, hash: string, imageURL: string) { + if (!key) { + /** + * If no key is provided, do not cache the result + */ + return await Vibrant.from(imageURL).getPalette(); + } + + if (!colorsCache.hasOwnProperty(key) || colorsCache[key].hash !== hash) { + /** + * If key is provided, but not found in cache, or the hash mismatches => Regenerate color scheme + */ + const palette = await Vibrant.from(imageURL).getPalette(); + + colorsCache[key] = { + hash: hash, + Vibrant: { + hex: palette.Vibrant.hex, + rgb: palette.Vibrant.rgb, + bodyTextColor: palette.Vibrant.bodyTextColor + }, + DarkMuted: { + hex: palette.DarkMuted.hex, + rgb: palette.DarkMuted.rgb, + bodyTextColor: palette.DarkMuted.bodyTextColor + } + } + + /* Save the result in localStorage */ + localStorage.setItem('StackColorsCache', JSON.stringify(colorsCache)); + } + + return colorsCache[key]; +} + +export { + getColor +} \ No newline at end of file diff --git a/themes/hugo-theme-stack/assets/ts/colorScheme.ts b/themes/hugo-theme-stack/assets/ts/colorScheme.ts new file mode 100644 index 0000000..8cb8a20 --- /dev/null +++ b/themes/hugo-theme-stack/assets/ts/colorScheme.ts @@ -0,0 +1,88 @@ +type colorScheme = 'light' | 'dark' | 'auto'; + +class StackColorScheme { + private localStorageKey = 'StackColorScheme'; + private currentScheme: colorScheme; + private systemPreferScheme: colorScheme; + + constructor(toggleEl: HTMLElement) { + this.bindMatchMedia(); + this.currentScheme = this.getSavedScheme(); + + this.dispatchEvent(document.documentElement.dataset.scheme as colorScheme); + + if (toggleEl) + this.bindClick(toggleEl); + + if (document.body.style.transition == '') + document.body.style.setProperty('transition', 'background-color .3s ease'); + } + + private saveScheme() { + localStorage.setItem(this.localStorageKey, this.currentScheme); + } + + private bindClick(toggleEl: HTMLElement) { + toggleEl.addEventListener('click', (e) => { + if (this.isDark()) { + /// Disable dark mode + this.currentScheme = 'light'; + } + else { + this.currentScheme = 'dark'; + } + + this.setBodyClass(); + + if (this.currentScheme == this.systemPreferScheme) { + /// Set to auto + this.currentScheme = 'auto'; + } + + this.saveScheme(); + }) + } + + private isDark() { + return (this.currentScheme == 'dark' || this.currentScheme == 'auto' && this.systemPreferScheme == 'dark'); + } + + private dispatchEvent(colorScheme: colorScheme) { + const event = new CustomEvent('onColorSchemeChange', { + detail: colorScheme + }); + window.dispatchEvent(event); + } + + private setBodyClass() { + if (this.isDark()) { + document.documentElement.dataset.scheme = 'dark'; + } + else { + document.documentElement.dataset.scheme = 'light'; + } + + this.dispatchEvent(document.documentElement.dataset.scheme as colorScheme); + } + + private getSavedScheme(): colorScheme { + const savedScheme = localStorage.getItem(this.localStorageKey); + + if (savedScheme == 'light' || savedScheme == 'dark' || savedScheme == 'auto') return savedScheme; + else return 'auto'; + } + + private bindMatchMedia() { + window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change', (e) => { + if (e.matches) { + this.systemPreferScheme = 'dark'; + } + else { + this.systemPreferScheme = 'light'; + } + this.setBodyClass(); + }); + } +} + +export default StackColorScheme; diff --git a/themes/hugo-theme-stack/assets/ts/createElement.ts b/themes/hugo-theme-stack/assets/ts/createElement.ts new file mode 100644 index 0000000..3a1e85e --- /dev/null +++ b/themes/hugo-theme-stack/assets/ts/createElement.ts @@ -0,0 +1,34 @@ +/** + * createElement + * Edited from: + * @link https://stackoverflow.com/a/42405694 + */ +function createElement(tag, attrs, children) { + var element = document.createElement(tag); + + for (let name in attrs) { + if (name && attrs.hasOwnProperty(name)) { + let value = attrs[name]; + + if (name == "dangerouslySetInnerHTML") { + element.innerHTML = value.__html; + } + else if (value === true) { + element.setAttribute(name, name); + } else if (value !== false && value != null) { + element.setAttribute(name, value.toString()); + } + } + } + for (let i = 2; i < arguments.length; i++) { + let child = arguments[i]; + if (child) { + element.appendChild( + child.nodeType == null ? + document.createTextNode(child.toString()) : child); + } + } + return element; +} + +export default createElement; \ No newline at end of file diff --git a/themes/hugo-theme-stack/assets/ts/gallery.ts b/themes/hugo-theme-stack/assets/ts/gallery.ts new file mode 100644 index 0000000..9840f1e --- /dev/null +++ b/themes/hugo-theme-stack/assets/ts/gallery.ts @@ -0,0 +1,186 @@ +declare global { + interface Window { + PhotoSwipe: any; + PhotoSwipeUI_Default: any + } +} + +interface PhotoSwipeItem { + w: number; + h: number; + src: string; + msrc: string; + title?: string; + el: HTMLElement; +} + +class StackGallery { + private galleryUID: number; + private items: PhotoSwipeItem[] = []; + + constructor(container: HTMLElement, galleryUID = 1) { + if (window.PhotoSwipe == undefined || window.PhotoSwipeUI_Default == undefined) { + console.error("PhotoSwipe lib not loaded."); + return; + } + + this.galleryUID = galleryUID; + + StackGallery.createGallery(container); + this.loadItems(container); + this.bindClick(); + } + + private loadItems(container: HTMLElement) { + this.items = []; + + const figures = container.querySelectorAll('figure.gallery-image'); + + for (const el of figures) { + const figcaption = el.querySelector('figcaption'), + img = el.querySelector('img'); + + let aux: PhotoSwipeItem = { + w: parseInt(img.getAttribute('width')), + h: parseInt(img.getAttribute('height')), + src: img.src, + msrc: img.getAttribute('data-thumb') || img.src, + el: el + } + + if (figcaption) { + aux.title = figcaption.innerHTML; + } + + this.items.push(aux); + } + } + + public static createGallery(container: HTMLElement) { + /// The process of wrapping image with figure tag is done using JavaScript instead of only Hugo markdown render hook + /// because it can not detect whether image is being wrapped by a link or not + /// and it lead to a invalid HTML construction (
) + + const images = container.querySelectorAll('img.gallery-image'); + for (const img of Array.from(images)) { + /// Images are wrapped with figure tag if the paragraph has only images without texts + /// This is done to allow inline images within paragraphs + const paragraph = img.closest('p'); + + if (!paragraph || !container.contains(paragraph)) continue; + + if (paragraph.textContent.trim() == '') { + /// Once we insert figcaption, this check no longer works + /// So we add a class to paragraph to mark it + paragraph.classList.add('no-text'); + } + + let isNewLineImage = paragraph.classList.contains('no-text'); + if (!isNewLineImage) continue; + + const hasLink = img.parentElement.tagName == 'A'; + + let el: HTMLElement = img; + /// Wrap image with figure tag, with flex-grow and flex-basis values extracted from img's data attributes + const figure = document.createElement('figure'); + figure.style.setProperty('flex-grow', img.getAttribute('data-flex-grow') || '1'); + figure.style.setProperty('flex-basis', img.getAttribute('data-flex-basis') || '0'); + if (hasLink) { + /// Wrap if it exists + el = img.parentElement; + } + el.parentElement.insertBefore(figure, el); + figure.appendChild(el); + + /// Add figcaption if it exists + if (img.hasAttribute('alt')) { + const figcaption = document.createElement('figcaption'); + figcaption.innerText = img.getAttribute('alt'); + figure.appendChild(figcaption); + } + + /// Wrap img tag with tag if image was not wrapped by tag + if (!hasLink) { + figure.className = 'gallery-image'; + + const a = document.createElement('a'); + a.href = img.src; + a.setAttribute('target', '_blank'); + img.parentNode.insertBefore(a, img); + a.appendChild(img); + } + } + + const figuresEl = container.querySelectorAll('figure.gallery-image'); + + let currentGallery = []; + + for (const figure of figuresEl) { + if (!currentGallery.length) { + /// First iteration + currentGallery = [figure]; + } + else if (figure.previousElementSibling === currentGallery[currentGallery.length - 1]) { + /// Adjacent figures + currentGallery.push(figure); + } + else if (currentGallery.length) { + /// End gallery + StackGallery.wrap(currentGallery); + currentGallery = [figure]; + } + } + + if (currentGallery.length > 0) { + StackGallery.wrap(currentGallery); + } + } + + /** + * Wrap adjacent figure tags with div.gallery + * @param figures + */ + public static wrap(figures: HTMLElement[]) { + const galleryContainer = document.createElement('div'); + galleryContainer.className = 'gallery'; + + const parentNode = figures[0].parentNode, + first = figures[0]; + + parentNode.insertBefore(galleryContainer, first) + + for (const figure of figures) { + galleryContainer.appendChild(figure); + } + } + + public open(index: number) { + const pswp = document.querySelector('.pswp') as HTMLDivElement; + const ps = new window.PhotoSwipe(pswp, window.PhotoSwipeUI_Default, this.items, { + index: index, + galleryUID: this.galleryUID, + getThumbBoundsFn: (index) => { + const thumbnail = this.items[index].el.getElementsByTagName('img')[0], + pageYScroll = window.pageYOffset || document.documentElement.scrollTop, + rect = thumbnail.getBoundingClientRect(); + + return { x: rect.left, y: rect.top + pageYScroll, w: rect.width }; + } + }); + + ps.init(); + } + + private bindClick() { + for (const [index, item] of this.items.entries()) { + const a = item.el.querySelector('a'); + + a.addEventListener('click', (e) => { + e.preventDefault(); + this.open(index); + }) + } + } +} + +export default StackGallery; \ No newline at end of file diff --git a/themes/hugo-theme-stack/assets/ts/main.ts b/themes/hugo-theme-stack/assets/ts/main.ts new file mode 100644 index 0000000..f3160ae --- /dev/null +++ b/themes/hugo-theme-stack/assets/ts/main.ts @@ -0,0 +1,112 @@ +/*! +* Hugo Theme Stack +* +* @author: Jimmy Cai +* @website: https://jimmycai.com +* @link: https://github.com/CaiJimmy/hugo-theme-stack +*/ +import StackGallery from "ts/gallery"; +import { getColor } from 'ts/color'; +import menu from 'ts/menu'; +import createElement from 'ts/createElement'; +import StackColorScheme from 'ts/colorScheme'; +import { setupScrollspy } from 'ts/scrollspy'; +import { setupSmoothAnchors } from "ts/smoothAnchors"; + +let Stack = { + init: () => { + /** + * Bind menu event + */ + menu(); + + const articleContent = document.querySelector('.article-content') as HTMLElement; + if (articleContent) { + new StackGallery(articleContent); + setupSmoothAnchors(); + setupScrollspy(); + } + + /** + * Add linear gradient background to tile style article + */ + const articleTile = document.querySelector('.article-list--tile'); + if (articleTile) { + let observer = new IntersectionObserver(async (entries, observer) => { + entries.forEach(entry => { + if (!entry.isIntersecting) return; + observer.unobserve(entry.target); + + const articles = entry.target.querySelectorAll('article.has-image'); + articles.forEach(async articles => { + const image = articles.querySelector('img'), + imageURL = image.src, + key = image.getAttribute('data-key'), + hash = image.getAttribute('data-hash'), + articleDetails: HTMLDivElement = articles.querySelector('.article-details'); + + const colors = await getColor(key, hash, imageURL); + + articleDetails.style.background = ` + linear-gradient(0deg, + rgba(${colors.DarkMuted.rgb[0]}, ${colors.DarkMuted.rgb[1]}, ${colors.DarkMuted.rgb[2]}, 0.5) 0%, + rgba(${colors.Vibrant.rgb[0]}, ${colors.Vibrant.rgb[1]}, ${colors.Vibrant.rgb[2]}, 0.75) 100%)`; + }) + }) + }); + + observer.observe(articleTile) + } + + + /** + * Add copy button to code block + */ + const highlights = document.querySelectorAll('.article-content div.highlight'); + const copyText = `Copy`, + copiedText = `Copied!`; + + highlights.forEach(highlight => { + const copyButton = document.createElement('button'); + copyButton.innerHTML = copyText; + copyButton.classList.add('copyCodeButton'); + highlight.appendChild(copyButton); + + const codeBlock = highlight.querySelector('code[data-lang]'); + if (!codeBlock) return; + + copyButton.addEventListener('click', () => { + navigator.clipboard.writeText(codeBlock.textContent) + .then(() => { + copyButton.textContent = copiedText; + + setTimeout(() => { + copyButton.textContent = copyText; + }, 1000); + }) + .catch(err => { + alert(err) + console.log('Something went wrong', err); + }); + }); + }); + + new StackColorScheme(document.getElementById('dark-mode-toggle')); + } +} + +window.addEventListener('load', () => { + setTimeout(function () { + Stack.init(); + }, 0); +}) + +declare global { + interface Window { + createElement: any; + Stack: any + } +} + +window.Stack = Stack; +window.createElement = createElement; \ No newline at end of file diff --git a/themes/hugo-theme-stack/assets/ts/menu.ts b/themes/hugo-theme-stack/assets/ts/menu.ts new file mode 100644 index 0000000..34615ba --- /dev/null +++ b/themes/hugo-theme-stack/assets/ts/menu.ts @@ -0,0 +1,83 @@ +/** + * Slide up/down + * Code from https://dev.to/bmsvieira/vanilla-js-slidedown-up-4dkn + * @param target + * @param duration + */ +let slideUp = (target: HTMLElement, duration = 500) => { + target.classList.add('transiting'); + target.style.transitionProperty = 'height, margin, padding'; + target.style.transitionDuration = duration + 'ms'; + ///target.style.boxSizing = 'border-box'; + target.style.height = target.offsetHeight + 'px'; + target.offsetHeight; + target.style.overflow = 'hidden'; + target.style.height = "0"; + target.style.paddingTop = "0"; + target.style.paddingBottom = "0"; + target.style.marginTop = "0"; + target.style.marginBottom = "0"; + window.setTimeout(() => { + target.classList.remove('show') + target.style.removeProperty('height'); + target.style.removeProperty('padding-top'); + target.style.removeProperty('padding-bottom'); + target.style.removeProperty('margin-top'); + target.style.removeProperty('margin-bottom'); + target.style.removeProperty('overflow'); + target.style.removeProperty('transition-duration'); + target.style.removeProperty('transition-property'); + target.classList.remove('transiting'); + }, duration); +} + +let slideDown = (target: HTMLElement, duration = 500) => { + target.classList.add('transiting'); + target.style.removeProperty('display'); + + target.classList.add('show'); + + let height = target.offsetHeight; + target.style.overflow = 'hidden'; + target.style.height = "0"; + target.style.paddingTop = "0"; + target.style.paddingBottom = "0"; + target.style.marginTop = "0"; + target.style.marginBottom = "0"; + target.offsetHeight; + ///target.style.boxSizing = 'border-box'; + target.style.transitionProperty = "height, margin, padding"; + target.style.transitionDuration = duration + 'ms'; + target.style.height = height + 'px'; + target.style.removeProperty('padding-top'); + target.style.removeProperty('padding-bottom'); + target.style.removeProperty('margin-top'); + target.style.removeProperty('margin-bottom'); + window.setTimeout(() => { + target.style.removeProperty('height'); + target.style.removeProperty('overflow'); + target.style.removeProperty('transition-duration'); + target.style.removeProperty('transition-property'); + target.classList.remove('transiting'); + }, duration); +} + +let slideToggle = (target, duration = 500) => { + if (window.getComputedStyle(target).display === 'none') { + return slideDown(target, duration); + } else { + return slideUp(target, duration); + } +} + +export default function () { + const toggleMenu = document.getElementById('toggle-menu'); + if (toggleMenu) { + toggleMenu.addEventListener('click', () => { + if (document.getElementById('main-menu').classList.contains('transiting')) return; + document.body.classList.toggle('show-menu'); + slideToggle(document.getElementById('main-menu'), 300); + toggleMenu.classList.toggle('is-active'); + }); + } +} \ No newline at end of file diff --git a/themes/hugo-theme-stack/assets/ts/scrollspy.ts b/themes/hugo-theme-stack/assets/ts/scrollspy.ts new file mode 100644 index 0000000..8a14085 --- /dev/null +++ b/themes/hugo-theme-stack/assets/ts/scrollspy.ts @@ -0,0 +1,131 @@ +// Implements a scroll spy system for the ToC, displaying the current section with an indicator and scrolling to it when needed. + +// Inspired from https://gomakethings.com/debouncing-your-javascript-events/ +function debounced(func: Function) { + let timeout; + return () => { + if (timeout) { + window.cancelAnimationFrame(timeout); + } + + timeout = window.requestAnimationFrame(() => func()); + } +} + +const headersQuery = ".article-content h1[id], .article-content h2[id], .article-content h3[id], .article-content h4[id], .article-content h5[id], .article-content h6[id]"; +const tocQuery = "#TableOfContents"; +const navigationQuery = "#TableOfContents li"; +const activeClass = "active-class"; + +function scrollToTocElement(tocElement: HTMLElement, scrollableNavigation: HTMLElement) { + let textHeight = tocElement.querySelector("a").offsetHeight; + let scrollTop = tocElement.offsetTop - scrollableNavigation.offsetHeight / 2 + textHeight / 2 - scrollableNavigation.offsetTop; + if (scrollTop < 0) { + scrollTop = 0; + } + scrollableNavigation.scrollTo({ top: scrollTop, behavior: "smooth" }); +} + +type IdToElementMap = { [key: string]: HTMLElement }; + +function buildIdToNavigationElementMap(navigation: NodeListOf): IdToElementMap { + const sectionLinkRef: IdToElementMap = {}; + navigation.forEach((navigationElement: HTMLElement) => { + const link = navigationElement.querySelector("a"); + const href = link.getAttribute("href"); + if (href.startsWith("#")) { + sectionLinkRef[href.slice(1)] = navigationElement; + } + }); + + return sectionLinkRef; +} + +function computeOffsets(headers: NodeListOf) { + let sectionsOffsets = []; + headers.forEach((header: HTMLElement) => { sectionsOffsets.push({ id: header.id, offset: header.offsetTop }) }); + sectionsOffsets.sort((a, b) => a.offset - b.offset); + return sectionsOffsets; +} + +function setupScrollspy() { + let headers = document.querySelectorAll(headersQuery); + if (!headers) { + console.warn("No header matched query", headers); + return; + } + + let scrollableNavigation = document.querySelector(tocQuery) as HTMLElement | undefined; + if (!scrollableNavigation) { + console.warn("No toc matched query", tocQuery); + return; + } + + let navigation = document.querySelectorAll(navigationQuery); + if (!navigation) { + console.warn("No navigation matched query", navigationQuery); + return; + } + + let sectionsOffsets = computeOffsets(headers); + + // We need to avoid scrolling when the user is actively interacting with the ToC. Otherwise, if the user clicks on a link in the ToC, + // we would scroll their view, which is not optimal usability-wise. + let tocHovered: boolean = false; + scrollableNavigation.addEventListener("mouseenter", debounced(() => tocHovered = true)); + scrollableNavigation.addEventListener("mouseleave", debounced(() => tocHovered = false)); + + let activeSectionLink: Element; + + let idToNavigationElement: IdToElementMap = buildIdToNavigationElementMap(navigation); + + function scrollHandler() { + let scrollPosition = document.documentElement.scrollTop || document.body.scrollTop; + + let newActiveSection: HTMLElement | undefined; + + // Find the section that is currently active. + // It is possible for no section to be active, so newActiveSection may be undefined. + sectionsOffsets.forEach((section) => { + if (scrollPosition >= section.offset - 20) { + newActiveSection = document.getElementById(section.id); + } + }); + + // Find the link for the active section. Once again, there are a few edge cases: + // - No active section = no link => undefined + // - No active section but the link does not exist in toc (e.g. because it is outside of the applicable ToC levels) => undefined + let newActiveSectionLink: HTMLElement | undefined + if (newActiveSection) { + newActiveSectionLink = idToNavigationElement[newActiveSection.id]; + } + + if (newActiveSection && !newActiveSectionLink) { + // The active section does not have a link in the ToC, so we can't scroll to it. + console.debug("No link found for section", newActiveSection); + } else if (newActiveSectionLink !== activeSectionLink) { + if (activeSectionLink) + activeSectionLink.classList.remove(activeClass); + if (newActiveSectionLink) { + newActiveSectionLink.classList.add(activeClass); + if (!tocHovered) { + // Scroll so that newActiveSectionLink is in the middle of scrollableNavigation, except when it's from a manual click (hence the tocHovered check) + scrollToTocElement(newActiveSectionLink, scrollableNavigation); + } + } + activeSectionLink = newActiveSectionLink; + } + } + + window.addEventListener("scroll", debounced(scrollHandler)); + + // Resizing may cause the offset values to change: recompute them. + function resizeHandler() { + sectionsOffsets = computeOffsets(headers); + scrollHandler(); + } + + window.addEventListener("resize", debounced(resizeHandler)); +} + +export { setupScrollspy }; \ No newline at end of file diff --git a/themes/hugo-theme-stack/assets/ts/search.tsx b/themes/hugo-theme-stack/assets/ts/search.tsx new file mode 100644 index 0000000..856b48d --- /dev/null +++ b/themes/hugo-theme-stack/assets/ts/search.tsx @@ -0,0 +1,326 @@ +interface pageData { + title: string, + date: string, + permalink: string, + content: string, + image?: string, + preview: string, + matchCount: number +} + +interface match { + start: number, + end: number +} + +/** + * Escape HTML tags as HTML entities + * Edited from: + * @link https://stackoverflow.com/a/5499821 + */ +const tagsToReplace = { + '&': '&', + '<': '<', + '>': '>', + '"': '"', + '…': '…' +}; + +function replaceTag(tag) { + return tagsToReplace[tag] || tag; +} + +function replaceHTMLEnt(str) { + return str.replace(/[&<>"]/g, replaceTag); +} + +function escapeRegExp(string) { + return string.replace(/[.*+\-?^${}()|[\]\\]/g, '\\$&'); +} + +class Search { + private data: pageData[]; + private form: HTMLFormElement; + private input: HTMLInputElement; + private list: HTMLDivElement; + private resultTitle: HTMLHeadElement; + private resultTitleTemplate: string; + + constructor({ form, input, list, resultTitle, resultTitleTemplate }) { + this.form = form; + this.input = input; + this.list = list; + this.resultTitle = resultTitle; + this.resultTitleTemplate = resultTitleTemplate; + + this.handleQueryString(); + this.bindQueryStringChange(); + this.bindSearchForm(); + } + + /** + * Processes search matches + * @param str original text + * @param matches array of matches + * @param ellipsis whether to add ellipsis to the end of each match + * @param charLimit max length of preview string + * @param offset how many characters before and after the match to include in preview + * @returns preview string + */ + private static processMatches(str: string, matches: match[], ellipsis: boolean = true, charLimit = 140, offset = 20): string { + matches.sort((a, b) => { + return a.start - b.start; + }); + + let i = 0, + lastIndex = 0, + charCount = 0; + + const resultArray: string[] = []; + + while (i < matches.length) { + const item = matches[i]; + + /// item.start >= lastIndex (equal only for the first iteration) + /// because of the while loop that comes after, iterating over variable j + + if (ellipsis && item.start - offset > lastIndex) { + resultArray.push(`${replaceHTMLEnt(str.substring(lastIndex, lastIndex + offset))} [...] `); + resultArray.push(`${replaceHTMLEnt(str.substring(item.start - offset, item.start))}`); + charCount += offset * 2; + } + else { + /// If the match is too close to the end of last match, don't add ellipsis + resultArray.push(replaceHTMLEnt(str.substring(lastIndex, item.start))); + charCount += item.start - lastIndex; + } + + let j = i + 1, + end = item.end; + + /// Include as many matches as possible + /// [item.start, end] is the range of the match + while (j < matches.length && matches[j].start <= end) { + end = Math.max(matches[j].end, end); + ++j; + } + + resultArray.push(`${replaceHTMLEnt(str.substring(item.start, end))}`); + charCount += end - item.start; + + i = j; + lastIndex = end; + + if (ellipsis && charCount > charLimit) break; + } + + /// Add the rest of the string + if (lastIndex < str.length) { + let end = str.length; + if (ellipsis) end = Math.min(end, lastIndex + offset); + + resultArray.push(`${replaceHTMLEnt(str.substring(lastIndex, end))}`); + + if (ellipsis && end != str.length) { + resultArray.push(` [...]`); + } + } + + return resultArray.join(''); + } + + private async searchKeywords(keywords: string[]) { + const rawData = await this.getData(); + const results: pageData[] = []; + + const regex = new RegExp(keywords.filter((v, index, arr) => { + arr[index] = escapeRegExp(v); + return v.trim() !== ''; + }).join('|'), 'gi'); + + for (const item of rawData) { + const titleMatches: match[] = [], + contentMatches: match[] = []; + + let result = { + ...item, + preview: '', + matchCount: 0 + } + + const contentMatchAll = item.content.matchAll(regex); + for (const match of Array.from(contentMatchAll)) { + contentMatches.push({ + start: match.index, + end: match.index + match[0].length + }); + } + + const titleMatchAll = item.title.matchAll(regex); + for (const match of Array.from(titleMatchAll)) { + titleMatches.push({ + start: match.index, + end: match.index + match[0].length + }); + } + + if (titleMatches.length > 0) result.title = Search.processMatches(result.title, titleMatches, false); + if (contentMatches.length > 0) { + result.preview = Search.processMatches(result.content, contentMatches); + } + else { + /// If there are no matches in the content, use the first 140 characters as preview + result.preview = replaceHTMLEnt(result.content.substring(0, 140)); + } + + result.matchCount = titleMatches.length + contentMatches.length; + if (result.matchCount > 0) results.push(result); + } + + /// Result with more matches appears first + return results.sort((a, b) => { + return b.matchCount - a.matchCount; + }); + } + + private async doSearch(keywords: string[]) { + const startTime = performance.now(); + + const results = await this.searchKeywords(keywords); + this.clear(); + + for (const item of results) { + this.list.append(Search.render(item)); + } + + const endTime = performance.now(); + + this.resultTitle.innerText = this.generateResultTitle(results.length, ((endTime - startTime) / 1000).toPrecision(1)); + } + + private generateResultTitle(resultLen, time) { + return this.resultTitleTemplate.replace("#PAGES_COUNT", resultLen).replace("#TIME_SECONDS", time); + } + + public async getData() { + if (!this.data) { + /// Not fetched yet + const jsonURL = this.form.dataset.json; + this.data = await fetch(jsonURL).then(res => res.json()); + const parser = new DOMParser(); + + for (const item of this.data) { + item.content = parser.parseFromString(item.content, 'text/html').body.innerText; + } + } + + return this.data; + } + + private bindSearchForm() { + let lastSearch = ''; + + const eventHandler = (e) => { + e.preventDefault(); + const keywords = this.input.value.trim(); + + Search.updateQueryString(keywords, true); + + if (keywords === '') { + lastSearch = ''; + return this.clear(); + } + + if (lastSearch === keywords) return; + lastSearch = keywords; + + this.doSearch(keywords.split(' ')); + } + + this.input.addEventListener('input', eventHandler); + this.input.addEventListener('compositionend', eventHandler); + } + + private clear() { + this.list.innerHTML = ''; + this.resultTitle.innerText = ''; + } + + private bindQueryStringChange() { + window.addEventListener('popstate', (e) => { + this.handleQueryString() + }) + } + + private handleQueryString() { + const pageURL = new URL(window.location.toString()); + const keywords = pageURL.searchParams.get('keyword'); + this.input.value = keywords; + + if (keywords) { + this.doSearch(keywords.split(' ')); + } + else { + this.clear() + } + } + + private static updateQueryString(keywords: string, replaceState = false) { + const pageURL = new URL(window.location.toString()); + + if (keywords === '') { + pageURL.searchParams.delete('keyword') + } + else { + pageURL.searchParams.set('keyword', keywords); + } + + if (replaceState) { + window.history.replaceState('', '', pageURL.toString()); + } + else { + window.history.pushState('', '', pageURL.toString()); + } + } + + public static render(item: pageData) { + return ; + } +} + +declare global { + interface Window { + searchResultTitleTemplate: string; + } +} + +window.addEventListener('load', () => { + setTimeout(function () { + const searchForm = document.querySelector('.search-form') as HTMLFormElement, + searchInput = searchForm.querySelector('input') as HTMLInputElement, + searchResultList = document.querySelector('.search-result--list') as HTMLDivElement, + searchResultTitle = document.querySelector('.search-result--title') as HTMLHeadingElement; + + new Search({ + form: searchForm, + input: searchInput, + list: searchResultList, + resultTitle: searchResultTitle, + resultTitleTemplate: window.searchResultTitleTemplate + }); + }, 0); +}) + +export default Search; \ No newline at end of file diff --git a/themes/hugo-theme-stack/assets/ts/smoothAnchors.ts b/themes/hugo-theme-stack/assets/ts/smoothAnchors.ts new file mode 100644 index 0000000..16ab6a3 --- /dev/null +++ b/themes/hugo-theme-stack/assets/ts/smoothAnchors.ts @@ -0,0 +1,37 @@ +// Implements smooth scrolling when clicking on an anchor link. +// This is required instead of using modern CSS because Chromium does not currently support scrolling +// one element with scrollTo while another element is scrolled because of a click on a link. This would +// thus not work with the ToC scrollspy and e.g. footnotes. + +// Here are additional links about this issue: +// - https://stackoverflow.com/questions/49318497/google-chrome-simultaneously-smooth-scrollintoview-with-more-elements-doesn +// - https://stackoverflow.com/questions/57214373/scrollintoview-using-smooth-function-on-multiple-elements-in-chrome +// - https://bugs.chromium.org/p/chromium/issues/detail?id=833617 +// - https://bugs.chromium.org/p/chromium/issues/detail?id=1043933 +// - https://bugs.chromium.org/p/chromium/issues/detail?id=1121151 + +const anchorLinksQuery = "a[href]"; + +function setupSmoothAnchors() { + document.querySelectorAll(anchorLinksQuery).forEach(aElement => { + let href = aElement.getAttribute("href"); + if (!href.startsWith("#")) { + return; + } + aElement.addEventListener("click", clickEvent => { + clickEvent.preventDefault(); + + const targetId = decodeURI(aElement.getAttribute("href").substring(1)), + target = document.getElementById(targetId) as HTMLElement, + offset = target.getBoundingClientRect().top - document.documentElement.getBoundingClientRect().top; + + window.history.pushState({}, "", aElement.getAttribute("href")); + scrollTo({ + top: offset, + behavior: "smooth" + }); + }); + }); +} + +export { setupSmoothAnchors }; \ No newline at end of file diff --git a/themes/hugo-theme-stack/config.yaml b/themes/hugo-theme-stack/config.yaml new file mode 100644 index 0000000..b1a0bff --- /dev/null +++ b/themes/hugo-theme-stack/config.yaml @@ -0,0 +1,149 @@ +module: + hugoVersion: + extended: true + min: "0.87.0" + +params: + mainSections: + - post + featuredImageField: image + rssFullContent: true + favicon: + + footer: + since: + customText: + + dateFormat: + published: Jan 02, 2006 + lastUpdated: Jan 02, 2006 15:04 MST + + sidebar: + compact: false + emoji: + subtitle: + avatar: + enabled: true + local: true + src: img/avatar.png + + article: + headingAnchor: false + math: false + toc: true + readingTime: true + license: + enabled: false + default: Licensed under CC BY-NC-SA 4.0 + + comments: + enabled: false + provider: disqus + + disqusjs: + shortname: + apiUrl: + apiKey: + admin: + adminLabel: + + utterances: + repo: + issueTerm: pathname + label: + + beaudar: + repo: + issueTerm: pathname + label: + theme: + + remark42: + host: + site: + locale: + + vssue: + platform: + owner: + repo: + clientId: + clientSecret: + autoCreateIssue: false + + # Waline client configuration see: https://waline.js.org/en/reference/client/props.html + waline: + serverURL: + lang: + visitor: + avatar: + emoji: + - https://cdn.jsdelivr.net/gh/walinejs/emojis/weibo + requiredMeta: + - nick + - mail + locale: + admin: Admin + placeholder: + + twikoo: + envId: + region: + path: + lang: + + giscus: + repo: + repoID: + category: + categoryID: + mapping: + strict: + lightTheme: + darkTheme: + reactionsEnabled: 1 + emitMetadata: 0 + inputPosition: + lang: + + gitalk: + owner: + admin: + repo: + clientID: + clientSecret: + + cusdis: + host: + id: + + widgets: + homepage: [] + page: [] + + opengraph: + twitter: + # Your Twitter username + site: + + # Available values: summary, summary_large_image + card: summary_large_image + + defaultImage: + opengraph: + enabled: false + local: false + src: + + colorScheme: + # Display toggle + toggle: true + + # Available values: auto, light, dark + default: auto + + imageProcessing: + cover: + enabled: true + content: + enabled: true diff --git a/themes/hugo-theme-stack/data/external.yaml b/themes/hugo-theme-stack/data/external.yaml new file mode 100644 index 0000000..4fc0bca --- /dev/null +++ b/themes/hugo-theme-stack/data/external.yaml @@ -0,0 +1,44 @@ +Vibrant: + - src: https://cdn.jsdelivr.net/npm/node-vibrant@3.1.6/dist/vibrant.min.js + integrity: sha256-awcR2jno4kI5X0zL8ex0vi2z+KMkF24hUW8WePSA9HM= + type: script + +PhotoSwipe: + - src: https://cdn.jsdelivr.net/npm/photoswipe@4.1.3/dist/photoswipe.min.js + integrity: sha256-ePwmChbbvXbsO02lbM3HoHbSHTHFAeChekF1xKJdleo= + type: script + defer: true + + - src: https://cdn.jsdelivr.net/npm/photoswipe@4.1.3/dist/photoswipe-ui-default.min.js + integrity: sha256-UKkzOn/w1mBxRmLLGrSeyB4e1xbrp4xylgAWb3M42pU= + type: script + defer: true + + - src: https://cdn.jsdelivr.net/npm/photoswipe@4.1.3/dist/default-skin/default-skin.min.css + type: style + + - src: https://cdn.jsdelivr.net/npm/photoswipe@4.1.3/dist/photoswipe.min.css + type: style + +KaTeX: + - src: https://cdn.jsdelivr.net/npm/katex@0.16.9/dist/katex.min.css + integrity: sha384-n8MVd4RsNIU0tAv4ct0nTaAbDJwPJzDEaqSD1odI+WdtXRGWt2kTvGFasHpSy3SV + type: style + + - src: https://cdn.jsdelivr.net/npm/katex@0.16.9/dist/katex.min.js + integrity: sha384-XjKyOOlGwcjNTAIQHIpgOno0Hl1YQqzUOEleOLALmuqehneUG+vnGctmUb0ZY0l8 + type: script + defer: true + + - src: https://cdn.jsdelivr.net/npm/katex@0.16.9/dist/contrib/auto-render.min.js + integrity: sha384-+VBxd3r6XgURycqtZ117nYw44OOcIax56Z4dCRWbxyPt0Koah1uHoK0o4+/RRE05 + type: script + defer: true + +Cactus: + - src: https://latest.cactus.chat/cactus.js + integrity: + type: script + - src: https://latest.cactus.chat/style.css + integrity: + type: style diff --git a/themes/hugo-theme-stack/debug.sh b/themes/hugo-theme-stack/debug.sh new file mode 100755 index 0000000..4d1312e --- /dev/null +++ b/themes/hugo-theme-stack/debug.sh @@ -0,0 +1 @@ +cd exampleSite && hugo server --gc --themesDir=../.. \ No newline at end of file diff --git a/themes/hugo-theme-stack/exampleSite/.gitignore b/themes/hugo-theme-stack/exampleSite/.gitignore new file mode 100644 index 0000000..6db5459 --- /dev/null +++ b/themes/hugo-theme-stack/exampleSite/.gitignore @@ -0,0 +1,30 @@ +# Compiled Object files, Static and Dynamic libs (Shared Objects) +*.o +*.a +*.so + +# Folders +_obj +_test + +# Architecture specific extensions/prefixes +*.[568vq] +[568vq].out + +*.cgo1.go +*.cgo2.c +_cgo_defun.c +_cgo_gotypes.go +_cgo_export.* + +_testmain.go + +*.exe +*.test + +public +themes +resources + +assets/jsconfig.json +.DS_Store diff --git a/themes/hugo-theme-stack/exampleSite/LICENSE b/themes/hugo-theme-stack/exampleSite/LICENSE new file mode 100644 index 0000000..4527efb --- /dev/null +++ b/themes/hugo-theme-stack/exampleSite/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2014 Steve Francia + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. \ No newline at end of file diff --git a/themes/hugo-theme-stack/exampleSite/README.md b/themes/hugo-theme-stack/exampleSite/README.md new file mode 100644 index 0000000..dbaf5e5 --- /dev/null +++ b/themes/hugo-theme-stack/exampleSite/README.md @@ -0,0 +1,3 @@ +This is an example site used for solely for testing purposes. **It is not meant to be used as a template for your site**. + +To create a new site, please use the starter template: [CaiJimmy/hugo-theme-stack-starter](https://github.com/CaiJimmy/hugo-theme-stack-starter/) \ No newline at end of file diff --git a/themes/hugo-theme-stack/exampleSite/content/_index.md b/themes/hugo-theme-stack/exampleSite/content/_index.md new file mode 100644 index 0000000..530dfe8 --- /dev/null +++ b/themes/hugo-theme-stack/exampleSite/content/_index.md @@ -0,0 +1,8 @@ +--- +menu: + main: + name: Home + weight: -100 + params: + icon: home +--- \ No newline at end of file diff --git a/themes/hugo-theme-stack/exampleSite/content/_index.zh-cn.md b/themes/hugo-theme-stack/exampleSite/content/_index.zh-cn.md new file mode 100644 index 0000000..e4b59a8 --- /dev/null +++ b/themes/hugo-theme-stack/exampleSite/content/_index.zh-cn.md @@ -0,0 +1,8 @@ +--- +menu: + main: + name: 主页 + weight: -100 + params: + icon: home +--- \ No newline at end of file diff --git a/themes/hugo-theme-stack/exampleSite/content/categories/Test/_index.md b/themes/hugo-theme-stack/exampleSite/content/categories/Test/_index.md new file mode 100644 index 0000000..de42112 --- /dev/null +++ b/themes/hugo-theme-stack/exampleSite/content/categories/Test/_index.md @@ -0,0 +1,9 @@ +--- +title: "Test" +description: "This is an example category" +slug: "test" +image: "hutomo-abrianto-l2jk-uxb1BY-unsplash.jpg" +style: + background: "#2a9d8f" + color: "#fff" +--- diff --git a/themes/hugo-theme-stack/exampleSite/content/categories/Test/hutomo-abrianto-l2jk-uxb1BY-unsplash.jpg b/themes/hugo-theme-stack/exampleSite/content/categories/Test/hutomo-abrianto-l2jk-uxb1BY-unsplash.jpg new file mode 100644 index 0000000000000000000000000000000000000000..c3859434e720f0654b13e3379ecc18eb621aaa47 GIT binary patch literal 52927 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 literal 0 HcmV?d00001 diff --git a/themes/hugo-theme-stack/exampleSite/content/page/about/index.md b/themes/hugo-theme-stack/exampleSite/content/page/about/index.md new file mode 100644 index 0000000..68911f9 --- /dev/null +++ b/themes/hugo-theme-stack/exampleSite/content/page/about/index.md @@ -0,0 +1,34 @@ +--- +title: About +description: Hugo, the world's fastest framework for building websites +date: '2019-02-28' +aliases: + - about-us + - about-hugo + - contact +license: CC BY-NC-ND +lastmod: '2020-10-09' +menu: + main: + weight: -90 + params: + icon: user +--- + +Written in Go, Hugo is an open source static site generator available under the [Apache License 2.0.](https://github.com/gohugoio/hugo/blob/master/LICENSE) Hugo supports TOML, YAML and JSON data file types, Markdown and HTML content files and uses shortcodes to add rich content. Other notable features are taxonomies, multilingual mode, image processing, custom output formats, HTML/CSS/JS minification and support for Sass SCSS workflows. + +Hugo makes use of a variety of open source projects including: + +* https://github.com/yuin/goldmark +* https://github.com/alecthomas/chroma +* https://github.com/muesli/smartcrop +* https://github.com/spf13/cobra +* https://github.com/spf13/viper + +Hugo is ideal for blogs, corporate websites, creative portfolios, online magazines, single page applications or even a website with thousands of pages. + +Hugo is for people who want to hand code their own website without worrying about setting up complicated runtimes, dependencies and databases. + +Websites built with Hugo are extremely fast, secure and can be deployed anywhere including, AWS, GitHub Pages, Heroku, Netlify and any other hosting provider. + +Learn more and contribute on [GitHub](https://github.com/gohugoio). diff --git a/themes/hugo-theme-stack/exampleSite/content/page/about/index.zh-cn.md b/themes/hugo-theme-stack/exampleSite/content/page/about/index.zh-cn.md new file mode 100644 index 0000000..0284003 --- /dev/null +++ b/themes/hugo-theme-stack/exampleSite/content/page/about/index.zh-cn.md @@ -0,0 +1,10 @@ +--- +title: 关于 +menu: + main: + weight: -90 + params: + icon: user +--- + +This is a test page for i18n support. \ No newline at end of file diff --git a/themes/hugo-theme-stack/exampleSite/content/page/archives/index.md b/themes/hugo-theme-stack/exampleSite/content/page/archives/index.md new file mode 100644 index 0000000..2862deb --- /dev/null +++ b/themes/hugo-theme-stack/exampleSite/content/page/archives/index.md @@ -0,0 +1,11 @@ +--- +title: "Archives" +date: 2019-05-28 +layout: "archives" +slug: "archives" +menu: + main: + weight: -70 + params: + icon: archives +--- diff --git a/themes/hugo-theme-stack/exampleSite/content/page/links/index.md b/themes/hugo-theme-stack/exampleSite/content/page/links/index.md new file mode 100644 index 0000000..9e29bf3 --- /dev/null +++ b/themes/hugo-theme-stack/exampleSite/content/page/links/index.md @@ -0,0 +1,37 @@ +--- +title: Links +links: + - title: GitHub + description: GitHub is the world's largest software development platform. + website: https://github.com + image: https://github.githubassets.com/images/modules/logos_page/GitHub-Mark.png + - title: TypeScript + description: TypeScript is a typed superset of JavaScript that compiles to plain JavaScript. + website: https://www.typescriptlang.org + image: ts-logo-128.jpg +menu: + main: + weight: -50 + params: + icon: link + +comments: false +--- + +To use this feature, add `links` section to frontmatter. + +This page's frontmatter: + +```yaml +links: + - title: GitHub + description: GitHub is the world's largest software development platform. + website: https://github.com + image: https://github.githubassets.com/images/modules/logos_page/GitHub-Mark.png + - title: TypeScript + description: TypeScript is a typed superset of JavaScript that compiles to plain JavaScript. + website: https://www.typescriptlang.org + image: ts-logo-128.jpg +``` + +`image` field accepts both local and external images. \ No newline at end of file diff --git a/themes/hugo-theme-stack/exampleSite/content/page/links/ts-logo-128.jpg b/themes/hugo-theme-stack/exampleSite/content/page/links/ts-logo-128.jpg new file mode 100644 index 0000000000000000000000000000000000000000..85e33236069a2534315630db8bfef9e02166c3e1 GIT binary patch literal 2071 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 literal 0 HcmV?d00001 diff --git a/themes/hugo-theme-stack/exampleSite/content/post/chinese-test/helena-hertz-wWZzXlDpMog-unsplash.jpg b/themes/hugo-theme-stack/exampleSite/content/post/chinese-test/helena-hertz-wWZzXlDpMog-unsplash.jpg new file mode 100644 index 0000000000000000000000000000000000000000..0120706797853a9e955b70cfe60bc9b74ace1021 GIT binary patch literal 15530 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 literal 0 HcmV?d00001 diff --git a/themes/hugo-theme-stack/exampleSite/content/post/chinese-test/hudai-gayiran-3Od_VKcDEAA-unsplash.jpg b/themes/hugo-theme-stack/exampleSite/content/post/chinese-test/hudai-gayiran-3Od_VKcDEAA-unsplash.jpg new file mode 100644 index 0000000000000000000000000000000000000000..1a280b25b56ed41c475e4ce38bc59a81042b2887 GIT binary patch literal 18711 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 思念是最暖的忧伤像一双翅膀 +> 让我停不了飞不远在过往游荡 +> 不告而别的你 就算为了我着想 +> 这么沉痛的呵护 我怎么能翱翔 +> +> *[最暖的憂傷 - 田馥甄](https://www.youtube.com/watch?v=3aypp_YlBzI)* + +## 图片 + +![Photo by Florian Klauer on Unsplash](florian-klauer-nptLmg6jqDo-unsplash.jpg) ![Photo by Luca Bravo on Unsplash](luca-bravo-alS7ewQ41M8-unsplash.jpg) + +![Photo by Helena Hertz on Unsplash](helena-hertz-wWZzXlDpMog-unsplash.jpg) ![Photo by Hudai Gayiran on Unsplash](hudai-gayiran-3Od_VKcDEAA-unsplash.jpg) + +```markdown +![Photo by Florian Klauer on Unsplash](florian-klauer-nptLmg6jqDo-unsplash.jpg) ![Photo by Luca Bravo on Unsplash](luca-bravo-alS7ewQ41M8-unsplash.jpg) + +![Photo by Helena Hertz on Unsplash](helena-hertz-wWZzXlDpMog-unsplash.jpg) ![Photo by Hudai Gayiran on Unsplash](hudai-gayiran-3Od_VKcDEAA-unsplash.jpg) +``` + +相册语法来自 [Typlog](https://typlog.com/) \ No newline at end of file diff --git a/themes/hugo-theme-stack/exampleSite/content/post/chinese-test/luca-bravo-alS7ewQ41M8-unsplash.jpg b/themes/hugo-theme-stack/exampleSite/content/post/chinese-test/luca-bravo-alS7ewQ41M8-unsplash.jpg new file mode 100644 index 0000000000000000000000000000000000000000..f6c90bc31ac84d54fe664bbf550e3cfb5224bd73 GIT binary patch literal 32400 zcmbrkWmr_*7dJeBfFLO$jmk}TcS!0;4+A37(k0!YAUz;5Nav74NlPmr$dE%iL#ar2 zH@t`Y{y)!ky3|v$w@W;y`z|O`lz@aKGC@8L~t*oG|Z4QN+ z`?~vPWubBY|2A;b1){u*n~ArIhw~VOONoO=iF4BfVgv?=hXY)o|9j!$-NC^pAiTkX z?*8}qY8K=Lk^$ZRfdC2wvN_|Pv^711OhbusBp3?bbIUIA5G~d^Mg2G!97kf6AHUbaFc? z>6$bI*{U*w1jn<1=5M?IZwQ1+?#n?-Urv6ZLu7*zeIj5~zy7iZ$o-{k$JmoG4E z$9+n`Pyl_9g^8efDj-GBcCulQRG>)~jYKmSU4&17$9W3+|QrD9|&fdwiI}a=GN8+QD0sY z{W%or_IbG9&3i)x*3UI#O^-7){o>jw=^haJ3NH^B%dI-z zCa<(IZXkRd&Z!p@o0vL$%NxG?$c};t?UsKXi2pehmb9s6tvgck0=RD{Q-<;^W6Fb5 z{;pN|%(8RSd0S#?)2r93Ae`iZ0lt&x0;@JUTmLfOPMr+PgG?{i5rxUlFZmstlhAGT zYO1lr-(noAAd+h}f9G;D-s(QN&LF%zpy}Jzz4k8?rpv`DO4QC|Sv4dAu72p{u=F$3 z6Dr|W^GYzMU6I_!e3b6E0pNv15Ztj=IN3KIOWK*+exn1YNQk^-s(69fvfaLva6+lOLgL@Z-C|Ori(W*+(0gQ7A&3v~1e)s%exf@X8)%{oQY*ij+ zp_zjLwJsytmlIb%R>{HuwE?5V$zAbhY-T(_ole@EH4hyw=9ZY!`)_q+nJG>m5!Xlm zczwV-6yoIay~22!1Fn+Rvi!!j!vJr)4$5kEB9YaRIl8S2PNiF* zBMVndHkW+PS{gqm!;S%~D-y>cUJH)!Q~Rpg(wA&^2#R3GDCCCwNYkxh;OVn8X4OJA@yFKv<+x5Hq?6QSllWG zNey)vXfO=+_fnok54oDAHA0ei$o_2tuOvM7IKCr=@~|1Y9i_DA$ukK>53Cw#|Io9| zI$Uk3Xc0pjxYcIOM>rx}ygi^MLsI#vhVsUN2*H_KV_5~^Rg3oLiY*>GR!^4yI2jJl zU-AD?*KVAuSvrwlCvWIj&VKGxEF-JM_#0}%QyjF#u-%@5=L?1%`^$f7+q32j}7|+gL}(;!IAG4j7Fw*?0(6w2RtAwJ0-m;$Mqe1?e3u zO`4Le_9JIM9y)fr6%G4n|JrXUF=g;XU7i~l+xVY!CAbz>trcfZj<>{mp=G?Bh73ft zg%P&$<}X%n7g!k(c}B#!cDug|I<&Z{+>lfAl=E;y*z)SjlYd2fb zEB^N*GsNsBUr8)Sp4YfGi3M|6&Dp^+KbEWcE}^lKkX&ysQ`>+m;?hR%^ zfze+mG`$Lux_A)=;2<+$W^SvrQ#*62jmA3@?bu3aV{DUAVo+_6 zb%!}Kt<530O0cxMXN<=xq)vW+B&f{3AQ7D5l47t~E}5^&U+}Zuh(L>8u)mt6;s#_( z7Ul(79r^X#)THJ->)Ggj%}Db5h6VL6dX4mwqQ)UUZRi0_{`WC|=L{+f2Dq0qxDFkP zwGjE%A*K#eAqFkMZ3(Q#dA5^NdFBla_Q|U+KV5z?D86bVIgUn1Rd3AA5)Es|rMP#i&&TcwcV@d`Xl!qyf`4DQ}_J0~7=>sDsaN7j2ona~(;HCwbP=k@3CKY1Pf4qD)h7hhlB(c!XhwxNS4z zYHPh?WN^cH5D%KT0V3lvQc`a^Y>Q4bWNzj|CVl}RjPiiLMgRUzP=yF=wQ!Fk50sv7zFyu zSz_7b7F+>TWg(Xs-aaXDKXb*HRa|&D+8vga`$o~zLJKkxj0f{0wK>}5`Erx$t(KN% z@fX}n6SD{d?n&rN$5b|#2SziFRjW`}Q+k(jh1pz303lfv_(dBpvLF3A?(tfg$=F^# ztZVc)@K)gLXA230uNB)5#9FFOY!qB()-5nJKwg)Q6MO3oJbKMn-j?m#$I+5+YjVKX zU#*Do0xZ^QuX1bp=a`(#QoqT)wOWG!`l1kG{{c(8e>TPJnxRL=6jjj(#_~@2z0JBE zM5A6Y_4>$s*ZF4gW{YD}y7zd$9+%xroEqzE0BO8gGctATTuY4?L?8G&)kSO~Tm#ut zMeOH@dc7S-d>^?;PD(wGuldWjVrOpGkFM$%&Za<~^ZgYYcad1a5N{3@C+ySA#o0nT zUwRR0j;GqpcZ8&48((_vyxyOy74`OJ6g9?rdT5)Ner|+$y@=mvEVsTV{Ym^7xHQBrF60ykTBU*JCaA2&4 z@midYoVPtxC}hToBC8Zh%KfpK!8@)#YgQd+5Vzj=U}ZW}&Cs^6Rz5p`Yg{X7)w8XI zo^4p8eF?sB&!RTl_|Pz05)#B$u!-gFq#fKxsPm^aypGJ0z5Y!0R^vVL%*p!~yDaZy zrmgw&!I6m))1w9TigV8eb%WV-7oX|Z?88}NDi5UZ4pVIg3LHxS(MaqCkC*KvH2v^3 zCgZZnX!iW`_Vt1m?j>?IRtJ-ASi&UB=<`>ddqH1wk`%mdf!onfzYa*WV_1z3q%$>)Z}nUsKxVGD zv_9hUa9?kA7!NmeDno>3*YUq>8#=VTy5l8xy`b><>==A);wBgKOqL6iYD$m5uyZY_ z$F8uP@X2C4Q#ES;{+7~7+TmnDlPOa+GH1*1OsakED0ix*g}6wd5gbS{>+wYOpzGA^ zY5^Sx3N5FYA6}A~svg&B6z9A$;Oy`5aelH|A-1f%>gUp-IoYx32&CO7D4olM#WyL7 z9s7uGk{cT2Fa9Bm|NW$iDSRR066@|ZP(sia;9++ZG$;1@DCo<%nceCmdhg8cj;(

^ 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


Ql zH;tjLzNWt!;v0Rl9U_7fUcE>DIhY@;ts-Z#gG&M28IWSL=cUuc;dD*5?7@-B+9$Q2D2?Z z@X#0~h%(ns5#0|!E{)tk>Lm`tQgsuv;7cniU~ZTMGG26ptG&K(<|@T0bz-hQ4*PQa zY?jHd=IUoM6L55a`~WzPWf1IEr%E!*m6w-SOR0vt%$q3`X5OhPqH`PFx*!BJ-T_3x zC1htGS}-+kryjO206gOPC+Vs4ypL4EROs?_Y4?OV6H??XF z-gI&N>vf_%Y`?*>(m1>vMQ&(<%xSpMcd2N>8SaJ|6@5wYq&=I+dID^wFbqBSg`7Qb zX~PEt&W>JpbY85veA&(Wu_KnU<>G>5>qRf;Bg5v~|5&=;%eAfC^@2*)-tV|S<~guh z)pR?8$){DQ$yXkOO^%gq{g&5H!Z0>Px9g@V_mX8@VN)2c!D5O6jpC)joJUz#I*=I; z+{-ExE+Xl5$EAwB6aS5$3j57h;H(exPvKD34zgW-;*pRr_3nErzV3#LBTGRgx^^iA zBc3q`zE5TG#kWoI@Rk?QH9k+i)!U~^5DaZ&1|Xm~Z@)2j0@@SGH5px2>CM5k>v(IzT`h@^|j+b;<=c=W%Y8^Kdaa0MXpcR z8V6#dV)G!tqL6k%GZpIBp+S%4Es8DnuW`MttI3zCX9 zX@}_q#9MAG@R%N=7N7+Ndb?dRJaB+%rvkfW*gE9XtjsPV!?Fyyo1&Wz)j^@KzCSe9 zI;%O!IimwIRy^-di_{zKc2oEs>8Ti?%a(c^#WF0aCfnl%pI5VmA(`h*Rpfpo+j%D% zyx<7X9np40$yd_n#sys(L^XI`1?xsn_8$ph8c1JVG0(Ja2bq%KYcaunBD2Y2Nrr;x0~V9cB`38 zx-CKwG}1KO(OEddHXS9qAJ{T)Q_27yoNtv7&B z-@*sz^HM?cNTbc@c{Wn&apu=pQM=;{k^P;MOD};so=$GLrn~u>_5Iwk#VqeK^0DB8 zm%hp691X?TJzS8{Dbv%^i-BARE&F|dhDvVn4C!im<*$HgJ&Wz?Q!Vt;3}zRK3w&y> zicFMY0a|{LwGTa4e^|Q4E$AV)dFW|Ahxp}DO%k+GbuM)`zpHt4_f+ii=wo{Cx&cx1 z5Tn4={GC0lt>=4P$_nHR^sqP)(Q|(FSQamO!HILaY5*|>Rl#FodNkVXbm41lJx-hv zrg)Tp$I^+mT0UTxJpI5M54V~8dy+YeVtGD{D;&9p+OyV9KAGlCqLaP}{$Zn2=LUSq zdJkaDKnv?Cec}X4`?&mQuexn>^l?HhC(&qCc=7F^`Pc4YJs`DuX@_~Gq7-tJ$A^rE zNxa}%LjOVD^C`u^Hq(b*78aU0hZYa3 z>LJB%xt{iu5?@P+4JcOxsK4s%F0idB^7sUEM8!)tkaPRXBMKI;thSk^mZvdKn>Zc2 z_%G)$KA5(xdTvb-L%F@ql1>&{G1uM3UMvp84=F!JGHR7tghw#|wGFF0*$yohj6iH_ z@klikbQ5?i*0S$$YfZn&&-s!^#@?JYl+K2)Y0wmOZRZWhxdoYTug<-p_)cGV_>0-F zlXtW};BKmKQJhz7f6{yCW4EXqd0Rsyi$knB5>i5q8$n)XmlXl9f**TstsbADs3W%K zI++5fGKx4Y?`0%2<+M82-(Lj>`sa)7)?@^b16g7O!miRE;5{-<^A<|nz`hp`rsk`( zzPXFn{?H^Vd6@EAe;(7G)}CAq?n(`UPy|fXSh>v*^%{yhYO`no#BsKW5=vU{lGjH$ zP61Qk;9HX;%w!>ZHnv(^1|dp39|~Pz6$FdDSf(si;$NgRwum%{+y_t?n#o04dm%~@ zIpOlW!Er%B!pGyot(YQWgBjNg*D7fr#$K?WD2< zaJ)P%Fc4W@lVas63$n6Ct!pXdx7R&NLM5iDZVoeGvDcBS2 z$WjzI%P{*BXmsy$FK|uqT=~)5*+w_efp*jA*OL5YsuFiG_p`+-gZH(jeH9K1F;VgD zu@2uCpKmkXJ&#cLt#2)*8Y>jzJpomX$H1uC#FfuFMJ&V0bo!t0xo7Lcx&txzTN{6?3kvqK zJJ#eITedLQKoqK|HxKHE&w*e=xB6rYZ=?Lmk0Y;;M&Nv2d{elcSO;nR6;F!`3XJi~ z>Ha72YhsmCp-)NYX5}96z~Qvm?%~MQzV4q0SLTP?0q=0Q>Z7Fv_W0A|DA^BNW#NNq zwQkPyKuFJN8(KT)P<@u+2JV556Nc?pG^l9W>S&^&?k}&MwK_sQ8xxCs`|!P}AeWxd zsZ#aa(tVE5yPnU;&OmwjHV$y1N(zM3N0>`?;zn(ZdA}@rNW5ZE`;AtDxzMKrl)}UH z^BK}fN_=0*sIRI>;4=$ofhns|FCGvOp$i)RnFVQjeml_J08!hJFD)q6`v9ux?JG$_ zi0|LdlP+|p?oi)V=MBUNt1k}}X#^_a2Hzh3QbWZ5_{A72`pEnHw{31P|9!#WEN|n5 zl@J4m*;7M?w@y~v@L#A6zVT13b?V;dk73v%i)si(u<$PeENb~->I0}i_O7P2)<4-C zjb>NDuL~j5%#?j}J>ThqW=c{Zpk{#*TA3ZaH3bamdJqp?*rBkrdQ_g~y z_^_UfNXZ4`7pDsGTjHl34lO6U?EkwF9H6b$;Lv;S?aSI-?3LEGrQyA?ruDijbFT7l zF_7DCwVW1!*fAtFG>y>jw?7RJ{si8UT)LKbS*NC^+$2VR#)W5=Uz`5d`Qq(Byn4Bl z0GpSv`DBN=yc18nnYwF)cA^l;oXWD{FwWboMG4gpCDveNz*f z;*iK!E!a{8cdmU<9GLwI_XaK8Dos|9ZkYKt$l+x9%h{q!MVH$M_(O(ivH9nw^SncL zmb;h+LS{&0!mhw8;vq5(E$&&`qs6hGO{2xRpRLu$^;3d{lNx=)uk`YvG;S4r?fjOb z=VxYD!8}ZsvNH}VQyrAbbrj=a*@cVqGE82JU}FBbI?iqCZtda-C}Jw_*Z6c);8t_; z$-?|)@V;jsQhmfT`t4uFp&@6XiDg`fuc@c^Eama16mHmW|D$wS!ctsGAOBKj1j%Cg z{nY_Ag!H=x{L~`dcEP~I@A+fF=UkC-@2#5Z_`c7!@JRu1OOxrt0HNQ=vwtbIQ?SQk z;9^l$Xp}55=X-fisJ2E1Y>DH_-O6)NcNK2rDmxA_@Za?=>6a6XreTFZ@Jls!LNPs* z!%HddTG_PEBJ&5MH>crd9&@WK6Oa73zYN!N_15ac7&W)_gB`^h<+38VgPH#TGnIhl z;gCdocB6DV@eMU2)8K`8%gqIP3y#c?`{SQ>L{!fM)VMm&Xp+!A`WpTDaDHQOj{bYiWG*#u8J>Fj#jV z%_(aSup@vXX>m*?JIR&|du41e8JEsazxwi;rL5dGU6QY3bAY%pdGL9Op?5CTQlvcplY$`v@L-4M+p6o zJ^Kj*1pHR*X&x#sT626Oik554fbztwWXkXer_;^TgE$?rTV*u#uqc*8K9*E#s?K4}IRYAadYZ59n>S8COuQ=$d9H9)_LSE@P(sVa3wjTjnD7|~_wbGv zwRKCU;#cy(WOIdL-B?p4<=pu`2dn#?hB_eW!BQ5chs`eBf(a*+uqg>hRe$f1| zs@}Zl8}=Mb?iI2$+TCyaIcUZm9~&6i@ZLI7^b_27mnd&(*#8N4C{D`1*a8kUxTe2clnWf?~8@do}`ZRzK= zPgL459Vc>Z%N_8qlRkiI;E*=m4_ZuwutjB|tQTS}2FQ8#sursyu1628zK(>I zT@b}C1C?WugL|v(qi$k0t@<^AIt;|fU8mMuG7*kf2TSN^ z)U*$&O|af7Am4T?IK8PJ_`O4t{|QpQ!6@&Jh*F>r@8enCZ(#BLF*jjHa~ygA&l002 z^Y7F(KBQVqerIVp|0438gjb$KxbupzmnNsOgV{7CrnJd!wd7f}L?Tr;dd7T-tE>0f zXb=jMsZ`_Q~2cQDa$}sA$egFc$!4Pqb1PbdUKKm+E8e z05QTS%{Ug4n9jlp^2Im%Qe(|03G*P}?)4Bjr;ql;)@Kn_#zG{@!<)K4XqDwL0qT@UCQ_L78%49T8)iSmmzoefEz1%i4c2 z1bos_%a^5$DVTYAK!cHu97PaZ)qCIk3w!d&dmv@mX+{(qedKVF4{x?xN&u-0Mq_M!!$D- zYqILV+I~@n`OUEBhKz~`=X7;ecVXXGRQG75;{M)P-qumT zte;&|2zh^ihGg+rmkfC9q5KabgWv2%P#~ZEpy@0%9i+TnXZphcK>kUiN#^`;RC@qHmU&1St=ApX~ruiZfB z1ATfD9JiZt+N#}!=A60V3Y*@gw*q8N4J*aZW5JzkAUsOMoFrQ`0*=QBNHyE}<1{WZ*U z7#7gEf|Ue(s0Pl@?ZsQuw{JwuFJkH6x}coOI2tkpbQNof{1Osj#nbfSV`XSk7YUdd zFwwwSRXqo#j+-2MHp!h*;$g~?+f|?i)$Kntw_(83G&fHrYSXw?;XaFPC|jlB2vY;gdnnS-o+xKEN!w&v+- zK0vEwZI$t}+Y3o>C$E`l&|=hZQOaej`H+uTa8@%j!ysWp!cfKC!BsE;d2K|0_|ok8 z0gw=tJN0p`kHxFp9TxyGC-7g2n^1h-CD!XUjOhf7V(*n2IdJzm%jc{7vNv>AZSTjf zhzleF&sAAPX#<%dH-y{;mb{&iy-T;C@?HU=>ZqA2vdYT%z%N<4n8Gs0Idd!ILB&$c zhcV|Ta|)2%j5HY6JcmyREX*Jy$pvu2NvVhRF)qsaEcLhMu)%?)$FLvNODcLvkBL6b zc8xr7KiT{hk`&^yjJ4yW{WaKP45B`Ca49GD7Iv z0p>G0 zNJ>hIJJ3jb6K7j?np7DC;@^~lppWzxp{p;a!338|I2#{yW_3i)r{a#hD5VZ-p)hjygX2lHR+<3uSr2 z)uPE!8KRd{=nIONC&f25l2EsDC%ZbB5BqiHEoS>)FkF?7{qkk~giE>oX{rcOK6Zz+ zL+@6CDmK-y{)OyXqeA-*Q%K#FrnC#)VQoV~(GOwJrv(duJ@w^WIlu_C^ z{PG0nTc|D~`sE3^DV%XxN+Si92+i5gl`~Nt6+w{jktrJ1Bd|fC)6V{dB_0Y6t235O zqB$b=VL!j$gYYLLOgcJNLx9+~^x?yEdPTOZGWf*H<~$Xa_j&Yi8YmE@@K$M$bK+I5 zX!#{9zw%Opc&CP9AV{!0A_9QOoK)fBOEBSijZBOGT3QltvG{X9Y4LkW`KgEK9YLYg zj^gQ?vbJd!2dgS>q$k7jH=vUV53e=e*t(IUr0wyeSY1j#!J}+HWP+@O%SQ7_xYVN| zN@krosCDNjK*BMhFPrOB5W$0Bu1XC_Srieo1zBaC68+TDwf^1PKUv@nDALzHANonL zIMEYqNm^E}YjZUy(TR-(ZwTX9=aL?0>Z>KuCZ>Z5ku`C_ItuyC#h_0<-Q1mBb;53`5uW0R4*()jBfq2`w#8u%A2~`x}9@M8aNxdV;J5eGFImNYcF-TtRNorcUFS$s;EiC zP0uQ@&-XsBLexD=vo-9NIEWbezt}5qBR#Ua{z1m;0S2Yv!rj|a^~M>1zeBtYut_#Y zQ)gH0^?7k%QY!hDwTod#*a1%-%0KT^9lU5g5EWxA$K;oS-F+xo1O)}InLoBR)bg;z z2Tza@zM)u^I9Pnv8`l1!_;SL3x>JxTK6#-N>ln5kw$t4%-%`kuUuC5C(%WkOEz>YO zxJSg=5HWX<^}3h>t>~Bwo z%Z8x!kqSKLiVH2wm2063Vs-9v0rx#+0L`6G93H@qz|@OdM6s`wFlZmi*4cL<)}-Tyyjn6SO{? zJLI0s}oqHnJ~9)714x1MPlom(J_wE-CzsgBx)Z z-43Y%0%F874f@IGx&6cud@$`2+l94=iSMy~3QtsQTAVB-w{P!(tlx%aa{W$girxtj zupws|Xq~S|=wpq_g=SNZg=E?L6~Iy~{-s%WTFtT@^0(Vk|EjbKSRLH+ zCUb=%(=c71uV!3c^t+WOf76d*a^3Zg^a|Jdr@ADj z%G;)=i(C^|VQ6A_Jf9&Ur@J#)H{)ZCQjO9px$B0eElxZ%B5YAa5B~0=ycD}Ck;+3)#Hee!rO`KN-4WyXR2qIUdvG_l`KV9P=H(h18jA5G3E=_#%F*P}W z;W9bIf=?5BcrO&3I!W}2maUn7!8a@biWp06>LpuDIxpLqmDv8}uD$fe01l<_h?)cw z4_oO~`E?dJD~w-QuGs|&aMW-qQ^=8dy#6jNniS4TRU~Y%Isg2_C1pY%Q+IP?wF0Y6 z_0cWGhw@?JcU_NDvu9dO0^){sfV>JzZ7utOqbf2fE@ryRgvsuM$UaDI-tSc7ZRWVB z^|mfrBA|PaK;|p`a82}^SmRBtui^9mJw7SlS7L2-bT;QA<=3yJS^bj9B_M80T2iyPDq0;SC zbh(&HvRT=y`-5g4O;`49E0CYsS0n>I;OP;VCF!7H3`oFSfq;40O~nRr!#8e=Zke;c zp^Yn`GCq1(q`AW#d#KoY4~luq%cRI5&Rn*KBHl!X*0K^ES=>2@PF1K`Nz zKpgDb&)VR&Ni6~R_kUh)@1Z3;Wv&hu#6}9_tBN{4@1I7#>=hXXNigahNEWy_$woS4 zSq<%!EoMDjDR#JRVx!pZxF{qq3Fq@v^-BnK2}m_62jOMh#?qZEe6RF%TvxlH+(|Bh zJR#@%VT-nmB25J=9JYj|;Bk$G#(7KP``^XQ{nbp#aEAY~nAGy^Z$dv^@8X^7(N^R2 zfkrGn2QnYOggsRk9uawu;#-jXy%YgJC4ZGTvI7mJkYphN;m%0GOA65Kto|^g??No_ z&J#cNk4!&05v#uHRmqFLoD3)rNDbGQk?3t8X+ra5SU^~6jW3D54>b>Z8K3jb*aM(4 zG7I~V%T4I}Nk47{+#sj1wT#eh@k;oU>XDRJC<(3kr@wDa=`#es-R(Ar1)TQVOOh|H zyPMxZ6!_2Tl%-z5xx5jDQ$wMDnESWDhv{@)aqoJ13^d>1dEleg0 zcGlm8&ZcAS(UQt~Z3&LaS@kf}Edq35(Gw()9YN5W+AdejLIz zGdUOX% z?gB?yNaq?5i`N_hz3kt~3=dy&W%JA!_62^T%Y^q~iY-3fBw#`y0~?|>BH;It*^m0R z@w&IE1aC=B9_F|K;5{sFTy)O2oidY@@W9BHQM+<{3+KB+yWH9PiH#^WhyAz_LzlC_ zMZ}?NZ+?IqFmMnT`ed1L7sTnB5^!D5dxWKeG+4#!;X%k(mBxPZNS?h+k>rJ%9^bVW ze>7bnw*Cpj7}xjtP7>!g;PZQX9Qn-gJe{2NQ177w)3Ou;xW~?H4gT2VOeSgcuQb-t zHy!C?w0!#Bi%$HbL3bEq)ecrCo<~O|7*QtI%v22MgddDPOCh_-<)5rwoVcc*n(wgV z8B4VoPT^TIBm8k~5fO0im#e^9mSS*^-fnCvvE$d% zw!lpH7$S3uj!I3}D8gL=VCgXgu{|*diNIHET96hV>-0={ZE4&@`QPK?5xUjU0mZ4K zZ<#OGoeFp!cnI84GlVYvp_y1d?cg>uTM1KG&za~aM4k3ru6(Bv zjHQ#vdLjcX?UMgo!8FYk+~rrTf5iQ;=$WcEsd9uptavBN_U&d^jgz zP?`Pu21=H__^E^w?HtFHs93b?(@QcOwT5<800_uG0W=uhDNel5H4&D2DE<8PRh`u% z;^gG~{&%s^Z+%ddSlC5ya5|R)PC>xiGqHi1c-$D*;zg%nvcy{_PwminI2m)My>ig4 z>CGS<*}+Fn)<810CD1KMc|@0t(>giMtzdjQ8#GXS_cPGA*cMEu4m{wt*Qd zi+cg%>fB_j(BZA)OpZ0$38MHGoS}ytyS`*8-DaavSk=&?pIFWq|8%speS-XVkfJ`~1xdO@>$0Yb^;>A}@{<*o9}fLJ>>Cc6 zn=g=cf8%awv4v+9Vc%VlUEgS5^6BNps+zG@zlnan9}CB+Zp;06Kxk4u@G`(Y^xni? zJTU)n*}*~*w%}SPKkVkH!;+l-LU>ESJVM3AuxtYUeDflS&IdK83uJ3*!%Q;1Fys$)Doi`8mhk;il zn8tjd$&|7Wh3cz0^83+~$#-V%UO&`JJia7d*wx$~;>;=G2~3^7bz&+V_Hd6LCX%x( zN53tl#ktpJXxAt50=d(`&-kux1A%i)kIrV$@ zZ}}IQm*NtK!S_pcRf$EL-(@aUA@ZW5pqyp8u~L5lW2A`LS@?o+Gh2WrszQk{YUe{C zG#Eq+k-eH3${e;-^S4|+kKZ|1;Cw$vyJ7^p6hvE!4IP4sk2z8q?3?)!^i=X4Dp|_5 z{mbY!#7mVnBU(V9QS}#_+E@NEg!dRfc}OZ%?Cfq3d!C=id8Dg4U$f z|EacI-q2$a%13hAqhx}QL?F5NP&x4^-egAYu7-Z(OO01ro267Qo6|D;$;gij#yN+A zGJHS9S!2(g)b;fv`3rgrex<&9jyxOqRAl%xh}vy5%s~7@qXUvQ*x3H(4-L_gHN50* zSGQJ!K^yt}^_NqnIja#z)+iXd3zr1u9n6npZ`C!?NdG!>Pc?}AV%|ap;N&4Piz0#& z6=q7yhCm~BnmmIxQ&ngD$aQpRHGO^v77+%R5rKmgF$E@Qc4x5@o;vUJV^#$7nL z&)g$Z=h|-~uxgJoFB8dv`8P>~^}YSEuGr@xLG~W~)74B$${!j%0&SiQ>p)3-Y5qEf zi_>)kI3y43s+XmAaXKx4^?i}#QRlS9?!+y>BO4q0Hv}*ODEMg3y!AgcS#!z0xRh$W zOX;`IUv=Rs@N;^E1GcWzwiCb8nW&D!1Dn(F=osP7*qAsf{e)ub5;Q^g)^a5gbiO`3)XDjO>Ak@ zneLA){mJ@p+)>gxhgOc7Q;y3RwJ)1Y;)V!-f_`(gAa`*J_2OgG7oeZ~)L;KB%l?v6 ziYg00x{RKFPlE>=pz@c_x5-&<1!#&~9q+SatvAZs8iup0ANyzeyo|NuTdw>Lx#yWk zo;EuyM$Ofy&KR*?P)!n9F+7#ul?F1w58kkX8G&;%v&K6$a3r;8h!{4VGM#tSthdH* zJSiZE{h>*NKR-?<^c%D&qpQc=TVGg$50dB?J|#a$Eqztobe-zHxXQc(r|Y&eU4tu| z1qT^S;DN0zjxtAbu}P>6`8vA{mk!Hor6w*U5r3|rMXg;EBx6`e~;W3_IMMeiX*&_npxCOu!{lwc5%sANC@|VLUbj;R6IKx%_O|X8$HcT5?}EHY2cI$ zY;!VwQapHA#*_(hz&f|d$p!Utzqd`Qytzv8KUx3tpk%5c`U2y0zAP|pEV0aKSTE62 zyE~_+K|u6Cc@ksf{CfqjH5X5!9}atRtV;h!LmCYALd z7Ed|O-2`7B%0WWt9og$g3vAOFXr6N)=9Pwl=Tso@!^ek#2Di?sJF}gnKbjd;B&YwO znaX`9xc4IL%9}qlv1Sdo&PGIuzi!@%cit2SXU~a^!Oh2>)u+-_(bZ&xkPCT|gU5m$ z1tny4ize1w^#c6<&;+d_uuU}@g=&UHBSh9`f?x?xZ12p|=CW{NLF=d0cRP<3G<_ua zYYLBZ+n}k0oIdffRc*ZVvyJ}3@e8O9(}<*dfMp@b{aD@x7(>r$mIII1Yt1#8NB#U! zJaf&DE#uBwUaIjZ`&7*;Xm*HcLa`8dw~KFXEh$Y;1rFINvn88;XHMX`D#NgqbL@nu z{-BpL4jHe|tyQO9o5?bN8S`PlfHB{`&un?FT;nO*3l51r$guc9b_#~g{fTa^!1)C( zPLIFxx9oHy|H$8@uN5%31arQl!}cUoq~BRac_+Lmh+{IbY2!JfG&bxQ|E zw})Z1Hki7_&j2tZOcNZFb?vvCeUG-%2cSD|*t1V=gho*+dY2PDU)ek`pldh*``?X zVUDw$a=YQ4uc{$8@5&#VRg0dkjcw_p6bkLCAl(YXDqqqW9r11yG!n6&II)XUeotk5 zx_+l%_}k>Lhp&M2580u|z>U6qL87&gcHZkC@y#HQ)cAG|Sx{r#o+`d$A>hy-@W`8i z>{aqLj+)%%$mjKuYTd(LR_`=&%CtH{b1(%EgeFNBsyJnjnqPMW%Z3fr^xE$EzBuJSE1{Y<>RFP&^b z7btf7m*{`*Q;M6+?JIrXeXfku+y|Bh_MgAnm&QEAkG|2J;#G#Tw(F&&CijLqqnmfJ z*M9IAIQ{ljF)JA;kSCNM-j`vo3#{9qkPzu>b~&N~0PIZ8Szit67X(32GlRnn0su>r zuKHVpzUDw7PFr^GBD1>WUe?(N>e4&BENkOCo#&nXF^AX7Bset`jb?rcqmt5auz7J` z_1C~Sk@?Y>$9Ri4KY8OY>pFFPD8Ga7+3SFmPpheaY_cV|X8nQqB z|9VQM+(UFZmlKnR!wR6Tpw}#w8__KPG2a)o*@lPbIRQ83u+ms9oIj(1X~Bss5pY=-}sbmi2+UUqd2Nh1BY>eLTY_bCqCA z{+j7?W^u)m_`<0SOVtc<8-urxnF<59D_j2e3yt+ExGkk>hwQ-KYbq;Zq2j-+5t@a8 zLXP^0l`*nkP8NBFgr7vk2@2t)A{B*j8sRJnh8@gJ%ON#ShfApnrNBZ`A~X3y4;TI4 zhG*z>>w&-^EHgi+hG=G=aBj|aVzDZiFm2MqqT6D;YTP|hQmuFTplXtxE-cH4qTTmi z=)LwnjuNha#JL^v^86b9H}BTP;MkFiT>+*1a6%J2`#Z4gBR&471W_IzT%n}I=aBgW zo4;@EgVlv&2rdc&rZ9cue9^V-WCej6nzXB(YYJj5mP>p#C{XbA$&X%;0B3)L^e-3J zWj-^w4>DTXO9#*Nd2Y)zUtcp<&ENF8q@gEu{)F@6aJ%2_pJBf*`SLyA1D3JFHv}Qa zy1n7FD78xAZQhT+W7@O@fbzBI>BJMg*T>P%aL;+I{A-KD(uq*HptZgP(aVW$i^cGl zr|Bm(Ft0hE(dnn0KAp|6sJWib8z>FdQc%l}KQzBi46;{qLrHbgQiOI}n};>4Ot9s?t9ieeda?Lb$w!;FtarJ4RuwqaKUL8eq%I*A_x<>WR}Hk7q2K|hxlXjdD~glYf1Zo$*^yI{Dil`jaMtW<2e$I) zMpuf+D9iF<@UifX?4GEe+7qUV&vI^ek{zvE{Er-sn;%ma6OR{QzOTHf@yEhj!RK2i zvnSt&C=AxS(PbfNR(rmQDyq(|Ir#!Lk@zM0Ws&O7^c04P?ebB`8Kz=gHHP;)&`g}a zZ>b34PQJ9AL=FK%_cD9g5B8yLR^;=lCdzS+i-Ht@Onqgl)V+W~^qTGc#L=SeP}qWC z#s))k`EE{){lY0~iz9-?16VO#K5k*JM*^k&z-`asKI`1b?M2y7+Z z-u`98%|}&q#|5LTVV+Ftv1V&+-41`%KX?1U8IAEMk(|TO&b7Hl^Z2H=Z+~c-%>K}n zg>S4em}i-;XkDP}f45!Jpu&g_ zEQ)<^!JH*;kaYpgiHQ_*pfX?=pOFFyaZL?Ro4t8 za{Uy|S=L;znNwk?x1D;9_zfJ2-op;0G|^&v4=W11uH!n0mgd3*;3XaZ_m$?fnkF=C zPp(6tcfCPE|KH1aXlXTQKC2>PW_nL3&p5YsTCyTpUxlpbhPyW^W5Ku~*;S6U)Gbao(aT3I0Rn}iycvYPi9?-9_s^N~VUBcf8V|@^6Bs4MJoHY#10poM zdE?z;8*m+hf3M^3W&FSExNE{ja~-1j1mtb{zsmq#yskmh=o_}UPYAbDXWahBG!psw ze6x3f@O)#RV_{&-SlZmu=-xFJ}vsKKR^Eua9uj6 literal 0 HcmV?d00001 diff --git a/themes/hugo-theme-stack/exampleSite/content/post/emoji-support/index.md b/themes/hugo-theme-stack/exampleSite/content/post/emoji-support/index.md new file mode 100644 index 0000000..bc3e348 --- /dev/null +++ b/themes/hugo-theme-stack/exampleSite/content/post/emoji-support/index.md @@ -0,0 +1,50 @@ ++++ +author = "Hugo Authors" +title = "Emoji Support" +date = "2019-03-05" +description = "Guide to emoji usage in Hugo" +categories = [ + "Test" +] +tags = [ + "emoji", +] +image = "the-creative-exchange-d2zvqp3fpro-unsplash.jpg" ++++ + +Emoji can be enabled in a Hugo project in a number of ways. + +The [`emojify`](https://gohugo.io/functions/emojify/) function can be called directly in templates or [Inline Shortcodes](https://gohugo.io/templates/shortcode-templates/#inline-shortcodes). + +To enable emoji globally, set `enableEmoji` to `true` in your site's [configuration](https://gohugo.io/getting-started/configuration/) and then you can type emoji shorthand codes directly in content files; e.g. + +

🙈 :see_no_evil: 🙉 :hear_no_evil: 🙊 :speak_no_evil:

+
+ +The [Emoji cheat sheet](http://www.emoji-cheat-sheet.com/) is a useful reference for emoji shorthand codes. + +*** + +**N.B.** The above steps enable Unicode Standard emoji characters and sequences in Hugo, however the rendering of these glyphs depends on the browser and the platform. To style the emoji you can either use a third party emoji font or a font stack; e.g. + +{{< highlight html >}} +.emoji { + font-family: Apple Color Emoji, Segoe UI Emoji, NotoColorEmoji, Segoe UI Symbol, Android Emoji, EmojiSymbols; +} +{{< /highlight >}} + +{{< css.inline >}} + +{{< /css.inline >}} diff --git a/themes/hugo-theme-stack/exampleSite/content/post/emoji-support/the-creative-exchange-d2zvqp3fpro-unsplash.jpg b/themes/hugo-theme-stack/exampleSite/content/post/emoji-support/the-creative-exchange-d2zvqp3fpro-unsplash.jpg new file mode 100644 index 0000000000000000000000000000000000000000..e34a59dba9f555f5d0fb25296c5aa76098cf5593 GIT binary patch literal 35369 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

v9EV5W@LrwY7jbSgcD|U?s4!}a} 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 DX>Mr7 literal 0 HcmV?d00001 diff --git a/themes/hugo-theme-stack/exampleSite/content/post/markdown-syntax/index.md b/themes/hugo-theme-stack/exampleSite/content/post/markdown-syntax/index.md new file mode 100644 index 0000000..c584c4c --- /dev/null +++ b/themes/hugo-theme-stack/exampleSite/content/post/markdown-syntax/index.md @@ -0,0 +1,168 @@ ++++ +author = "Hugo Authors" +title = "Markdown Syntax Guide" +date = "2019-03-11" +description = "Sample article showcasing basic Markdown syntax and formatting for HTML elements." +tags = [ + "markdown", + "css", + "html", + "themes", +] +categories = [ + "themes", + "syntax", +] +series = ["Themes Guide"] +aliases = ["migrate-from-jekyl"] +image = "pawel-czerwinski-8uZPynIu-rQ-unsplash.jpg" ++++ + +This article offers a sample of basic Markdown syntax that can be used in Hugo content files, also it shows whether basic HTML elements are decorated with CSS in a Hugo theme. + + +## Headings + +The following HTML `

`—`

` elements represent six levels of section headings. `

` is the highest section level while `

` is the lowest. + +# H1 +## H2 +### H3 +#### H4 +##### H5 +###### H6 + +## Paragraph + +Xerum, quo qui aut unt expliquam qui dolut labo. Aque venitatiusda cum, voluptionse latur sitiae dolessi aut parist aut dollo enim qui voluptate ma dolestendit peritin re plis aut quas inctum laceat est volestemque commosa as cus endigna tectur, offic to cor sequas etum rerum idem sintibus eiur? Quianimin porecus evelectur, cum que nis nust voloribus ratem aut omnimi, sitatur? Quiatem. Nam, omnis sum am facea corem alique molestrunt et eos evelece arcillit ut aut eos eos nus, sin conecerem erum fuga. Ri oditatquam, ad quibus unda veliamenimin cusam et facea ipsamus es exerum sitate dolores editium rerore eost, temped molorro ratiae volorro te reribus dolorer sperchicium faceata tiustia prat. + +Itatur? Quiatae cullecum rem ent aut odis in re eossequodi nonsequ idebis ne sapicia is sinveli squiatum, core et que aut hariosam ex eat. + +## Blockquotes + +The blockquote element represents content that is quoted from another source, optionally with a citation which must be within a `footer` or `cite` element, and optionally with in-line changes such as annotations and abbreviations. + +#### Blockquote without attribution + +> Tiam, ad mint andaepu dandae nostion secatur sequo quae. +> **Note** that you can use *Markdown syntax* within a blockquote. + +#### Blockquote with attribution + +> Don't communicate by sharing memory, share memory by communicating.
+> — Rob Pike[^1] + +[^1]: The above quote is excerpted from Rob Pike's [talk](https://www.youtube.com/watch?v=PAAkCSZUG1c) during Gopherfest, November 18, 2015. + +## Tables + +Tables aren't part of the core Markdown spec, but Hugo supports supports them out-of-the-box. + + Name | Age +--------|------ + Bob | 27 + Alice | 23 + +#### Inline Markdown within tables + +| Italics | Bold | Code | +| -------- | -------- | ------ | +| *italics* | **bold** | `code` | + +| A | B | C | D | E | F | +|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|------------------------------------------------------------|----------------------------------------------------------------------| +| Lorem ipsum dolor sit amet, consectetur adipiscing elit. | Phasellus ultricies, sapien non euismod aliquam, dui ligula tincidunt odio, at accumsan nulla sapien eget ex. | Proin eleifend dictum ipsum, non euismod ipsum pulvinar et. Vivamus sollicitudin, quam in pulvinar aliquam, metus elit pretium purus | Proin sit amet velit nec enim imperdiet vehicula. | Ut bibendum vestibulum quam, eu egestas turpis gravida nec | Sed scelerisque nec turpis vel viverra. Vivamus vitae pretium sapien | + +## Code Blocks + +#### Code block with backticks + +```html + + + + + Example HTML5 Document + + +

Test

+ + +``` + +#### Code block indented with four spaces + + + + + + Example HTML5 Document + + +

Test

+ + + +#### Code block with Hugo's internal highlight shortcode +{{< highlight html >}} + + + + + Example HTML5 Document + + +

Test

+ + +{{< /highlight >}} + +#### Diff code block + +```diff +[dependencies.bevy] +git = "https://github.com/bevyengine/bevy" +rev = "11f52b8c72fc3a568e8bb4a4cd1f3eb025ac2e13" +- features = ["dynamic"] ++ features = ["jpeg", "dynamic"] +``` + +## List Types + +#### Ordered List + +1. First item +2. Second item +3. Third item + +#### Unordered List + +* List item +* Another item +* And another item + +#### Nested list + +* Fruit + * Apple + * Orange + * Banana +* Dairy + * Milk + * Cheese + +## Other Elements — abbr, sub, sup, kbd, mark + +GIF is a bitmap image format. + +H2O + +Xn + Yn = Zn + +Press CTRL + ALT + Delete to end the session. + +Most salamanders are nocturnal, and hunt for insects, worms, and other small creatures. + +## Hyperlinked image + +[![Google](https://www.google.com/images/branding/googlelogo/1x/googlelogo_light_color_272x92dp.png)](https://google.com) \ No newline at end of file diff --git a/themes/hugo-theme-stack/exampleSite/content/post/markdown-syntax/pawel-czerwinski-8uZPynIu-rQ-unsplash.jpg b/themes/hugo-theme-stack/exampleSite/content/post/markdown-syntax/pawel-czerwinski-8uZPynIu-rQ-unsplash.jpg new file mode 100644 index 0000000000000000000000000000000000000000..1634e85ba231c9e2ed2cbd42ffaf48f214b0374f GIT binary patch literal 55974 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 E*+vdPDF6Tf literal 0 HcmV?d00001 diff --git a/themes/hugo-theme-stack/exampleSite/content/post/math-typesetting/index.md b/themes/hugo-theme-stack/exampleSite/content/post/math-typesetting/index.md new file mode 100644 index 0000000..060fd7f --- /dev/null +++ b/themes/hugo-theme-stack/exampleSite/content/post/math-typesetting/index.md @@ -0,0 +1,45 @@ +--- +author: Hugo Authors +title: Math Typesetting +date: 2019-03-08 +description: A brief guide to setup KaTeX +math: true +--- + +Mathematical notation in a Hugo project can be enabled by using third party JavaScript libraries. + + +In this example we will be using [KaTeX](https://katex.org/) + +- Create a partial under `/layouts/partials/math.html` +- Within this partial reference the [Auto-render Extension](https://katex.org/docs/autorender.html) or host these scripts locally. +- Include the partial in your templates like so: + +```bash +{{ if or .Params.math .Site.Params.math }} +{{ partial "math.html" . }} +{{ end }} +``` + +- To enable KaTeX globally set the parameter `math` to `true` in a project's configuration +- To enable KaTeX on a per page basis include the parameter `math: true` in content files + +**Note:** Use the online reference of [Supported TeX Functions](https://katex.org/docs/supported.html) + +{{< math.inline >}} +{{ if or .Page.Params.math .Site.Params.math }} + + + + +{{ end }} +{{}} + +### Examples + +Inline math: $\varphi = \dfrac{1+\sqrt5}{2}= 1.6180339887…$ + +Block math: +$$ + \varphi = 1+\frac{1} {1+\frac{1} {1+\frac{1} {1+\cdots} } } +$$ diff --git a/themes/hugo-theme-stack/exampleSite/content/post/placeholder-text/index.ar.md b/themes/hugo-theme-stack/exampleSite/content/post/placeholder-text/index.ar.md new file mode 100644 index 0000000..b0328f4 --- /dev/null +++ b/themes/hugo-theme-stack/exampleSite/content/post/placeholder-text/index.ar.md @@ -0,0 +1,32 @@ ++++ +author = "Hugo Authors" +title = "مثال نص" +date = "2019-03-09" +description = "هذا النص هو مثال لنص يمكن أن يستبدل في نفس المساحة" +categories = [ + "تجربة", + "تجربة مع فراغات" +] +tags = [ + "ماركداون", + "نص", + "وسم مع فراغات" +] +image = "matt-le-SJSpo9hQf7s-unsplash.jpg" ++++ +## فقرة 1 + +هذا النص هو مثال لنص يمكن أن يستبدل في نفس المساحة، لقد تم توليد هذا النص من [مولد النص العربى](https://colorslab.com/textgator/)، حيث يمكنك أن تولد مثل هذا النص أو العديد من النصوص الأخرى إضافة إلى زيادة عدد الحروف التى يولدها التطبيق. +إذا كنت تحتاج إلى عدد أكبر من الفقرات يتيح لك مولد النص العربى زيادة عدد الفقرات كما تريد، النص لن يبدو مقسما ولا يحوي أخطاء لغوية، مولد النص العربى مفيد لمصممي المواقع على وجه الخصوص، حيث يحتاج العميل فى كثير من الأحيان أن يطلع على صورة حقيقية لتصميم الموقع. +ومن هنا وجب على المصمم أن يضع نصوصا مؤقتة على التصميم ليظهر للعميل الشكل كاملاً،دور مولد النص العربى أن يوفر على المصمم عناء البحث عن نص بديل لا علاقة له بالموضوع الذى يتحدث عنه التصميم فيظهر بشكل لا يليق. +هذا النص يمكن أن يتم تركيبه على أي تصميم دون مشكلة فلن يبدو وكأنه نص منسوخ، غير منظم، غير منسق، أو حتى غير مفهوم. لأنه مازال نصاً بديلاً ومؤقتاً. + +## فقرة 2 + +هذا النص هو مثال لنص يمكن أن يستبدل في نفس المساحة، لقد تم توليد هذا النص من [مولد النص العربى](https://colorslab.com/textgator/)، حيث يمكنك أن تولد مثل هذا النص أو العديد من النصوص الأخرى إضافة إلى زيادة عدد الحروف التى يولدها التطبيق. +إذا كنت تحتاج إلى عدد أكبر من الفقرات يتيح لك مولد النص العربى زيادة عدد الفقرات كما تريد، النص لن يبدو مقسما ولا يحوي أخطاء لغوية، مولد النص العربى مفيد لمصممي المواقع على وجه الخصوص، حيث يحتاج العميل فى كثير من الأحيان أن يطلع على صورة حقيقية لتصميم الموقع. +ومن هنا وجب على المصمم أن يضع نصوصا مؤقتة على التصميم ليظهر للعميل الشكل كاملاً،دور مولد النص العربى أن يوفر على المصمم عناء البحث عن نص بديل لا علاقة له بالموضوع الذى يتحدث عنه التصميم فيظهر بشكل لا يليق. +هذا النص يمكن أن يتم تركيبه على أي تصميم دون مشكلة فلن يبدو وكأنه نص منسوخ، غير منظم، غير منسق، أو حتى غير مفهوم. لأنه مازال نصاً بديلاً ومؤقتاً. + +## تجربة RTL +كلمة 1 Text كلمة 2 diff --git a/themes/hugo-theme-stack/exampleSite/content/post/placeholder-text/index.md b/themes/hugo-theme-stack/exampleSite/content/post/placeholder-text/index.md new file mode 100644 index 0000000..280197e --- /dev/null +++ b/themes/hugo-theme-stack/exampleSite/content/post/placeholder-text/index.md @@ -0,0 +1,51 @@ ++++ +author = "Hugo Authors" +title = "Placeholder Text" +date = "2019-03-09" +description = "Lorem Ipsum Dolor Si Amet" +categories = [ + "Test", + "Test with whitespaces" +] +tags = [ + "markdown", + "text", + "tag with whitespaces" +] +image = "matt-le-SJSpo9hQf7s-unsplash.jpg" ++++ + +Lorem est tota propiore conpellat pectoribus de pectora summo. Redit teque digerit hominumque toris verebor lumina non cervice subde tollit usus habet Arctonque, furores quas nec ferunt. Quoque montibus nunc caluere tempus inhospita parcite confusaque translucet patri vestro qui optatis lumine cognoscere flos nubis! Fronde ipsamque patulos Dryopen deorum. + +1. Exierant elisi ambit vivere dedere +2. Duce pollice +3. Eris modo +4. Spargitque ferrea quos palude + +Rursus nulli murmur; hastile inridet ut ab gravi sententia! Nomine potitus silentia flumen, sustinet placuit petis in dilapsa erat sunt. Atria tractus malis. + +1. Comas hunc haec pietate fetum procerum dixit +2. Post torum vates letum Tiresia +3. Flumen querellas +4. Arcanaque montibus omnes +5. Quidem et + +# Vagus elidunt + + + +[The Van de Graaf Canon](https://en.wikipedia.org/wiki/Canons_of_page_construction#Van_de_Graaf_canon) + +## Mane refeci capiebant unda mulcebat + +Victa caducifer, malo vulnere contra dicere aurato, ludit regale, voca! Retorsit colit est profanae esse virescere furit nec; iaculi matertera et visa est, viribus. Divesque creatis, tecta novat collumque vulnus est, parvas. **Faces illo pepulere** tempus adest. Tendit flamma, ab opes virum sustinet, sidus sequendo urbis. + +Iubar proles corpore raptos vero auctor imperium; sed et huic: manus caeli Lelegas tu lux. Verbis obstitit intus oblectamina fixis linguisque ausus sperare Echionides cornuaque tenent clausit possit. Omnia putatur. Praeteritae refert ausus; ferebant e primus lora nutat, vici quae mea ipse. Et iter nil spectatae vulnus haerentia iuste et exercebat, sui et. + +Eurytus Hector, materna ipsumque ut Politen, nec, nate, ignari, vernum cohaesit sequitur. Vel **mitis temploque** vocatus, inque alis, *oculos nomen* non silvis corpore coniunx ne displicet illa. Crescunt non unus, vidit visa quantum inmiti flumina mortis facto sic: undique a alios vincula sunt iactata abdita! Suspenderat ego fuit tendit: luna, ante urbem Propoetides **parte**. + +{{< css.inline >}} + +{{< /css.inline >}} diff --git a/themes/hugo-theme-stack/exampleSite/content/post/placeholder-text/matt-le-SJSpo9hQf7s-unsplash.jpg b/themes/hugo-theme-stack/exampleSite/content/post/placeholder-text/matt-le-SJSpo9hQf7s-unsplash.jpg new file mode 100644 index 0000000000000000000000000000000000000000..3b28790012746a7c09fcab4273506077f7fe7561 GIT binary patch literal 14205 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 +--- + +## YouTube Privacy Enhanced Shortcode + +{{< youtube ZJthWmvUzzc >}} + +
+ +--- + +## Twitter Simple Shortcode + +{{< twitter_simple user="DesignReviewed" id="1085870671291310081" >}} + +
+ +--- + +## Vimeo Simple Shortcode + +{{< vimeo_simple 48912912 >}} + +## bilibilibi Shortcode + +{{< bilibili av498363026 >}} + +## Gist Shortcode + +{{< gist spf13 7896402 >}} + +## Gitlab Snippets Shortcode + +{{< gitlab 2349278 >}} + +## Quote Shortcode + +Stack adds a `quote` shortcode. For example: + +{{< quote author="A famous person" source="The book they wrote" url="https://en.wikipedia.org/wiki/Book">}} +Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum. +{{< /quote >}} + +{{< quote source="Anonymous book" url="https://en.wikipedia.org/wiki/Book">}} +Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum. +{{< /quote >}} + +{{< quote source="Some book">}} +Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum. +{{< /quote >}} + +{{< quote author="Somebody">}} +Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum. +{{< /quote >}} + diff --git a/themes/hugo-theme-stack/exampleSite/hugo.yaml b/themes/hugo-theme-stack/exampleSite/hugo.yaml new file mode 100644 index 0000000..a1e3829 --- /dev/null +++ b/themes/hugo-theme-stack/exampleSite/hugo.yaml @@ -0,0 +1,251 @@ +baseurl: https://example.com +languageCode: en-us +theme: hugo-theme-stack +paginate: 3 +title: Example Site +copyright: Example Person + +# Theme i18n support +# Available values: ar, bn, ca, de, el, en, es, fr, hu, id, it, ja, ko, nl, pt-br, th, uk, zh-cn, zh-hk, zh-tw +DefaultContentLanguage: en + +# Set hasCJKLanguage to true if DefaultContentLanguage is in [zh-cn ja ko] +# This will make .Summary and .WordCount behave correctly for CJK languages. +hasCJKLanguage: false + +languages: + en: + languageName: English + title: Example Site + weight: 1 + params: + description: Example description + zh-cn: + languageName: 中文 + title: 演示站点 + weight: 2 + params: + description: 演示说明 + ar: + languageName: عربي + languagedirection: rtl + title: موقع تجريبي + weight: 3 + params: + description: وصف تجريبي + +services: + # Change it to your Disqus shortname before using + disqus: + shortname: "hugo-theme-stack" + # GA Tracking ID + googleAnalytics: + id: + +permalinks: + post: /p/:slug/ + page: /:slug/ + +params: + mainSections: + - post + featuredImageField: image + rssFullContent: true + favicon: # e.g.: favicon placed in `static/favicon.ico` of your site folder, then set this field to `/favicon.ico` (`/` is necessary) + + footer: + since: 2020 + customText: + + dateFormat: + published: Jan 02, 2006 + lastUpdated: Jan 02, 2006 15:04 MST + + sidebar: + emoji: 🍥 + subtitle: Lorem ipsum dolor sit amet, consectetur adipiscing elit. + avatar: + enabled: true + local: true + src: img/avatar.png + + article: + math: false + toc: true + readingTime: true + license: + enabled: true + default: Licensed under CC BY-NC-SA 4.0 + + comments: + enabled: true + provider: disqus + + disqusjs: + shortname: + apiUrl: + apiKey: + admin: + adminLabel: + + utterances: + repo: + issueTerm: pathname + label: + + beaudar: + repo: + issueTerm: pathname + label: + theme: + + remark42: + host: + site: + locale: + + vssue: + platform: + owner: + repo: + clientId: + clientSecret: + autoCreateIssue: false + + # Waline client configuration see: https://waline.js.org/en/reference/component.html + waline: + serverURL: + lang: + pageview: + emoji: + - https://unpkg.com/@waline/emojis@1.0.1/weibo + requiredMeta: + - name + - email + - url + locale: + admin: Admin + placeholder: + + twikoo: + envId: + region: + path: + lang: + + # See https://cactus.chat/docs/reference/web-client/#configuration for description of the various options + cactus: + defaultHomeserverUrl: "https://matrix.cactus.chat:8448" + serverName: "cactus.chat" + siteName: "" # You must insert a unique identifier here matching the one you registered (See https://cactus.chat/docs/getting-started/quick-start/#register-your-site) + + giscus: + repo: + repoID: + category: + categoryID: + mapping: + lightTheme: + darkTheme: + reactionsEnabled: 1 + emitMetadata: 0 + + gitalk: + owner: + admin: + repo: + clientID: + clientSecret: + + cusdis: + host: + id: + widgets: + homepage: + - type: search + - type: archives + params: + limit: 5 + - type: categories + params: + limit: 10 + - type: tag-cloud + params: + limit: 10 + page: + - type: toc + + opengraph: + twitter: + # Your Twitter username + site: + + # Available values: summary, summary_large_image + card: summary_large_image + + defaultImage: + opengraph: + enabled: false + local: false + src: + + colorScheme: + # Display toggle + toggle: true + + # Available values: auto, light, dark + default: auto + + imageProcessing: + cover: + enabled: true + content: + enabled: true + +### Custom menu +### See https://stack.jimmycai.com/config/menu +### To remove about, archive and search page menu item, remove `menu` field from their FrontMatter +menu: + main: [] + + social: + - identifier: github + name: GitHub + url: https://github.com/CaiJimmy/hugo-theme-stack + params: + icon: brand-github + + - identifier: twitter + name: Twitter + url: https://twitter.com + params: + icon: brand-twitter + +related: + includeNewer: true + threshold: 60 + toLower: false + indices: + - name: tags + weight: 100 + + - name: categories + weight: 200 + +markup: + goldmark: + renderer: + ## Set to true if you have HTML content inside Markdown + unsafe: true + tableOfContents: + endLevel: 4 + ordered: true + startLevel: 2 + highlight: + noClasses: false + codeFences: true + guessSyntax: true + lineNoStart: 1 + lineNos: true + lineNumbersInTable: true + tabWidth: 4 diff --git a/themes/hugo-theme-stack/go.mod b/themes/hugo-theme-stack/go.mod new file mode 100644 index 0000000..63df635 --- /dev/null +++ b/themes/hugo-theme-stack/go.mod @@ -0,0 +1,3 @@ +module github.com/CaiJimmy/hugo-theme-stack/v3 + +go 1.17 diff --git a/themes/hugo-theme-stack/i18n/ar.yaml b/themes/hugo-theme-stack/i18n/ar.yaml new file mode 100644 index 0000000..63101aa --- /dev/null +++ b/themes/hugo-theme-stack/i18n/ar.yaml @@ -0,0 +1,74 @@ +toggleMenu: + other: اخفي القائمة + +darkMode: + other: الوضع الداكن + +list: + page: + one: "{{ .Count }} صفحه" + other: "{{ .Count }} صفحات" + + section: + other: قسم + + subsection: + one: قسم فرعي + other: اقسام فرعية + +article: + back: + other: خلف + + tableOfContents: + other: جدول المحتويات + + relatedContent: + other: محتوى مشابهه + + lastUpdatedOn: + other: التعديل الاخير + + readingTime: + one: "تُقرأ خلال دقيقة" + other: "تُقرأ خلال {{ .Count }} دقائق" + +notFound: + title: + other: غير موجود + + subtitle: + other: تعذر العثور على الصفحة المطلوبة. + +widget: + archives: + title: + other: الارشيفات + + more: + other: اكثر + + tagCloud: + title: + other: وسوم + + categoriesCloud: + title: + other: التصنيفات + +search: + title: + other: بحث + + placeholder: + other: اكتب... + + resultTitle: + other: "#PAGES_COUNT نتيجة (#TIME_SECONDS ثواني)" + +footer: + builtWith: + other: "مبني بستخدام {{ .Generator }}" + + designedBy: + other: "قالب {{ .Theme }} مصمم من {{ .DesignedBy }}" diff --git a/themes/hugo-theme-stack/i18n/be.yaml b/themes/hugo-theme-stack/i18n/be.yaml new file mode 100644 index 0000000..605cd08 --- /dev/null +++ b/themes/hugo-theme-stack/i18n/be.yaml @@ -0,0 +1,72 @@ +toggleMenu: + other: Паказаць/схаваць меню + +darkMode: + other: Цёмны рэжым + +list: + page: + one: "{{ .Count }} старонка" + few: "{{ .Count }} старонкі" + many: "{{ .Count }} старонак" + other: "{{ .Count }} старонкі" + + section: + other: Раздзел + + subsection: + one: Падраздзел + few: Падраздзелы + many: Падраздзелы + other: Падраздзелы + +article: + back: + other: Назад + + relatedContent: + other: Таксама рэкамендуем + + lastUpdatedOn: + other: Абноўлена + + tableOfContents: + other: Змест + + readingTime: + other: "Час чытання: {{ .Count }} хв." + +notFound: + title: + other: Не знойдзена + + subtitle: + other: Запытваемая старонка не існуе + +widget: + archives: + title: + other: Архівы + more: + other: Яшчэ + + tagCloud: + title: + other: Тэгі + +search: + title: + other: Пошук + + placeholder: + other: Увядзіце нешта... + + resultTitle: + other: "Знайдзена #PAGES_COUNT старонак (за #TIME_SECONDS с.)" + +footer: + builtWith: + other: Створана пры дапамозе {{ .Generator }} + + designedBy: + other: Тэма {{ .Theme }}, дызайн {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/bn.yaml b/themes/hugo-theme-stack/i18n/bn.yaml new file mode 100644 index 0000000..36f25a3 --- /dev/null +++ b/themes/hugo-theme-stack/i18n/bn.yaml @@ -0,0 +1,73 @@ +toggleMenu: + other: টগল মেনু + +darkMode: + other: ডার্ক মোড + +list: + page: + one: "{{ .Count }} পাতা" + other: "{{ .Count }} পাতা" + + section: + other: অনুচ্ছেদ + + subsection: + one: উপ-অনুচ্ছেদ + other: উপ-অনুচ্ছেদ + +article: + back: + other: পেছনে + + tableOfContents: + other: সূচিপত্র + + relatedContent: + other: সম্পর্কিত বিষয়বস্তু + + lastUpdatedOn: + other: সর্বশেষ আপডেট করা হয়েছে + + readingTime: + one: "{{ .Count }} মিনিটে পড়া যাবে" + other: "{{ .Count }} মিনিটে পড়া যাবে" + +notFound: + title: + other: পাওয়া যায়নি + + subtitle: + other: এই পাতাটি বিদ্যমান নেই + +widget: + archives: + title: + other: আর্কাইভ + + more: + other: আরও + + tagCloud: + title: + other: ট্যাগ + categoriesCloud: + title: + other: বিভাগ + +search: + title: + other: অনুসন্ধান + + placeholder: + other: কিছু টাইপ করুন... + + resultTitle: + other: "#PAGES_COUNT পাতা (#TIME_SECONDS সেকেন্ড)" + +footer: + builtWith: + other: "{{ .Generator }} দিয়ে নির্মিত" + + designedBy: + other: "থিম {{ .Theme }} ডিজাইন করেছেন {{ .DesignedBy }}" diff --git a/themes/hugo-theme-stack/i18n/ca.yaml b/themes/hugo-theme-stack/i18n/ca.yaml new file mode 100644 index 0000000..af4167e --- /dev/null +++ b/themes/hugo-theme-stack/i18n/ca.yaml @@ -0,0 +1,73 @@ +toggleMenu: + other: Toggle Menu + +darkMode: + other: Mode fosc + +list: + page: + one: "{{ .Count }} pàgina" + other: "{{ .Count }} pàgines" + + section: + other: Secció + + subsection: + one: Subsecció + other: Subseccions + +article: + back: + other: Tornar + + tableOfContents: + other: Taula de contingut + + relatedContent: + other: Continguts relacionats + + lastUpdatedOn: + other: Última vegada actualitzat + + readingTime: + one: "{{ .Count }} minut a llegir" + other: "{{ .Count }} minuts a llegir" + +notFound: + title: + other: No Trobat + + subtitle: + other: Aquesta pàgina no existeix + +widget: + archives: + title: + other: Arxiu + + more: + other: Més + + tagCloud: + title: + other: Etiquetes + categoriesCloud: + title: + other: Categories + +search: + title: + other: Cerca + + placeholder: + other: Tecleja alguna cosa... + + resultTitle: + other: "#PAGES_COUNT pàgines en (#TIME_SECONDS segons)" + +footer: + builtWith: + other: Creat amb {{ .Generator }} + + designedBy: + other: Tema {{ .Theme }} dissenyat per {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/cs.yaml b/themes/hugo-theme-stack/i18n/cs.yaml new file mode 100644 index 0000000..7b9b519 --- /dev/null +++ b/themes/hugo-theme-stack/i18n/cs.yaml @@ -0,0 +1,73 @@ +toggleMenu: + other: Skrýt menu + +darkMode: + other: Tmavý režim + +list: + page: + one: "{{ .Count }} stránka" + other: "{{ .Count }} stránek" + + section: + other: Kategorie + + subsection: + one: Podkategorie + other: Podkategorie + +article: + back: + other: Zpět + + tableOfContents: + other: Obsah + + relatedContent: + other: Související + + lastUpdatedOn: + other: Naposledy aktualizováno + + readingTime: + one: "{{ .Count }} minuta" + other: "{{ .Count }} minut" + +notFound: + title: + other: Nenalezeno + + subtitle: + other: Tato stránka neexistuje + +widget: + archives: + title: + other: Archivy + + more: + other: Více + + tagCloud: + title: + other: Štítky + categoriesCloud: + title: + other: Kategorie + +search: + title: + other: Hledat + + placeholder: + other: Zadejte něco... + + resultTitle: + other: "#PAGES_COUNT stránek (#TIME_SECONDS sekund)" + +footer: + builtWith: + other: Vytvořeno pomocí {{ .Generator }} + + designedBy: + other: Šablona {{ .Theme }} od {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/de.yaml b/themes/hugo-theme-stack/i18n/de.yaml new file mode 100644 index 0000000..7ab5b56 --- /dev/null +++ b/themes/hugo-theme-stack/i18n/de.yaml @@ -0,0 +1,74 @@ +toggleMenu: + other: Menü umschalten + +darkMode: + other: Dunkler Modus + +list: + page: + one: "{{ .Count }} Seite" + other: "{{ .Count }} Seiten" + + section: + other: Abschnitt + + subsection: + one: Unterabschnitt + other: Unterabschnitte + +article: + back: + other: Zurück + + tableOfContents: + other: Inhaltsverzeichnis + + relatedContent: + other: Verwandte Inhalte + + lastUpdatedOn: + other: Zuletzt aktualisiert am + + readingTime: + one: "{{ .Count }} Minute Lesezeit" + other: "{{ .Count }} Minuten Lesezeit" + +notFound: + title: + other: Seite nicht gefunden + + subtitle: + other: Diese Seite existiert nicht + +widget: + archives: + title: + other: Archiv + + more: + other: Weitere + + tagCloud: + title: + other: Schlagwörter + + categoriesCloud: + title: + other: Kategorien + +search: + title: + other: Suche + + placeholder: + other: Etwas tippen... + + resultTitle: + other: "#PAGES_COUNT Seiten (#TIME_SECONDS Sekunden)" + +footer: + builtWith: + other: Erstellt mit {{ .Generator }} + + designedBy: + other: Theme {{ .Theme }} gestaltet von {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/el.yaml b/themes/hugo-theme-stack/i18n/el.yaml new file mode 100644 index 0000000..27a147d --- /dev/null +++ b/themes/hugo-theme-stack/i18n/el.yaml @@ -0,0 +1,70 @@ +toggleMenu: + other: Εναλλαγή Μενού + +darkMode: + other: Σκοτεινό θέμα + +list: + page: + one: "{{ .Count }} σελιδα" + other: "{{ .Count }} σελιδες" + + section: + other: Ενότητα + + subsection: + one: Υποενότητα + other: Υποενότητες + +article: + back: + other: Πισω + + tableOfContents: + other: Πινακας περιεχομενων + + relatedContent: + other: Σχετικο περιεχομενο + + lastUpdatedOn: + other: Τελευταια τροποποιηση στις + + readingTime: + one: "{{ .Count }} λεπτό ανάγνωσης" + ### Seems that there's no need to add 's' even if it's plural in English + other: "{{ .Count }} λεπτά ανάγνωσης" + +notFound: + title: + other: Δε βρέθηκε + subtitle: + other: Η σελίδα δε βρέθηκε. + +widget: + archives: + title: + other: Αρχειο + + more: + other: Περισσότερα + + tagCloud: + title: + other: Tags + +search: + title: + other: Αναζήτηση + + placeholder: + other: Πληκτρολογήστε κάτι... + + resultTitle: + other: "#PAGES_COUNT σελιδες (#TIME_SECONDS δευτερολεπτα)" + +footer: + builtWith: + other: Δημιουργήθηκε με τη χρήση {{ .Generator }} + + designedBy: + other: Το θέμα {{ .Theme }} σχεδιάστηκε από το {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/en.yaml b/themes/hugo-theme-stack/i18n/en.yaml new file mode 100644 index 0000000..fb07328 --- /dev/null +++ b/themes/hugo-theme-stack/i18n/en.yaml @@ -0,0 +1,73 @@ +toggleMenu: + other: Toggle Menu + +darkMode: + other: Dark Mode + +list: + page: + one: "{{ .Count }} page" + other: "{{ .Count }} pages" + + section: + other: Section + + subsection: + one: Subsection + other: Subsections + +article: + back: + other: Back + + tableOfContents: + other: Table of contents + + relatedContent: + other: Related content + + lastUpdatedOn: + other: Last updated on + + readingTime: + one: "{{ .Count }} minute read" + other: "{{ .Count }} minute read" + +notFound: + title: + other: Not Found + + subtitle: + other: This page does not exist + +widget: + archives: + title: + other: Archives + + more: + other: More + + tagCloud: + title: + other: Tags + categoriesCloud: + title: + other: Categories + +search: + title: + other: Search + + placeholder: + other: Type something... + + resultTitle: + other: "#PAGES_COUNT pages (#TIME_SECONDS seconds)" + +footer: + builtWith: + other: Built with {{ .Generator }} + + designedBy: + other: Theme {{ .Theme }} designed by {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/es.yaml b/themes/hugo-theme-stack/i18n/es.yaml new file mode 100644 index 0000000..6b4b3af --- /dev/null +++ b/themes/hugo-theme-stack/i18n/es.yaml @@ -0,0 +1,73 @@ +toggleMenu: + other: Ocultar menú + +darkMode: + other: Modo oscuro + +list: + page: + one: "{{ .Count }} página" + other: "{{ .Count }} páginas" + + section: + other: Sección + + subsection: + one: Subsección + other: Subsecciones + +article: + back: + other: Volver + + tableOfContents: + other: Tabla de contenido + + relatedContent: + other: Contenidos relacionados + + lastUpdatedOn: + other: Última actualización + + readingTime: + one: "Tiempo de lectura {{ .Count }} minuto" + other: "Tiempo de lectura {{ .Count }} minutos" + +notFound: + title: + other: No Encontrado + + subtitle: + other: Esta página no existe + +widget: + archives: + title: + other: Archivo + + more: + other: Más + + tagCloud: + title: + other: Etiquetas + categoriesCloud: + title: + other: Categorías + +search: + title: + other: Búsqueda + + placeholder: + other: Escribe algo... + + resultTitle: + other: "#PAGES_COUNT páginas en (#TIME_SECONDS segundos)" + +footer: + builtWith: + other: Creado con {{ .Generator }} + + designedBy: + other: Tema {{ .Theme }} diseñado por {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/fa.yaml b/themes/hugo-theme-stack/i18n/fa.yaml new file mode 100644 index 0000000..3655757 --- /dev/null +++ b/themes/hugo-theme-stack/i18n/fa.yaml @@ -0,0 +1,73 @@ +toggleMenu: + other: منو + +darkMode: + other: حالت شب + +list: + page: + one: "{{ .Count }} صفحه" + other: "{{ .Count }} صفحه" + + section: + other: بخش + + subsection: + one: زیربخش + other: زیربخش + +article: + back: + other: قبلی + + tableOfContents: + other: فهرست + + relatedContent: + other: مطالب مرتبط + + lastUpdatedOn: + other: آخرین بروزرسانی در + + readingTime: + one: "مطالعه در {{ .Count }} دقیقه" + other: "مطالعه در {{ .Count }} دقیقه" + +notFound: + title: + other: یافت نشد + + subtitle: + other: این صحه وجود ندارد + +widget: + archives: + title: + other: آرشیو + + more: + other: بیشتر + + tagCloud: + title: + other: تگ ها + categoriesCloud: + title: + other: دسته بندی + +search: + title: + other: جستجو + + placeholder: + other: تایپ کنید ... + + resultTitle: + other: "#PAGES_COUNT صفحه (#TIME_SECONDS ثانیه)" + +footer: + builtWith: + other: قدرت گرفته از {{ .Generator }} + + designedBy: + other: قالب {{ .Theme }} ساخته شده توسط {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/fr.yaml b/themes/hugo-theme-stack/i18n/fr.yaml new file mode 100644 index 0000000..c3feb1d --- /dev/null +++ b/themes/hugo-theme-stack/i18n/fr.yaml @@ -0,0 +1,69 @@ +toggleMenu: + other: Afficher le menu + +darkMode: + other: Mode sombre + +list: + page: + one: "{{ .Count }} page" + other: "{{ .Count }} pages" + + section: + other: Section + + subsection: + one: Sous-section + other: Sous-sections + +article: + back: + other: Retour + + tableOfContents: + other: Table des matières + + relatedContent: + other: Contenus liés + + lastUpdatedOn: + other: Dernière mise à jour le + + readingTime: + one: "{{ .Count }} minute de lecture" + other: "{{ .Count }} minutes de lecture" + +notFound: + title: + other: Page non trouvée + subtitle: + other: Cette page n'existe pas. + +widget: + archives: + title: + other: Archives + + more: + other: Autres + + tagCloud: + title: + other: Mots clés + +search: + title: + other: Rechercher + + placeholder: + other: Cherchez un article, une publication, etc. + + resultTitle: + other: "#PAGES_COUNT pages (#TIME_SECONDS secondes)" + +footer: + builtWith: + other: Généré avec {{ .Generator }} + + designedBy: + other: Thème {{ .Theme }} conçu par {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/hi.yaml b/themes/hugo-theme-stack/i18n/hi.yaml new file mode 100644 index 0000000..27316fe --- /dev/null +++ b/themes/hugo-theme-stack/i18n/hi.yaml @@ -0,0 +1,73 @@ +toggleMenu: + other: मेनू टॉगल करें + +darkMode: + other: डार्क मोड + +list: + page: + one: "{{ .Count }} पेज" + other: "{{ .Count }} पेज" + + section: + other: अनुभाग + + subsection: + one: उपधारा + other: उपखंड + +article: + back: + other: पीछे + + tableOfContents: + other: विषयसूची + + relatedContent: + other: संबंधित सामग्री + + lastUpdatedOn: + other: अंतिम बार अपडेट किया गया + + readingTime: + one: "{{ .Count }} मिनट पढ़ें" + other: "{{ .Count }} मिनट पढ़ें" + +notFound: + title: + other: 404 नहीं मिला। + + subtitle: + other: यह पृष्ठ मौजूद नहीं है। + +widget: + archives: + title: + other: अभिलेखागार + + more: + other: अधिक + + tagCloud: + title: + other: टैग + categoriesCloud: + title: + other: श्रेणियाँ + +search: + title: + other: खोज + + placeholder: + other: कुछ लिखें... + + resultTitle: + other: "#PAGES_COUNT पेज (#TIME_SECONDS सेकंड)" + +footer: + builtWith: + other: निर्मित {{ .Generator }} के साथ + + designedBy: + other: थीम {{ .Theme }} द्वारा डिज़ाइन किया गया {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/hu.yaml b/themes/hugo-theme-stack/i18n/hu.yaml new file mode 100644 index 0000000..5e5af92 --- /dev/null +++ b/themes/hugo-theme-stack/i18n/hu.yaml @@ -0,0 +1,73 @@ +toggleMenu: + other: Menü Kapcsolása + +darkMode: + other: Sötét Mód + +list: + page: + one: "{{ .Count }} oldal" + other: "{{ .Count }} oldalak" + + section: + other: Szekció + + subsection: + one: Alszekció + other: Alszekciók + +article: + back: + other: Vissza + + tableOfContents: + other: Tartalomjegyzék + + relatedContent: + other: Kapcsolódó tartalom + + lastUpdatedOn: + other: Utolsó frissítés időpontja + + readingTime: + one: "{{ .Count }} percnyi olvasmány" + other: "{{ .Count }} percnyi olvasmány" + +notFound: + title: + other: Nem található + + subtitle: + other: Ez az oldal nem létezik + +widget: + archives: + title: + other: Archívum + + more: + other: Több + + tagCloud: + title: + other: Cimkék + categoriesCloud: + title: + other: Kategóriák + +search: + title: + other: Keresés + + placeholder: + other: Írj valamit... + + resultTitle: + other: "#PAGES_COUNT oldal (#TIME_SECONDS másodperc alatt)" + +footer: + builtWith: + other: "{{ .Generator }} használatával készült" + + designedBy: + other: A {{ .Theme }} dizájnt {{ .DesignedBy }} tervezte diff --git a/themes/hugo-theme-stack/i18n/id.yaml b/themes/hugo-theme-stack/i18n/id.yaml new file mode 100644 index 0000000..8104351 --- /dev/null +++ b/themes/hugo-theme-stack/i18n/id.yaml @@ -0,0 +1,73 @@ +toggleMenu: + other: Tampilkan Menu + +darkMode: + other: Mode Gelap + +list: + page: + one: "{{ .Count }} halaman" + other: "{{ .Count }} halaman" + + section: + other: Bagian + + subsection: + one: Subbagian + other: Subbagian + +article: + back: + other: Kembali + + tableOfContents: + other: Daftar Isi + + relatedContent: + other: Konten terkait + + lastUpdatedOn: + other: Terakhir diperbarui pada + + readingTime: + one: "Waktu Membaca: {{ .Count }} menit" + other: "Waktu Membaca: {{ .Count }} menit" + +notFound: + title: + other: Tidak ditemukan + subtitle: + other: Halaman yang Anda akses tidak ditemukan. + +widget: + archives: + title: + other: Arsip + + more: + other: Lebih + + tagCloud: + title: + other: Tag + + categoriesCloud: + title: + other: Kategori + +search: + title: + other: Cari + + placeholder: + other: Ketik sesuatu... + + resultTitle: + other: "#PAGES_COUNT halaman (#TIME_SECONDS detik)" + +footer: + builtWith: + other: Dibangun dengan {{ .Generator }} + + designedBy: + other: Tema {{ .Theme }} dirancang oleh {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/it.yaml b/themes/hugo-theme-stack/i18n/it.yaml new file mode 100644 index 0000000..0cbeeab --- /dev/null +++ b/themes/hugo-theme-stack/i18n/it.yaml @@ -0,0 +1,73 @@ +toggleMenu: + other: Toggle Menu + +darkMode: + other: Dark Mode + +list: + page: + one: "{{ .Count }} pagina" + other: "{{ .Count }} pagine" + + section: + other: Sezione + + subsection: + one: Sottosezione + other: Sottosezioni + +article: + back: + other: Indietro + + tableOfContents: + other: Indice + + relatedContent: + other: Contenuti correlati + + lastUpdatedOn: + other: Aggiornato il + + readingTime: + one: "{{ .Count }} min per leggere" + other: "{{ .Count }} min per leggere" + +notFound: + title: + other: Non trovato + subtitle: + other: Questa pagina non esiste. + +widget: + archives: + title: + other: Archivi + + more: + other: Di più + + tagCloud: + title: + other: Tags + + categoriesCloud: + title: + other: Categorie + +search: + title: + other: Cerca + + placeholder: + other: Scrivi qualcosa... + + resultTitle: + other: "#PAGES_COUNT pagine (#TIME_SECONDS secondi)" + +footer: + builtWith: + other: Realizzato con {{ .Generator }} + + designedBy: + other: Tema {{ .Theme }} realizzato da {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/ja.yaml b/themes/hugo-theme-stack/i18n/ja.yaml new file mode 100644 index 0000000..12352ee --- /dev/null +++ b/themes/hugo-theme-stack/i18n/ja.yaml @@ -0,0 +1,70 @@ +toggleMenu: + other: メニューを開く・閉じる + +darkMode: + other: ダークモード + +list: + page: + other: "{{ .Count }} ページ目" + + section: + other: セクション + + subsection: + other: サブセクション + +article: + back: + other: 前のページ + + tableOfContents: + other: 目次 + + relatedContent: + other: 関連するコンテンツ + + lastUpdatedOn: + other: 最終更新 + + readingTime: + other: "読了時間: {{ .Count }}分" + +notFound: + title: + other: 404 Not Found + subtitle: + other: 指定されたページは存在しません。 + +widget: + archives: + title: + other: アーカイブ + + more: + other: さらに見る + + tagCloud: + title: + other: タグ + + categoriesCloud: + title: + other: カテゴリ + +search: + title: + other: 検索 + + placeholder: + other: 入力... + + resultTitle: + other: "#PAGES_COUNT 件 (#TIME_SECONDS 秒)" + +footer: + builtWith: + other: "{{ .Generator }} で構築されています。" + + designedBy: + other: テーマ {{ .Theme }} は {{ .DesignedBy }} によって設計されています。 diff --git a/themes/hugo-theme-stack/i18n/ko.yaml b/themes/hugo-theme-stack/i18n/ko.yaml new file mode 100644 index 0000000..11cdc4a --- /dev/null +++ b/themes/hugo-theme-stack/i18n/ko.yaml @@ -0,0 +1,72 @@ +toggleMenu: + other: 메뉴 여닫기 + +darkMode: + other: 다크 모드 + +list: + page: + one: "{{ .Count }} 페이지" + other: "{{ .Count }} 페이지" + + section: + other: 섹션 + + subsection: + one: 서브섹션 + other: 서브섹션 + +article: + back: + other: 뒤로가기 + + tableOfContents: + other: 목차 + + relatedContent: + other: 관련 글 + + lastUpdatedOn: + other: "마지막 수정: " + + readingTime: + one: "{{ .Count }} 분 정도" + other: "{{ .Count }} 분 정도" + +notFound: + title: + other: 찾을 수 없음 + + subtitle: + other: 페이지를 찾을 수 없습니다. + +widget: + archives: + title: + other: 보관함 + more: + other: 더보기 + + categoriesCloud: + title: + other: 카테고리 + + tagCloud: + title: + other: 태그 + +search: + title: + other: 검색 + + placeholder: + other: 검색어를 입력하세요... + + resultTitle: + other: "#PAGES_COUNT 페이지 (#TIME_SECONDS 초)" + +footer: + builtWith: + other: "{{ .Generator }}로 만듦" + designedBy: + other: "{{ .DesignedBy }}의 {{ .Theme }} 테마 사용 중" diff --git a/themes/hugo-theme-stack/i18n/nl.yaml b/themes/hugo-theme-stack/i18n/nl.yaml new file mode 100644 index 0000000..b5bf264 --- /dev/null +++ b/themes/hugo-theme-stack/i18n/nl.yaml @@ -0,0 +1,59 @@ +toggleMenu: + other: Open Menu + +darkMode: + other: Donkere modus + +list: + page: + one: "{{ .Count }} pagina" + other: "{{ .Count }} pagina's" + + section: + other: Sectie + + subsection: + one: Subsectie + other: Subsecties + +article: + relatedContent: + other: Gerelateerde inhoud + lastUpdatedOn: + other: Laatst bijgewerkt op + readingTime: + other: "{{ .Count }} leestijd" + +notFound: + title: + other: Niet gevonden + subtitle: + other: Deze pagina bestaat niet. + +widget: + archives: + title: + other: Archief + more: + other: Meer + tagCloud: + title: + other: Tags + + categoriesCloud: + title: + other: Categorie + +search: + title: + other: Zoeken + placeholder: + other: Typ iets + resultTitle: + other: "#PAGES_COUNT pagina's (#TIME_SECONDS seconden)" + +footer: + builtWith: + other: Gemaakt met {{ .Generator }} + designedBy: + other: Theme {{ .Theme }} ontworpen door {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/pl.yaml b/themes/hugo-theme-stack/i18n/pl.yaml new file mode 100644 index 0000000..9f2982f --- /dev/null +++ b/themes/hugo-theme-stack/i18n/pl.yaml @@ -0,0 +1,82 @@ +toggleMenu: + other: Przełącz Menu + +darkMode: + other: Tryb ciemny + +list: + page: + one: "{{ .Count }} strona" + few: "{{ .Count }} strony" + many: "{{ .Count }} stron" + other: "{{ .Count }} stron" + + section: + other: Sekcja + + subsection: + one: Podsekcja + few: Podsekcje + many: Podsekcji + other: Podsekcji + +article: + back: + other: Wróć + + tableOfContents: + other: Spis treści + + relatedContent: + other: Powiązane artykuły + + lastUpdatedOn: + other: Ostatnio zaktualizowany + + readingTime: + one: "Przeczytasz w {{ .Count }} minutę" + few: "Przeczytasz w {{ .Count }} minuty" + many: "Przeczytasz w {{ .Count }} minut" + other: "Przeczytasz w {{ .Count }} minut" + +notFound: + title: + other: Nie znaleziono + subtitle: + other: Ta strona nie istnieje + +widget: + archives: + title: + other: Archiwum + + more: + other: Więcej + + tagCloud: + title: + other: Tagi + + categoriesCloud: + title: + other: Kategorie + +search: + title: + other: Szukaj + + placeholder: + other: Wpisz coś... + + resultTitle: + one: "#PAGES_COUNT strona (#TIME_SECONDS sekund)" + few: "#PAGES_COUNT strony (#TIME_SECONDS sekund)" + many: "#PAGES_COUNT stron (#TIME_SECONDS sekund)" + other: "#PAGES_COUNT stron (#TIME_SECONDS sekund)" + +footer: + builtWith: + other: Zbudowano z {{ .Generator }} + + designedBy: + other: Motyw {{ .Theme }} zaprojektowany przez {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/pt-br.yaml b/themes/hugo-theme-stack/i18n/pt-br.yaml new file mode 100644 index 0000000..2784f3d --- /dev/null +++ b/themes/hugo-theme-stack/i18n/pt-br.yaml @@ -0,0 +1,67 @@ +toggleMenu: + other: Alternar Menu + +darkMode: + other: Modo Escuro + +list: + page: + one: "{{ .Count }} página" + other: "{{ .Count }} páginas" + + section: + other: Seção + + subsection: + one: Subseção + other: Subseções + +article: + back: + other: Voltar + + tableOfContents: + other: Índice + + relatedContent: + other: Conteúdo relacionado + + lastUpdatedOn: + other: Última atualização em + + readingTime: + one: "{{ .Count }} minuto de leitura" + other: "{{ .Count }} minutos de leitura" + +notFound: + title: + other: Não Encontrado + subtitle: + other: Esta página não existe. + +widget: + archives: + title: + other: Arquivos + more: + other: Mais + tagCloud: + title: + other: Tags + categoriesCloud: + title: + other: Categorias + +search: + title: + other: Busca + placeholder: + other: Digite algo... + resultTitle: + other: "#PAGES_COUNT páginas (#TIME_SECONDS segundos)" + +footer: + builtWith: + other: Criado com {{ .Generator }} + designedBy: + other: Tema {{ .Theme }} desenvolvido por {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/pt-pt.yaml b/themes/hugo-theme-stack/i18n/pt-pt.yaml new file mode 100644 index 0000000..f524969 --- /dev/null +++ b/themes/hugo-theme-stack/i18n/pt-pt.yaml @@ -0,0 +1,67 @@ +toggleMenu: + other: Alternar Menu + +darkMode: + other: Modo Escuro + +list: + page: + one: "{{ .Count }} página" + other: "{{ .Count }} páginas" + + section: + other: Secção + + subsection: + one: Subsecção + other: Subsecções + +article: + back: + other: Voltar + + tableOfContents: + other: Índice + + relatedContent: + other: Conteúdo relacionado + + lastUpdatedOn: + other: Última atualização a + + readingTime: + one: "{{ .Count }} minuto de leitura" + other: "{{ .Count }} minutos de leitura" + +notFound: + title: + other: Não Encontrado + subtitle: + other: Esta página não existe. + +widget: + archives: + title: + other: Arquivos + more: + other: Mais + tagCloud: + title: + other: Tags + categoriesCloud: + title: + other: Categorias + +search: + title: + other: Pesquisa + placeholder: + other: Escreva algo... + resultTitle: + other: "#PAGES_COUNT páginas (#TIME_SECONDS segundos)" + +footer: + builtWith: + other: Criado com {{ .Generator }} + designedBy: + other: Tema {{ .Theme }} desenvolvido por {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/ru.yaml b/themes/hugo-theme-stack/i18n/ru.yaml new file mode 100644 index 0000000..b1f1e51 --- /dev/null +++ b/themes/hugo-theme-stack/i18n/ru.yaml @@ -0,0 +1,63 @@ +toggleMenu: + other: Показать/скрыть меню + +darkMode: + other: Тёмный режим + +list: + page: + one: "{{ .Count }} страница" + few: "{{ .Count }} страницы" + many: "{{ .Count }} страниц" + other: "{{ .Count }} страниц" + + section: + other: Раздел + + subsection: + one: Подраздел + few: Подразделы + many: Подразделы + other: Подразделы + +article: + back: + other: Назад + relatedContent: + other: Также рекомендуем + lastUpdatedOn: + other: Обновлено + tableOfContents: + other: Содержание + readingTime: + other: "Время чтения: {{ .Count }} мин." + +notFound: + title: + other: Не найдено + subtitle: + other: Запрашиваемая страница не существует + +widget: + archives: + title: + other: Архивы + more: + other: Ещё + tagCloud: + title: + other: Теги + +search: + title: + other: Поиск + placeholder: + other: Введите что-нибудь... + resultTitle: + other: "Найдено #PAGES_COUNT страниц (за #TIME_SECONDS с.)" + +footer: + builtWith: + other: Создано при помощи {{ .Generator }} + designedBy: + other: Тема {{ .Theme }}, дизайн {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/sk.yaml b/themes/hugo-theme-stack/i18n/sk.yaml new file mode 100644 index 0000000..59c680e --- /dev/null +++ b/themes/hugo-theme-stack/i18n/sk.yaml @@ -0,0 +1,71 @@ +toggleMenu: + other: Skryť menu + +darkMode: + other: Tmavý režim + +list: + page: + one: "{{ .Count }} stránka" + other: "{{ .Count }} stránok" + + section: + other: Kategórie + + subsection: + one: Podkategória + other: Podkategórie + +article: + back: + other: Späť + + tableOfContents: + other: Obsah + + relatedContent: + other: Súvisiace + + lastUpdatedOn: + other: Naposledy aktualizované + + readingTime: + one: "{{ .Count }} minúta" + other: "{{ .Count }} minút" + +notFound: + title: + other: Nenájdené + + subtitle: + other: Tato stránka neexistuje + +widget: + archives: + title: + other: Archívy + more: + other: Viac + tagCloud: + title: + other: Štítky + categoriesCloud: + title: + other: Kategórie + +search: + title: + other: Hladať + + placeholder: + other: Zadajte niečo... + + resultTitle: + other: "#PAGES_COUNT stránok (#TIME_SECONDS sekúnd)" + +footer: + builtWith: + other: Vytvorené pomocou {{ .Generator }} + + designedBy: + other: Šablóna {{ .Theme }} od {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/th.yaml b/themes/hugo-theme-stack/i18n/th.yaml new file mode 100644 index 0000000..9982c06 --- /dev/null +++ b/themes/hugo-theme-stack/i18n/th.yaml @@ -0,0 +1,70 @@ +toggleMenu: + other: สลับเมนู + +darkMode: + other: ธีมมืด + +list: + page: + one: "{{ .Count }} หน้า" + other: "{{ .Count }} หน้า" + + section: + other: หมวดหมู่ + + subsection: + one: หมวดหมู่ย่อย + other: หมวดหมู่ย่อยอื่นๆ + +article: + back: + other: กลับไป + + tableOfContents: + other: สารบัญ + + relatedContent: + other: เนื้อหาคล้ายคลึงกัน + + lastUpdatedOn: + other: อัปเดตล่าสุดเมื่อ + + readingTime: + one: "น่าจะใช้เวลา {{ .Count }} นาทีในการอ่าน" + other: "น่าจะใช้เวลา {{ .Count }} นาทีในการอ่าน" + +notFound: + title: + other: ไม่พบหัวข้อ + + subtitle: + other: ไม่พบหน้านี้ในระบบ + +widget: + archives: + title: + other: เนื้อหาที่เก็บถาวรแล้ว + + more: + other: อื่นๆ นอกจากนี้ + + tagCloud: + title: + other: แท็ก + +search: + title: + other: ค้นหา + + placeholder: + other: พิมพ์เพื่อค้นหา ... + + resultTitle: + other: "#PAGES_COUNT pages (#TIME_SECONDS seconds)" + +footer: + builtWith: + other: ถูกสร้างด้วย {{ .Generator }} + + designedBy: + other: ธีม {{ .Theme }} ออกแบบโดย {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/tr.yaml b/themes/hugo-theme-stack/i18n/tr.yaml new file mode 100644 index 0000000..2dbb9d5 --- /dev/null +++ b/themes/hugo-theme-stack/i18n/tr.yaml @@ -0,0 +1,53 @@ +toggleMenu: + other: Menüyü Gizle + +darkMode: + other: Koyu Mod + +list: + page: + one: "{{ .Count }} makale" + other: "{{ .Count }} makale" + + section: + other: Bölüm + + subsection: + one: Alt bölüm + other: Alt bölümler + +article: + relatedContent: + other: Alakalı içerikler + lastUpdatedOn: + other: Son güncelleme + +notFound: + title: + other: Bulunamadı + subtitle: + other: Aradığınız sayfa mevcut değil. + +widget: + archives: + title: + other: Arşiv + more: + other: Daha fazla + tagCloud: + title: + other: Etiketler + +search: + title: + other: Arama + placeholder: + other: Birşeyler yazın... + resultTitle: + other: "#PAGES_COUNT sayfa (#TIME_SECONDS saniye)" + +footer: + builtWith: + other: "{{ .Generator }} ile oluşturuldu." + designedBy: + other: "{{ .Theme }} teması {{ .DesignedBy }} tarafından tasarlandı" diff --git a/themes/hugo-theme-stack/i18n/uk.yaml b/themes/hugo-theme-stack/i18n/uk.yaml new file mode 100644 index 0000000..3bd4f71 --- /dev/null +++ b/themes/hugo-theme-stack/i18n/uk.yaml @@ -0,0 +1,71 @@ +toggleMenu: + other: Показати меню + +darkMode: + other: Темна тема + +list: + page: + one: "{{ .Count }} сторінка" + few: "{{ .Count }} сторінки" + other: "{{ .Count }} сторінок" + + section: + other: Секція + + subsection: + one: Підсекція + other: Підсекції + +article: + back: + other: Назад + + tableOfContents: + other: Зміст + + relatedContent: + other: Схожі матеріали + + lastUpdatedOn: + other: Востаннє оновлено + + readingTime: + one: "Час читання: {{ .Count }} хв" + other: "Час читання: {{ .Count }} хв" + +notFound: + title: + other: Не знайдено + + subtitle: + other: Ця сторінка не існує + +widget: + archives: + title: + other: Архіви + + more: + other: Більше + + tagCloud: + title: + other: Теґи + +search: + title: + other: Пошук + + placeholder: + other: Напишіть що-небудь... + + resultTitle: + other: "#PAGES_COUNT сторінок (#TIME_SECONDS секунд)" + +footer: + builtWith: + other: Створено з {{ .Generator }} + + designedBy: + other: Тема {{ .Theme }}, дизайн {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/vi.yaml b/themes/hugo-theme-stack/i18n/vi.yaml new file mode 100644 index 0000000..13dc624 --- /dev/null +++ b/themes/hugo-theme-stack/i18n/vi.yaml @@ -0,0 +1,74 @@ +toggleMenu: + other: Hiển thị Menu + +darkMode: + other: Chế độ nền tối + +list: + page: + one: "{{ .Count }} trang" + other: "{{ .Count }} trang" + + section: + other: Section + + subsection: + one: Subsection + other: Subsections + +article: + back: + other: Trở lại + + tableOfContents: + other: Mục lục + + relatedContent: + other: Bài viết liên quan + + lastUpdatedOn: + other: Cập nhật lần cuối + + readingTime: + one: "{{ .Count }} phút đọc" + other: "{{ .Count }} phút đọc" + +notFound: + title: + other: Không tìm thấy + + subtitle: + other: Trang này không tồn tại + +widget: + archives: + title: + other: Lưu trữ + + more: + other: Còn nữa + + tagCloud: + title: + other: Nhãn dán + + categoriesCloud: + title: + other: Chuỗi bài + +search: + title: + other: Tìm kiếm + + placeholder: + other: Nhập từ khoá ... + + resultTitle: + other: "#PAGES_COUNT trang (#TIME_SECONDS giây)" + +footer: + builtWith: + other: Built with {{ .Generator }} + + designedBy: + other: Theme {{ .Theme }} thiết kế bởi {{ .DesignedBy }} diff --git a/themes/hugo-theme-stack/i18n/zh-cn.yaml b/themes/hugo-theme-stack/i18n/zh-cn.yaml new file mode 100644 index 0000000..da39c8f --- /dev/null +++ b/themes/hugo-theme-stack/i18n/zh-cn.yaml @@ -0,0 +1,67 @@ +toggleMenu: + other: 切换菜单 + +darkMode: + other: 暗色模式 + +list: + page: "{{ .Count }} 个页面" + + section: 章节 + + subsection: 子章节 + +article: + back: + other: 返回 + + tableOfContents: + other: 目录 + + relatedContent: + other: 相关文章 + + lastUpdatedOn: + other: 最后更新于 + + readingTime: + other: "阅读时长: {{ .Count }} 分钟" + +notFound: + title: + other: 404 错误 + subtitle: + other: 页面不存在 + +widget: + archives: + title: + other: 归档 + + more: + other: 更多 + + tagCloud: + title: + other: 标签云 + + categoriesCloud: + title: + other: 分类 + +search: + title: + other: 搜索 + + placeholder: + other: 输入关键词... + + resultTitle: + other: "#PAGES_COUNT 个结果 (用时 #TIME_SECONDS 秒)" + +footer: + builtWith: + other: 使用 {{ .Generator }} 构建 + + designedBy: + other: 主题 {{ .Theme }} 由 {{ .DesignedBy }} 设计 diff --git a/themes/hugo-theme-stack/i18n/zh-hk.yaml b/themes/hugo-theme-stack/i18n/zh-hk.yaml new file mode 100644 index 0000000..9e3c246 --- /dev/null +++ b/themes/hugo-theme-stack/i18n/zh-hk.yaml @@ -0,0 +1,73 @@ +toggleMenu: + other: 切換選單 + +darkMode: + other: 深色模式 + +list: + page: + one: "第 {{ .Count }} 頁" + other: "第 {{ .Count }} 頁" + + section: + other: Section + + subsection: + one: Subsection + other: Subsections + +article: + back: + other: 返回 + + tableOfContents: + other: 目錄 + + relatedContent: + other: 相關內容 + + lastUpdatedOn: + other: 上次改過於 + + readingTime: + one: "需要 {{ .Count }} 分鐘閱讀" + other: "需要 {{ .Count }} 分鐘閱讀" + +notFound: + title: + other: Not Found + + subtitle: + other: 頁面不存在 + +widget: + archives: + title: + other: Archives + + more: + other: 更多 + + tagCloud: + title: + other: Tags + categoriesCloud: + title: + other: Categories + +search: + title: + other: 搜尋 + + placeholder: + other: Type 關鍵字... + + resultTitle: + other: "#PAGES_COUNT pages (#TIME_SECONDS seconds)" + +footer: + builtWith: + other: Built with {{ .Generator }} + + designedBy: + other: 主題 {{ .Theme }} 由 {{ .DesignedBy }} 設計 diff --git a/themes/hugo-theme-stack/i18n/zh-tw.yaml b/themes/hugo-theme-stack/i18n/zh-tw.yaml new file mode 100644 index 0000000..4b71572 --- /dev/null +++ b/themes/hugo-theme-stack/i18n/zh-tw.yaml @@ -0,0 +1,73 @@ +toggleMenu: + other: 切換選單 + +darkMode: + other: 夜晚模式 + +list: + page: + one: "第 {{ .Count }} 頁" + other: "第 {{ .Count }} 頁" + + section: + other: 段落 + + subsection: + one: 小節 + other: 小節 + +article: + back: + other: 返回 + + tableOfContents: + other: 目錄 + + relatedContent: + other: 相關文章 + + lastUpdatedOn: + other: 最後更新 + + readingTime: + one: "閱讀時間: {{ .Count }} 分鐘" + other: "閱讀時間: {{ .Count }} 分鐘" + +notFound: + title: + other: 404 錯誤 + + subtitle: + other: 頁面不存在 + +widget: + archives: + title: + other: 紀錄 + + more: + other: 更多 + + tagCloud: + title: + other: 標籤雲 + categoriesCloud: + title: + other: 分類 + +search: + title: + other: 搜尋 + + placeholder: + other: 輸入關鍵字... + + resultTitle: + other: "#PAGES_COUNT 個結果 (用時 #TIME_SECONDS 秒)" + +footer: + builtWith: + other: 使用 {{ .Generator }} 建立 + + designedBy: + other: 主題 {{ .Theme }} 由 {{ .DesignedBy }} 設計 diff --git a/themes/hugo-theme-stack/images/screenshot.png b/themes/hugo-theme-stack/images/screenshot.png new file mode 100644 index 0000000000000000000000000000000000000000..efcfd8a789bea2e548b573abdc5b4a309775491e GIT binary patch literal 51344 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
d^7F~>zZ}Ujwe1DzH95kJOAj=qb|o{q%$q^ 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 E2l$aK(f|Me literal 0 HcmV?d00001 diff --git a/themes/hugo-theme-stack/layouts/404.html b/themes/hugo-theme-stack/layouts/404.html new file mode 100644 index 0000000..b89d2b6 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/404.html @@ -0,0 +1,7 @@ +{{ define "main" }} +
+

{{ T "notFound.title" }}

+

{{ T "notFound.subtitle" }}

+
+ {{ partialCached "footer/footer" . }} +{{ end }} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/_default/_markup/render-heading.html b/themes/hugo-theme-stack/layouts/_default/_markup/render-heading.html new file mode 100644 index 0000000..f79308a --- /dev/null +++ b/themes/hugo-theme-stack/layouts/_default/_markup/render-heading.html @@ -0,0 +1,6 @@ + + {{- if site.Params.Article.HeadingAnchor -}} +
+ {{- end -}} + {{ .Text | safeHTML }} + \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/_default/_markup/render-image.html b/themes/hugo-theme-stack/layouts/_default/_markup/render-image.html new file mode 100644 index 0000000..0ed5584 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/_default/_markup/render-image.html @@ -0,0 +1,41 @@ +{{- $image := .Page.Resources.GetMatch (printf "%s" (.Destination | safeURL)) -}} +{{- $Permalink := .Destination | relURL | safeURL -}} +{{- $alt := .PlainText | safeHTML -}} +{{- $Width := 0 -}} +{{- $Height := 0 -}} +{{- $Srcset := "" -}} + +{{/* SVG and external images won't work with gallery layout, because their width and height attributes are unknown */}} +{{- $galleryImage := false -}} + +{{- if $image -}} + {{- $notSVG := ne (path.Ext .Destination) ".svg" -}} + {{- $Permalink = $image.RelPermalink -}} + + {{- if $notSVG -}} + {{- $Width = $image.Width -}} + {{- $Height = $image.Height -}} + {{- $galleryImage = true -}} + + {{- if (default true .Page.Site.Params.imageProcessing.content.enabled) -}} + {{- $small := $image.Resize `480x` -}} + {{- $big := $image.Resize `1024x` -}} + {{- $Srcset = printf `%s 480w, %s 1024w` $small.RelPermalink $big.RelPermalink -}} + {{- end -}} + {{- end -}} +{{- end -}} + +{{ . }} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/_default/_markup/render-link.html b/themes/hugo-theme-stack/layouts/_default/_markup/render-link.html new file mode 100644 index 0000000..843854d --- /dev/null +++ b/themes/hugo-theme-stack/layouts/_default/_markup/render-link.html @@ -0,0 +1,3 @@ +{{ .Text | safeHTML }} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/_default/archives.html b/themes/hugo-theme-stack/layouts/_default/archives.html new file mode 100644 index 0000000..5d5243c --- /dev/null +++ b/themes/hugo-theme-stack/layouts/_default/archives.html @@ -0,0 +1,35 @@ +{{ define "body-class" }}template-archives{{ end }} +{{ define "main" }} +
+ {{- $taxonomy := $.Site.GetPage "taxonomyTerm" "categories" -}} + {{- $terms := $taxonomy.Pages -}} + {{ if $terms }} +

{{ $taxonomy.Title }}

+
+
+ {{ range $terms }} + {{ partial "article-list/tile" (dict "context" . "size" "250x150" "Type" "taxonomy") }} + {{ end }} +
+
+ {{ end }} +
+ + {{ $pages := where .Site.RegularPages "Type" "in" .Site.Params.mainSections }} + {{ $notHidden := where .Site.RegularPages "Params.hidden" "!=" true }} + {{ $filtered := ($pages | intersect $notHidden) }} + + {{ range $filtered.GroupByDate "2006" }} + {{ $id := lower (replace .Key " " "-") }} +
+

{{ .Key }}

+
+ {{ range .Pages }} + {{ partial "article-list/compact" . }} + {{ end }} +
+
+ {{ end }} + + {{ partialCached "footer/footer" . }} +{{ end }} diff --git a/themes/hugo-theme-stack/layouts/_default/baseof.html b/themes/hugo-theme-stack/layouts/_default/baseof.html new file mode 100644 index 0000000..83fdaa3 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/_default/baseof.html @@ -0,0 +1,28 @@ + + + + {{- partial "head/head.html" . -}} + {{- block "head" . -}}{{ end }} + + + {{- partial "head/colorScheme" . -}} + + {{/* The container is wider when there's any activated widget */}} + {{- $hasWidget := false -}} + {{- range .Site.Params.widgets -}} + {{- if gt (len .) 0 -}} + {{- $hasWidget = true -}} + {{- end -}} + {{- end -}} +
+ {{- block "left-sidebar" . -}} + {{ partial "sidebar/left.html" . }} + {{- end -}} + {{- block "right-sidebar" . -}}{{ end }} +
+ {{- block "main" . }}{{- end }} +
+
+ {{ partial "footer/include.html" . }} + + diff --git a/themes/hugo-theme-stack/layouts/_default/list.html b/themes/hugo-theme-stack/layouts/_default/list.html new file mode 100644 index 0000000..9bc618d --- /dev/null +++ b/themes/hugo-theme-stack/layouts/_default/list.html @@ -0,0 +1,85 @@ +{{ define "main" }} +
+

+ {{ if eq .Parent (.GetPage "/") }} + {{ T "list.section" }} + {{ else }} + {{ .Parent.Title }} + {{ end }} +

+ +
+
+

{{ T "list.page" (len .Pages) }}

+

{{ .Title }}

+ {{ with .Params.description }} +

{{ . }}

+ {{ end }} +
+ + {{- $image := partialCached "helper/image" (dict "Context" . "Type" "section") .RelPermalink "section" -}} + {{ if $image.exists }} +
+ {{ if $image.resource }} + {{- $Permalink := $image.resource.RelPermalink -}} + {{- $Width := $image.resource.Width -}} + {{- $Height := $image.resource.Height -}} + + {{- if (default true .Page.Site.Params.imageProcessing.cover.enabled) -}} + {{- $thumbnail := $image.resource.Fill "120x120" -}} + {{- $Permalink = $thumbnail.RelPermalink -}} + {{- $Width = $thumbnail.Width -}} + {{- $Height = $thumbnail.Height -}} + {{- end -}} + + + {{ else }} + + {{ end }} +
+ {{ end }} +
+
+ + {{- $subsections := .Sections -}} + {{- $pages := .Pages | complement $subsections -}} + + {{- if eq (len $pages) 0 -}} + {{/* If there are no normal pages, display subsections in list style, with pagination */}} + {{/* This happens with taxonomies like categories or tags */}} + {{- $pages = $subsections -}} + {{- $subsections = slice -}} + {{- end -}} + + {{- with $subsections -}} + + {{- end -}} + + {{/* List only pages that are not a subsection */}} + {{ $paginator := .Paginate $pages }} +
+ {{ range $paginator.Pages }} + {{ partial "article-list/compact" . }} + {{ end }} +
+ + {{- partial "pagination.html" . -}} + + {{ partialCached "footer/footer" . }} +{{ end }} + +{{ define "right-sidebar" }} + {{ partial "sidebar/right.html" (dict "Context" . "Scope" "homepage") }} +{{ end }} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/_default/rss.xml b/themes/hugo-theme-stack/layouts/_default/rss.xml new file mode 100644 index 0000000..5874559 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/_default/rss.xml @@ -0,0 +1,48 @@ +{{- $pctx := . -}} +{{- if .IsHome -}}{{ $pctx = .Site }}{{- end -}} +{{- $pages := slice -}} +{{- if or $.IsHome $.IsSection -}} +{{- $pages = $pctx.RegularPages -}} +{{- else -}} +{{- $pages = $pctx.Pages -}} +{{- end -}} +{{- $pages := where $pages "Params.hidden" "!=" true -}} +{{- $limit := .Site.Config.Services.RSS.Limit -}} +{{- if ge $limit 1 -}} +{{- $pages = $pages | first $limit -}} +{{- end -}} +{{- printf "" | safeHTML }} + + + {{ if eq .Title .Site.Title }}{{ .Site.Title }}{{ else }}{{ with .Title }}{{.}} on {{ end }}{{ .Site.Title }}{{ end }} + {{ .Permalink }} + Recent content {{ if ne .Title .Site.Title }}{{ with .Title }}in {{.}} {{ end }}{{ end }}on {{ .Site.Title }} + Hugo -- gohugo.io{{ with .Site.LanguageCode }} + {{.}}{{end}}{{ with .Site.Params.Author.email }} + {{.}}{{ with $.Site.Params.Author.name }} ({{.}}){{end}}{{end}}{{ with .Site.Params.Author.email }} + {{.}}{{ with $.Site.Params.Author.name }} ({{.}}){{end}}{{end}}{{ with .Site.Copyright }} + {{.}}{{end}}{{ if not .Date.IsZero }} + {{ .Date.Format "Mon, 02 Jan 2006 15:04:05 -0700" | safeHTML }}{{ end }} + {{- with .OutputFormats.Get "RSS" -}} + {{ printf "" .Permalink .MediaType | safeHTML }} + {{- end -}} + {{ range $pages }} + {{- $content := safeHTML (.Summary | html) -}} + {{- if .Site.Params.rssFullContent -}} + {{- $content = safeHTML (.Content | html) -}} + {{- end -}} + + {{ .Title }} + {{ .Permalink }} + {{ .Date.Format "Mon, 02 Jan 2006 15:04:05 -0700" | safeHTML }} + {{ with .Site.Params.Author.email }}{{.}}{{ with $.Site.Params.Author.name }} ({{.}}){{end}}{{end}} + {{ .Permalink }} + + {{- $image := partial "helper/image" (dict "Context" . "Type" "rss") -}} + {{- if $image.exists -}} + {{ "<" | html }}img src="{{ $image.permalink | absURL }}" alt="Featured image of post {{ .Title }}" {{ "/>" | html}} + {{- end -}}{{ $content }} + + {{ end }} + + diff --git a/themes/hugo-theme-stack/layouts/_default/single.html b/themes/hugo-theme-stack/layouts/_default/single.html new file mode 100644 index 0000000..5f300bf --- /dev/null +++ b/themes/hugo-theme-stack/layouts/_default/single.html @@ -0,0 +1,46 @@ +{{ define "body-class" }} + article-page + {{/* + Enable the right sidebar if + - Widget different from 'TOC' is enabled + - TOC is enabled and not empty + */}} + {{- $HasWidgetNotTOC := false -}} + {{- $TOCWidgetEnabled := false -}} + {{- range .Site.Params.widgets.page -}} + {{- if ne .type "toc" -}} + {{ $HasWidgetNotTOC = true -}} + {{- else -}} + {{ $TOCWidgetEnabled = true -}} + {{- end -}} + {{- end -}} + + {{- $TOCManuallyDisabled := eq .Params.toc false -}} + {{- $TOCEnabled := and (not $TOCManuallyDisabled) $TOCWidgetEnabled -}} + {{- $hasTOC := ge (len .TableOfContents) 100 -}} + {{- .Scratch.Set "TOCEnabled" (and $TOCEnabled $hasTOC) -}} + + {{- .Scratch.Set "hasWidget" (or $HasWidgetNotTOC (and $TOCEnabled $hasTOC)) -}} +{{ end }} + +{{ define "main" }} + {{ partial "article/article.html" . }} + + {{ if .Params.links }} + {{ partial "article/components/links" . }} + {{ end }} + + {{ partial "article/components/related-content" . }} + + {{ if not (eq .Params.comments false) }} + {{ partial "comments/include" . }} + {{ end }} + + {{ partialCached "footer/footer" . }} + + {{ partialCached "article/components/photoswipe" . }} +{{ end }} + +{{ define "right-sidebar" }} + {{ if .Scratch.Get "hasWidget" }}{{ partial "sidebar/right.html" (dict "Context" . "Scope" "page") }}{{ end}} +{{ end }} diff --git a/themes/hugo-theme-stack/layouts/index.html b/themes/hugo-theme-stack/layouts/index.html new file mode 100644 index 0000000..0cd0b88 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/index.html @@ -0,0 +1,19 @@ +{{ define "main" }} + {{ $pages := where .Site.RegularPages "Type" "in" .Site.Params.mainSections }} + {{ $notHidden := where .Site.RegularPages "Params.hidden" "!=" true }} + {{ $filtered := ($pages | intersect $notHidden) }} + {{ $pag := .Paginate ($filtered) }} + +
+ {{ range $index, $element := $pag.Pages }} + {{ partial "article-list/default" . }} + {{ end }} +
+ + {{- partial "pagination.html" . -}} + {{- partial "footer/footer" . -}} +{{ end }} + +{{ define "right-sidebar" }} + {{ partial "sidebar/right.html" (dict "Context" . "Scope" "homepage") }} +{{ end }} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/page/search.html b/themes/hugo-theme-stack/layouts/page/search.html new file mode 100644 index 0000000..fbfb74d --- /dev/null +++ b/themes/hugo-theme-stack/layouts/page/search.html @@ -0,0 +1,33 @@ +{{ define "body-class" }}template-search{{ end }} +{{ define "head" }} + {{- with .OutputFormats.Get "json" -}} + + {{- end -}} +{{ end }} +{{ define "main" }} +
+

+ + +

+ + +
+ +
+

+
+
+ + + +{{- $opts := dict "minify" hugo.IsProduction "JSXFactory" "createElement" -}} +{{- $searchScript := resources.Get "ts/search.tsx" | js.Build $opts -}} + + +{{ partialCached "footer/footer" . }} +{{ end }} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/page/search.json b/themes/hugo-theme-stack/layouts/page/search.json new file mode 100644 index 0000000..5d4e627 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/page/search.json @@ -0,0 +1,26 @@ +{{- $pages := where .Site.RegularPages "Type" "in" .Site.Params.mainSections -}} +{{- $notHidden := where .Site.RegularPages "Params.hidden" "!=" true -}} +{{- $filtered := ($pages | intersect $notHidden) -}} + +{{- $result := slice -}} + +{{- range $filtered -}} + {{- $data := dict "title" .Title "date" .Date "permalink" .Permalink "content" (.Plain) -}} + + {{- $image := partialCached "helper/image" (dict "Context" . "Type" "articleList") .RelPermalink "articleList" -}} + {{- if $image.exists -}} + {{- $imagePermalink := "" -}} + {{- if and $image.resource (default true .Page.Site.Params.imageProcessing.cover.enabled) -}} + {{- $thumbnail := $image.resource.Fill "120x120" -}} + {{- $imagePermalink = (absURL $thumbnail.Permalink) -}} + {{- else -}} + {{- $imagePermalink = $image.permalink -}} + {{- end -}} + + {{- $data = merge $data (dict "image" (absURL $imagePermalink)) -}} + {{- end -}} + + {{- $result = $result | append $data -}} +{{- end -}} + +{{ jsonify $result }} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/article-list/compact.html b/themes/hugo-theme-stack/layouts/partials/article-list/compact.html new file mode 100644 index 0000000..376512a --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/article-list/compact.html @@ -0,0 +1,40 @@ +
+ +
+

+ {{- .Title -}} +

+
+ +
+
+ + {{- $image := partialCached "helper/image" (dict "Context" . "Type" "articleList") .RelPermalink "articleList" -}} + {{ if $image.exists }} +
+ {{ if $image.resource }} + {{- $Permalink := $image.resource.RelPermalink -}} + {{- $Width := $image.resource.Width -}} + {{- $Height := $image.resource.Height -}} + + {{- if (default true .Page.Site.Params.imageProcessing.cover.enabled) -}} + {{- $thumbnail := $image.resource.Fill "120x120" -}} + {{- $Permalink = $thumbnail.RelPermalink -}} + {{- $Width = $thumbnail.Width -}} + {{- $Height = $thumbnail.Height -}} + {{- end -}} + + {{ .Title }} + {{ else }} + Featured image of post {{ .Title }} + {{ end }} +
+ {{ end }} +
+
\ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/article-list/default.html b/themes/hugo-theme-stack/layouts/partials/article-list/default.html new file mode 100644 index 0000000..02e0b30 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/article-list/default.html @@ -0,0 +1,4 @@ +{{ $image := partialCached "helper/image" (dict "Context" . "Type" "articleList") .RelPermalink "articleList" }} +
+ {{ partial "article/components/header" . }} +
\ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/article-list/tile.html b/themes/hugo-theme-stack/layouts/partials/article-list/tile.html new file mode 100644 index 0000000..be5744b --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/article-list/tile.html @@ -0,0 +1,39 @@ +{{ $image := partialCached "helper/image" (dict "Context" .context "Type" .Type) .context.RelPermalink .Type }} +
+ + + {{ if $image.exists }} +
+ {{ if $image.resource }} + {{- $imageRaw := $image.resource | resources.Fingerprint "md5" -}} + {{- $Permalink := $imageRaw.RelPermalink -}} + {{- $Width := $imageRaw.Width -}} + {{- $Height := $imageRaw.Height -}} + + {{- if .context.Site.Params.imageProcessing.cover.enabled -}} + {{- $thumbnail := $imageRaw.Fill .size -}} + {{- $Permalink = $thumbnail.RelPermalink -}} + {{- $Width = $thumbnail.Width -}} + {{- $Height = $thumbnail.Height -}} + {{- end -}} + + Featured image of post {{ .context.Title }} + {{ else }} + + {{ end }} +
+ {{ end }} + +
+

+ {{- .context.Title -}} +

+
+
+
diff --git a/themes/hugo-theme-stack/layouts/partials/article/article.html b/themes/hugo-theme-stack/layouts/partials/article/article.html new file mode 100644 index 0000000..f3f7e90 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/article/article.html @@ -0,0 +1,11 @@ +
+ {{ partial "article/components/header" . }} + + {{ partial "article/components/content" . }} + + {{ partial "article/components/footer" . }} + + {{ if or .Params.math .Site.Params.article.math }} + {{ partialCached "article/components/math.html" . }} + {{ end }} +
\ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/article/components/content.html b/themes/hugo-theme-stack/layouts/partials/article/components/content.html new file mode 100644 index 0000000..61e536c --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/article/components/content.html @@ -0,0 +1,5 @@ +
+ + {{ $wrappedTable := printf "
${1}
" }} + {{ .Content | replaceRE "((?:.|\n)+?
)" $wrappedTable | safeHTML }} +
diff --git a/themes/hugo-theme-stack/layouts/partials/article/components/details.html b/themes/hugo-theme-stack/layouts/partials/article/components/details.html new file mode 100644 index 0000000..cc0a0fc --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/article/components/details.html @@ -0,0 +1,61 @@ +
+ {{ if .Params.categories }} + + {{ end }} + +
+

+ + {{- .Title -}} + +

+ + {{ with .Params.description }} +

+ {{ . }} +

+ {{ end }} +
+ + {{ $showReadingTime := .Params.readingTime | default (.Site.Params.article.readingTime) }} + {{ $showDate := not .Date.IsZero }} + {{ $showFooter := or $showDate $showReadingTime }} + {{ if $showFooter }} +
+ {{ if $showDate }} +
+ {{ partial "helper/icon" "date" }} + +
+ {{ end }} + + {{ if $showReadingTime }} +
+ {{ partial "helper/icon" "clock" }} + +
+ {{ end }} +
+ {{ end }} + + {{ if .IsTranslated }} + + {{ end }} +
diff --git a/themes/hugo-theme-stack/layouts/partials/article/components/footer.html b/themes/hugo-theme-stack/layouts/partials/article/components/footer.html new file mode 100644 index 0000000..6853921 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/article/components/footer.html @@ -0,0 +1,19 @@ +
+ {{ partial "article/components/tags" . }} + + {{ if and (.Site.Params.article.license.enabled) (not (eq .Params.license false)) }} +
+ {{ partial "helper/icon" "copyright" }} + {{ default .Site.Params.article.license.default .Params.license | markdownify }} +
+ {{ end }} + + {{- if ne .Lastmod .Date -}} +
+ {{ partial "helper/icon" "clock" }} + + {{ T "article.lastUpdatedOn" }} {{ .Lastmod.Format ( or .Site.Params.dateFormat.lastUpdated "Jan 02, 2006 15:04 MST" ) }} + +
+ {{- end -}} +
diff --git a/themes/hugo-theme-stack/layouts/partials/article/components/header.html b/themes/hugo-theme-stack/layouts/partials/article/components/header.html new file mode 100644 index 0000000..7582ec2 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/article/components/header.html @@ -0,0 +1,35 @@ +
+ {{- $image := partialCached "helper/image" (dict "Context" . "Type" "article") .RelPermalink "article" -}} + {{ if $image.exists }} +
+ + {{ if $image.resource }} + {{- $Permalink := $image.resource.RelPermalink -}} + {{- $Width := $image.resource.Width -}} + {{- $Height := $image.resource.Height -}} + {{- $Srcset := "" -}} + + {{- if (default true .Page.Site.Params.imageProcessing.cover.enabled) -}} + {{- $thumbnail := $image.resource.Resize "800x" -}} + {{- $thumbnailRetina := $image.resource.Resize "1600x" -}} + {{- $Srcset = printf "%s 800w, %s 1600w" $thumbnail.RelPermalink $thumbnailRetina.RelPermalink -}} + {{- $Permalink = $thumbnail.RelPermalink -}} + {{- $Width = $thumbnail.Width -}} + {{- $Height = $thumbnail.Height -}} + {{- end -}} + + Featured image of post {{ .Title }} + {{ else }} + Featured image of post {{ .Title }} + {{ end }} + +
+ {{ end }} + + {{ partialCached "article/components/details" . .RelPermalink }} +
\ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/article/components/links.html b/themes/hugo-theme-stack/layouts/partials/article/components/links.html new file mode 100644 index 0000000..a2ac26c --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/article/components/links.html @@ -0,0 +1,30 @@ +
+ {{ range $i, $link := .Params.links }} + + {{ end }} +
\ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/article/components/math.html b/themes/hugo-theme-stack/layouts/partials/article/components/math.html new file mode 100644 index 0000000..bd1a7f8 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/article/components/math.html @@ -0,0 +1,13 @@ +{{- partial "helper/external" (dict "Context" . "Namespace" "KaTeX") -}} + \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/article/components/photoswipe.html b/themes/hugo-theme-stack/layouts/partials/article/components/photoswipe.html new file mode 100644 index 0000000..c33ff49 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/article/components/photoswipe.html @@ -0,0 +1,68 @@ + + + +{{- partial "helper/external" (dict "Context" . "Namespace" "PhotoSwipe") -}} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/article/components/related-content.html b/themes/hugo-theme-stack/layouts/partials/article/components/related-content.html new file mode 100644 index 0000000..aba88e3 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/article/components/related-content.html @@ -0,0 +1,13 @@ +{{ $related := (where (.Site.RegularPages.Related .) "Params.hidden" "!=" true) | first 5 }} +{{ with $related }} + +{{ end }} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/article/components/tags.html b/themes/hugo-theme-stack/layouts/partials/article/components/tags.html new file mode 100644 index 0000000..aae38b4 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/article/components/tags.html @@ -0,0 +1,7 @@ +{{ if .Params.Tags }} + +{{ end }} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/comments/include.html b/themes/hugo-theme-stack/layouts/partials/comments/include.html new file mode 100644 index 0000000..a3d0618 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/comments/include.html @@ -0,0 +1,3 @@ +{{ if .Site.Params.comments.enabled }} + {{ partial (printf "comments/provider/%s" .Site.Params.comments.provider) . }} +{{ end }} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/comments/provider/beaudar.html b/themes/hugo-theme-stack/layouts/partials/comments/provider/beaudar.html new file mode 100644 index 0000000..761801f --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/comments/provider/beaudar.html @@ -0,0 +1,46 @@ + + + + + diff --git a/themes/hugo-theme-stack/layouts/partials/comments/provider/cactus.html b/themes/hugo-theme-stack/layouts/partials/comments/provider/cactus.html new file mode 100644 index 0000000..ae172d3 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/comments/provider/cactus.html @@ -0,0 +1,29 @@ +{{- with .Site.Params.comments.cactus -}} +{{- partial "helper/external" (dict "Context" $ "Namespace" "Cactus") -}} + + + +
+ + +{{- end -}} diff --git a/themes/hugo-theme-stack/layouts/partials/comments/provider/cusdis.html b/themes/hugo-theme-stack/layouts/partials/comments/provider/cusdis.html new file mode 100644 index 0000000..a89746c --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/comments/provider/cusdis.html @@ -0,0 +1,21 @@ +{{- $host := default "https://cusdis.com" .Site.Params.comments.cusdis.host -}} +
+ + + diff --git a/themes/hugo-theme-stack/layouts/partials/comments/provider/disqus.html b/themes/hugo-theme-stack/layouts/partials/comments/provider/disqus.html new file mode 100644 index 0000000..fb17b77 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/comments/provider/disqus.html @@ -0,0 +1,22 @@ +
+ {{ template "_internal/disqus.html" . }} +
+ + + + \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/comments/provider/disqusjs.html b/themes/hugo-theme-stack/layouts/partials/comments/provider/disqusjs.html new file mode 100644 index 0000000..8dbcc13 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/comments/provider/disqusjs.html @@ -0,0 +1,61 @@ +{{- $pc := .Site.Config.Privacy.Disqus -}} +{{- $disqusjs := .Site.Params.Comments.disqusjs -}} +{{- if and (not $pc.Disable) (and $disqusjs.Shortname $disqusjs.ApiKey) -}} + +{{- $style := resources.Get "scss/partials/comments/disqusjs.scss" | resources.ToCSS | minify -}} + + +
+
+ + +
+{{- end -}} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/comments/provider/giscus.html b/themes/hugo-theme-stack/layouts/partials/comments/provider/giscus.html new file mode 100644 index 0000000..f7f435d --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/comments/provider/giscus.html @@ -0,0 +1,51 @@ +{{- with .Site.Params.comments.giscus -}} + + +{{- end -}} diff --git a/themes/hugo-theme-stack/layouts/partials/comments/provider/gitalk.html b/themes/hugo-theme-stack/layouts/partials/comments/provider/gitalk.html new file mode 100644 index 0000000..95ca133 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/comments/provider/gitalk.html @@ -0,0 +1,30 @@ +{{- with .Site.Params.comments.gitalk -}} +
+ + + + +{{ end }} diff --git a/themes/hugo-theme-stack/layouts/partials/comments/provider/remark42.html b/themes/hugo-theme-stack/layouts/partials/comments/provider/remark42.html new file mode 100644 index 0000000..18acf1b --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/comments/provider/remark42.html @@ -0,0 +1,29 @@ +{{- with .Site.Params.comments.remark42 -}} +
+ +{{- end -}} diff --git a/themes/hugo-theme-stack/layouts/partials/comments/provider/twikoo.html b/themes/hugo-theme-stack/layouts/partials/comments/provider/twikoo.html new file mode 100644 index 0000000..53830dd --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/comments/provider/twikoo.html @@ -0,0 +1,58 @@ + +
+ + +{{- with .Site.Params.comments.twikoo -}} + +{{- end -}} diff --git a/themes/hugo-theme-stack/layouts/partials/comments/provider/utterances.html b/themes/hugo-theme-stack/layouts/partials/comments/provider/utterances.html new file mode 100644 index 0000000..b1e370b --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/comments/provider/utterances.html @@ -0,0 +1,46 @@ + + + + + diff --git a/themes/hugo-theme-stack/layouts/partials/comments/provider/vssue.html b/themes/hugo-theme-stack/layouts/partials/comments/provider/vssue.html new file mode 100644 index 0000000..79ac381 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/comments/provider/vssue.html @@ -0,0 +1,27 @@ +{{- with .Site.Params.comments.vssue -}} + + +
+ + + + + +{{- end -}} diff --git a/themes/hugo-theme-stack/layouts/partials/comments/provider/waline.html b/themes/hugo-theme-stack/layouts/partials/comments/provider/waline.html new file mode 100644 index 0000000..9d1a2a0 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/comments/provider/waline.html @@ -0,0 +1,34 @@ + + +
+ + +{{- with .Site.Params.comments.waline -}} +{{- $config := dict "el" "#waline" "dark" `html[data-scheme="dark"]` -}} +{{- $replaceKeys := dict "serverurl" "serverURL" "requiredmeta" "requiredMeta" "wordlimit" "wordLimit" "pagesize" "pageSize" "imageuploader" "imageUploader" "texrenderer" "texRenderer" -}} + +{{- range $key, $val := . -}} + {{- if ne $val nil -}} + {{- $replaceKey := index $replaceKeys $key -}} + {{- $k := default $key $replaceKey -}} + + {{- $config = merge $config (dict $k $val) -}} + {{- end -}} +{{- end -}} + + +{{- end -}} diff --git a/themes/hugo-theme-stack/layouts/partials/data/description.html b/themes/hugo-theme-stack/layouts/partials/data/description.html new file mode 100644 index 0000000..7f6cc32 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/data/description.html @@ -0,0 +1,17 @@ + +{{ $description := .Site.Params.sidebar.subtitle }} + + +{{ if .Site.Params.description }} + {{ $description = .Site.Params.description }} +{{ end }} + +{{ if .Description }} + + {{ $description = .Description }} +{{ else if .IsPage }} + + {{ $description = .Summary }} +{{ end }} + +{{ return (replaceRE "\n" " " $description | plainify) }} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/data/title.html b/themes/hugo-theme-stack/layouts/partials/data/title.html new file mode 100644 index 0000000..85a7bc7 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/data/title.html @@ -0,0 +1,38 @@ +{{- $title := .Title -}} +{{- $siteTitle := .Site.Title -}} + +{{- if .IsHome -}} + + + + {{ $pages := where .Site.RegularPages "Section" "in" .Site.Params.mainSections }} + {{ $notHidden := where .Site.RegularPages "Params.hidden" "!=" true }} + {{ $filtered := ($pages | intersect $notHidden) }} + {{ $pag := .Paginate ($filtered) }} + + {{ if .Paginator.HasPrev }} + + {{ $title = printf "%s - %s" .Paginator $siteTitle }} + {{ else }} + {{ $title = $siteTitle}} + {{ end }} +{{- else if eq .Kind "term" -}} + + + + {{ $notHidden := where .Pages "Params.hidden" "!=" true }} + {{ $pag := .Paginate ($notHidden) }} + + + {{ $title = slice (title .Data.Singular) ": " $title }} + + {{ if .Paginator.HasPrev }} + + {{ $title = $title | append " - " .Paginator }} + {{ end }} + + {{ $title = $title | append " - " $siteTitle }} + {{ $title = delimit $title "" }} +{{- end -}} + +{{ return $title }} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/footer/components/custom-font.html b/themes/hugo-theme-stack/layouts/partials/footer/components/custom-font.html new file mode 100644 index 0000000..8e2ff37 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/footer/components/custom-font.html @@ -0,0 +1,11 @@ + \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/footer/components/script.html b/themes/hugo-theme-stack/layouts/partials/footer/components/script.html new file mode 100644 index 0000000..4cb350c --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/footer/components/script.html @@ -0,0 +1,12 @@ +{{- partial "helper/external" (dict "Context" . "Namespace" "Vibrant") -}} + +{{- $opts := dict "minify" hugo.IsProduction -}} +{{- $script := resources.Get "ts/main.ts" | js.Build $opts -}} + + + +{{- with resources.Get "ts/custom.ts" -}} + {{/* Place your custom script in HUGO_SITE_FOLDER/assets/ts/custom.ts */}} + {{- $customScript := . | js.Build $opts -}} + +{{- end -}} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/footer/custom.html b/themes/hugo-theme-stack/layouts/partials/footer/custom.html new file mode 100644 index 0000000..e69de29 diff --git a/themes/hugo-theme-stack/layouts/partials/footer/footer.html b/themes/hugo-theme-stack/layouts/partials/footer/footer.html new file mode 100644 index 0000000..5193afa --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/footer/footer.html @@ -0,0 +1,23 @@ +{{- $ThemeVersion := "3.26.0" -}} +
+ + +
+ {{ with .Site.Params.footer.customText }} + {{ . | safeHTML }}
+ {{ end }} + + {{- $Generator := `Hugo` -}} + {{- $Theme := printf `Stack` $ThemeVersion -}} + {{- $DesignedBy := `Jimmy` -}} + + {{ T "footer.builtWith" (dict "Generator" $Generator) | safeHTML }}
+ {{ T "footer.designedBy" (dict "Theme" $Theme "DesignedBy" $DesignedBy) | safeHTML }} +
+
diff --git a/themes/hugo-theme-stack/layouts/partials/footer/include.html b/themes/hugo-theme-stack/layouts/partials/footer/include.html new file mode 100644 index 0000000..4b50a88 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/footer/include.html @@ -0,0 +1,3 @@ +{{ partialCached "footer/components/script.html" . }} +{{ partialCached "footer/components/custom-font.html" . }} +{{ partial "footer/custom.html" . }} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/head/colorScheme.html b/themes/hugo-theme-stack/layouts/partials/head/colorScheme.html new file mode 100644 index 0000000..42f4dd8 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/head/colorScheme.html @@ -0,0 +1,39 @@ +{{- $defaultColorScheme := default "auto" .Site.Params.colorScheme.default -}} +{{- if not (default false .Site.Params.colorScheme.toggle) -}} + {{/* If toggle is disabled, force default scheme */}} + +{{- else -}} + {{/* Otherwise set to default scheme only if no preference is set by user */}} + +{{- end -}} + + diff --git a/themes/hugo-theme-stack/layouts/partials/head/custom.html b/themes/hugo-theme-stack/layouts/partials/head/custom.html new file mode 100644 index 0000000..e69de29 diff --git a/themes/hugo-theme-stack/layouts/partials/head/head.html b/themes/hugo-theme-stack/layouts/partials/head/head.html new file mode 100644 index 0000000..a7991c1 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/head/head.html @@ -0,0 +1,26 @@ + + + +{{- $description := partialCached "data/description" . .RelPermalink -}} + +{{ with .Params.Keywords }}{{ end }} + +{{- $title := partial "data/title" . -}} +{{ $title }} + + + +{{- partial "head/style.html" . -}} +{{- partial "head/script.html" . -}} +{{- partial "head/opengraph/include.html" . -}} + +{{- range .AlternativeOutputFormats -}} + +{{- end -}} + +{{ with .Site.Params.favicon }} + +{{ end }} + +{{- template "_internal/google_analytics.html" . -}} +{{- partial "head/custom.html" . -}} diff --git a/themes/hugo-theme-stack/layouts/partials/head/opengraph/include.html b/themes/hugo-theme-stack/layouts/partials/head/opengraph/include.html new file mode 100644 index 0000000..3a43f48 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/head/opengraph/include.html @@ -0,0 +1,2 @@ +{{ partial "head/opengraph/provider/base" . }} +{{ partial "head/opengraph/provider/twitter" . }} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/head/opengraph/provider/base.html b/themes/hugo-theme-stack/layouts/partials/head/opengraph/provider/base.html new file mode 100644 index 0000000..055745d --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/head/opengraph/provider/base.html @@ -0,0 +1,43 @@ +{{- $title := partialCached "data/title" . .RelPermalink -}} +{{- $description := partialCached "data/description" . .RelPermalink -}} + + + + + + + +{{- with .Params.locale -}} + +{{- end -}} + +{{- if .IsPage -}} + + {{- range .Params.tags -}} + + {{- end -}} +{{- end -}} + +{{- if .IsPage -}} + {{- if not .Date.IsZero -}} + + {{- end -}} + {{- if not .Lastmod.IsZero -}} + + {{- end -}} +{{- else -}} + {{- if not .Site.Lastmod.IsZero -}} + + {{- end -}} +{{- end -}} + +{{ $image := partialCached "helper/image" (dict "Context" . "Type" "opengraph") .RelPermalink "opengraph" }} +{{- if $image.exists -}} + +{{- end -}} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/head/opengraph/provider/twitter.html b/themes/hugo-theme-stack/layouts/partials/head/opengraph/provider/twitter.html new file mode 100644 index 0000000..c39eba3 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/head/opengraph/provider/twitter.html @@ -0,0 +1,16 @@ +{{- with .Site.Params.opengraph.twitter.site -}} + + +{{- end -}} + +{{- $title := partialCached "data/title" . .RelPermalink -}} +{{- $description := partialCached "data/description" . .RelPermalink -}} + + + + +{{- $image := partialCached "helper/image" (dict "Context" . "Type" "opengraph") .RelPermalink "opengraph" -}} +{{- if $image.exists -}} + + +{{- end -}} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/head/script.html b/themes/hugo-theme-stack/layouts/partials/head/script.html new file mode 100644 index 0000000..e69de29 diff --git a/themes/hugo-theme-stack/layouts/partials/head/style.html b/themes/hugo-theme-stack/layouts/partials/head/style.html new file mode 100644 index 0000000..ee6b017 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/head/style.html @@ -0,0 +1,3 @@ +{{ $sass := resources.Get "scss/style.scss" }} +{{ $style := $sass | resources.ToCSS | minify | resources.Fingerprint "sha256" }} + \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/helper/external.html b/themes/hugo-theme-stack/layouts/partials/helper/external.html new file mode 100644 index 0000000..88d9525 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/helper/external.html @@ -0,0 +1,29 @@ +{{- $List := index .Context.Site.Data.external .Namespace -}} +{{- with $List -}} + {{- range . -}} + {{- if eq .type "script" -}} + + {{- else if eq .type "style" -}} + + {{- else -}} + {{- errorf "Error: unknown external resource type: %s" .type -}} + {{- end -}} + {{- end -}} +{{- else -}} + {{- errorf "Error: external resource '%s' is not found" .Namespace -}} +{{- end -}} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/helper/icon.html b/themes/hugo-theme-stack/layouts/partials/helper/icon.html new file mode 100644 index 0000000..72162e8 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/helper/icon.html @@ -0,0 +1,6 @@ +{{- $iconFile := resources.GetMatch (printf "icons/%s.svg" .) -}} +{{- if $iconFile -}} + {{- $iconFile.Content | safeHTML -}} +{{- else -}} + {{- errorf "Error: icon '%s.svg' is not found under 'assets/icons' folder" . -}} +{{- end -}} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/helper/image.html b/themes/hugo-theme-stack/layouts/partials/helper/image.html new file mode 100644 index 0000000..11fc3b6 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/helper/image.html @@ -0,0 +1,61 @@ +{{ $result := dict "exists" false "permalink" nil "resource" nil "isDefault" false }} +{{ $imageField := default "image" .Context.Site.Params.featuredImageField }} +{{ $imageValue := index .Context.Params $imageField }} + +{{ if $imageValue }} + + {{ $result = merge $result (dict "exists" true) }} + {{ $url := urls.Parse $imageValue }} + + {{ if or (eq $url.Scheme "http") (eq $url.Scheme "https") }} + + {{ $result = merge $result (dict "permalink" $imageValue) }} + {{ else }} + {{ $pageResourceImage := .Context.Resources.GetMatch (printf "%s" ($imageValue | safeURL)) }} + + {{ if $pageResourceImage }} + + {{ $result = merge $result (dict "permalink" $pageResourceImage.RelPermalink) }} + + + {{ if ne (path.Ext $imageValue) ".svg" }} + {{ $result = merge $result (dict "resource" $pageResourceImage) }} + {{ end }} + {{ else }} + + {{ $result = merge $result (dict "permalink" (relURL $imageValue)) }} + {{ end }} + + {{ end }} + +{{ else if and (ne .Type nil) (index .Context.Site.Params.defaultImage .Type) }} + + {{ $defaultImageSetting := index .Context.Site.Params.defaultImage .Type }} + + {{ if $defaultImageSetting.enabled }} + {{ $result = merge $result (dict "isDefault" true) }} + {{ $result = merge $result (dict "exists" true) }} + + {{ if $defaultImageSetting.local }} + {{ $siteResourceImage := resources.GetMatch (printf "%s" ($defaultImageSetting.src | safeURL)) }} + + {{ if $siteResourceImage }} + + {{ $result = merge $result (dict "permalink" $siteResourceImage.RelPermalink) }} + {{ $result = merge $result (dict "resource" $siteResourceImage) }} + {{ else }} + + {{ errorf "Failed loading image: %q" $defaultImageSetting.src }} + {{ $result = merge $result (dict "exists" false) }} + {{ end }} + + {{ else }} + + {{ $result = merge $result (dict "permalink" (relURL $defaultImageSetting.src)) }} + {{ end }} + + {{ end }} + +{{ end }} + +{{ return $result }} diff --git a/themes/hugo-theme-stack/layouts/partials/pagination.html b/themes/hugo-theme-stack/layouts/partials/pagination.html new file mode 100644 index 0000000..7756050 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/pagination.html @@ -0,0 +1,26 @@ +{{ if gt .Paginator.TotalPages 1 }} + +{{ end }} diff --git a/themes/hugo-theme-stack/layouts/partials/sidebar/left.html b/themes/hugo-theme-stack/layouts/partials/sidebar/left.html new file mode 100644 index 0000000..21e7d3e --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/sidebar/left.html @@ -0,0 +1,103 @@ + diff --git a/themes/hugo-theme-stack/layouts/partials/sidebar/right.html b/themes/hugo-theme-stack/layouts/partials/sidebar/right.html new file mode 100644 index 0000000..6333f10 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/sidebar/right.html @@ -0,0 +1,16 @@ +{{- $scope := default "homepage" .Scope -}} +{{- $context := .Context -}} +{{- with (index .Context.Site.Params.widgets $scope) -}} + +{{ end }} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/widget/archives.html b/themes/hugo-theme-stack/layouts/partials/widget/archives.html new file mode 100644 index 0000000..1f2abc5 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/widget/archives.html @@ -0,0 +1,35 @@ +{{- $query := first 1 (where .Context.Site.Pages "Layout" "==" "archives") -}} +{{- $context := .Context -}} +{{- $limit := default 5 .Params.limit -}} +{{- if $query -}} + {{- $archivesPage := index $query 0 -}} +
+
+ {{ partial "helper/icon" "infinity" }} +
+

{{ T "widget.archives.title" }}

+ + {{ $pages := where $context.Site.RegularPages "Type" "in" $context.Site.Params.mainSections }} + {{ $notHidden := where $context.Site.RegularPages "Params.hidden" "!=" true }} + {{ $filtered := ($pages | intersect $notHidden) }} + {{ $archives := $filtered.GroupByDate "2006" }} + +
+ {{ range $index, $item := first (add $limit 1) ($archives) }} + {{- $id := lower (replace $item.Key " " "-") -}} + + {{ end }} +
+
+{{- else -}} + {{- warnf "Archives page not found. Create a page with layout: archives." -}} +{{- end -}} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/widget/categories.html b/themes/hugo-theme-stack/layouts/partials/widget/categories.html new file mode 100644 index 0000000..10c8a35 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/widget/categories.html @@ -0,0 +1,16 @@ +{{- $context := .Context -}} +{{- $limit := default 10 .Params.limit -}} +
+
+ {{ partial "helper/icon" "categories" }} +
+

{{ T "widget.categoriesCloud.title" }}

+ +
+ {{ range first $limit $context.Site.Taxonomies.categories.ByCount }} + + {{ .Page.Title }} + + {{ end }} +
+
diff --git a/themes/hugo-theme-stack/layouts/partials/widget/search.html b/themes/hugo-theme-stack/layouts/partials/widget/search.html new file mode 100644 index 0000000..7b0fc73 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/widget/search.html @@ -0,0 +1,16 @@ +{{- $query := first 1 (where .Context.Site.Pages "Layout" "==" "search") -}} +{{- if $query -}} + {{- $searchPage := index $query 0 -}} +
+

+ + + + +

+
+{{- else -}} + {{- warnf "Search page not found. Create a page with layout: search." -}} +{{- end -}} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/widget/tag-cloud.html b/themes/hugo-theme-stack/layouts/partials/widget/tag-cloud.html new file mode 100644 index 0000000..e64e5e2 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/widget/tag-cloud.html @@ -0,0 +1,16 @@ +{{- $context := .Context -}} +{{- $limit := default 10 .Params.limit -}} +
+
+ {{ partial "helper/icon" "tag" }} +
+

{{ T "widget.tagCloud.title" }}

+ +
+ {{ range first $limit $context.Site.Taxonomies.tags.ByCount }} + + {{ .Page.Title }} + + {{ end }} +
+
\ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/partials/widget/toc.html b/themes/hugo-theme-stack/layouts/partials/widget/toc.html new file mode 100644 index 0000000..e311de3 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/partials/widget/toc.html @@ -0,0 +1,12 @@ +{{ if (.Context.Scratch.Get "TOCEnabled") }} +
+
+ {{ partial "helper/icon" "hash" }} +
+

{{ T "article.tableOfContents" }}

+ +
+ {{ .Context.TableOfContents }} +
+
+{{ end }} \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/shortcodes/bilibili.html b/themes/hugo-theme-stack/layouts/shortcodes/bilibili.html new file mode 100644 index 0000000..cb72e43 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/shortcodes/bilibili.html @@ -0,0 +1,23 @@ +{{ $vid := (.Get 0) }} +{{ $videopage := default 1 (.Get 1) }} +{{ $basicQuery := querify "page" $videopage "high_quality" 1 "as_wide" 1 }} +{{ $videoQuery := "" }} + +{{ if strings.HasPrefix (lower $vid) "av" }} + {{ $videoQuery = querify "aid" (strings.TrimPrefix "av" (lower $vid)) }} +{{ else if strings.HasPrefix (lower $vid) "bv" }} + {{ $videoQuery = querify "bvid" $vid }} +{{ else }} +

Bilibili 视频av号或BV号错误!请检查视频av号或BV号是否正确

+

当前视频av或BV号:{{ $vid }},视频分P:{{ $videopage }}

+{{ end }} + +
+ +
diff --git a/themes/hugo-theme-stack/layouts/shortcodes/gitlab.html b/themes/hugo-theme-stack/layouts/shortcodes/gitlab.html new file mode 100644 index 0000000..b5a16cf --- /dev/null +++ b/themes/hugo-theme-stack/layouts/shortcodes/gitlab.html @@ -0,0 +1,4 @@ + \ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/shortcodes/quote.html b/themes/hugo-theme-stack/layouts/shortcodes/quote.html new file mode 100644 index 0000000..09bb07c --- /dev/null +++ b/themes/hugo-theme-stack/layouts/shortcodes/quote.html @@ -0,0 +1,15 @@ +
+

{{ .Inner | markdownify }}

+ {{- if or (.Get "author") (.Get "source") -}} + + {{- if .Get "author" -}} + + {{- .Get "author" -}}{{- if .Get "source" -}}, {{ end -}} + + {{- end -}} + {{- with .Get "url" -}}{{- end -}} + {{ .Get "source" }} + {{- if .Get "url" -}}{{- end -}} + + {{- end -}} +
\ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/shortcodes/tencent.html b/themes/hugo-theme-stack/layouts/shortcodes/tencent.html new file mode 100644 index 0000000..463dec5 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/shortcodes/tencent.html @@ -0,0 +1,10 @@ +{{ $vid := .Get 0 }} +
+ +
\ No newline at end of file diff --git a/themes/hugo-theme-stack/layouts/shortcodes/video.html b/themes/hugo-theme-stack/layouts/shortcodes/video.html new file mode 100644 index 0000000..5324754 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/shortcodes/video.html @@ -0,0 +1,14 @@ +{{- $src := .Get "src" | default (.Get 0) -}} +
+ +
diff --git a/themes/hugo-theme-stack/layouts/shortcodes/youtube.html b/themes/hugo-theme-stack/layouts/shortcodes/youtube.html new file mode 100644 index 0000000..2f85931 --- /dev/null +++ b/themes/hugo-theme-stack/layouts/shortcodes/youtube.html @@ -0,0 +1,13 @@ +{{- $pc := .Page.Site.Config.Privacy.YouTube -}} +{{- if not $pc.Disable -}} +{{- $ytHost := cond $pc.PrivacyEnhanced "www.youtube-nocookie.com" "www.youtube.com" -}} +{{- $id := .Get "id" | default (.Get 0) -}} +
+ +
+{{ end -}} \ No newline at end of file diff --git a/themes/hugo-theme-stack/netlify.toml b/themes/hugo-theme-stack/netlify.toml new file mode 100644 index 0000000..b7cd29f --- /dev/null +++ b/themes/hugo-theme-stack/netlify.toml @@ -0,0 +1,26 @@ +[build] + publish = "exampleSite/public" + +[build.environment] + HUGO_VERSION = "0.124.0" + HUGO_THEME = "repo" + +[context.production] + command = "cd exampleSite && hugo --gc --themesDir ../.. -b ${URL}" + [context.production.environment] + HUGO_ENV = "production" + +[context.branch-deploy] + command = "cd exampleSite && hugo --gc --themesDir ../.. -b ${DEPLOY_PRIME_URL}" + +[context.deploy-preview] + command = "cd exampleSite && hugo --gc --themesDir ../.. -b ${DEPLOY_PRIME_URL}" + +[[plugins]] + package = "netlify-plugin-hugo-cache-resources" + + [plugins.inputs] + # If it should show more verbose logs (optional, default = true) + debug = true + # Relative path to source directory in case you use Hugo's "--s" option + srcdir = "exampleSite" diff --git a/themes/hugo-theme-stack/theme.toml b/themes/hugo-theme-stack/theme.toml new file mode 100644 index 0000000..6c5ea62 --- /dev/null +++ b/themes/hugo-theme-stack/theme.toml @@ -0,0 +1,27 @@ +# theme.toml template for a Hugo theme +# See https://github.com/gohugoio/hugoThemes#themetoml for an example + +name = "Stack" +license = "GPL-3.0-only" +licenselink = "https://github.com/CaiJimmy/hugo-theme-stack/blob/master/LICENSE" +description = "Card-style Hugo theme designed for bloggers" +homepage = "https://github.com/CaiJimmy/hugo-theme-stack" +demosite = "https://demo.stack.jimmycai.com" + +tags = ["blog", "responsive", "clean", "light", "dark", "personal"] + +features = [ + "disqus", + "photoswipe", + "opengraph", + "widgets", + "darkmode", + "table of contents", + "search", +] + +min_version = "0.123.0" + +[author] +name = "Jimmy Cai" +homepage = "https://jimmycai.com"