regular backup
This commit is contained in:
parent
c7eec5c7a9
commit
b5945b86b0
|
@ -201,7 +201,7 @@ in {
|
||||||
pkgs.samba
|
pkgs.samba
|
||||||
|
|
||||||
# Java
|
# Java
|
||||||
pkgs.jdk22
|
pkgs.jdk23
|
||||||
pkgs.jdt-language-server
|
pkgs.jdt-language-server
|
||||||
|
|
||||||
# Python
|
# Python
|
||||||
|
@ -236,6 +236,7 @@ in {
|
||||||
pkgs.jellyfin-ffmpeg
|
pkgs.jellyfin-ffmpeg
|
||||||
# pkgs.spotify
|
# pkgs.spotify
|
||||||
# unstable.spotify-player
|
# unstable.spotify-player
|
||||||
|
pkgs.spotdl
|
||||||
|
|
||||||
# Streaming
|
# Streaming
|
||||||
# pkgs.obs-studio
|
# pkgs.obs-studio
|
||||||
|
@ -263,7 +264,7 @@ in {
|
||||||
# pkgs.pavucontrol # Volume control
|
# pkgs.pavucontrol # Volume control
|
||||||
# pkgs.pasystray # Volume tray icon
|
# pkgs.pasystray # Volume tray icon
|
||||||
pkgs.yaru-theme
|
pkgs.yaru-theme
|
||||||
unstable.adwaita-icon-theme
|
# unstable.adwaita-icon-theme
|
||||||
pkgs.adwaita-qt
|
pkgs.adwaita-qt
|
||||||
pkgs.adwaita-qt6
|
pkgs.adwaita-qt6
|
||||||
pkgs.wiki-tui
|
pkgs.wiki-tui
|
||||||
|
@ -271,6 +272,7 @@ in {
|
||||||
pkgs.starship # Prompt bar
|
pkgs.starship # Prompt bar
|
||||||
pkgs.patchelf
|
pkgs.patchelf
|
||||||
# pkgs.screenkey
|
# pkgs.screenkey
|
||||||
|
pkgs.ipatool # Search and download IPAs
|
||||||
|
|
||||||
# My version of BerkeleyMono NF is incomplete. Should add some fallback fonts.
|
# My version of BerkeleyMono NF is incomplete. Should add some fallback fonts.
|
||||||
# (pkgs.nerdfonts.override { fonts = [
|
# (pkgs.nerdfonts.override { fonts = [
|
||||||
|
|
|
@ -139,19 +139,19 @@ local plugins = {
|
||||||
opts = {},
|
opts = {},
|
||||||
config = function(_, opts) require'lsp_signature'.setup(opts) end
|
config = function(_, opts) require'lsp_signature'.setup(opts) end
|
||||||
},
|
},
|
||||||
-- {
|
{
|
||||||
-- "folke/which-key.nvim",
|
"folke/which-key.nvim",
|
||||||
-- event = "VeryLazy",
|
event = "VeryLazy",
|
||||||
-- init = function()
|
init = function()
|
||||||
-- vim.o.timeout = true
|
vim.o.timeout = true
|
||||||
-- vim.o.timeoutlen = 300
|
vim.o.timeoutlen = 300
|
||||||
-- end,
|
end,
|
||||||
-- opts = {
|
opts = {
|
||||||
-- -- your configuration comes here
|
-- your configuration comes here
|
||||||
-- -- or leave it empty to use the default settings
|
-- or leave it empty to use the default settings
|
||||||
-- -- refer to the configuration section below
|
-- refer to the configuration section below
|
||||||
-- }
|
}
|
||||||
-- },
|
},
|
||||||
{
|
{
|
||||||
'jdhao/better-escape.vim' -- `jk` without causing `j` to have delay
|
'jdhao/better-escape.vim' -- `jk` without causing `j` to have delay
|
||||||
},
|
},
|
||||||
|
@ -487,7 +487,10 @@ local plugins = {
|
||||||
require("fzf-lua").setup({})
|
require("fzf-lua").setup({})
|
||||||
end
|
end
|
||||||
},
|
},
|
||||||
{ 'NStefan002/screenkey.nvim' },
|
-- {
|
||||||
|
-- 'NStefan002/screenkey.nvim',
|
||||||
|
-- branch = "dev",
|
||||||
|
-- },
|
||||||
{ 'kosayoda/nvim-lightbulb' },
|
{ 'kosayoda/nvim-lightbulb' },
|
||||||
{ 'mfussenegger/nvim-jdtls' }, -- Java LS
|
{ 'mfussenegger/nvim-jdtls' }, -- Java LS
|
||||||
}
|
}
|
||||||
|
@ -1184,7 +1187,7 @@ require("telescope").setup {
|
||||||
|
|
||||||
require('mini.trailspace').setup {}
|
require('mini.trailspace').setup {}
|
||||||
|
|
||||||
require('lsp_lines').setup {}
|
require('lsp_lines').setup()
|
||||||
|
|
||||||
require("nvim-lightbulb").setup {
|
require("nvim-lightbulb").setup {
|
||||||
autocmd = { enabled = true }
|
autocmd = { enabled = true }
|
||||||
|
|
|
@ -1,50 +1,52 @@
|
||||||
return [[
|
return [[
|
||||||
static vector<MLL<MDL1>> power1;
|
static vector<ll> power1;
|
||||||
static vector<MLL<MDL2>> power2;
|
static vector<ll> power2;
|
||||||
static const ll b = rd();
|
static const ll b = rd() % INF;
|
||||||
|
static const ll b1 = inverse(b, MDL1);
|
||||||
|
static const ll b2 = inverse(b, MDL2);
|
||||||
template <typename _Tp>
|
template <typename _Tp>
|
||||||
struct hash_vec {
|
struct hash_vec {
|
||||||
using hash_type = pll;
|
using hash_type = pll;
|
||||||
MLL<MDL1> hash1;
|
ll hash1;
|
||||||
MLL<MDL2> hash2;
|
ll hash2;
|
||||||
vector<_Tp> seq;
|
vector<_Tp> seq;
|
||||||
size_t size() {
|
size_t size() {
|
||||||
return seq.size();
|
return seq.size();
|
||||||
}
|
}
|
||||||
void push_back(const _Tp& x) {
|
void push_back(const _Tp& x) {
|
||||||
hash1 = hash1 * b + x;
|
hash1 = (hash1 * b % MDL1 + x) % MDL1;
|
||||||
hash2 = hash2 * b + x;
|
hash2 = (hash2 * b % MDL2 + x) % MDL2;
|
||||||
seq.push_back(x);
|
seq.push_back(x);
|
||||||
}
|
}
|
||||||
void push_front(const _Tp& x) {
|
void push_front(const _Tp& x) {
|
||||||
size_t length = size();
|
size_t length = size();
|
||||||
hash1 += x * power1[length];
|
hash1 = (hash1 + x * power1[length] % MDL1) % MDL1;
|
||||||
hash2 += x * power2[length];
|
hash2 = (hash2 + x * power2[length] % MDL2) % MDL2;
|
||||||
seq.push_front(x);
|
seq.push_front(x);
|
||||||
}
|
}
|
||||||
void pop_back() {
|
void pop_back() {
|
||||||
_Tp e = seq.back(); seq.pop_back();
|
_Tp e = seq.back(); seq.pop_back();
|
||||||
hash1 = (hash1 - e) / b;
|
hash1 = mod(hash1 - e, MDL1) * b1 % MDL1;
|
||||||
hash2 = (hash2 - e) / b;
|
hash2 = mod(hash2 - e, MDL2) * b2 % MDL2;
|
||||||
}
|
}
|
||||||
void pop_front() {
|
void pop_front() {
|
||||||
_Tp e = seq.front(); seq.pop_front();
|
_Tp e = seq.front(); seq.pop_front();
|
||||||
int length = seq.size();
|
int length = seq.size();
|
||||||
hash1 -= e * power1[length];
|
hash1 = mod(hash1 - e * power1[length] % MDL1, MDL1);
|
||||||
hash2 -= e * power2[length];
|
hash2 = mod(hash2 - e * power2[length] % MDL2, MDL2);
|
||||||
}
|
}
|
||||||
void set(size_t pos, const _Tp& value) {
|
void set(size_t pos, const _Tp& value) {
|
||||||
int length = seq.size();
|
int length = seq.size();
|
||||||
int old_value = seq[pos];
|
int old_value = seq[pos];
|
||||||
hash1 += (value - old_value) * power1[length - 1 - pos];
|
hash1 = (hash1 + (value - old_value) * power1[length - 1 - pos] % MDL1) % MDL1;
|
||||||
hash2 += (value - old_value) * power2[length - 1 - pos];
|
hash2 = (hash2 + (value - old_value) * power2[length - 2 - pos] % MDL2) % MDL2;
|
||||||
seq[pos] = value;
|
seq[pos] = value;
|
||||||
}
|
}
|
||||||
const _Tp& operator[](size_t pos) {
|
const _Tp& operator[](size_t pos) {
|
||||||
return seq[pos];
|
return seq[pos];
|
||||||
}
|
}
|
||||||
hash_type hash() {
|
hash_type hash() {
|
||||||
return {hash1.val, hash2.val};
|
return { hash1, hash2 };
|
||||||
}
|
}
|
||||||
void clear() {
|
void clear() {
|
||||||
hash1 = 0;
|
hash1 = 0;
|
||||||
|
@ -53,13 +55,13 @@ struct hash_vec {
|
||||||
}
|
}
|
||||||
hash_vec(size_t maxn) {
|
hash_vec(size_t maxn) {
|
||||||
clear();
|
clear();
|
||||||
MLL<MDL1> c1 = power1.size() ? power1.back() * b : 1;
|
ll c1 = power1.size() ? power1.back() * b % MDL1 : 1;
|
||||||
MLL<MDL2> c2 = power2.size() ? power2.back() * b : 1;
|
ll c2 = power2.size() ? power2.back() * b % MDL2 : 1;
|
||||||
for (int i = power1.size(); i < maxn; ++i) {
|
for (int i = power1.size(); i < maxn; ++i) {
|
||||||
power1.push_back(c1);
|
power1.push_back(c1);
|
||||||
power2.push_back(c2);
|
power2.push_back(c2);
|
||||||
c1 *= b;
|
c1 = c1 * b % MDL1;
|
||||||
c2 *= b;
|
c2 = c2 * b % MDL2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
hash_vec(size_t maxn, const _Tp& init_value) : hash_vec(maxn) {
|
hash_vec(size_t maxn, const _Tp& init_value) : hash_vec(maxn) {
|
||||||
|
@ -68,9 +70,8 @@ struct hash_vec {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
struct range_hash {
|
struct range_hash {
|
||||||
vector<pair<MLL<MDL1>, MLL<MDL2>>> hp;
|
vector<pll> hp;
|
||||||
template <typename T>
|
template <typename T>
|
||||||
range_hash(const T& vec) {
|
range_hash(const T& vec) {
|
||||||
hp.emplace_back();
|
hp.emplace_back();
|
||||||
|
@ -80,12 +81,11 @@ struct range_hash {
|
||||||
hp.emplace_back(hs.hash());
|
hp.emplace_back(hs.hash());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// query hash of subarray [l, r]. Index starts from 0.
|
/// query hash of subarray [l, r]. Index starts from 0.
|
||||||
pair<MLL<MDL1>, MLL<MDL2>> range_query(size_t l, size_t r) {
|
inline pll range_query(size_t l, size_t r) {
|
||||||
return {
|
return {
|
||||||
(hp[r + 1].first - hp[l].first * power1[r + 1 - l]),
|
mod(hp[r + 1].first - hp[l].first * power1[r + 1 - l] % MDL1, MDL1),
|
||||||
(hp[r + 1].second - hp[l].second * power2[r + 1 - l]),
|
mod(hp[r + 1].second - hp[l].second * power2[r + 1 - l] % MDL2, MDL2),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -405,3 +405,15 @@ ls.add_snippets(nil, {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
local odt = require('snippets.odt')
|
||||||
|
ls.add_snippets(nil, {
|
||||||
|
cpp = {
|
||||||
|
snip({
|
||||||
|
trig = 'odt',
|
||||||
|
namr = 'odt',
|
||||||
|
dscr = 'Old Driver Tre',
|
||||||
|
},{
|
||||||
|
text(lines(odt))
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
|
@ -0,0 +1,52 @@
|
||||||
|
return [=[
|
||||||
|
template <typename T, typename IndexType = ll>
|
||||||
|
struct ODT {
|
||||||
|
struct Info {
|
||||||
|
IndexType l, r;
|
||||||
|
mutable T val;
|
||||||
|
Info(const IndexType& l, const IndexType& r, const T& val) : l(l), r(r), val(val) {}
|
||||||
|
friend inline bool operator<(const Info& lhs, const Info& rhs) { return lhs.l < rhs.l; }
|
||||||
|
};
|
||||||
|
|
||||||
|
set<Info> info;
|
||||||
|
|
||||||
|
ODT() = delete;
|
||||||
|
ODT(const IndexType& left, const IndexType& right, const T& val) : info {{ left, right, val }} {}
|
||||||
|
|
||||||
|
typename set<Info>::iterator split(const IndexType& x) {
|
||||||
|
auto it = info.lower_bound({ x, {}, {} });
|
||||||
|
if (it != info.end() and it->l == x) {
|
||||||
|
return it;
|
||||||
|
}
|
||||||
|
--it;
|
||||||
|
auto [l, r, val] = *it;
|
||||||
|
info.erase(it);
|
||||||
|
info.emplace(l, x - 1, val);
|
||||||
|
return info.emplace(x, r, val).first;
|
||||||
|
}
|
||||||
|
|
||||||
|
void assign(const IndexType& l, const IndexType& r, const T& val) {
|
||||||
|
auto ri = split(r + 1), li = split(l);
|
||||||
|
info.erase(li, ri);
|
||||||
|
info.emplace(l, r, val);
|
||||||
|
}
|
||||||
|
|
||||||
|
void transform(const IndexType& l, const IndexType& r, const function<T(const Info&)>& operation) {
|
||||||
|
auto ri = split(r + 1), li = split(l);
|
||||||
|
for (; li != ri; ++li) {
|
||||||
|
li->val = operation(*li);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename U>
|
||||||
|
U accumulate(const IndexType& l, const IndexType& r, U&& init, const function<U(const U&, const Info&)>& operation = std::plus()) {
|
||||||
|
auto ri = split(r + 1), li = split(l);
|
||||||
|
U res = init;
|
||||||
|
for (; li != ri; ++li) {
|
||||||
|
res = operation(res, *li);
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
]=]
|
Loading…
Reference in New Issue