Cursor
Silent install package for Cursor
2.3.34-1
Development
Development
- package: tis-cursor
- name: Cursor
- version: 2.3.34-1
- categories: Development
- maintainer: WAPT Team,Tranquil IT,Flavien SCHELFAUT
- editor: Anysphere
- locale: all
- target_os: linux
- impacted_process: Cursor
- architecture: arm64
- signature_date:
- size: 226.46 Mo
- homepage : https://cursor.com/
package : tis-cursor
version : 2.3.34-1
architecture : arm64
section : base
priority : optional
name : Cursor
categories : Development
maintainer : WAPT Team,Tranquil IT,Flavien SCHELFAUT
description : Cursor is a modern IDE built on VS Code, integrating AI to generate, explain, and fix code. It boosts development speed with smart, context-aware assistance.
depends :
conflicts :
maturity : PROD
locale : all
target_os : linux
min_wapt_version : 2.5
sources :
installed_size :
impacted_process : Cursor
description_fr : Cursor est un IDE moderne basé sur VS Code, intégrant une IA pour générer, expliquer et corriger le code. Il accélère le développement grâce à une assistance intelligente et contextuelle.
description_pl : Cursor to nowoczesne IDE oparte na VS Code, integrujące sztuczną inteligencję do generowania, wyjaśniania i naprawiania kodu. Przyspiesza rozwój dzięki inteligentnej i kontekstowej pomocy.
description_de : Cursor ist eine moderne IDE auf Basis von VS Code, die KI integriert, um Code zu generieren, zu erklären und zu korrigieren. Sie beschleunigt die Entwicklung durch intelligente, kontextbezogene Unterstützung.
description_es : Cursor es un IDE moderno basado en VS Code que integra IA para generar, explicar y corregir código. Acelera el desarrollo con asistencia inteligente y contextual.
description_pt : Cursor é um IDE moderno baseado no VS Code, integrando IA para gerar, explicar e corrigir código. Ele acelera o desenvolvimento com assistência inteligente e contextual.
description_it : Cursor è un IDE moderno basato su VS Code che integra l'IA per generare, spiegare e correggere il codice. Accelera lo sviluppo grazie a un'assistenza intelligente e contestuale.
description_nl : Cursor is een moderne IDE gebaseerd op VS Code, met geïntegreerde AI om code te genereren, uitleggen en corrigeren. Het versnelt de ontwikkeling met slimme, contextuele assistentie.
description_ru : Cursor — это современная IDE на основе VS Code, интегрирующая ИИ для генерации, объяснения и исправления кода. Она ускоряет разработку благодаря умной и контекстной помощи.
audit_schedule :
editor : Anysphere
keywords : cursor,ide,integrated,development,environment
licence :
homepage : https://cursor.com/
package_uuid : f4e7c6a8-976a-4ffc-9133-171ab4757bc3
valid_from :
valid_until :
forced_install_on :
changelog : https://cursor.com/changelog
min_os_version :
max_os_version :
icon_sha256sum : 9cba6454810418fa31660e69ced09aa546f75bcfd3d873a4414f250694fa623c
signer : Tranquil IT
signer_fingerprint: 8c5127a75392be9cc9afd0dbae1222a673072c308c14d88ab246e23832e8c6bb
signature_date : 2026-01-20T03:09:03.000000
signed_attributes : package,version,architecture,section,priority,name,categories,maintainer,description,depends,conflicts,maturity,locale,target_os,min_wapt_version,sources,installed_size,impacted_process,description_fr,description_pl,description_de,description_es,description_pt,description_it,description_nl,description_ru,audit_schedule,editor,keywords,licence,homepage,package_uuid,valid_from,valid_until,forced_install_on,changelog,min_os_version,max_os_version,icon_sha256sum,signer,signer_fingerprint,signature_date,signed_attributes
signature : HiSBMhLK4jr4J8q5liISZwkhbCo1GruA55cssazkKOwfa5wDr5cj3JpxhE+q3KzJFZpOJW64a+GKiBcTqMzfg+W9GLar+Ji6dLHZKHUHrVGfEHam1hRVcUUR498ngwqMV/aKkSj1lvrSih12k0UxLKXOcgYZrZYvXS2G2CmIaJ4F4A7Ds6Q7LrKbojpLX4+vKorg0vmBmU/O61nKzjGfAF4C27SQN00cb9h2drP5Ky3pMiC1kcNE943DC0qx9NWcklM+J/bxLV37+rju2p+7m8vo/oGtmoQek1Tc9pd6n/OmkR7Ag4EOgLdFCvRWyTyIaif020t0Ah8Ne4dtj6BWjw==
# -*- coding: utf-8 -*-
from setuphelpers import *
from iniparse import ConfigParser
def install():
install_dir = makepath('/','opt',control.package.split('-',1)[1])
appimage = glob.glob("*.AppImage")[0]
install_appimage(appimage,install_dir)
def uninstall():
install_dir = makepath('/','opt',control.package.split('-',1)[1])
uninstall_appimage(install_dir)
def install_appimage(appimage,install_dir,binaliasname=None):
run('chmod a+x ./' + appimage)
if isdir(install_dir):
uninstall_appimage(install_dir)
mkdirs(install_dir)
name_appimage = appimage.split('/')[-1]
filecopyto(appimage, makepath(install_dir, name_appimage))
run('"./%s" --appimage-extract' % appimage)
for desktop in glob.glob(makepath('squashfs-root','*.desktop')):
desktop_cp = ConfigParser()
desktop_cp.optionxform = str
desktop_file = open(desktop, encoding="utf-8")
desktop_cp.readfp(desktop_file)
bin_path = desktop_cp.get('Desktop Entry',"Exec")
newbin_path = install_dir + '/' + name_appimage
if ' %' in bin_path:
newbin_path = newbin_path + ' %' + bin_path.split(' %',1)[1]
icon_path = desktop_cp.get('Desktop Entry',"Icon")
srcicon = makepath('squashfs-root',icon_path +'.svg')
if not isfile(srcicon):
srcicon = makepath('squashfs-root',icon_path +'.png')
new_icon = install_dir + '/' + srcicon.split('/')[-1]
filecopyto(srcicon,new_icon)
desktop_cp.set('Desktop Entry',"Exec",newbin_path)
desktop_cp.set('Desktop Entry',"Icon",new_icon)
with open(desktop, 'w', encoding="utf-8") as f:
desktop_cp.write(f)
pathdesk = makepath(install_dir,desktop.split('/')[-1])
filecopyto(desktop, pathdesk)
run('chown root:root "%s" ' % pathdesk)
for f in glob.glob(makepath(install_dir,'*.desktop')):
run('ln -sf "%s" "/usr/share/applications/%s"' % (f,f.split('/')[-1]))
if binaliasname :
run(f"ln -sf {install_dir}/{name_appimage} /usr/bin/{binaliasname}")
remove_tree('squashfs-root')
def uninstall_appimage(install_dir):
if not glob.glob(makepath(install_dir,'*.desktop')):
error('.desktop not found')
for f in glob.glob(makepath(install_dir,'*.desktop')):
deskfile = f.split('/')[-1]
system_desktop = makepath("/","usr","share","applications",deskfile)
if isfile(system_desktop):
remove_file(system_desktop)
remove_tree(install_dir)
# -*- coding: utf-8 -*-
from setuphelpers import *
from setupdevhelpers import *
def update_package():
# Declaring local variables
package_updated = False
proxies = get_proxies()
if not proxies:
proxies = get_proxies_from_wapt_console()
app_name = control.name
os_dict = {
'windows-x64': 'win32-x64',
'windows-arm64': 'win32-arm64',
'darwin-arm': 'darwin-arm64',
'darwin-x64': 'darwin-x64',
'linux-x64': 'linux-x64',
'linux-arm64': 'linux-arm64',
}
os_type = control.target_os + "-" + ensure_list(control.architecture)[0]
user_agent = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Cursor/1.7.43 Chrome/132.0.6834.210 Electron/34.5.8 Safari/537.36"
latest_version = f"https://api2.cursor.sh/updates/download/golden/{os_dict[os_type]}/cursor/latest"
download_url = requests.head(latest_version, proxies=proxies, headers={'User-agent': user_agent}).headers['location']
latest_bin = download_url.rsplit('/', 1)[-1]
latest_bin_extension = latest_bin.rsplit('.', 1)[-1]
version = latest_bin.split('-')[1]
# Downloading latest binaries
print(f"Latest {app_name} version is: {version}")
print(f"Download URL is: {download_url}")
if not isfile(latest_bin):
print(f"Downloading: {latest_bin}")
wget(download_url, latest_bin, proxies=proxies)
else:
print(f"Binary is present: {latest_bin}")
# Changing version of the package
if Version(version) > Version(control.get_software_version()):
print(f"Software version updated (from: {control.get_software_version()} to: {Version(version)})")
package_updated = True
else:
print(f"Software version up-to-date ({Version(version)})")
for f in glob.glob(f'*.{latest_bin_extension}'):
if f != latest_bin:
remove_file(f)
control.set_software_version(version)
control.save_control_to_wapt()
return package_updated
efc9593c77efa20353f1d3a70108e91ddb9b9e18344fa62dad548f02c1d64dd7 : Cursor-2.3.34-aarch64.AppImage
38d056ab130f7bf7c481c12636a4e9959de36561d3dfcbe54c6e3571bc0c1dc3 : WAPT/certificate.crt
116920ef4bbb313eb530a7368728c4acfea948c7ed08d8bea56995db42ca2475 : WAPT/control
9cba6454810418fa31660e69ced09aa546f75bcfd3d873a4414f250694fa623c : WAPT/icon.png
ec4f8f47534d5f9b6e4e134323975379113edbcb00221b89af02e9f0e7e30c63 : luti.json
00ae1ed1d79c947842ba2de3240a3b335ecbea6c4438acda634a0169fabb1042 : setup.py
4e57e0ea91fdca936198baf5c0e34015c19a04cbca2c7d74ff51129339083b75 : update_package.py