5 Commits

Author SHA1 Message Date
0107f77570 Merge pull request 'chore(deps): update ghcr.io/renovatebot/renovate docker tag to v39.216.1' (#3) from renovate/ghcr.io-renovatebot-renovate-39.x into main
All checks were successful
Go / build (push) Successful in -12s
renovate / renovate (push) Successful in 48s
Reviewed-on: #3
2025-03-26 00:07:43 +00:00
d5f658244b chore(deps): update ghcr.io/renovatebot/renovate docker tag to v39.216.1
All checks were successful
Go / build (pull_request) Successful in -12s
2025-03-26 00:00:58 +00:00
78e2568e2b docs: update changelog
All checks were successful
Go / build (push) Successful in -11s
renovate / renovate (push) Successful in 37s
2025-03-26 00:11:13 +01:00
75ba450d9b feat(index): add save and load functionality for Index using gob encoding/decoding 2025-03-26 00:10:28 +01:00
dd7f0c0a28 docs: add first release in Changelog
All checks were successful
Go / build (push) Successful in -11s
renovate / renovate (push) Successful in 16s
2025-03-25 23:09:54 +01:00
4 changed files with 99 additions and 3 deletions

View File

@@ -10,7 +10,7 @@ on:
jobs: jobs:
renovate: renovate:
runs-on: ubuntu-latest runs-on: ubuntu-latest
container: ghcr.io/renovatebot/renovate:39.215.2 container: ghcr.io/renovatebot/renovate:39.216.1
steps: steps:
- uses: actions/checkout@v4 - uses: actions/checkout@v4
- run: renovate - run: renovate

View File

@@ -6,6 +6,16 @@ All notable changes to this project will be documented in this file.
### 🚀 Features ### 🚀 Features
- *(index)* Add save and load functionality for Index using gob encoding/decoding
### 📚 Documentation
- Add first release in Changelog
## [0.1.0] - 2025-03-25
### 🚀 Features
- Added documentation for gosearch system architecture and updated Go module version to 1.23.5 - Added documentation for gosearch system architecture and updated Go module version to 1.23.5
- Update internal HTTP server to use Fiber v2 with new routes and middleware configuration - Update internal HTTP server to use Fiber v2 with new routes and middleware configuration
- Added new search route and metric endpoint to internal controller - Added new search route and metric endpoint to internal controller
@@ -30,5 +40,6 @@ All notable changes to this project will be documented in this file.
- Added golang workflow for building and testing project - Added golang workflow for building and testing project
- Update Go version in build-and-test workflow to 1.23 - Update Go version in build-and-test workflow to 1.23
- Added renovate configuration files for Gitea workflow automation - Added renovate configuration files for Gitea workflow automation
- Add release pipeline
<!-- generated by git-cliff --> <!-- generated by git-cliff -->

View File

@@ -7,7 +7,7 @@ import (
func main() { func main() {
// Initialize Index // Initialize Index
index.CreateIndex() index.InitIndex("default")
// Start HTTP Server // Start HTTP Server
http.StartService() http.StartService()

View File

@@ -2,6 +2,12 @@ package index
import ( import (
"bufio" "bufio"
"bytes"
"encoding/gob"
"errors"
"fmt"
"log"
"os"
"strings" "strings"
) )
@@ -13,7 +19,40 @@ var Index InvertedIndex
var DocFreq DocumentFrequency var DocFreq DocumentFrequency
var Documents []string var Documents []string
func CreateIndex() { type SavedIndex struct {
Index InvertedIndex
DocFreq DocumentFrequency
Documents []string
}
func InitIndex(name string) {
createIndex()
// check if index as file exists
// if not, create one and save it
indexFilePath := "/tmp/" + name + ".db"
if _, err := os.Stat(indexFilePath); errors.Is(err, os.ErrNotExist) {
f, err := os.Create(indexFilePath)
if err != nil {
log.Fatal(err)
}
defer f.Close()
} else {
var savedIndex SavedIndex
err = readStructFromFile(indexFilePath, &savedIndex)
if err != nil {
fmt.Println("Fehler beim Lesen:", err)
return
}
Index = savedIndex.Index
DocFreq = savedIndex.DocFreq
Documents = savedIndex.Documents
}
}
func createIndex() {
index := make(InvertedIndex) index := make(InvertedIndex)
docFreq := make(DocumentFrequency) docFreq := make(DocumentFrequency)
var docs []string var docs []string
@@ -23,6 +62,21 @@ func CreateIndex() {
DocFreq = docFreq DocFreq = docFreq
} }
func updateIndex(name string) {
savedIndex := SavedIndex{
Index: Index,
DocFreq: DocFreq,
Documents: Documents,
}
indexFilePath := "/tmp/" + name + ".db"
err := writeStructToFile(indexFilePath, savedIndex)
if err != nil {
fmt.Println("Fehler beim Schreiben:", err)
return
}
}
func AddDocToIndex(url string, content string) { func AddDocToIndex(url string, content string) {
Documents = append(Documents, url) Documents = append(Documents, url)
@@ -46,4 +100,35 @@ func AddDocToIndex(url string, content string) {
} }
} }
updateIndex("default")
}
func writeStructToFile(filename string, data interface{}) error {
var buf bytes.Buffer
enc := gob.NewEncoder(&buf)
err := enc.Encode(data)
if err != nil {
return fmt.Errorf("error when encoding the structs: %w", err)
}
err = os.WriteFile(filename, buf.Bytes(), 0644)
if err != nil {
return fmt.Errorf("error when writing to the file: %w", err)
}
return nil
}
func readStructFromFile(filename string, data interface{}) error {
content, err := os.ReadFile(filename)
if err != nil {
return fmt.Errorf("error reading the file: %w", err)
}
buf := bytes.NewBuffer(content)
dec := gob.NewDecoder(buf)
err = dec.Decode(data)
if err != nil {
return fmt.Errorf("error when decoding the structs: %w", err)
}
return nil
} }