Contribuire al Progetto
Caution
Gli attuali maintainer del progetto stanno ricercando l'internazionalizzazione automatizzata della documentazione. Pertanto, qualsiasi PR relativa all'internazionalizzazione/traduzione della documentazione NON sarà accettata!
Si prega di NON inviare PR relative all'internazionalizzazione/traduzione della documentazione!
Grazie per il tuo interesse in questo progetto! Prima di iniziare a contribuire, ti preghiamo di dedicare un po' di tempo a leggere le seguenti linee guida per garantire che il tuo contributo possa essere accettato senza problemi.
Tipi di Contributi Non Accettati
- Documentazione internazionalizzazione/traduzione
- Contributi relativi all'infrastruttura core, come HTTP API, ecc.
- Issue contrassegnate esplicitamente come "No help needed" (incluse le issue nel repository Byaidu/PDFMathTranslate).
- Altri contributi ritenuti inappropriati dai maintainer.
- Contribuire alla documentazione, ma modificando la documentazione in lingue diverse dall'inglese.
Si prega di NON inviare PR relativi ai tipi sopra menzionati.
Note
Se vuoi contribuire alla documentazione, modifica solo la versione inglese della documentazione. Le altre versioni linguistiche sono tradotte dai contributori stessi.
Processo di Contribuzione
- Forka questo repository e clonalo localmente.
- Crea un nuovo branch:
git checkout -b feature/<feature-name>
. - Sviluppa e assicurati che il tuo codice soddisfi i requisiti.
- Esegui il commit del tuo codice:
- Esegui il push sul tuo repository:
git push origin feature/<feature-name>
. - Crea una PR su GitHub, fornisci una descrizione dettagliata e richiedi una revisione a @awwaawwa.
- Assicurati che tutti i controlli automatizzati siano superati.
Tip
Non è necessario attendere che lo sviluppo sia completamente completato per creare una PR. Crearne una in anticipo ci permette di esaminare la tua implementazione e fornire suggerimenti.
Se hai domande sul codice sorgente o su questioni correlate, contatta il maintainer all'indirizzo [email protected].
I file delle risorse per la versione 2.0 sono condivisi con BabelDOC. Il codice per scaricare le risorse correlate si trova in BabelDOC. Se vuoi aggiungere nuovi file di risorse, contatta il maintainer di BabelDOC all'indirizzo [email protected].
Requisiti di base
1. Flusso di lavoro
- Si prega di effettuare un fork dal branch
main
e sviluppare sul proprio branch forkato. - Quando si invia una Pull Request (PR), fornire una descrizione dettagliata delle modifiche apportate.
- Se la PR non supera i controlli automatizzati (indicati da
checks failed
e una croce rossa), si prega di rivedere i corrispondentidetails
e modificare l'invio per garantire che la nuova PR superi tutti i controlli.
2. Sviluppo e Test
- Utilizzare il comando
pip install -e .
per sviluppo e test.
3. Formattazione del codice
- Configura lo strumento
pre-commit
e abilitablack
eflake8
per la formattazione del codice.
4. Aggiornamenti delle dipendenze
- Se introduci nuove dipendenze, aggiorna tempestivamente l'elenco delle dipendenze nel file
pyproject.toml
.
5. Aggiornamenti della documentazione
- Se aggiungi nuove opzioni per la riga di comando, aggiorna di conseguenza l'elenco delle opzioni per la riga di comando in tutte le versioni linguistiche del file
README.md
.
6. Messaggi di Commit
- Utilizzare Conventional Commits, ad esempio:
feat(translator): add openai
.
7. Stile di Codifica
- Assicurati che il codice inviato aderisca agli standard di stile di codifica di base.
- Utilizza snake_case o camelCase per la denominazione delle variabili.
8. Formattazione della Documentazione
- Per la formattazione di
README.md
, si prega di seguire le Linee guida per la scrittura in cinese. - Assicurarsi che la documentazione in inglese e cinese sia sempre aggiornata; gli aggiornamenti della documentazione in altre lingue sono opzionali.
Aggiungere un motore di traduzione
- Aggiungi una nuova classe di configurazione del traduttore nel file
pdf2zh/config/translate_engine_model.py
. - Aggiungi un'istanza della nuova classe di configurazione del traduttore all'alias di tipo
TRANSLATION_ENGINE_SETTING_TYPE
nello stesso file. - Aggiungi la nuova classe di implementazione del traduttore nella cartella
pdf2zh/translator/translator_impl
.
Note
Questo progetto non intende supportare alcun motore di traduzione con un RPS (richieste al secondo) inferiore a 4. Si prega di non inviare supporto per tali motori.
Struttura del progetto
- cartella config: Sistema di configurazione.
- cartella translator: Implementazioni relative al traduttore.
- gui.py: Fornisce l'interfaccia grafica.
- const.py: Alcune costanti.
- main.py: Fornisce lo strumento da riga di comando.
- high_level.py: Interfacce di alto livello basate su BabelDOC.
- http_api.py: Fornisce l'API HTTP (non avviato).
Contattaci
Se hai domande, invia feedback tramite Issue o unisciti al nostro gruppo Telegram. Grazie per il tuo contributo!
Tip
Immersive Translate sponsorizza mensilmente codici di abbonamento Pro per i contributori attivi di questo progetto. Per i dettagli, consultare: BabelDOC/PDFMathTranslate Regole di Ricompensa per i Contributori